

| Bit(s)      | Mnemonic | Name | Description |
|-------------|----------|------|-------------|
| 3:          |          |      | Reserved    |
| 4:          |          |      | Reserved    |
| 5:          |          |      | Reserved    |
| 6:          |          |      | Reserved    |
| 7: Reserved |          |      |             |

**A0020C24    GPIO\_MODE2    GPIO Mode Control**      **00000000**

| Bit   | 31     | 30 | 29 | 28     | 27 | 26 | 25     | 24 | 23 | 22     | 21 | 20 | 19 | 18 | 17 | 16 |   |
|-------|--------|----|----|--------|----|----|--------|----|----|--------|----|----|----|----|----|----|---|
| Name  | GPIO23 |    |    | GPIO22 |    |    | GPIO21 |    |    | GPIO20 |    |    |    |    |    |    |   |
| Type  | WO     |    |    | WO     |    |    | WO     |    |    | WO     |    |    |    |    |    | WO |   |
| Reset | 0      | 0  | 0  |        | 0  | 0  | 0      |    | 0  | 0      | 0  |    | 0  | 0  | 0  | 0  | 0 |
| Bit   | 15     | 14 | 13 | 12     | 11 | 10 | 9      | 8  | 7  | 6      | 5  | 4  | 3  | 2  | 1  | 0  |   |
| Name  | GPIO19 |    |    | GPIO18 |    |    | GPIO17 |    |    | GPIO16 |    |    |    |    |    |    |   |
| Type  | WO     |    |    | WO     |    |    | WO     |    |    | WO     |    |    |    |    |    | WO |   |
| Reset | 0      | 0  | 0  |        | 0  | 0  | 0      |    | 0  | 0      | 0  |    | 0  | 0  | 0  | 0  | 0 |

**Overview:** For bitwise access of GPIO\_MODE2

| Bit(s) | Mnemonic | Name   | Description                                            |
|--------|----------|--------|--------------------------------------------------------|
| 30:28  |          | GPIO23 | <b>Bitwise SET operation for Aux. mode of BPI_BUS1</b> |
|        |          |        | 0:<br>1: SET bits                                      |
| 26:24  |          | GPIO22 | <b>Bitwise SET operation for Aux. mode of BPI_BUS2</b> |
|        |          |        | 0:<br>1: SET bits                                      |
| 22:20  |          | GPIO21 | <b>Bitwise SET operation for Aux. mode of KROW0</b>    |
|        |          |        | 0:<br>1: SET bits                                      |
| 18:16  |          | GPIO20 | <b>Bitwise SET operation for Aux. mode of KROW1</b>    |
|        |          |        | 0:<br>1: SET bits                                      |
| 14:12  |          | GPIO19 | <b>Bitwise SET operation for Aux. mode of KROW2</b>    |
|        |          |        | 0:<br>1: SET bits                                      |
| 10:8   |          | GPIO18 | <b>Bitwise SET operation for Aux. mode of KROW3</b>    |
|        |          |        | 0:<br>1: SET bits                                      |
| 6:4    |          | GPIO17 | <b>Bitwise SET operation for Aux. mode of KROW4</b>    |
|        |          |        | 0:<br>1: SET bits                                      |
| 2:0    |          | GPIO16 | <b>Bitwise SET operation for Aux. mode of KCOL0</b>    |
|        |          |        | 0:<br>1: SET bits                                      |

**A0020C28    GPIO\_MODE2    GPIO Mode Control**      **00000000**

| Bit  | 31     | 30 | 29 | 28     | 27 | 26 | 25     | 24 | 23 | 22     | 21 | 20 | 19 | 18 | 17 | 16 |  |
|------|--------|----|----|--------|----|----|--------|----|----|--------|----|----|----|----|----|----|--|
| Name | GPIO23 |    |    | GPIO22 |    |    | GPIO21 |    |    | GPIO20 |    |    |    |    |    |    |  |

| Type  |        | WO |    |        |    | WO |        |   |   | WO     |   |   |   | WO |   |   |  |
|-------|--------|----|----|--------|----|----|--------|---|---|--------|---|---|---|----|---|---|--|
| Reset |        | 0  | 0  | 0      |    | 0  | 0      | 0 |   | 0      | 0 | 0 |   | 0  | 0 | 0 |  |
| Bit   | 15     | 14 | 13 | 12     | 11 | 10 | 9      | 8 | 7 | 6      | 5 | 4 | 3 | 2  | 1 | 0 |  |
| Name  | GPIO19 |    |    | GPIO18 |    |    | GPIO17 |   |   | GPIO16 |   |   |   |    |   |   |  |
| Type  | WO     |    |    | WO     |    |    | WO     |   |   | WO     |   |   |   |    |   |   |  |
| Reset | 0      | 0  | 0  |        | 0  | 0  | 0      |   | 0 | 0      | 0 |   | 0 | 0  | 0 |   |  |

**Overview:** For bitwise access of GPIO\_MODE2

| Bit(s) | Mnemonic | Name   | Description                                            |      |
|--------|----------|--------|--------------------------------------------------------|------|
| 30:28  |          | GPIO23 | <b>Bitwise CLR operation for Aux. mode of BPI_BUS1</b> |      |
|        |          |        | 0:<br>1: CLR bits                                      | Keep |
| 26:24  |          | GPIO22 | <b>Bitwise CLR operation for Aux. mode of BPI_BUS2</b> |      |
|        |          |        | 0:<br>1: CLR bits                                      | Keep |
| 22:20  |          | GPIO21 | <b>Bitwise CLR operation for Aux. mode of KROW0</b>    |      |
|        |          |        | 0:<br>1: CLR bits                                      | Keep |
| 18:16  |          | GPIO20 | <b>Bitwise CLR operation for Aux. mode of KROW1</b>    |      |
|        |          |        | 0:<br>1: CLR bits                                      | Keep |
| 14:12  |          | GPIO19 | <b>Bitwise CLR operation for Aux. mode of KROW2</b>    |      |
|        |          |        | 0:<br>1: CLR bits                                      | Keep |
| 10:8   |          | GPIO18 | <b>Bitwise CLR operation for Aux. mode of KROW3</b>    |      |
|        |          |        | 0:<br>1: CLR bits                                      | Keep |
| 6:4    |          | GPIO17 | <b>Bitwise CLR operation for Aux. mode of KROW4</b>    |      |
|        |          |        | 0:<br>1: CLR bits                                      | Keep |
| 2:0    |          | GPIO16 | <b>Bitwise CLR operation for Aux. mode of KCOL0</b>    |      |
|        |          |        | 0:<br>1: CLR bits                                      | Keep |

| A0020C30 GPIO MODE3 GPIO Mode Control |        |    |    |    |    |    |        |    |    |    |    |    |        |    | 00000001 |    |   |  |
|---------------------------------------|--------|----|----|----|----|----|--------|----|----|----|----|----|--------|----|----------|----|---|--|
| Bit                                   | 31     | 30 | 29 | 28 | 27 | 26 | 25     | 24 | 23 | 22 | 21 | 20 | 19     | 18 | 17       | 16 |   |  |
| Name                                  | GPIO31 |    |    |    |    |    | GPIO30 |    |    |    |    |    | GPIO29 |    |          |    |   |  |
| Type                                  | RW     |    |    |    |    |    | RW     |    |    |    |    |    | RW     |    |          |    |   |  |
| Reset                                 | 0      | 0  | 0  |    | 0  | 0  | 0      |    | 0  | 0  | 0  | 0  | 0      | 0  | 0        | 0  | 0 |  |
| Bit                                   | 15     | 14 | 13 | 12 | 11 | 10 | 9      | 8  | 7  | 6  | 5  | 4  | 3      | 2  | 1        | 0  |   |  |
| Name                                  | GPIO27 |    |    |    |    |    | GPIO26 |    |    |    |    |    | GPIO25 |    |          |    |   |  |
| Type                                  | RW     |    |    |    |    |    | RW     |    |    |    |    |    | RW     |    |          |    |   |  |
| Reset                                 | 0      | 0  | 0  | 0  |    | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0      | 0  | 0        | 0  | 1 |  |

**Overview:** Configures GPIO aux. mode

| Bit(s) | Mnemonic | Name   | Description                 |                            |
|--------|----------|--------|-----------------------------|----------------------------|
| 30:28  |          | GPIO31 | <b>Aux. mode of GPIO_31</b> |                            |
|        |          |        | 0:<br>1:<br>2:              | GPIO31<br>MCCK<br>Reserved |
|        |          |        |                             | (IO)<br>(O)                |

| Bit(s) | Mnemonic | Name                        | Description                                                                              |                                                              |
|--------|----------|-----------------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------|
|        |          |                             | 3:<br>4:<br>5:<br>6:<br>7: Reserved                                                      | Reserved<br>(I)<br>Reserved<br>Reserved                      |
| 26:24  | GPIO30   | <b>Aux. mode of GPIO_30</b> | U2RXD<br>GPIO30<br>CMCSK<br>LPTE<br>CMCSD2<br>EINT16<br>JTRCK<br>7: Reserved             | (IO)<br>(I)<br>(I)<br>(I)<br>(I)<br>Reserved<br>(O)          |
| 23:20  | GPIO29   | <b>Aux. mode of GPIO_29</b> | GPIO29<br>CMMCLK<br>LSA0DA1<br>DAISYNC<br>SPIMISO<br>FMJTDO<br>JTDO<br>8: MC2DA0 (IO)    | (IO)<br>(O)<br>(O)<br>(O)<br>(IO)<br>(O)<br>(O)<br>Reserved  |
| 19:16  | GPIO28   | <b>Aux. mode of GPIO_28</b> | GPIO28<br>CMCSD1<br>LSDA1<br>DAIPCMOUT<br>SPIMOSI<br>FMJTRSTB<br>JTRST_B<br>8: MC2CK (O) | (IO)<br>(I)<br>(IO)<br>(O)<br>(IO)<br>(I)<br>(I)<br>Reserved |
| 15:12  | GPIO27   | <b>Aux. mode of GPIO_27</b> | GPIO27<br>CMCSD0<br>LSCE_B1<br>DAIPCMIN<br>SPISCK<br>FMJTCK<br>JTCK<br>8: MC2CM0 (O)     | (IO)<br>(I)<br>(O)<br>(I)<br>(IO)<br>(I)<br>(I)<br>Reserved  |
| 10:8   | GPIO26   | <b>Aux. mode of GPIO_26</b> | GPIO26<br>CMPDN<br>LSCK1<br>DAICLK<br>SPICS<br>FMJTMS<br>JTMS<br>7: Reserved)            | (IO)<br>(O)<br>(O)<br>(O)<br>(IO)<br>(I)<br>(I)              |
| 6:4    | GPIO25   | <b>Aux. mode of GPIO_25</b> | GPIO25<br>CMRST<br>TESTMODE_D<br>CLKO1<br>EINT15                                         | (IO)<br>(O)<br>(O)<br>(O)<br>(I)                             |

| Bit(s) | Mnemonic | Name | Description                                                                          |                                                                                                           |
|--------|----------|------|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
|        |          |      | 5:<br>6:<br>7: Reserved                                                              | FMJTDI<br>JTDI<br>(I)<br>(I)                                                                              |
| 2:0    | GPIO24   |      | <b>Aux. mode of GPIO_24</b><br>0:<br>1:<br>2:<br>3:<br>4:<br>5:<br>6:<br>7: Reserved | GPIO24<br>BPI_BUS0<br>(IO)<br>(O)<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved |

| A0020C34 <u>GPIO_MODE3</u> GPIO Mode Control |        |    |    |    |        |    |    |    |        |    |    |    |        |    |    | 00000000 |  |  |  |
|----------------------------------------------|--------|----|----|----|--------|----|----|----|--------|----|----|----|--------|----|----|----------|--|--|--|
| Bit                                          | 31     | 30 | 29 | 28 | 27     | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19     | 18 | 17 | 16       |  |  |  |
| Name                                         | GPIO31 |    |    |    | GPIO30 |    |    |    | GPIO29 |    |    |    | GPIO28 |    |    |          |  |  |  |
| Type                                         | WO     |    |    |          |  |  |  |
| Reset                                        | 0      | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0      | 0  | 0  | 0        |  |  |  |
| Bit                                          | 15     | 14 | 13 | 12 | 11     | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3      | 2  | 1  | 0        |  |  |  |
| Name                                         | GPIO27 |    |    |    | GPIO26 |    |    |    | GPIO25 |    |    |    | GPIO24 |    |    |          |  |  |  |
| Type                                         | WO     |    |    |          |  |  |  |
| Reset                                        | 0      | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0      | 0  | 0  | 0        |  |  |  |

**Overview:** For bitwise access of GPIO\_MODE3

| Bit(s) | Mnemonic | Name | Description                                            |      |
|--------|----------|------|--------------------------------------------------------|------|
| 30:28  | GPIO31   |      | <b>Bitwise SET operation for Aux. mode of MCCK</b>     |      |
|        |          |      | 0:<br>1: SET bits                                      | Keep |
| 26:24  | GPIO30   |      | <b>Bitwise SET operation for Aux. mode of CMCSK</b>    |      |
|        |          |      | 0:<br>1: SET bits                                      | Keep |
| 23:20  | GPIO29   |      | <b>Bitwise SET operation for Aux. mode of CMMCLK</b>   |      |
|        |          |      | 0:<br>1: SET bits                                      | Keep |
| 19:16  | GPIO28   |      | <b>Bitwise SET operation for Aux. mode of CMCSD1</b>   |      |
|        |          |      | 0:<br>1: SET bits                                      | Keep |
| 15:12  | GPIO27   |      | <b>Bitwise SET operation for Aux. mode of CMCSD0</b>   |      |
|        |          |      | 0:<br>1: SET bits                                      | Keep |
| 10:8   | GPIO26   |      | <b>Bitwise SET operation for Aux. mode of CMPDN</b>    |      |
|        |          |      | 0:<br>1: SET bits                                      | Keep |
| 6:4    | GPIO25   |      | <b>Bitwise SET operation for Aux. mode of CMRST</b>    |      |
|        |          |      | 0:<br>1: SET bits                                      | Keep |
| 2:0    | GPIO24   |      | <b>Bitwise SET operation for Aux. mode of BPI_BUS0</b> |      |
|        |          |      | 0:<br>1: SET bits                                      | Keep |

**A0020C38    GPIO\_MODE3    GPIO Mode Control**                                                  **00000000**

| Bit   | 31     | 30 | 29 | 28     | 27 | 26 | 25     | 24 | 23 | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------|----|----|--------|----|----|--------|----|----|--------|----|----|----|----|----|----|
| Name  | GPIO31 |    |    | GPIO30 |    |    | GPIO29 |    |    | GPIO28 |    |    |    |    |    |    |
| Type  | WO     |    |    | WO     |    |    | WO     |    |    | WO     |    |    | WO |    |    |    |
| Reset | 0      | 0  | 0  | 0      | 0  | 0  | 0      | 0  | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15     | 14 | 13 | 12     | 11 | 10 | 9      | 8  | 7  | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | GPIO27 |    |    | GPIO26 |    |    | GPIO25 |    |    | GPIO24 |    |    |    |    |    |    |
| Type  | WO     |    |    | WO     |    |    | WO     |    |    | WO     |    |    | WO |    |    |    |
| Reset | 0      | 0  | 0  | 0      | 0  | 0  | 0      | 0  | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** For bitwise access of GPIO\_MODE3

| Bit(s) | Mnemonic | Name                                            | Description       | Keep |
|--------|----------|-------------------------------------------------|-------------------|------|
| 30:28  | GPIO31   | Bitwise CLR operation for Aux. mode of MCCK     | 0:<br>1: CLR bits | Keep |
| 26:24  | GPIO30   | Bitwise CLR operation for Aux. mode of CMCSK    | 0:<br>1: CLR bits | Keep |
| 23:20  | GPIO29   | Bitwise CLR operation for Aux. mode of CMMCLK   | 0:<br>1: CLR bits | Keep |
| 19:16  | GPIO28   | Bitwise CLR operation for Aux. mode of CMCSD1   | 0:<br>1: CLR bits | Keep |
| 15:12  | GPIO27   | Bitwise CLR operation for Aux. mode of CMCSD0   | 0:<br>1: CLR bits | Keep |
| 10:8   | GPIO26   | Bitwise CLR operation for Aux. mode of CMPDN    | 0:<br>1: CLR bits | Keep |
| 6:4    | GPIO25   | Bitwise CLR operation for Aux. mode of CMRST    | 0:<br>1: CLR bits | Keep |
| 2:0    | GPIO24   | Bitwise CLR operation for Aux. mode of BPI_BUS0 | 0:<br>1: CLR bits | Keep |

**A0020C40    GPIO\_MODE4    GPIO Mode Control**                                          **11100000**

| Bit   | 31     | 30 | 29 | 28     | 27 | 26 | 25     | 24 | 23 | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------|----|----|--------|----|----|--------|----|----|--------|----|----|----|----|----|----|
| Name  | GPIO39 |    |    | GPIO38 |    |    | GPIO37 |    |    | GPIO36 |    |    |    |    |    |    |
| Type  | RW     |    |    | RW     |    |    | RW     |    |    | RW     |    |    | RW |    |    |    |
| Reset | 0      | 0  | 1  | 0      | 0  | 0  | 1      | 0  | 0  | 0      | 1  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15     | 14 | 13 | 12     | 11 | 10 | 9      | 8  | 7  | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | GPIO35 |    |    | GPIO34 |    |    | GPIO33 |    |    | GPIO32 |    |    |    |    |    |    |
| Type  | RW     |    |    | RW     |    |    | RW     |    |    | RW     |    |    | RW |    |    |    |
| Reset | 0      | 0  | 0  | 0      | 0  | 0  | 0      | 0  | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** Configures GPIO aux. mode

| Bit(s) | Mnemonic | Name                        | Description |           |
|--------|----------|-----------------------------|-------------|-----------|
| 30:28  | GPIO39   | <b>Aux. mode of GPIO_39</b> | 0:          | GPIO39    |
|        |          |                             | 1:          | SIM1_SCLK |
|        |          |                             | 2:          | (IO)      |
|        |          |                             | 3:          | (IO)      |
|        |          |                             | 4:          | Reserved  |
|        |          |                             | 5:          | Reserved  |
|        |          |                             | 6:          | Reserved  |
|        |          |                             | 7: Reserved | Reserved  |
| 26:24  | GPIO38   | <b>Aux. mode of GPIO_38</b> | 0:          | GPIO38    |
|        |          |                             | 1:          | SIM1_SRST |
|        |          |                             | 2:          | (IO)      |
|        |          |                             | 3:          | (IO)      |
|        |          |                             | 4:          | Reserved  |
|        |          |                             | 5:          | Reserved  |
|        |          |                             | 6:          | Reserved  |
|        |          |                             | 7: Reserved | Reserved  |
| 22:20  | GPIO37   | <b>Aux. mode of GPIO_37</b> | 0:          | GPIO37    |
|        |          |                             | 1:          | SIM1_SIO  |
|        |          |                             | 2:          | (IO)      |
|        |          |                             | 3:          | (IO)      |
|        |          |                             | 4:          | Reserved  |
|        |          |                             | 5:          | Reserved  |
|        |          |                             | 6:          | Reserved  |
|        |          |                             | 7: Reserved | Reserved  |
| 18:16  | GPIO36   | <b>Aux. mode of GPIO_36</b> | 0:          | GPIO36    |
|        |          |                             | 1:          | MCDA3     |
|        |          |                             | 2:          | (I)       |
|        |          |                             | 3:          | (O)       |
|        |          |                             | 4:          | DAIPCMOUT |
|        |          |                             | 5:          | (O)       |
|        |          |                             | 6:          | Reserved  |
|        |          |                             | 7: Reserved | Reserved  |
| 14:12  | GPIO35   | <b>Aux. mode of GPIO_35</b> | 0:          | GPIO35    |
|        |          |                             | 1:          | MCDA2     |
|        |          |                             | 2:          | (I)       |
|        |          |                             | 3:          | (O)       |
|        |          |                             | 4:          | DAICLK    |
|        |          |                             | 5:          | Reserved  |
|        |          |                             | 6:          | Reserved  |
|        |          |                             | 7: Reserved | Reserved  |
| 10:8   | GPIO34   | <b>Aux. mode of GPIO_34</b> | 0:          | GPIO34    |
|        |          |                             | 1:          | MCDA1     |
|        |          |                             | 2:          | (I)       |
|        |          |                             | 3:          | Reserved  |
|        |          |                             | 4:          | DAIPCMIN  |
|        |          |                             | 5:          | (I)       |
|        |          |                             | 6:          | Reserved  |
|        |          |                             | 7: Reserved | Reserved  |
| 6:4    | GPIO33   | <b>Aux. mode of GPIO_33</b> | 0:          | GPIO33    |
|        |          |                             |             | (IO)      |

| Bit(s) | Mnemonic | Name | Description                                                                                             |                                                                    |
|--------|----------|------|---------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
|        |          |      | 1: MCDA0<br>2:<br>3:<br>4: DA ISYNC<br>5:<br>6:<br>7: Reserved                                          | (IO)<br>Reserved<br>Reserved<br>(O)<br>Reserved<br>Reserved        |
| 2:0    | GPIO32   |      | <b>Aux. mode of GPIO_32</b><br>0: GPIO32<br>1: MCCM0<br>2:<br>3:<br>4: U2TXD<br>5:<br>6:<br>7: Reserved | (IO)<br>(O)<br>Reserved<br>Reserved<br>(O)<br>Reserved<br>Reserved |

**A0020C44    GPIO\_MODE4    GPIO Mode Control                                          00000000**

| Bit   | 31     | 30 | 29 | 28 | 27     | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19     | 18 | 17 | 16 |
|-------|--------|----|----|----|--------|----|----|----|--------|----|----|----|--------|----|----|----|
| Name  | GPIO39 |    |    |    | GPIO38 |    |    |    | GPIO37 |    |    |    | GPIO36 |    |    |    |
| Type  | WO     |    |    |    |
| Reset | 0      | 0  | 0  |    | 0      | 0  | 0  |    | 0      | 0  | 0  |    | 0      | 0  | 0  |    |
| Bit   | 15     | 14 | 13 | 12 | 11     | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3      | 2  | 1  | 0  |
| Name  | GPIO35 |    |    |    | GPIO34 |    |    |    | GPIO33 |    |    |    | GPIO32 |    |    |    |
| Type  | WO     |    |    |    |
| Reset | 0      | 0  | 0  |    | 0      | 0  | 0  |    | 0      | 0  | 0  |    | 0      | 0  | 0  |    |

**Overview:** For bitwise access of GPIO\_MODE4

| Bit(s) | Mnemonic | Name | Description                                                                  |      |
|--------|----------|------|------------------------------------------------------------------------------|------|
| 30:28  | GPIO39   |      | <b>Bitwise SET operation for Aux. mode of SIM1_SCLK</b><br>0:<br>1: SET bits | Keep |
| 26:24  | GPIO38   |      | <b>Bitwise SET operation for Aux. mode of SIM1_SRST</b><br>0:<br>1: SET bits | Keep |
| 22:20  | GPIO37   |      | <b>Bitwise SET operation for Aux. mode of SIM1_SIO</b><br>0:<br>1: SET bits  | Keep |
| 18:16  | GPIO36   |      | <b>Bitwise SET operation for Aux. mode of MCDA3</b><br>0:<br>1: SET bits     | Keep |
| 14:12  | GPIO35   |      | <b>Bitwise SET operation for Aux. mode of MCDA2</b><br>0:<br>1: SET bits     | Keep |
| 10:8   | GPIO34   |      | <b>Bitwise SET operation for Aux. mode of MCDA1</b><br>0:<br>1: SET bits     | Keep |
| 6:4    | GPIO33   |      | <b>Bitwise SET operation for Aux. mode of MCDA0</b><br>0:<br>1: SET bits     | Keep |

| Bit(s) | Mnemonic | Name                                         | Description               |
|--------|----------|----------------------------------------------|---------------------------|
| 2:0    | GPIO32   | Bitwise SET operation for Aux. mode of MCCM0 | Keep<br>0:<br>1: SET bits |

**A0020C48    GPIO\_MODE4 - GPIO Mode Control**      **00000000**

| Bit          | 31            | 30 | 29 | 28 | 27            | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19            | 18 | 17 | 16 |
|--------------|---------------|----|----|----|---------------|----|----|----|---------------|----|----|----|---------------|----|----|----|
| <b>Name</b>  | <b>GPIO39</b> |    |    |    | <b>GPIO38</b> |    |    |    | <b>GPIO37</b> |    |    |    | <b>GPIO36</b> |    |    |    |
| <b>Type</b>  | WO            |    |    |    |
| <b>Reset</b> | 0             | 0  | 0  |    | 0             | 0  | 0  |    | 0             | 0  | 0  |    | 0             | 0  | 0  |    |
| <b>Bit</b>   | 15            | 14 | 13 | 12 | 11            | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3             | 2  | 1  | 0  |
| <b>Name</b>  | <b>GPIO35</b> |    |    |    | <b>GPIO34</b> |    |    |    | <b>GPIO33</b> |    |    |    | <b>GPIO32</b> |    |    |    |
| <b>Type</b>  | WO            |    |    |    |
| <b>Reset</b> | 0             | 0  | 0  |    | 0             | 0  | 0  |    | 0             | 0  | 0  |    | 0             | 0  | 0  |    |

**Overview:** For bitwise access of GPIO\_MODE4

| Bit(s) | Mnemonic | Name                                             | Description               |
|--------|----------|--------------------------------------------------|---------------------------|
| 30:28  | GPIO39   | Bitwise CLR operation for Aux. mode of SIM1_SCLK | Keep<br>0:<br>1: CLR bits |
| 26:24  | GPIO38   | Bitwise CLR operation for Aux. mode of SIM1_SRST | Keep<br>0:<br>1: CLR bits |
| 22:20  | GPIO37   | Bitwise CLR operation for Aux. mode of SIM1_SIO  | Keep<br>0:<br>1: CLR bits |
| 18:16  | GPIO36   | Bitwise CLR operation for Aux. mode of MCDA3     | Keep<br>0:<br>1: CLR bits |
| 14:12  | GPIO35   | Bitwise CLR operation for Aux. mode of MCDA2     | Keep<br>0:<br>1: CLR bits |
| 10:8   | GPIO34   | Bitwise CLR operation for Aux. mode of MCDA1     | Keep<br>0:<br>1: CLR bits |
| 6:4    | GPIO33   | Bitwise CLR operation for Aux. mode of MCDA0     | Keep<br>0:<br>1: CLR bits |
| 2:0    | GPIO32   | Bitwise CLR operation for Aux. mode of MCCM0     | Keep<br>0:<br>1: CLR bits |

**A0020C50    GPIO\_MODE5 - GPIO Mode Control**      **01000111**

| Bit          | 31            | 30 | 29 | 28 | 27            | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19            | 18 | 17 | 16 |
|--------------|---------------|----|----|----|---------------|----|----|----|---------------|----|----|----|---------------|----|----|----|
| <b>Name</b>  | <b>GPIO47</b> |    |    |    | <b>GPIO46</b> |    |    |    | <b>GPIO45</b> |    |    |    | <b>GPIO44</b> |    |    |    |
| <b>Type</b>  | RW            |    |    |    |
| <b>Reset</b> | 0             | 0  | 0  |    | 0             | 0  | 1  |    | 0             | 0  | 0  |    | 0             | 0  | 0  |    |
| <b>Bit</b>   | 15            | 14 | 13 | 12 | 11            | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3             | 2  | 1  | 0  |

| Name  | GPIO43 |   |   | GPIO42 |   |   | GPIO41 |   |   | GPIO40 |   |   |
|-------|--------|---|---|--------|---|---|--------|---|---|--------|---|---|
| Type  | RW     |   |   | RW     |   |   | RW     |   |   | RW     |   |   |
| Reset | 0      | 0 | 0 | 0      | 0 | 1 | 0      | 0 | 1 | 0      | 0 | 1 |

**Overview:** Configures GPIO aux. mode

| Bit(s) | Mnemonic | Name                        | Description |      |
|--------|----------|-----------------------------|-------------|------|
| 30:28  | GPIO47   | <b>Aux. mode of GPIO_47</b> | 0:          | (IO) |
|        |          |                             | 1:          |      |
|        |          |                             | 2:          |      |
|        |          |                             | 3:          |      |
|        |          |                             | 4:          |      |
|        |          |                             | 5:          |      |
|        |          |                             | 6:          |      |
|        |          |                             | 7: Reserved |      |
| 26:24  | GPIO46   | <b>Aux. mode of GPIO_46</b> | 0:          | (IO) |
|        |          |                             | 1:          |      |
|        |          |                             | 2:          |      |
|        |          |                             | 3:          |      |
|        |          |                             | 4:          |      |
|        |          |                             | 5:          |      |
|        |          |                             | 6:          |      |
|        |          |                             | 7: Reserved |      |
| 22:20  | GPIO45   | <b>Aux. mode of GPIO_45</b> | 0:          | (IO) |
|        |          |                             | 1:          |      |
|        |          |                             | 2:          |      |
|        |          |                             | 3:          |      |
|        |          |                             | 4:          |      |
|        |          |                             | 5:          |      |
|        |          |                             | 6:          |      |
|        |          |                             | 7: Reserved |      |
| 18:16  | GPIO44   | <b>Aux. mode of GPIO_44</b> | 0:          | (IO) |
|        |          |                             | 1:          |      |
|        |          |                             | 2:          |      |
|        |          |                             | 3:          |      |
|        |          |                             | 4:          |      |
|        |          |                             | 5:          |      |
|        |          |                             | 6:          |      |
|        |          |                             | 7: Reserved |      |
| 14:12  | GPIO43   | <b>Aux. mode of GPIO_43</b> | 0:          | (IO) |
|        |          |                             | 1:          |      |
|        |          |                             | 2:          |      |
|        |          |                             | 3:          |      |
|        |          |                             | 4:          |      |
|        |          |                             | 5:          |      |
|        |          |                             | 6:          |      |
|        |          |                             | 7: Reserved |      |
| 10:8   | GPIO42   | <b>Aux. mode of GPIO_42</b> | 0:          | (IO) |
|        |          |                             | 1:          |      |
|        |          |                             | 2:          |      |
|        |          |                             | 3:          |      |
|        |          |                             | 4:          |      |
|        |          |                             | 5:          |      |
|        |          |                             | 6:          |      |
|        |          |                             | 7: Reserved |      |

| Bit(s) | Mnemonic | Name | Description                                                                          |                                                                                             |
|--------|----------|------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| 6:4    | GPIO41   |      | 6:<br>7: Reserved                                                                    | Reserved                                                                                    |
| 2:0    | GPIO40   |      | <b>Aux. mode of GPIO_41</b><br>0:<br>1:<br>2:<br>3:<br>4:<br>5:<br>6:<br>7: Reserved | GPIO41 (IO)<br>SIM2_SRST (IO)<br>CLKO3 (O)<br>U2CTS (I)<br>Reserved<br>Reserved<br>Reserved |
|        |          |      | <b>Aux. mode of GPIO_40</b><br>0:<br>1:<br>2:<br>3:<br>4:<br>5:<br>6:<br>7: Reserved | GPIO40 (IO)<br>SIM2_SIO (IO)<br>Reserved (O)<br>U2RTS Reserved<br>Reserved<br>Reserved      |

| A0020C54 <u>GPIO_MODE5</u> - GPIO Mode Control |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00000000 |  |  |  |
|------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|--|--|--|
| Bit                                            | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |  |  |  |
| Name                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |
| Type                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |
| Reset                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |
| Bit                                            | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |  |  |  |
| Name                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |
| Type                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |
| Reset                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |

**Overview:** For bitwise access of GPIO\_MODE5

| Bit(s) | Mnemonic | Name | Description                                              |      |
|--------|----------|------|----------------------------------------------------------|------|
| 30:28  | GPIO47   |      | <b>Bitwise SET operation for Aux. mode of LSCK</b>       | Keep |
|        |          |      | 0:<br>1: SET bits                                        |      |
| 26:24  | GPIO46   |      | <b>Bitwise SET operation for Aux. mode of LSCE_B</b>     | Keep |
|        |          |      | 0:<br>1: SET bits                                        |      |
| 22:20  | GPIO45   |      | <b>Bitwise SET operation for Aux. mode of TESTMODE_D</b> | Keep |
|        |          |      | 0:<br>1: SET bits                                        |      |
| 18:16  | GPIO44   |      | <b>Bitwise SET operation for Aux. mode of SDA28</b>      | Keep |
|        |          |      | 0:<br>1: SET bits                                        |      |
| 14:12  | GPIO43   |      | <b>Bitwise SET operation for Aux. mode of SCL28</b>      | Keep |
|        |          |      | 0:<br>1: SET bits                                        |      |
| 10:8   | GPIO42   |      | <b>Bitwise SET operation for Aux. mode of SIM2_SCLK</b>  | Keep |
|        |          |      | 0:                                                       |      |

| Bit(s) | Mnemonic | Name   | Description                                                                                 |      |
|--------|----------|--------|---------------------------------------------------------------------------------------------|------|
| 6:4    |          | GPIO41 | 1: SET bits<br><b>Bitwise SET operation for Aux. mode of SIM2_SRST</b><br>0:<br>1: SET bits | Keep |
| 2:0    |          | GPIO40 | 0:<br>1: SET bits<br><b>Bitwise SET operation for Aux. mode of SIM2_SIO</b>                 | Keep |

**A0020C58    GPIO\_MODE5    GPIO Mode Control                          00000000**

| Bit          | 31     | 30 | 29 | 28 | 27 | 26     | 25 | 24 | 23 | 22 | 21     | 20 | 19 | 18 | 17 | 16     |
|--------------|--------|----|----|----|----|--------|----|----|----|----|--------|----|----|----|----|--------|
| <b>Name</b>  |        |    |    |    |    |        |    |    |    |    |        |    |    |    |    |        |
| <b>Type</b>  |        |    |    |    |    |        |    |    |    |    |        |    |    |    |    |        |
| <b>Reset</b> |        |    |    |    |    |        |    |    |    |    |        |    |    |    |    |        |
| <b>Bit</b>   | 15     | 14 | 13 | 12 | 11 | 10     | 9  | 8  | 7  | 6  | 5      | 4  | 3  | 2  | 1  | 0      |
| <b>Name</b>  |        |    |    |    |    |        |    |    |    |    |        |    |    |    |    |        |
| <b>Type</b>  |        |    |    |    |    |        |    |    |    |    |        |    |    |    |    |        |
| <b>Reset</b> |        |    |    |    |    |        |    |    |    |    |        |    |    |    |    |        |
|              | GPIO47 |    |    |    |    | GPIO46 |    |    |    |    | GPIO45 |    |    |    |    | GPIO44 |
|              |        | WO |    |    |    | WO     |    |    |    |    | WO     |    |    |    |    | WO     |
|              | 0      | 0  | 0  |    |    | 0      | 0  | 0  |    |    | 0      | 0  | 0  |    | 0  | 0      |
|              |        |    |    |    |    |        |    |    |    |    |        |    |    |    |    |        |
|              |        |    |    |    |    |        |    |    |    |    |        |    |    |    |    |        |
|              | GPIO43 |    |    |    |    | GPIO42 |    |    |    |    | GPIO41 |    |    |    |    | GPIO40 |
|              |        | WO |    |    |    | WO     |    |    |    |    | WO     |    |    |    |    | WO     |
|              | 0      | 0  | 0  |    |    | 0      | 0  | 0  |    |    | 0      | 0  | 0  |    | 0  | 0      |

**Overview:** For bitwise access of GPIO\_MODE5

| Bit(s) | Mnemonic | Name   | Description                                                                   |      |
|--------|----------|--------|-------------------------------------------------------------------------------|------|
| 30:28  |          | GPIO47 | <b>Bitwise CLR operation for Aux. mode of LSCK</b><br>0:<br>1: CLR bits       | Keep |
| 26:24  |          | GPIO46 | <b>Bitwise CLR operation for Aux. mode of LSCE_B</b><br>0:<br>1: CLR bits     | Keep |
| 22:20  |          | GPIO45 | <b>Bitwise CLR operation for Aux. mode of TESTMODE_D</b><br>0:<br>1: CLR bits | Keep |
| 18:16  |          | GPIO44 | <b>Bitwise CLR operation for Aux. mode of SDA28</b><br>0:<br>1: CLR bits      | Keep |
| 14:12  |          | GPIO43 | <b>Bitwise CLR operation for Aux. mode of SCL28</b><br>0:<br>1: CLR bits      | Keep |
| 10:8   |          | GPIO42 | <b>Bitwise CLR operation for Aux. mode of SIM2_SCLK</b><br>0:<br>1: CLR bits  | Keep |
| 6:4    |          | GPIO41 | <b>Bitwise CLR operation for Aux. mode of SIM2_SRST</b><br>0:<br>1: CLR bits  | Keep |
| 2:0    |          | GPIO40 | <b>Bitwise CLR operation for Aux. mode of SIM2_SIO</b><br>0:<br>1: CLR bits   | Keep |

**A0020C60    GPIO\_MODE6    GPIO Mode Control                          00001000**

| Bit   | 31 | 30 | 29 | 28 | 27     | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19     | 18 | 17 | 16     |
|-------|----|----|----|----|--------|----|----|----|--------|----|----|----|--------|----|----|--------|
| Name  |    |    |    |    | GPIO55 |    |    |    | GPIO54 |    |    |    | GPIO53 |    |    | GPIO52 |
| Type  |    |    |    |    | RW     |    |    |    | RW     |    |    |    | RW     |    |    | RW     |
| Reset |    | 0  | 0  | 0  |        | 0  | 0  | 0  |        | 0  | 0  | 0  |        | 0  | 0  | 0      |
| Bit   | 15 | 14 | 13 | 12 | 11     | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3      | 2  | 1  | 0      |
| Name  |    |    |    |    | GPIO51 |    |    |    | GPIO50 |    |    |    | GPIO49 |    |    | GPIO48 |
| Type  |    |    |    |    | RW     |    |    |    | RW     |    |    |    | RW     |    |    | RW     |
| Reset |    | 0  | 0  | 1  | 0      | 0  | 0  | 0  |        | 0  | 0  | 0  |        | 0  | 0  | 0      |

**Overview:** Configures GPIO aux. mode

| Bit(s) | Mnemonic | Name   | Description                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------|--------|-----------------------------|--------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 30:28  |          | GPIO55 | <b>Aux. mode of GPIO_55</b> |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 0: AGPIO55                  | (AGIO) |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 1: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 2: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 3: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 4: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 5: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 6: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 7: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26:24  |          | GPIO54 | <b>Aux. mode of GPIO_54</b> |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 0: AGPIO54                  | (AGIO) |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 1: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 2: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 3: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 4: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 5: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 6: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 7: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22:20  |          | GPIO53 | <b>Aux. mode of GPIO_53</b> |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 0: AGPIO53                  | (AGI)  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 1: SRCLKENAI                | (I)    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 2: EINT24                   | (I)    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 3: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 4: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 5: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 6: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 7: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18:16  |          | GPIO52 | <b>Aux. mode of GPIO_52</b> |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 0: AGPI52                   | (AGI)  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 1: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 2: EINT23                   | (I)    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 3: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 4: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 5: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 6: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 7: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14:12  |          | GPIO51 | <b>Aux. mode of GPIO_51</b> |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 0: GPIO51                   | (IO)   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 1: RESETB                   | (IO)   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 2: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 3: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 4: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 5: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 6: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 7: Reserved                 |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11:8   |          | GPIO50 | <b>Aux. mode of GPIO_50</b> |        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |          |        | 0: GPIO50                   | (IO)   |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Mnemonic | Name                        | Description  |
|--------|----------|-----------------------------|--------------|
|        |          | 1:                          | LPTE (I)     |
|        |          | 2:                          | EINT22 (I)   |
|        |          | 3:                          | CMCSK (I)    |
|        |          | 4:                          | CMCSD2 (I)   |
|        |          | 5:                          | Reserved     |
|        |          | 6:                          | MCINS (I)    |
|        |          | 7:                          | Reserved     |
|        |          | 8:                          | Reserved     |
|        |          | 9: CLKO5 (O)                |              |
| 6:4    | GPIO49   | <b>Aux. mode of GPIO_49</b> |              |
|        |          | 0:                          | GPIO49 (IO)  |
|        |          | 1:                          | LSA0DA0 (O)  |
|        |          | 2:                          | LSCE1_B0 (O) |
|        |          | 3:                          | CMMCLK (O)   |
|        |          | 4:                          | Reserved     |
|        |          | 5:                          | Reserved     |
|        |          | 6:                          | Reserved     |
|        |          | 7: Reserved                 |              |
| 2:0    | GPIO48   | <b>Aux. mode of GPIO_48</b> |              |
|        |          | 0:                          | GPIO48 (IO)  |
|        |          | 1:                          | LSDA0 (IO)   |
|        |          | 2:                          | EINT21 (I)   |
|        |          | 3:                          | CMCSD1 (I)   |
|        |          | 4:                          | WIFITOBT (I) |
|        |          | 5:                          | Reserved     |
|        |          | 6:                          | Reserved     |
|        |          | 7: Reserved                 |              |

**A0020C64    GPIO\_MODE6    GPIO Mode Control    00000000**

| Bit          | 31            | 30 | 29 | 28 | 27            | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19            | 18 | 17 | 16 |
|--------------|---------------|----|----|----|---------------|----|----|----|---------------|----|----|----|---------------|----|----|----|
| <b>Name</b>  | <b>GPIO55</b> |    |    |    | <b>GPIO54</b> |    |    |    | <b>GPIO53</b> |    |    |    | <b>GPIO52</b> |    |    |    |
| <b>Type</b>  | WO            |    |    |    |
| <b>Reset</b> | 0             | 0  | 0  |    | 0             | 0  | 0  |    | 0             | 0  | 0  |    | 0             | 0  | 0  |    |
| <b>Bit</b>   | 15            | 14 | 13 | 12 | 11            | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3             | 2  | 1  | 0  |
| <b>Name</b>  | <b>GPIO51</b> |    |    |    | <b>GPIO50</b> |    |    |    | <b>GPIO49</b> |    |    |    | <b>GPIO48</b> |    |    |    |
| <b>Type</b>  | WO            |    |    |    |
| <b>Reset</b> | 0             | 0  | 0  | 0  | 0             | 0  | 0  |    | 0             | 0  | 0  |    | 0             | 0  | 0  |    |

**Overview:** For bitwise access of GPIO\_MODE6

| Bit(s) | Mnemonic | Name                                                    | Description |
|--------|----------|---------------------------------------------------------|-------------|
| 30:28  | GPIO55   | <b>Bitwise SET operation for Aux. mode of SRCLKENAI</b> |             |
|        |          | 0:                                                      | Keep        |
|        |          | 1: SET bits                                             |             |
| 26:24  | GPIO54   | <b>Bitwise SET operation for Aux. mode of EINT</b>      |             |
|        |          | 0:                                                      | Keep        |
|        |          | 1: SET bits                                             |             |
| 22:20  | GPIO53   | <b>Bitwise SET operation for Aux. mode of TP4</b>       |             |
|        |          | 0:                                                      | Keep        |
|        |          | 1: SET bits                                             |             |
| 18:16  | GPIO52   | <b>Bitwise SET operation for Aux. mode of TP3</b>       |             |
|        |          | 0:                                                      | Keep        |

| Bit(s) | Mnemonic | Name | Description                                                             |      |
|--------|----------|------|-------------------------------------------------------------------------|------|
| 14:12  | GPIO51   |      | 1: SET bits<br><b>Bitwise SET operation for Aux. mode of RESETB</b>     |      |
| 11:8   | GPIO50   |      | 0:<br>1: SET bits<br><b>Bitwise SET operation for Aux. mode of LPTE</b> | Keep |
| 6:4    | GPIO49   |      | 0:<br>1: SET bits<br><b>Bitwise SET operation for Aux. mode of LSA0</b> | Keep |
| 2:0    | GPIO48   |      | 0:<br>1: SET bits<br><b>Bitwise SET operation for Aux. mode of LSDA</b> | Keep |

**A0020C68    GPIO\_MODE6    GPIO Mode Control    00000000**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0  | 0  | 0  |    | 0  | 0  | 0  |    | 0  | 0  | 0  |    | 0  | 0  | 0  |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    | 0  | 0  | 0  |    | 0  | 0  | 0  |    |

**Overview:** For bitwise access of GPIO\_MODE6

| Bit(s) | Mnemonic | Name | Description                                             |      |
|--------|----------|------|---------------------------------------------------------|------|
| 30:28  | GPIO55   |      | <b>Bitwise CLR operation for Aux. mode of SRCLKENAI</b> |      |
|        |          |      | 0:<br>1: CLR bits                                       | Keep |
| 26:24  | GPIO54   |      | <b>Bitwise CLR operation for Aux. mode of EINT</b>      |      |
|        |          |      | 0:<br>1: CLR bits                                       | Keep |
| 22:20  | GPIO53   |      | <b>Bitwise CLR operation for Aux. mode of TP4</b>       |      |
|        |          |      | 0:<br>1: CLR bits                                       | Keep |
| 18:16  | GPIO52   |      | <b>Bitwise CLR operation for Aux. mode of TP3</b>       |      |
|        |          |      | 0:<br>1: CLR bits                                       | Keep |
| 14:12  | GPIO51   |      | <b>Bitwise CLR operation for Aux. mode of RECLRB</b>    |      |
|        |          |      | 0:<br>1: CLR bits                                       | Keep |
| 11:8   | GPIO50   |      | <b>Bitwise CLR operation for Aux. mode of LPTE</b>      |      |
|        |          |      | 0:<br>1: CLR bits                                       | Keep |
| 6:4    | GPIO49   |      | <b>Bitwise CLR operation for Aux. mode of LSA0</b>      |      |
|        |          |      | 0:<br>1: CLR bits                                       | Keep |
| 2:0    | GPIO48   |      | <b>Bitwise CLR operation for Aux. mode of LSDA</b>      |      |

| Bit(s) | Mnemonic | Name | Description       | Keep |
|--------|----------|------|-------------------|------|
|        |          |      | 0:<br>1: CLR bits |      |
|        |          |      |                   |      |

**A0020D10 GPIO\_TDSEL GPIO TDSEL Control 00000000**

| Bit   | 31     | 30     | 29     | 28     | 27     | 26     | 25    | 24    | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16 |
|-------|--------|--------|--------|--------|--------|--------|-------|-------|----|----|----|----|----|----|--------|----|
| Name  |        |        |        |        |        |        |       |       |    |    |    |    |    |    | GPIO50 |    |
| Type  |        |        |        |        |        |        |       |       |    |    |    |    |    |    | RW     |    |
| Reset |        |        |        |        |        |        |       |       |    |    |    |    |    |    | 0      | 0  |
| Bit   | 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     | 7  | 6  | 5  | 4  | 3  | 2  | 1      | 0  |
| Name  | GPIO46 | GPIO42 | GPIO41 | GPIO36 | GPIO25 | GPIO18 | GPIO9 | GPIO8 |    |    |    |    |    |    |        |    |
| Type  | RW     | RW     | RW     | RW     | RW     | RW     | RW    | RW    |    |    |    |    |    |    |        | RW |
| Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  |

Overview: GPIO TX duty control register

| Bit(s) | Mnemonic      | Name         | Description            |
|--------|---------------|--------------|------------------------|
| 17:16  | <b>GPIO50</b> | GPIO50_TDSEL | GPIO50 Tx duty control |
| 15:14  | <b>GPIO46</b> | GPIO46_TDSEL | GPIO46 Tx duty control |
| 13:12  | <b>GPIO42</b> | GPIO42_TDSEL | GPIO42 Tx duty control |
| 11:10  | <b>GPIO41</b> | GPIO41_TDSEL | GPIO41 Tx duty control |
| 9:8    | <b>GPIO36</b> | GPIO36_TDSEL | GPIO36 Tx duty control |
| 7:6    | <b>GPIO25</b> | GPIO25_TDSEL | GPIO25 Tx duty control |
| 5:4    | <b>GPIO18</b> | GPIO18_TDSEL | GPIO18 Tx duty control |
| 3:2    | <b>GPIO9</b>  | GPIO9_TDSEL  | GPIO9 Tx duty control  |
| 1:0    | <b>GPIO8</b>  | GPIO8_TDSEL  | GPIO8 Tx duty control  |

**A0020D14 GPIO\_TDSEL\_S ET GPIO TDSEL Control 00000000**

| Bit   | 31     | 30     | 29     | 28     | 27     | 26     | 25    | 24    | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16 |
|-------|--------|--------|--------|--------|--------|--------|-------|-------|----|----|----|----|----|----|--------|----|
| Name  |        |        |        |        |        |        |       |       |    |    |    |    |    |    | GPIO50 |    |
| Type  |        |        |        |        |        |        |       |       |    |    |    |    |    |    | WO     |    |
| Reset |        |        |        |        |        |        |       |       |    |    |    |    |    |    | 0      | 0  |
| Bit   | 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     | 7  | 6  | 5  | 4  | 3  | 2  | 1      | 0  |
| Name  | GPIO46 | GPIO42 | GPIO41 | GPIO36 | GPIO25 | GPIO18 | GPIO9 | GPIO8 |    |    |    |    |    |    |        |    |
| Type  | WO     | WO     | WO     | WO     | WO     | WO     | WO    | WO    |    |    |    |    |    |    | WO     |    |
| Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  |

Overview: For bitwise access of GPIO\_TDSEL

| Bit(s) | Mnemonic      | Name         | Description                                           |
|--------|---------------|--------------|-------------------------------------------------------|
| 17:16  | <b>GPIO50</b> | GPIO50_TDSEL | Bitwise SET operation of GPIO50_TDSEL Tx duty control |
|        |               |              | 0:<br>1: SET bits                                     |
| 15:14  | <b>GPIO46</b> | GPIO46_TDSEL | Bitwise SET operation of GPIO46_TDSEL Tx duty control |
|        |               |              | 0:<br>1: SET bits                                     |
| 13:12  | <b>GPIO42</b> | GPIO42_TDSEL | Bitwise SET operation of GPIO42_TDSEL Tx duty control |

| Bit(s) | Mnemonic      | Name         | Description                                                  |      |
|--------|---------------|--------------|--------------------------------------------------------------|------|
| 11:10  | <b>GPIO41</b> | GPIO41_TDSEL | 0:<br>1: SET bits                                            | Keep |
|        |               |              | <b>Bitwise SET operation of GPIO41_TDSEL Tx duty control</b> |      |
| 9:8    | <b>GPIO36</b> | GPIO36_TDSEL | 0:<br>1: SET bits                                            | Keep |
|        |               |              | <b>Bitwise SET operation of GPIO36_TDSEL Tx duty control</b> |      |
| 7:6    | <b>GPIO25</b> | GPIO25_TDSEL | 0:<br>1: SET bits                                            | Keep |
|        |               |              | <b>Bitwise SET operation of GPIO25_TDSEL Tx duty control</b> |      |
| 5:4    | <b>GPIO18</b> | GPIO18_TDSEL | 0:<br>1: SET bits                                            | Keep |
|        |               |              | <b>Bitwise SET operation of GPIO18_TDSEL Tx duty control</b> |      |
| 3:2    | <b>GPIO9</b>  | GPIO9_TDSEL  | 0:<br>1: SET bits                                            | Keep |
|        |               |              | <b>Bitwise SET operation of GPIO9_TDSEL Tx duty control</b>  |      |
| 1:0    | <b>GPIO8</b>  | GPIO8_TDSEL  | 0:<br>1: SET bits                                            | Keep |
|        |               |              | <b>Bitwise SET operation of GPIO8_TDSEL Tx duty control</b>  |      |

A0020D18 GPIO\_TDSEL\_C GPIO TDSEL Control 00000000  
LR

| Bit          | 31            | 30            | 29            | 28            | 27            | 26            | 25           | 24           | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
|--------------|---------------|---------------|---------------|---------------|---------------|---------------|--------------|--------------|----|----|----|----|----|----|----|---------------|
| <b>Name</b>  |               |               |               |               |               |               |              |              |    |    |    |    |    |    |    | <b>GPIO50</b> |
| <b>Type</b>  |               |               |               |               |               |               |              |              |    |    |    |    |    |    |    | WO            |
| <b>Reset</b> |               |               |               |               |               |               |              |              |    |    |    |    |    |    |    | 0 0           |
| Bit          | 15            | 14            | 13            | 12            | 11            | 10            | 9            | 8            | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| <b>Name</b>  | <b>GPIO46</b> | <b>GPIO42</b> | <b>GPIO41</b> | <b>GPIO36</b> | <b>GPIO25</b> | <b>GPIO18</b> | <b>GPIO9</b> | <b>GPIO8</b> |    |    |    |    |    |    |    |               |
| <b>Type</b>  | WO            | WO            | WO            | WO            | WO            | WO            | WO           | WO           |    |    |    |    |    |    |    | WO            |
| <b>Reset</b> | 0             | 0             | 0             | 0             | 0             | 0             | 0            | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             |

**Overview:** For bitwise access of GPIO\_TDSEL

| Bit(s) | Mnemonic      | Name         | Description                                                  |      |
|--------|---------------|--------------|--------------------------------------------------------------|------|
| 17:16  | <b>GPIO50</b> | GPIO50_TDSEL | <b>Bitwise CLR operation of GPIO50_TDSEL Tx duty control</b> | Keep |
|        |               |              | 0:<br>1: CLR bits                                            |      |
| 15:14  | <b>GPIO46</b> | GPIO46_TDSEL | <b>Bitwise CLR operation of GPIO46_TDSEL Tx duty control</b> | Keep |
|        |               |              | 0:<br>1: CLR bits                                            |      |
| 13:12  | <b>GPIO42</b> | GPIO42_TDSEL | <b>Bitwise CLR operation of GPIO42_TDSEL Tx duty control</b> | Keep |
|        |               |              | 0:<br>1: CLR bits                                            |      |
| 11:10  | <b>GPIO41</b> | GPIO41_TDSEL | <b>Bitwise CLR operation of GPIO41_TDSEL Tx duty control</b> | Keep |
|        |               |              | 0:<br>1: CLR bits                                            |      |
| 9:8    | <b>GPIO36</b> | GPIO36_TDSEL | <b>Bitwise CLR operation of GPIO36_TDSEL Tx duty control</b> | Keep |
|        |               |              | 0:<br>1: CLR bits                                            |      |

| Bit(s) | Mnemonic      | Name         | Description                                                  |  |
|--------|---------------|--------------|--------------------------------------------------------------|--|
| 7:6    | <b>GPIO25</b> | GPIO25_TDSEL | <b>Bitwise CLR operation of GPIO25_TDSEL Tx duty control</b> |  |
|        |               |              | 0: Keep                                                      |  |
|        |               |              | 1: CLR bits                                                  |  |
| 5:4    | <b>GPIO18</b> | GPIO18_TDSEL | <b>Bitwise CLR operation of GPIO18_TDSEL Tx duty control</b> |  |
|        |               |              | 0: Keep                                                      |  |
|        |               |              | 1: CLR bits                                                  |  |
| 3:2    | <b>GPIO9</b>  | GPIO9_TDSEL  | <b>Bitwise CLR operation of GPIO9_TDSEL Tx duty control</b>  |  |
|        |               |              | 0: Keep                                                      |  |
|        |               |              | 1: CLR bits                                                  |  |
| 1:0    | <b>GPIO8</b>  | GPIO8_TDSEL  | <b>Bitwise CLR operation of GPIO8_TDSEL Tx duty control</b>  |  |
|        |               |              | 0: Keep                                                      |  |
|        |               |              | 1: CLR bits                                                  |  |

| <b>A0020E00 CLK_OUT0 CLK Out Selection Control 00000004</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
|-------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Bit                                                         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
| <b>Name</b>                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Type</b>                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Reset</b>                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| Bit                                                         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| <b>Name</b>                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CLK_OUT0</b> |
| <b>Type</b>                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW              |
| <b>Reset</b>                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 1 0 0         |

**Overview:** CLK OUT0 Setting

| Bit(s) | Mnemonic        | Name | Description                            |
|--------|-----------------|------|----------------------------------------|
| 3:0    | <b>CLK_OUT0</b> | CFG0 | <b>Selects clock output for CLKO_0</b> |
|        |                 |      | [1]: 26Mhz                             |
|        |                 |      | [4]: 32Khz_clock                       |
|        |                 |      | others: debug clock                    |

| <b>A0020E10 CLK_OUT1 CLK Out Selection Control 00000004</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
|-------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Bit                                                         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
| <b>Name</b>                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Type</b>                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Reset</b>                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| Bit                                                         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| <b>Name</b>                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CLK_OUT1</b> |
| <b>Type</b>                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW              |
| <b>Reset</b>                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 1 0 0         |

**Overview:** CLK OUT1 setting

| Bit(s) | Mnemonic        | Name | Description                            |
|--------|-----------------|------|----------------------------------------|
| 3:0    | <b>CLK_OUT1</b> | CFG1 | <b>Selects clock output for CLKO_1</b> |
|        |                 |      | [1]: 26Mhz                             |
|        |                 |      | [4]: 32Khz_clock                       |
|        |                 |      | others: debug clock                    |

**A0020E20 CLK\_OUT2 CLK Out Selection Control 00000004**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Overview:** CLK OUT2 setting

| Bit(s) | Mnemonic        | Name | Description                                                                                     |
|--------|-----------------|------|-------------------------------------------------------------------------------------------------|
| 3:0    | <b>CLK_OUT2</b> | CFG2 | <b>Selects clock output for CLKO_2</b><br>[1]: 26Mhz<br>[4]: 32Khz_clock<br>others: debug clock |

**A0020E30 CLK\_OUT3 CLK Out Selection Control 00000004**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Overview:** CLK OUT3 setting

| Bit(s) | Mnemonic        | Name | Description                                                                                     |
|--------|-----------------|------|-------------------------------------------------------------------------------------------------|
| 3:0    | <b>CLK_OUT3</b> | CFG3 | <b>Selects clock output for CLKO_3</b><br>[1]: 26Mhz<br>[4]: 32Khz_clock<br>others: debug clock |

**A0020E40 CLK\_OUT4 CLK Out Selection Control 00000004**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Overview:** CLK OUT4 setting

| Bit(s) | Mnemonic        | Name | Description                                                                                     |
|--------|-----------------|------|-------------------------------------------------------------------------------------------------|
| 3:0    | <b>CLK_OUT4</b> | CFG4 | <b>Selects clock output for CLKO_4</b><br>[1]: 26Mhz<br>[4]: 32Khz_clock<br>others: debug clock |

| <b>A0020E50 CLK_OUT5 CLK Out Selection Control</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000004</b> |   |   |   |
|----------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|---|---|---|
| <b>Bit</b>                                         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                 |   |   |   |
| <b>Name</b>                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |   |   |
| <b>Type</b>                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |   |   |
| <b>Reset</b>                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |   |   |
| <b>Bit</b>                                         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                 |   |   |   |
| <b>Name</b>                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CLK_OUT5</b> |   |   |   |
| <b>Type</b>                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW              |   |   |   |
| <b>Reset</b>                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0               | 1 | 0 | 0 |

**Overview:** CLK OUT5 setting

| Bit(s) | Mnemonic        | Name | Description                                                                                     |
|--------|-----------------|------|-------------------------------------------------------------------------------------------------|
| 3:0    | <b>CLK_OUT5</b> | CFG5 | <b>Selects clock output for CLKO_5</b><br>[1]: 26Mhz<br>[4]: 32Khz_clock<br>others: debug clock |

## 3.5 General-purpose Timer

### 3.5.1 General Descriptions

Three general-purpose timers are provided. Two timers are 16 bits long and one timer is 32 bits long. Each runs independently. GPT1 ~ 2 use 32k clock source to count, whereas GPT4 uses 26M clock source. The 26M clock source can be gated when the system enters the sleep mode, and this will cause GPT4 to stop counting, whereas 32k clock source is always toggling. GPT1 and GPT2 can operate in one of the two modes: one-shot mode and auto-repeat mode. GPT4 are free running timer. In the one-shot mode, when the timer counts down and reaches 0, it will be halted. In the auto-repeat mode, when the timer reaches 0, it will simply be reset to counting down the initial value and repeating the count-down to 0. This loop keeps repeating until the disabling signal is set to 1. Regardless of the timer's mode, if the countdown initial value (i.e. GPTIMER1\_DAT for GPT1 or GPTIMER\_DAT2 for GPT2) is written when the timer is running, the new initial value will not take effect until the next time the timer is restarted. In the auto-repeat mode, the new countdown start value is used on the next countdown iteration. Therefore, before enabling the timer, the desired values for GPTIMER\_DAT and the GPTIMER\_PRESCALER registers must first be set.

Note that GPTimer's design is inherited from MT6260, GPT3 is removed for achieving lower cost.

For other timers, register addresses are the same with those of MT6260.

### 3.5.2 Register Definition

**Module name: GPTimer base address: (+A00C0000h)**

| Address  | Name                      | Width | Register function               |
|----------|---------------------------|-------|---------------------------------|
| A00C0000 | <u>GPTIMER1 CON</u>       | 32    | GPT1 control register           |
| A00C0004 | <u>GPTIMER1 DAT</u>       | 32    | GPT1 time-out interval register |
| A00C0008 | <u>GPTIMER2 CON</u>       | 32    | GPT2 control register           |
| A00C000C | <u>GPTIMER2 DAT</u>       | 32    | GPT2 time-out Interval register |
| A00C0010 | <u>GPTIMER STA</u>        | 32    | GPT status register             |
| A00C0014 | <u>GPTIMER1 PRESCALER</u> | 32    | GPT1 prescaler register         |
| A00C0018 | <u>GPTIMER2 PRESCALER</u> | 32    | GPT2 prescaler register         |
| A00C0028 | <u>GPTIMER4 CON</u>       | 32    | GPT4 control register           |
| A00C002C | <u>GPTIMER4 DAT</u>       | 32    | GPT4 data register              |

**A00C0000   GPTIMER1 CON    GPT1 Control Register                          00000000**

| Bit          | 31 | 30   | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14   | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | EN | MODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW | RW   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0  | 0    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                |
|--------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | EN       | EN   | <b>Controls GPT1 to start counting or to stop</b><br>0: Disable<br>1: Enable GPT1                                                          |
| 14     | MODE     | MODE | <b>Controls GPT1 to count repeatedly (in a loop) or just one-shot</b><br>0: One-shot mode is selected.<br>1: Auto-repeat mode is selected. |

**A00C0004   GPTIMER1 DAT    GPT1 Time-out Interval Register                          0000FFFF**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    | CNT |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    | RW  |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

| Bit(s) | Mnemonic | Name | Description                                                                                                                          |
|--------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | CNT      | CNT  | <b>Initial counting value</b><br>GPT1 counts down from GPTIMER1_DAT. When GPT1 counts down to 0, a GPT1 interrupt will be generated. |

**A00C0008 GPTIMER2\_CON GPT2 Control Register** 00000000

| Bit          | 31 | 30   | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15 | 14   | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | EN | MODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW | RW   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0  | 0    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                |
|--------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | EN       | EN   | <b>Controls GPT2 to start counting or to stop</b><br>0: Disable<br>1: Enable GPT2                                                          |
| 14     | MODE     | MODE | <b>Controls GPT2 to count repeatedly (in a loop) or just one-shot</b><br>0: One-shot mode is selected.<br>1: Auto-repeat mode is selected. |

**A00C000C GPTIMER2\_DAT GPT2 Time-out Interval Register** 0000FFFF

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    | CNT |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    | RW  |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

| Bit(s) | Mnemonic | Name | Description                                                                                                                          |
|--------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | CNT      | CNT  | <b>Initial counting value</b><br>GPT2 counts down from GPTIMER2_DAT. When GPT2 counts down to 0, a GPT2 interrupt will be generated. |

**A00C0010 GPTIMER\_STA GPT Status Register** 00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1    | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    | GPT2 | GPT1 |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    | RC   | RC   |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    | 0    | 0    |    |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                      |
|--------|----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | GPT2     | GPT2 | <b>GP timer time-out status</b><br>Each flag is set when the corresponding timer count-down is completed. Can be cleared when the CPU reads the status register. |
| 0      | GPT1     | GPT1 | <b>GP timer time-out status</b><br>Each flag is set when the corresponding timer count-down is completed. Can be cleared when the CPU reads the status register. |

**A00C0014 GPTIMER1 PRE SCALER GPT1 Prescaler Register 00000004**

| Bit       | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit       | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| PRESCALER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 1 0 0     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s)   | Mnemonic   | Name      | Description                                |
|----------|------------|-----------|--------------------------------------------|
| 2:0      | PRESCALE R | PRESCALER | Controls the counting clock for GP timer 1 |
| 0:       |            |           | 16,384Hz                                   |
| 1:       |            |           | 8,192Hz                                    |
| 2:       |            |           | 4,096Hz                                    |
| 3:       |            |           | 2,048Hz                                    |
| 4:       |            |           | 1,024Hz                                    |
| 5:       |            |           | 512Hz                                      |
| 6:       |            |           | 256Hz                                      |
| 7: 128Hz |            |           |                                            |

**A00C0018 GPTIMER2 PRE SCALER GPT2 Prescaler Register 00000004**

| Bit       | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit       | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| PRESCALER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 1 0 0     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s)   | Mnemonic   | Name      | Description                                |
|----------|------------|-----------|--------------------------------------------|
| 2:0      | PRESCALE R | PRESCALER | Controls the counting clock for GP timer 2 |
| 0:       |            |           | 16,384Hz                                   |
| 1:       |            |           | 8,192Hz                                    |
| 2:       |            |           | 4,096Hz                                    |
| 3:       |            |           | 2,048Hz                                    |
| 4:       |            |           | 1,024Hz                                    |
| 5:       |            |           | 512Hz                                      |
| 6:       |            |           | 256Hz                                      |
| 7: 128Hz |            |           |                                            |

A00C0028 GPTIMER4\_CON GPT4 Control Register

00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LOCK | EN |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW   | RW |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0    | 0  |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                                                                            |
|--------|----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | LOCK     | LOCK | <b>Controls GPT4 EN bit can be modified or not</b><br>If LOCK = 0, EN can be modified. If LOCK = 1, the EN value will be fixed, and the LOCK bit will always be 1 and cannot be modified until hardware reset.<br>0: Unlock<br>1: Lock |
| 0      | EN       | EN   | <b>Controls GPT4 to start counting or to stop</b><br>0: Disable<br>1: Enable GPT4                                                                                                                                                      |

A00C002C GPTIMER4\_DAT GPT4 Data Register

00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17         | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CNT[31:16] |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO         |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1          | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CNT[15:0]  |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO         |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0  |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                                                                                  |
|--------|----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | CNT      | CNT  | If EN = 1, GPT4 will be a free running timer. This register records the GPT4 value. If EN = 0, this register will be cleared to 0. This register does not allow continuous read. It requires at least 1 26M clock cycle between 2 APB reads. |

## 3.5.3 Application Note

When the GPT is in running status, GPTIMER\_DAT cannot be configured. To start GPT1 or GPT2, SW should make sure the timer has finished counting for at least 3 cycles of the 32k Hz clock.

## 3.6 MCU OSTIMER

### 3.6.1 Overview



*Figure 31. OS timer system view*

The OS timer is a hardware timer which specifies the OS time frame duration and generates time-out interrupts by programming the frame counter number. The OS timer has the pause mode. The user can specify pause duration period before the pause mode, and the timer will resume from the pause mode by the external wakeup sources or when the pause duration is timed out.

### 3.6.2 Terminology

*Table 46. Abbreviations*

| Abbreviation |                                    |
|--------------|------------------------------------|
| R/W          | Read/Write                         |
| RO           | Read only                          |
| WO           | Write only                         |
| W1C          | Write 1 to clear                   |
| RW1C         | Read/Write 1 to clear              |
| FRC          | Free running counter in the system |
| OST          | OS timer                           |

### 3.6.3 Introduction to Wakeup Source

The OS timer only accepts level trigger wakeup source. The wakeup sources are all treated as asynchronous input (will be changed) and will be synchronized by OST clock in OST wakeup source controller.

The possible wakeup sources are listed in the table below.

**Table 47. Wakeup sources**

| No | Wakeup source |
|----|---------------|
| 0  | GPT           |
| 1  | EINT          |
| 2  | Timer trigger |
| 3  | KP            |
| 4  | MSDC          |
| 5  | ANALOG        |
| 6  | DSP           |
| 7  | MSDC2         |
| 8  | SPISLV        |
| 9  | Reserved      |
| 10 | Reserved      |
| 11 | DSP_ASYNC     |
| 12 | Reserved      |
| 13 | Reserved      |
| 14 | Reserved      |
| 15 | Reserved      |
| 16 | Reserved      |

**Table 48. Characteristics of wakeup sources**

| No | Wakeup source | Edge/Level | SW clear | Clock domain |
|----|---------------|------------|----------|--------------|
| 0  | GPT           | Edge       |          | F32k_CK      |
| 1  | EINT          | Edge/Level |          | F32k_CK      |
| 2  | Timer trigger | Level      |          | F32k_CK      |
| 3  | KP            | Edge       |          |              |
| 4  | MSDC          | Level      |          |              |
| 5  | ANALOG        | Edge/Level |          |              |
| 6  | DSP           | Level      |          | DSP_CK       |
| 7  | MSDC2         | Level      |          |              |
| 8  | SPISLV        | Level      |          |              |
| 9  | Reserved      |            |          |              |
| 10 | Reserved      |            |          |              |
| 11 | DSP_ASYNC     | Level      |          | DSP_CK       |
| 12 | Reserved      |            |          |              |
| 13 | Reserved      |            |          |              |
| 14 | Reserved      |            |          |              |
| 15 | Reserved      |            |          |              |
| 16 | Reserved      |            |          |              |



**Figure 32. Wakeup event and irq\_b integration diagram**

`wakeup_irq_b` may be asserted before `wakeup_event_b` is asserted from the wakeup source peripheral to ensure the software will enter wakeup ISR after the pause command is set.

Recommended software programming sequence:

1. I-BIT is set when a pause command is executed.
2. Set up IRQ mask registers to select IRQ wakeup sources
3. Pause criteria are met.
4. Set up pause command.
5. Confirm the pause command is executed at OST, and check if the pause command is pending or not.
6. Set up processor in request for interrupt state.
7. The processor clock will be off if there is no interrupt.
8. Check if the pause request command is completed (after the processor clock is active or resumes).
9. Clear I-BIT.

### 3.6.4 Register Definition

| Address    | Name                | Width | Register function                                                                                                                                                                                                                                                                                                         |
|------------|---------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0XA01F0000 | <u>OST_CON</u>      | 32    | <b>OS timer control register</b><br>Only updated when OST_CMD.OST_WR is set and OST_STA.WR_RDY is high.                                                                                                                                                                                                                   |
| 0XA01F0004 | <u>OST_CMD</u>      | 32    | <b>OS timer command</b><br>Only valid when the write data BIT31 to BIT16 is 0x1153.                                                                                                                                                                                                                                       |
| 0XA01F0008 | <u>OST_STA</u>      | 32    | <b>OS timer status</b>                                                                                                                                                                                                                                                                                                    |
| 0XA01F000C | <u>OST_FRM</u>      | 32    | <b>OS timer frame duration</b><br>Specifies OS timer frame duration by micron second resolution. The maximum duration is 8ms and minimum duration is 1ms. This register should be set before OS timer is enabled. The hardware will set up OST_ISR[0] periodically at frame duration period when the OS timer is enabled. |
| 0XA01F0010 | <u>OST_FRM_F32K</u> | 32    | <b>OS timer frame duration by 32K clock</b>                                                                                                                                                                                                                                                                               |

| Address    | Name                | Width | Register function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|---------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |                     |       | <p>Specifies OS timer frame duration with 30.5176 micron second (32kHz) resolution. The maximum duration is 8ms and minimum duration is 1ms. This register should be set before the OS timer is enabled.</p> <p><math>OST\_FRAM\_F32K * 30.5176\mu s</math> should be less than <math>OST\_FRM\_NUM * OST\_FRM * 1\mu s - 30.5176\mu s</math>.</p> <p>Set up <math>OST\_FRM\_NUM</math> if the frame duration is shorter than system settling time.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0XA01F0014 | <u>OST_UFN</u>      | 32    | <p><b>OS timer un-alignment frame number</b></p> <p>Specifies OS timer un-alignment event frame number count. This register value is updated to OS timer only when <math>OST\_CMD.OST\_WR</math> is set. The read value of this register may not be the current OS time Un-alignment frame number. The hardware will count down the <math>OST\_UFN</math> counter at frame time-out and stop the count-down when the current value is 0. When the OS timer is in the pause mode, this counter is still active and wakes up the OS timer when <math>OST\_UFN</math> becomes 0 at frame time-out boundary.</p> <p>The software should enable the OS timer pause mode when <math>OST\_UFN</math> is larger than 1, or the pause command will be ignored by the hardware.</p>                                                                                                                                 |
| 0XA01F0018 | <u>OST_AFN</u>      | 32    | <p><b>OS timer alignment frame number</b></p> <p>Specifies OS timer alignment event frame number count. This register value is updated to the OS timer only when <math>OST\_CMD.OST\_WR</math> is set. The read value of this register may not be the current OS time alignment frame number. The hardware will count down the <math>OST\_AFN</math> counter at frame time-out and stop the count-down when the current value is 0. The hardware will set <math>OST\_ISR[1]</math> when <math>OST\_AFN</math> is 1 or 0 at frame time-out, and the OS timer is in normal mode. <math>OST\_AFN</math> is current hardware AFN down counter value, and the software cannot read this register directly. The software can only read the current frame number through the <math>OST\_AFN\_R</math> register, and there is synchronization latency from <math>OST\_AFN</math> to <math>OST\_AFN\_R</math>.</p> |
| 0XA01F001C | <u>OST_AFN_DLY</u>  | 32    | <p><b>OS timer alignment frame delay number count</b></p> <p>Specifies the OS timer alignment event frame delay count due to OS timer pause mode. The software has to use the <math>OST\_CMD.OST\_RD</math> command to update this register value, or the value may be out of date.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0XA01F0020 | <u>OST_UFN_R</u>    | 32    | <p><b>Current OS timer un-alignment frame number</b></p> <p>Specifies the OS timer current un-alignment frame number. The software has to use the <math>OST\_CMD.OST\_RD</math> command to update this register value, or the value may be out of date.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0XA01F0024 | <u>OST_AFN_R</u>    | 32    | <p><b>Current OS timer alignment frame number</b></p> <p>Specifies the OS timer current alignment frame number. The software has to use the <math>OST\_CMD.OST\_RD</math> command to update this register value, or the value may be out of date.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0XA01F0030 | <u>OST_INT_MASK</u> | 32    | <p><b>OS timer interrupt mask</b></p> <p>Specifies the OS timer interrupt mask control.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0XA01F0040 | <u>OST_ISR</u>      | 32    | <p><b>OS timer interrupt status</b></p> <p>Specifies the OS timer interrupt status. The software has to write 1 at the corresponding bit to clear the interrupt status bit. <math>OSR\_ISR[2-0]</math> are also cleared when the <math>OSR\_WR</math> command is executed and AFN, UFN are updated.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Address    | Name                   | Width | Register function                                                                                                             |
|------------|------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------|
| 0XA01F0050 | <u>OST_EVENT MASK</u>  | 32    | <b>OS timer event mask</b><br>Specifies which wakeup event will be masked to wake up the OS timer in the OS timer pause mode. |
| 0XA01F0054 | <u>OST_WAKEUP STA</u>  | 32    | <b>OS timer event wakeup status</b>                                                                                           |
| 0XA01F0060 | <u>OST_DBG_WAKE UP</u> | 32    | <b>OS timer debug wakeup</b>                                                                                                  |

**0XA01F0000 OS Timer Control Register OST\_CON**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19             | 18              | 17        | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----------------|-----------------|-----------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |                |                 |           |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |                |                 |           |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |                |                 |           |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3              | 2               | 1         | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    | <u>OST_DBG</u> | <u>UFN_DOWN</u> | <u>EN</u> |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    | RW             | RW              | RW        |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | 0              | 1               | 0         |    |

**Overview:** This register is only updated when OST\_CMD.OST\_WR is set and OST\_STA.WR\_RDY is high.

| Bit(s) | Name     | Description                                                                                                                                                                                                             |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | OST_DBG  | <b>Enables OST wakeup debugging function</b><br>0: Disable<br>1: Enable                                                                                                                                                 |
| 1      | UFN_DOWN | <b>Enables OST_UFN count-down</b><br>0: Disable OST_UFN count-down<br>1: Enable OST_UFN count-down                                                                                                                      |
| 0      | EN       | <b>Enables OS timer</b><br>0: OS timer is disabled. Then all internal timers are stopped.<br>1: OS Timer is enabled. The software has to ensure OST_AFN, OST_UFN, OST_FRAM are configured before enabling the OS timer. |

**0XA01F0004 OS Timer Command OST\_CMD**

| Bit   | 31                | 30                | 29                | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19            | 18            | 17                | 16 |
|-------|-------------------|-------------------|-------------------|----|----|----|----|----|----|----|----|----|---------------|---------------|-------------------|----|
| Name  |                   |                   |                   |    |    |    |    |    |    |    |    |    |               |               |                   |    |
| Type  |                   |                   |                   |    |    |    |    |    |    |    |    |    |               |               |                   |    |
| Reset | 0                 | 0                 | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0             | 0                 | 0  |
| Bit   | 15                | 14                | 13                | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3             | 2             | 1                 | 0  |
| Name  | <u>OST_KEY</u>    |                   |                   |    |    |    |    |    |    |    |    |    |               |               |                   |    |
| Type  |                   |                   |                   |    |    |    |    |    |    |    |    |    |               |               |                   |    |
| Reset | 0                 | 0                 | 0                 |    |    |    |    |    |    |    |    |    |               |               |                   |    |
| Name  | <u>OST_CON_WR</u> | <u>OST_AFN_WR</u> | <u>OST_UFN_WR</u> |    |    |    |    |    |    |    |    |    | <u>OST_WR</u> | <u>OST_RD</u> | <u>PAUSE_ST_R</u> |    |
| Type  | RW                | RW                | RW                |    |    |    |    |    |    |    |    |    | WO            | WO            | WO                |    |
| Reset | 0                 | 0                 | 0                 |    |    |    |    |    |    |    |    |    | 0             | 0             | 0                 |    |

**Overview:** The command is only valid when the write data BIT31 to BIT16 is 0x1153.

| Bit(s) | Name       | Description                                                                                                                                                                                                                   |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | OST_KEY    |                                                                                                                                                                                                                               |
| 15     | OST_CON_WR | Updates OST_CON when the OST_WR command is active.                                                                                                                                                                            |
| 14     | OST_AFN_WR | Updates OST_AFN when the OST_WR command is active.                                                                                                                                                                            |
| 13     | OST_UFN_WR | Updates OST_UFN when the OST_WR command is active.                                                                                                                                                                            |
| 2      | OST_WR     | Write 1 to this bit to update the bus clock domain OS timer configuration into the OST_SYSCLK domain                                                                                                                          |
| 1      | OST_RD     | Write 1 to this bit to update the current OS timer status to the bus clock domain                                                                                                                                             |
| 0      | PAUSE_STR  | Write 1 to this bit to enable the OS timer pause function. The command will be ignored if the current OST_UFN is less than 2. The software has to ensure OST_CMD.OST_WR is completed before the next software pause sequence. |

| OS Timer Status |            |    |    |    |    |    |    |    |    |              |    |           |    |         |       | OST_STA |         |
|-----------------|------------|----|----|----|----|----|----|----|----|--------------|----|-----------|----|---------|-------|---------|---------|
| Bit             | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22           | 21 | 20        | 19 | 18      | 17    | 16      | OST_STA |
| Name            |            |    |    |    |    |    |    |    |    |              |    |           |    |         |       |         |         |
| Type            |            |    |    |    |    |    |    |    |    |              |    |           |    |         |       |         |         |
| Reset           |            |    |    |    |    |    |    |    |    |              |    |           |    |         |       |         |         |
| Bit             | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6            | 5  | 4         | 3  | 2       | 1     | 0       | OST_STA |
| Name            | CPU_SLEE_P |    |    |    |    |    |    |    |    | AFN_DLY_OVER |    | PAUSE_REQ |    | CMD_CPL | READY |         |         |
| Type            | RO         |    |    |    |    |    |    |    |    | RO           |    | RO        |    | RO      | RO    |         |         |
| Reset           | 0          |    |    |    |    |    |    |    |    | 0            |    | 0         |    | 1       | 0     |         |         |



Figure 33. Pause command complete and pause request state

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                |
|--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | CPU_SLEEP    | The processor is in the sleep mode. (for debugging)<br>0: Active<br>1: Sleep                                                                                                                                                                                                                                                                                               |
| 6      | AFN_DLY_OVER | AFN_DLY counter overflows. This bit is cleared when AFN is updated.<br>0: Does not overflow<br>1: Overflow                                                                                                                                                                                                                                                                 |
| 4:3    | PAUSE_REQ    | An OS timer pause request is pending. A pause command will be completed when the pause command is set.<br>1. Processor is in the sleep mode (processor clock is off), UFN $\geq$ 2 and no wakeup sources<br>2. Any wakeup sources are sensed after the pause command is set.<br>3. UFN < 2<br>00: The last pause command request is not completed yet (CP15 is not enable) |

| Bit(s) | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | CMD_CPL | <p>and no wakeup source).</p> <p>01: The last pause command request is completed with OST pause mode being active.</p> <p>10: The last pause command request is completed with wakeup sources.</p> <p>11: The last pause command request is completed with UFN &lt; 2.</p> <p><b>OST command is completed. It takes several clocks from OST_CMD being updated to command being active.</b></p> <p>0: OST command is not completed.</p> <p>1: OST command is completed.</p> |
| 0      | READY   | <p><b>OS timer status</b></p> <p>0: OST is in pause mode.</p> <p>1: OST is in normal mode.</p>                                                                                                                                                                                                                                                                                                                                                                             |

| 0XA01F000C OS Timer Frame Duration |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OST_FRM |         |
|------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|---------|
| Bit                                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      | OST_FRM |
| Name                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         | RW      |
| Type                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         | OST_FRM |
| Reset                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         | OST_FRM |
| Bit                                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       | OST_FRM |
| Name                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         | RW      |
| Type                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         | OST_FRM |
| Reset                              |    |    |    |    | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0       | OST_FRM |

**Overview:** This register specifies the OS timer frame duration by micron second resolution. The maximum duration is 8ms and minimum duration is 1ms. This register should be set before the OS timer is enabled. The hardware will set up OST\_ISR[0] periodically at frame duration period when the OS timer is enabled.

| Bit(s) | Name    | Description |
|--------|---------|-------------|
| 12:0   | OST_FRM |             |

| 0XA01F0010 OS Timer Frame Duration by 32K Clock |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OST_FRM_F32K |              |
|-------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|--------------|
| Bit                                             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           | OST_FRM_F32K |
| Name                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              | OST_FRM_F32K |
| Type                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              | OST_FRM_F32K |
| Reset                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              | OST_FRM_F32K |
| Bit                                             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            | OST_FRM_F32K |
| Name                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              | OST_FRM_F32K |
| Type                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              | OST_FRM_F32K |
| Reset                                           | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0            | OST_FRM_F32K |

**Overview:** This register specifies the OS timer frame duration with 30.5176 micron second (32kHz) resolution. The maximum duration is 8ms and minimum duration is 1ms. This register should be set up before the OS timer is enabled. OST\_FRM\_NUM\*30.5176us should be less than OST\_FRM\_NUM\*OST\_FRM\*1us - 30.5176us. Set up OST\_FRM\_NUM if the frame duration is shorter than the system settling time.

| Bit(s) | Name        | Description |
|--------|-------------|-------------|
| 12:0   | OST_FRM_NUM |             |

| Bit(s) | Name         | Description |
|--------|--------------|-------------|
| 15:12  | OST_UFN      |             |
| 11:0   | OST_FRM_F32K |             |

**0XA01F0014****OS Timer Un-alignment Frame Number****OST\_UFN**

| Bit   | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | OST_UFN[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | OST_UFN[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** This register specifies the OS timer un-alignment event frame number count. This register value is updated to the OS timer only when OST\_CMD.OST\_WR is set. The read value of this register may not be the current OS time un-alignment frame number. The hardware will count down the OST\_UFN counter at frame time-out and stop the count-down when the current value is 0. When the OS timer is in the pause mode, this counter is still active and wakes up the OS timer when OST\_UFN becomes 0 at frame time-out boundary. The software should enable the OS timer pause mode when OST\_UFN is larger than 1, or the pause command will be ignored by hardware.

| Bit(s) | Name    | Description |
|--------|---------|-------------|
| 31:0   | OST_UFN |             |

**0XA01F0018****OS Timer Alignment Frame Number****OST\_AFN**

| Bit   | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | OST_AFN[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | OST_AFN[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** This register specifies the OS timer alignment event frame number count. This register value is updated to the OS timer only when OST\_CMD.OST\_WR is set. The read value of this register may not be the current OS time alignment frame number. The hardware will count down the OST\_AFN counter at frame time-out and stop the count-down when the current value is 0. The hardware will set up OST\_ISR[1] when OST\_AFN is 1 or 0 at frame time-out and the OS timer is in the normal mode. OST\_AFN is the current hardware AFN down counter value, and the software cannot read this register directly. The software can only read the current frame number through the OST\_AFN\_R register, and there is synchronization latency from OST\_AFN to OST\_AFN\_R.

| Bit(s) | Name    | Description |
|--------|---------|-------------|
| 31:0   | OST_AFN |             |

**0XA01F001C****OS Timer Alignment Frame Delay Number Count OST\_AFN\_DLY**

| Bit          | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>OST_AFN_DLY[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>OST_AFN_DLY[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** This register specifies the OS Timer Alignment event frame delay count due to OS timer pause mode. Software has to use OST\_CMD.OST\_RD command to update this register value, or the value maybe out of date.

| Bit(s) | Name        | Description |
|--------|-------------|-------------|
| 31:0   | OST_AFN_DLY |             |

**0XA01F0020****Current OS Timer Un-alignment Frame Number****OST\_UFN\_R**

| Bit          | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>OST_UFN_R[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>OST_UFN_R[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** This register specifies the OS timer current un-alignment frame number. The software has to use the OST\_CMD.OST\_RD command to update this register value, or the value may be out of date.

| Bit(s) | Name      | Description |
|--------|-----------|-------------|
| 31:0   | OST_UFN_R |             |

**0XA01F0024****Current OS Timer Alignment Frame Number****OST\_AFN\_R**

| Bit          | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>OST_AFN_R[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>OST_AFN_R[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** This register specifies the OS timer current alignment frame number. The software has to use the OST\_CMD.OST\_RD command to update this register value, or the value may be out of date.

| Bit(s) | Name      | Description |
|--------|-----------|-------------|
| 31:0   | OST_AFN_R |             |

| OS Timer Interrupt Mask |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OST_INT_MASK |              |
|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|--------------|
| Bit                     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |              |
| Name                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |              |
| Type                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |              |
| Reset                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |              |
| Bit                     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |              |
| Name                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              | OST_INT_MASK |
| Type                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              | RW           |
| Reset                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              | 1            |

**Overview:** This register specifies the OS timer interrupt mask control.

| Bit(s) | Name         | Description                                            |
|--------|--------------|--------------------------------------------------------|
|        |              | 0: Mask OS timer frame time-out interrupt              |
|        |              | 1: Mask OS timer alignment frame time-out interrupt    |
| 4:0    | OST_INT_MASK | 2: Mask OS timer un-alignment frame time-out interrupt |
|        |              | 3: Mask OS timer pause abort interrupt                 |
|        |              | 4: Mask OS timer pause interrupt                       |

| OS Timer Interrupt Status |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OST_ISR |         |
|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|---------|
| Bit                       | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |         |
| Name                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |         |
| Type                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |         |
| Reset                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |         |
| Bit                       | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |         |
| Name                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         | OST_ISR |
| Type                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         | W1C     |
| Reset                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         | 0       |

**Overview:** This register specifies the OS timer interrupt status. The software has to write 1 to the corresponding bit to clear the interrupt status bit. OSR\_ISR[2-0] are also cleared when the OSR\_WR command is executed and AFN, UFN are updated.

| Bit(s) | Name    | Description                                              |
|--------|---------|----------------------------------------------------------|
|        |         | 0: OS timer frame time-out interrupt status              |
|        |         | 1: OS timer alignment frame time-out interrupt status    |
| 4:0    | OST_ISR | 2: OS timer un-alignment frame time-out interrupt status |
|        |         | 3: OS timer pause abort interrupt status                 |
|        |         | 4: OS timer pause interrupt status                       |

| OS Timer Event Mask |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OST_EVENT_MASK |  |
|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|--|
| Bit                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16             |  |
| Name                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |  |

|              |                             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                               |   |   |
|--------------|-----------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------------------|---|---|
| <b>Name</b>  |                             |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>OST_EVENT_MASK [18:16]</b> |   |   |
| <b>Type</b>  |                             |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>RW</b>                     |   |   |
| <b>Reset</b> |                             |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0                             | 1 | 1 |
| <b>Bit</b>   | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                             |   |   |
| <b>Name</b>  | <b>OST_EVENT_MASK[15:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                               |   |   |
| <b>Type</b>  | <b>RW</b>                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                               |   |   |
| <b>Reset</b> | 1                           | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1                             | 1 | 1 |

**Overview:** This register specifies which wakeup event will be masked to wake up the OS timer in the OS timer pause mode.

| <b>Bit(s)</b> | <b>Name</b>           | <b>Description</b> |
|---------------|-----------------------|--------------------|
| 18:0          | <b>OST_EVENT_MASK</b> |                    |

| <b>0XA01F0054 OS Timer Event Wakeup Status</b> |                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>OST_WAKEUP_STA</b> |                               |   |   |
|------------------------------------------------|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|-------------------------------|---|---|
| <b>Bit</b>                                     | 31                          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |                               |   |   |
| <b>Name</b>                                    |                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       | <b>OST_WAKEUP_STA [18:16]</b> |   |   |
| <b>Type</b>                                    |                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       | <b>RO</b>                     |   |   |
| <b>Reset</b>                                   | 0                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                     | 0                             | 0 | 0 |
| <b>Bit</b>                                     | 15                          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |                               |   |   |
| <b>Name</b>                                    | <b>OST_WAKEUP_STA[15:0]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       | <b>RO</b>                     |   |   |
| <b>Type</b>                                    | <b>RO</b>                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |                               |   |   |
| <b>Reset</b>                                   | 0                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                     | 0                             | 0 | 0 |

| <b>Bit(s)</b> | <b>Name</b>           | <b>Description</b> |
|---------------|-----------------------|--------------------|
| 18:0          | <b>OST_WAKEUP_STA</b> |                    |

| <b>0XA01F0060 OS Timer Debug Wakeup</b> |                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>OST_DBG_WAKEOSUP</b> |                               |   |   |
|-----------------------------------------|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------|-------------------------------|---|---|
| <b>Bit</b>                              | 31                          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                      |                               |   |   |
| <b>Name</b>                             | <b>CIRQ_MASK_EN</b>         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | <b>OST_DBG_WAKEUP [18:16]</b> |   |   |
| <b>Type</b>                             | <b>RW</b>                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |                               |   |   |
| <b>Reset</b>                            | 0                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | 0                             | 0 | 0 |
| <b>Bit</b>                              | 15                          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                       |                               |   |   |
| <b>Name</b>                             | <b>OST_DBG_WAKEUP[15:0]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |                               |   |   |
| <b>Type</b>                             |                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |                               |   |   |
| <b>Reset</b>                            | 0                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                       | 0                             | 0 | 0 |

| <b>Bit(s)</b> | <b>Name</b>           | <b>Description</b>                                            |
|---------------|-----------------------|---------------------------------------------------------------|
| 31            | <b>CIRQ_MASK_EN</b>   | 0: Disable cirq mask function<br>1: Enable cirq mask function |
| 18:0          | <b>OST_DBG_WAKEUP</b> | Controls wakeup status in debug timing event1                 |



Figure 34. Debug wakeup events

## 3.7 UART1

### 3.7.1 General Description

The baseband chipset houses two UARTs. The UARTs provide full duplex serial communication channels between baseband chipset and external devices.

The UART has M16C450 and M16550A modes of operation, which are compatible with a range of standard software drivers. The extensions have been designed to be broadly software compatible with 16550A variants, but certain areas offer no consensus.

In common with the M16550A, the UART supports word lengths **from 5 to 8 bits, an optional parity bit** and one or two stop bits, and is fully programmable by an 8-bit CPU interface. A 16-bit programmable baud rate generator and an 8-bit scratch register are included, together with separate transmit and receive FIFOs. 8 modem control lines and a diagnostic loop-back mode are provided. UART also includes two DMA handshake lines, indicating when the FIFOs are ready to transfer data to the CPU. Interrupts can be generated from any of the 10 sources.

Note that UART is designed so that all internal operation is synchronized by the CLK signal. This synchronization results in minor timing differences between the UART and industry standard 16550A device, which means that the core is not clock for clock identical to the original device.

After a hardware reset, UART will be in M16C450 mode. Its FIFOs can then be enabled and UART can enter M16550A mode. UART has further functions beyond the M16550A mode. Each of the

extended functions can be selected individually under software control.

UART provides more powerful enhancements than the industry-standard 16550:

- Hardware flow control. This feature is very useful when the ISR latency is hard to predict and control in the embedded applications. The MCU is relieved of having to fetch the received data within a fixed amount of time.

Note that in order to enable any of the enhancements, the Enhanced Mode bit, EFR[4], must be set. If EFR[4] is not set, IER[7:5], FCR[5:4], IIR[5:4] and MCR[7:6] cannot be written. The enhanced mode bit ensures that UART is backward compatible with the software that has been written for 16C450 and 16550A devices. **Figure 35** is the block diagram of the UART1 device.



**Figure 35. Block Diagram of UART1**

### 3.7.2 Register Definition

Module name: UART1 Base address: (+A0080000h)

| Address  | Name       | Width | Register Function                                                                                                                                                                                           |
|----------|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0080000 | <u>RBR</u> | 8     | <b>RX Buffer Register</b><br>Note: Only w hen LCR[7] = 0.                                                                                                                                                   |
| A0080000 | <u>THR</u> | 8     | <b>TX Holding Register</b><br>Note: Only w hen LCR[7] = 0                                                                                                                                                   |
| A0080000 | <u>DLL</u> | 8     | <b>Divisor Latch (LS)</b><br>Divides the bclk frequency<br>Note: Modified w hen LCR[7]!=0                                                                                                                   |
| A0080004 | <u>IER</u> | 8     | <b>Interrupt Enable Register</b><br>Note: Only w hen LCR[7] = 0.<br>By storing 1 to a specific bit position, the interrupt associated w ith that bit is enabled. Otherwise, the interrupt will be disabled. |

| Address  | Name                | Width | Register Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|---------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                     |       | IER[3:0] are modified when LCR[7] = 0.<br>IER[7:4] are modified when LCR[7] = 0 & EFR[4] = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| A0080004 | <u>DLM</u>          | 8     | <b>Divisor Latch (MS)</b><br>Used to divide the clock frequency.*NOTE: modified when LCR[7]!=0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| A0080008 | <u>IIR</u>          | 8     | <b>Interrupt Identification Register</b><br>Note: Only when LCR!=BFh. Priority is from high to low as the following.<br>IIR[5:0]=0X1: No interrupt pending<br>IIR[5:0]=0X6: Line status interrupt (under IER[2]=1)<br>IIR[5:0]=0Xc: RX data time-out interrupt (under IER[0]=1)<br>IIR[5:0]=0X4: RX data are placed in the RX buffer register or the RX trigger level is reached. (under IER[0]=1).<br>IIR[5:0]=0X2: TX holding register is empty or the contents of the TX FIFO have been reduced to its trigger level (under IER[1]=1).<br>IIR[5:0]=0X10: XOFF character received (under IER[5]=1, EFR[4] = 1). |
| A0080008 | <u>FCR</u>          | 8     | <b>FIFO Control Register</b><br>FCR is used to control the trigger levels of the FIFOs or flush the FIFOs.<br>FCR[7:6] is modified when LCR != BFh<br>FCR[5:4] is modified when LCR != BFh & EFR[4] = 1<br>FCR[4:0] is modified when LCR != BFh                                                                                                                                                                                                                                                                                                                                                                   |
| A0080008 | <u>EFR</u>          | 8     | <b>Enhanced Feature Register</b><br>Note: Only when LCR=BFh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| A008000C | <u>LCR</u>          | 8     | <b>Line Control Register</b><br>Determines characteristics of serial communication signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| A0080010 | <u>MCR</u>          | 8     | <b>Modem Control Register</b><br>Controls interface signals of the UART.<br>MCR[5:0] are modified when LCR != 8'hBF,<br>MCR[7] can be read when LCR != 8'hBF & EFR[4] = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| A0080010 | <u>XON1</u>         | 8     | <b>XON1 Char Register</b><br>Note: XON1 is modified only when LCR=BFh.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| A0080014 | <u>LSR</u>          | 8     | <b>Line Status Register</b><br>Modified when LCR != BFh.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| A0080018 | <u>XOFF1</u>        | 8     | <b>XOFF1 Char Register</b><br>*Note: XOFF1 is modified only when LCR=BFh.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| A008001C | <u>SCR</u>          | 8     | <b>Scratch Register</b><br>A general purpose read/write register. After reset, its value will be un-defined.<br>Modified when LCR != BFh.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| A0080020 | <u>AUTOBAUD EN</u>  | 8     | <b>Auto Baud Detect Enable Register</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| A0080024 | <u>HIGHSPEED</u>    | 8     | <b>High Speed Mode Register</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| A0080028 | <u>SAMPLE COUNT</u> | 8     | <b>Sample Counter Register</b><br>When HIGHSPEED=3, sample_count will be the threshold value for UART sample counter (sample_num). Count from 0 to sample_count.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| A008002C | <u>SAMPLE POINT</u> | 8     | <b>Sample Point Register</b><br>When HIGHSPEED=3, UART gets the input data when sample_count=sample_num, e.g. system clock = 13MHz,                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Address  | Name                   | Width | Register Function                                                                                                                                                                                                                                                                         |
|----------|------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                        |       | 921600 = 13000000/14. Therefore, sample_count = 13, and sample point = 6 (sampling the central point to decrease the inaccuracy)<br>SAMPLE_POINT is usually (SAMPLE_COUNT-1)/2 without decimal.                                                                                           |
| A0080030 | <u>AUTOBAUD REG</u>    | 8     | <b>Auto Baud Monitor Register</b><br>the autobaud detection state ,it will not change until enable the autobaud_en again.                                                                                                                                                                 |
| A0080034 | <u>RATEFIX AD</u>      | 8     | <b>Clock Rate Fix Register</b>                                                                                                                                                                                                                                                            |
| A0080038 | <u>AUTOBAUDSAMPL E</u> | 8     | <b>Auto Baud Sample Register</b><br>Since the system clock may change, autobaud sample duration should change as the system clock changes. When system clock = 13MHz, autobaudsample = 6; when system clock = 26MHz, autobaudsample = 13. When system clock = 52MHz, autobaudsample = 27. |
| A008003C | <u>GUARD</u>           | 8     | <b>Guard Time Added Register</b>                                                                                                                                                                                                                                                          |
| A0080040 | <u>ESCAPE DAT</u>      | 8     | <b>Escape Character Register</b>                                                                                                                                                                                                                                                          |
| A0080044 | <u>ESCAPE EN</u>       | 8     | <b>Escape Enable Register</b>                                                                                                                                                                                                                                                             |
| A0080048 | <u>SLEEP EN</u>        | 8     | <b>Sleep Enable Register</b>                                                                                                                                                                                                                                                              |
| A008004C | <u>DMA EN</u>          | 8     | <b>DMA Enable Register</b>                                                                                                                                                                                                                                                                |
| A0080050 | <u>RXTRI AD</u>        | 8     | <b>Rx Trigger Address</b>                                                                                                                                                                                                                                                                 |
| A0080054 | <u>FRACDIV L</u>       | 8     | <b>Fractional Divider LSB Address</b>                                                                                                                                                                                                                                                     |
| A0080058 | <u>FRACDIV M</u>       | 8     | <b>Fractional Divider MSB Address</b>                                                                                                                                                                                                                                                     |
| A008005C | <u>FCR RD</u>          | 8     | <b>FIFO Control Register</b>                                                                                                                                                                                                                                                              |

**A0080000 RBR RX Buffer Register 00**

| Bit                                     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>RBR</b>                              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>RU</b>                               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Name | Description                                                                                                     |
|--------|------|-----------------------------------------------------------------------------------------------------------------|
| 7:0    | RBR  | <b>Read-only register</b><br>The received data can be read by accessing this register.<br>Only when LCR[7] = 0. |

**A0080000 THR TX Holding Register 00**

| Bit                                     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>THR</b>                              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>WO</b>                               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Name | Description                                                                                                                                             |
|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | THR  | <b>TX Holding Register</b><br>Write-only register. The data to be transmitted are written to this register and sent to the PC via serial communication. |

| Bit(s) | Name | Description         |
|--------|------|---------------------|
|        |      | Only when LCR[7]=0. |

**A0080000 DLL Divisor Latch (LS) 01**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DLL |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW  |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1   |

| Bit(s) | Name | Description                                                          |
|--------|------|----------------------------------------------------------------------|
| 7:0    | DLL  | Divisor latch low 8-bit data<br><i>Note: Modified when LCR[7]≠0.</i> |

**A0080004 IER Interrupt Enable Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6    | 5     | 4 | 3     | 2    | 1     | 0     |
|-------|----|----|----|----|----|----|---|---|------|------|-------|---|-------|------|-------|-------|
| Name  |    |    |    |    |    |    |   |   | CTSI | RTSI | XOFFI |   | EDSSI | ELSI | ETBEI | ERBFI |
| Type  |    |    |    |    |    |    |   |   | RW   | RW   | RW    |   | RW    | RW   | RW    | RW    |
| Reset |    |    |    |    |    |    |   |   | 0    | 0    | 0     |   | 0     | 0    | 0     | 0     |

| Bit(s) | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | CTSI  | Masks an interrupt that is generated when a rising edge is detected on the CTS modem control line.<br><i>Note: This interrupt is only enabled when hardware flow control is enabled.</i><br>0: Mask an interrupt that is generated when a rising edge is detected on the CTS modem control line.<br>1: Unmask an interrupt that is generated when a rising edge is detected on the CTS modem control line.                                               |
| 6      | RTSI  | Masks an interrupt that is generated when a rising edge is detected on the RTS modem control line.<br><i>Note: This interrupt is only enabled when hardware flow control is enabled.</i><br>0: Mask an interrupt that is generated when a rising edge is detected on the RTS modem control line.<br>1: Unmask an interrupt that is generated when a rising edge is detected on the RTS modem control line.                                               |
| 5      | XOFFI | Masks an interrupt that is generated when an XOFF character is received.<br><i>Note: This interrupt is only enabled when software flow control is enabled.</i><br>0: Mask an interrupt that is generated when an XOFF character is received.<br>1: Unmask an interrupt that is generated when an XOFF character is received.                                                                                                                             |
| 3      | EDSSI | When set to 1, an interrupt will be generated if DCTS (MSR[0]) becomes set.<br>0: No interrupt is generated if DCTS (MSR[0]) becomes set.<br>1: An interrupt is generated if DCTS (MSR[0]) becomes set.                                                                                                                                                                                                                                                  |
| 2      | ELSI  | When set to 1, an interrupt will be generated if BI, FE, PE or OE (LSR[4:1]) becomes set.<br>0: No interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.<br>1: An interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.                                                                                                                                                                                                        |
| 1      | ETBEI | When set to 1, an interrupt will be generated if the TX holding register is empty or the contents of the TX FIFO have been reduced to its trigger level.<br>0: No interrupt will be generated if the TX holding register is empty or the contents of the TX FIFO have been reduced to its trigger level.<br>1: An interrupt will be generated if the TX holding register is empty or the contents of the TX FIFO have been reduced to its trigger level. |
| 0      | ERBFI | When set to 1, an interrupt will be generated if RX data are placed in RX buffer register or the RX trigger level is reached.                                                                                                                                                                                                                                                                                                                            |

| Bit(s) | Name | Description                                                                                                           |
|--------|------|-----------------------------------------------------------------------------------------------------------------------|
|        |      | 0: No interrupt will be generated if RX data are placed in the RX buffer register or the RX trigger level is reached. |
|        |      | 1: An interrupt will be generated if RX Data are placed in the RX buffer register or the RX trigger level is reached. |

**A0080004 DLM Divisor Latch (MS) 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | DLM |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW  |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0   | 0 |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | Divisor latch high 8-bit data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|        |      | Note: Modified when LCR[7]! = 0. DLL & DLM can only be updated when DLAB(LCR[7]) is set to 1. Division by 1 will generate a BAUD signal that is constantly high. DLL & DLM setting formula is {DLH,DLL}=(system clock frequency/baud_pulse/baud_rate). When RATE_FIX(RATEFIX_AD[0])=0, system clock frequency = 52MHz. When RATE_FIX(RATEFIX_AD[0])=1 and RATE_FIX(RATEFIX_AD[2])=0, system clock frequency = 26MHz. When RATE_FIX(RATEFIX_AD[0])=1 and RATE_FIX(RATEFIX_AD[2])=1, system clock frequency = 13MHz. For baud_pulse value, refer to HIGH_SPEED(offset=24H) register |
|        |      | For example, when at 52MHz, default speed mode and 115200 baud rate, {DLH,DLL}=52MHz/16/115200=28.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7:0    | DLM  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**A0080008 IIR Interrupt Identification Register 01**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6 | 5 | 4 | 3  | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|-------|---|---|---|----|---|---|---|
| Name  |    |    |    |    |    |    |   |   | FIFOE |   |   |   | ID |   |   |   |
| Type  |    |    |    |    |    |    |   |   | RO    |   |   |   | RU |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0     | 0 | 0 | 0 | 0  | 0 | 0 | 1 |

| Bit(s)                                                                       | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
|------------------------------------------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---|----------------------|--------|---|-------------------------------------------------------------------------|--------|---|-------------------------------------------------------------------------|--------|---|-------------------------------------------------------------------------------------|--------|---|----------------------------|--------|---|-----------------------------------------------------------|------------------------------------------------------------------------------|--|--|--------|---|---------------------------------------------------------------------|--------|---|--------------------------------------------------------------------------------|
| 7:6                                                                          | FIFOE |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
| 5:0                                                                          | ID    | IIR[5:0] Priority level interrupt source <table> <tr><td>000001</td><td>-</td><td>No interrupt pending</td></tr> <tr><td>000110</td><td>1</td><td>Line status interrupt:<br/>BI, FE, PE or OE set in LSR. (Under IER[2]=1)</td></tr> <tr><td>001100</td><td>2</td><td>RX data time-out:<br/>Time-out on character in RX FIFO. (Under IER[0]=1)</td></tr> <tr><td>000100</td><td>3</td><td>RX data received:<br/>RX data received or RX trigger level reached. (Under IER[0]=1)</td></tr> <tr><td>000010</td><td>4</td><td>TX holding register empty:</td></tr> <tr><td>000000</td><td>5</td><td>Modem status change:<br/>DCTS set in MSR. (Under IER[3]=1)</td></tr> <tr><td>TX Holding Register empty or TX FIFO trigger level reached. (Under IER[1]=1)</td><td></td><td></td></tr> <tr><td>010000</td><td>6</td><td>Software flow control:<br/>XOFF Character received. (Under IER[5]=1)</td></tr> <tr><td>100000</td><td>7</td><td>Hardware flow control:<br/>CTS or RTS Rising Edge. (Under IER[7]=1 or IER[6]=1)</td></tr> </table> | 000001 | - | No interrupt pending | 000110 | 1 | Line status interrupt:<br>BI, FE, PE or OE set in LSR. (Under IER[2]=1) | 001100 | 2 | RX data time-out:<br>Time-out on character in RX FIFO. (Under IER[0]=1) | 000100 | 3 | RX data received:<br>RX data received or RX trigger level reached. (Under IER[0]=1) | 000010 | 4 | TX holding register empty: | 000000 | 5 | Modem status change:<br>DCTS set in MSR. (Under IER[3]=1) | TX Holding Register empty or TX FIFO trigger level reached. (Under IER[1]=1) |  |  | 010000 | 6 | Software flow control:<br>XOFF Character received. (Under IER[5]=1) | 100000 | 7 | Hardware flow control:<br>CTS or RTS Rising Edge. (Under IER[7]=1 or IER[6]=1) |
| 000001                                                                       | -     | No interrupt pending                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
| 000110                                                                       | 1     | Line status interrupt:<br>BI, FE, PE or OE set in LSR. (Under IER[2]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
| 001100                                                                       | 2     | RX data time-out:<br>Time-out on character in RX FIFO. (Under IER[0]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
| 000100                                                                       | 3     | RX data received:<br>RX data received or RX trigger level reached. (Under IER[0]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
| 000010                                                                       | 4     | TX holding register empty:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
| 000000                                                                       | 5     | Modem status change:<br>DCTS set in MSR. (Under IER[3]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
| TX Holding Register empty or TX FIFO trigger level reached. (Under IER[1]=1) |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
| 010000                                                                       | 6     | Software flow control:<br>XOFF Character received. (Under IER[5]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |
| 100000                                                                       | 7     | Hardware flow control:<br>CTS or RTS Rising Edge. (Under IER[7]=1 or IER[6]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        |   |                      |        |   |                                                                         |        |   |                                                                         |        |   |                                                                                     |        |   |                            |        |   |                                                           |                                                                              |  |  |        |   |                                                                     |        |   |                                                                                |

**Line status interrupt:** A RX line status interrupt (IIR[5:0] = 000110b) will be generated if ELSI (IER[2]) is set and any of BI, FE, PE or OE (LSR[4:1]) becomes set. The interrupt is cleared by reading the line status register.

**RX data time-out interrupt:** When the virtual FIFO mode is disabled, RX data time-out

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                         |
|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | interrupt will be generated if all of the following conditions are applied:<br>1. FIFO contains at least one character.<br>2. The most recent character is received longer than four character periods ago (including all start, parity and stop bits);<br>3. The most recent CPU read of the FIFO is longer than four character periods ago.                                       |
|        |      | The timeout timer is restarted upon receipt of a new byte from the RX shift register or upon a CPU read from the RX FIFO. The RX data time-out interrupt is enabled by setting EFRBI (IER[0]) to 1 and is cleared by reading RX FIFO.                                                                                                                                               |
|        |      | When the virtual FIFO mode is enabled, RX data time-out interrupt will be generated if all of the following conditions are applied:<br>1. FIFO is empty.<br>2. The most recent character is received longer than four character periods ago (including all start, parity and stop bits).<br>3. The most recent CPU read of the FIFO is longer than four character periods ago.      |
|        |      | The timeout timer is restarted upon receipt of a new byte from the RX shift register or reading DMA_EN register. The RX Data Timeout Interrupt is enabled by setting EFRBI (IER[0]) to 1 and is cleared by reading DMA_EN register.                                                                                                                                                 |
|        |      | <b>RX data received interrupt:</b> A RX received interrupt (IER[5:0] = 000100b) is generated if EFRBI (IER[0]) is set and either RX data are placed in the RX buffer register or the RX trigger level is reached. The interrupt is cleared by reading the RX buffer register or the RX FIFO (if enabled).                                                                           |
|        |      | <b>TX holding register empty interrupt:</b> A TX holding register empty interrupt (IIR[5:0] = 000010b) is generated if ETRBI (IER[1]) is set and either the TX holding register is empty or the contents of the TX FIFO are reduced to its trigger level. The interrupt is cleared by writing to the TX holding register or TX FIFO if FIFO is enabled.                             |
|        |      | <b>Modem status change interrupt:</b> A modem status change Interrupt (IIR[5:0] = 000000b) will be generated if EDSSI (IER[3]) is set and e DCTS (MSR[3:0]) becomes set. The interrupt is cleared by reading the modem status register.                                                                                                                                             |
|        |      | <b>Software flow control interrupt:</b> A software flow control interrupt (IIR[5:0] = 010000b) will be generated if the software flow control is enabled and XOFFI (IER[5]) becomes set, indicating that an XOFF character has been received. The interrupt is cleared by reading the interrupt identification register.                                                            |
|        |      | <b>Hardware flow control interrupt:</b> A hardware flow control interrupt (IER[5:0] = 100000b) will be generated if the hardware flow control is enabled and either RTSI (IER[6]) or CTSI (IER[7]) becomes set indicating that a rising edge has been detected on either the RTS/CTS modem control line. The interrupt is cleared by reading the interrupt identification register. |

| A0080008 FCR FIFO Control Register |    |    |    |    |    |    |   |   |       |       |       |       |    |    |    | 00 |
|------------------------------------|----|----|----|----|----|----|---|---|-------|-------|-------|-------|----|----|----|----|
| Bit                                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6     | 5     | 4     | 3  | 2  | 1  | 0  |
| Name                               |    |    |    |    |    |    |   |   | RFTL1 | RFTL0 | TFTL1 | TFTL0 |    |    |    |    |
| Type                               |    |    |    |    |    |    |   |   | WO    | WO    |       |       | WO | WO | WO |    |
| Reset                              |    |    |    |    |    |    |   |   | 0     | 0     | 0     | 0     |    | 0  | 0  | 0  |

| Bit(s) | Name        | Description                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------------------|
| 7:6    | RFTL1_RFTL0 | <b>RX FIFO trigger threshold</b><br>RX FIFO contains total 32 bytes.<br>0: 1<br>1: 6<br>2: 12 |

| Bit(s) | Name        | Description                                                                                                 |                                                    |           |             |        |
|--------|-------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------|-------------|--------|
|        |             | 3: RXTRIG                                                                                                   |                                                    |           |             |        |
| 5:4    | TFTL1_TFTL0 | <b>TX FIFO trigger threshold</b><br>TX FIFO contains total 32 bytes.                                        |                                                    |           |             |        |
|        |             | 0:<br>1:<br>2:<br>3: 14                                                                                     |                                                    |           | 1<br>4<br>8 |        |
| 2      | CLRT        | <b>Control bit to clear TX FIFO</b>                                                                         | 0:<br>1: Clear TX FIFO                             | No        |             | effect |
| 1      | CLRR        | <b>Control bit to clear RX FIFO</b>                                                                         | 0:<br>1: Clear RX FIFO                             | No        |             | effect |
| 0      | FIFOE       | <b>Enables FIFO</b><br>This bit must be set to 1 for any of other bits in the registers to have any effect. | 0: Disable both<br>1: Enable both RX and TX FIFOs. | RX and TX |             | FIFOs. |

**A0080008 EFR Enhanced Feature Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6        | 5 | 4         | 3 | 2 | 1            | 0 |
|-------|----|----|----|----|----|----|---|---|----------|----------|---|-----------|---|---|--------------|---|
| Name  |    |    |    |    |    |    |   |   | AUTO_CTS | AUTO_RTS |   | ENABL_E_E |   |   | SW_FLOW_CONT |   |
| Type  |    |    |    |    |    |    |   |   | RW       | RW       |   | RW        |   |   | RW           |   |
| Reset |    |    |    |    |    |    |   |   | 0        | 0        |   | 0         | 0 | 0 | 0            |   |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------------------------------------------------------|
| 7      | AUTO_CTS     | <b>Enables hardware transmission flow control</b><br>0:<br>1: Enable                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  | Disable                                                      |
| 6      | AUTO_RTS     | <b>Enables hardware reception flow control</b><br>0:<br>1: Enable                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  | Disable                                                      |
| 4      | ENABLE_E     | <b>Enables enhancement feature</b><br>0:<br>1: Enable                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  | Disable                                                      |
| 3:0    | SW_FLOW_CONT | <b>Software flow control bits</b><br>00xx: No TX flow control bytes<br>01xx: No TX flow control bytes<br>10xx: Transmit XON1/XOFF1 as flow control bytes<br>xx00: No RX flow control bytes<br>xx01: No RX flow control bytes<br>xx10: Receive XON1/XOFF1 as flow control bytes |  |  |  |  |  |  |  |  |  |  |  |  |  | control<br>control<br>bytes<br>control<br>control<br>control |

**A008000C LCR Line Control Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6  | 5  | 4   | 3   | 2   | 1         | 0 |
|-------|----|----|----|----|----|----|---|---|------|----|----|-----|-----|-----|-----------|---|
| Name  |    |    |    |    |    |    |   |   | DLAB | SB | SP | EPS | PEN | STB | WLS1_WLS0 |   |
| Type  |    |    |    |    |    |    |   |   | RW   | RW | RW | RW  | RW  | RW  | RW        |   |
| Reset |    |    |    |    |    |    |   |   | 0    | 0  | 0  | 0   | 0   | 0   | 0         |   |

| Bit(s) | Name | Description              |
|--------|------|--------------------------|
| 7      | DLAB | Divisor latch access bit |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                 |
|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |           | 0: RX and TX registers are read/written at Address 0 and the IER register is read/written at Address 4.<br>1: Divisor Latch LS is read/written at Address 0 and the Divisor Latch MS is read/written at Address 4.                                          |
| 6      | SB        | <b>Set break</b><br>0: No effect<br>1: SOUT signal is forced to the 0 state.                                                                                                                                                                                |
| 5      | SP        | <b>Stick parity</b><br>0: No effect.<br>1: The parity bit is forced to a defined state, depending on the states of EPS and PEN: If EPS=1 & PEN=1, the parity bit will be set and checked = 0. If EPS=0 & PEN=1, the parity bit will be set and checked = 1. |
| 4      | EPS       | <b>Selects even parity</b><br>0: When EPS=0, an odd number of ones is sent and checked.<br>1: When EPS=1, an even number of ones is sent and checked.                                                                                                       |
| 3      | PEN       | <b>Enables parity</b><br>0: The parity is neither transmitted nor checked.<br>1: The parity is transmitted and checked.                                                                                                                                     |
| 2      | STB       | <b>Number of STOP bits</b><br>0: One STOP bit is always added.<br>1: Two STOP bits are added after each character is sent; unless the character length is 5 when 1 STOP bit is added.                                                                       |
| 1:0    | WLS1_WLS0 | <b>Selects word length</b><br>0: 5 bits<br>1: 6 bits<br>2: 7 bits<br>3: 8 bits                                                                                                                                                                              |

| A0080010 MCR Modem Control Register 00 |    |    |    |    |    |    |   |   |             |   |   |      |   |   |     |   |
|----------------------------------------|----|----|----|----|----|----|---|---|-------------|---|---|------|---|---|-----|---|
| Bit                                    | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6 | 5 | 4    | 3 | 2 | 1   | 0 |
| Name                                   |    |    |    |    |    |    |   |   | XOFF STATUS |   |   | Loop |   |   | RTS |   |
| Type                                   |    |    |    |    |    |    |   |   | RU          |   |   | RW   |   |   | RW  |   |
| Reset                                  |    |    |    |    |    |    |   |   | 0           |   |   | 0    |   |   | 0   |   |

| Bit(s) | Name        | Description                                                                                                                                                    |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | XOFF_STATUS | <b>Read-only bit</b><br>0: When an XON character is received.<br>1: When an XOFF character is received.                                                        |
| 4      | Loop        | <b>Loop-back control bit</b><br>0: No loop-back is enabled.<br>1: Loop-back mode is enabled.                                                                   |
| 1      | RTS         | <b>Controls the state of the output NRTS, even in loop mode.</b><br>0: RTS will always output<br>1: RTS's output will be controlled by flow control condition. |

| A0080010 XON1 XON1 Char Register 00 |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|-------------------------------------|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| Bit                                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                |    |    |    |    |    |    |   |   | XON1 |   |   |   |   |   |   |   |
| Type                                |    |    |    |    |    |    |   |   | RW   |   |   |   |   |   |   |   |
| Reset                               |    |    |    |    |    |    |   |   | 0    | 0 | 0 | 0 | 0 | 0 | 0 |   |

| Bit(s) | Name | Description                                                                    |
|--------|------|--------------------------------------------------------------------------------|
| 7:0    | XON1 | <b>XON1 character for software flow control</b><br>Modified only when LCR=BFh. |

**A0080014 LSR Line Status Register** 60

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6            | 5    | 4  | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|---|---|-------------|--------------|------|----|----|----|----|----|
| Name  |    |    |    |    |    |    |   |   | FIFOE<br>RR | TEM <b>T</b> | THRE | BI | FE | PE | OE | DR |
| Type  |    |    |    |    |    |    |   |   | RU          | RU           | RU   | RU | RU | RU | RU | RU |
| Reset |    |    |    |    |    |    |   |   | 0           | 1            | 1    | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | FIFOERR      | <b>RX FIFO error indicator</b><br>0: No PE, FE, BI set in the RX FIFO.<br>1: Set to 1 when there is at least one PE, FE or BI in the RX FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6      | TEM <b>T</b> | <b>TX holding register (or TX FIFO) and the TX shift register are empty.</b><br>0: Empty conditions below are not met.<br>1: If FIFOs are enabled, the bit will be set whenever the TX FIFO and the TX shift register are empty. If FIFOs are disabled, the bit will be set whenever TX holding register and TX shift register are empty.                                                                                                                                                                                                                                                                |
| 5      | THRE         | <b>Indicates if there is room for TX holding register or TX FIFO is reduced to its trigger level</b><br>0: Reset whenever the contents of the TX FIFO are more than its trigger level (FIFOs are enabled), or whenever TX holding register is not empty (FIFOs are disabled).<br>1: Set whenever the contents of the TX FIFO are reduced to its trigger level (FIFOs are enabled), or whenever TX holding register is empty and ready to accept new data (FIFOs are disabled).                                                                                                                           |
| 4      | BI           | <b>Break interrupt</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit will be set whenever the SIN is held in the 0 state for more than one transmission time (START bit + DATA bits + PARITY + STOP bits). If the FIFOs are enabled, this error will be associated with a corresponding character in the FIFO and is flagged when this byte is at the top of the FIFO. When a break occurs, only one zero character is loaded into the FIFO: The next character transfer is enabled when SIN goes into the marking state and receives the next valid start bit. |
| 3      | FE           | <b>Framing error</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit will be set if the received data do not have a valid STOP bit. If the FIFOs are enabled, the state of this bit will be revealed when the byte it refers to is the next to be read.                                                                                                                                                                                                                                                                                                           |
| 2      | PE           | <b>Parity error</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit will be set if the received data do not have a valid parity bit. If the FIFOs are enabled, the state of this bit will be revealed when the referred byte is the next to be read.                                                                                                                                                                                                                                                                                                              |
| 1      | OE           | <b>Overrun error</b><br>0: Reset by the CPU reading this register.<br>1: If the FIFOs are disabled, this bit will be set if the RX buffer is not read by the CPU before the new data from the RX shift register overwrites the previous contents. If the FIFOs are enabled, an overrun error will occur when the RX FIFO is full and the RX shift register becomes full. OE will be set as soon as this happens. The character in the shift register is then overwritten, but not transferred to the FIFO.                                                                                               |
| 0      | DR           | <b>Data ready</b><br>0: Cleared by the CPU reading the RX buffer or by reading all the FIFO bytes.<br>1: Set by the RX buffer becoming full or by the FIFO becoming no empty.                                                                                                                                                                                                                                                                                                                                                                                                                            |

**A0080018 XOFF1****XOFF1 Char Register**

00

| Bit   | 15    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | XOFF1 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0     | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Bit(s)****Name****Description**

7:0

XOFF1

XOFF1 character for software flow control

Modified only when LCR=BFh.

**A008001C SCR****Scratch Register**

00

| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | SCR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Bit(s)****Name****Description**

7:0

SCR

General purpose read/write register

After reset, its value will be undefined. Modified when LCR != BFh.

**A0080020 AUTOBAUD\_EN****Auto Baud Detect Enable Register**

00

| Bit   | 15           | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | AUTOBAUD_SEL |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0            | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Bit(s)****Name****Description**

2

SLEEP\_ACK\_SEL

Selects sleep ack when autobaud\_en

0: Support sleep\_ack when autobaud\_en is opened  
1: Does not support sleep\_ack when autobaud\_en is opened.

1

AUTOBAUD\_SEL

Selects auto-baud

0: Support standard baud rate detection  
1: Support non-standard baud rate detection (support baud from 110 to 115200; recommended to use 52MHz to auto fix).

0

AUTOBAUD\_EN

Auto-baud enabling signal

0: Disable auto-baud function  
1: Enable auto-baud function (UARTn+0024h SPEED should be set to 0.)  
Note: When AUTOBAUD\_EN is active, there should not be A\*'a\* char before the auto baud char AT/at. If A\*'a\* is inevitable, autobaud will fail and please disable AUTOBAUD\_EN to reset the autobaud feature and autobaud\_en again.**A0080024 HIGH SPEED****High Speed Mode Register**

00

| Bit  | 15    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|-------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | SPEED |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | RW    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|       |   |   |
|-------|---|---|
| Reset | 0 | 0 |
|-------|---|---|

| Bit(s) | Name  | Description                                                                                                                                                                                                                                                                                                                                    |
|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |       | UART sample counter base                                                                                                                                                                                                                                                                                                                       |
| 1:0    | SPEED | 0: Based on 16*baud_pulse, baud_rate = system clock frequency/16/{DLH, DLL}<br>1: Based on 8*baud_pulse, baud_rate = system clock frequency/8/{DLH, DLL}<br>2: Based on 4*baud_pulse, baud_rate = system clock frequency/4/{DLH, DLL}<br>3: Based on sampe_count * baud_pulse, baud_rate = system clock frequency / (sampe_count+1)/{DLM, DLL} |

**A0080028 SAMPLE COUN T Sample Counter Register 00**

| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | SAMPLECOUNT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name        | Description                          |
|--------|-------------|--------------------------------------|
| 7:0    | SAMPLECOUNT | Only useful when HIGHSPEED mode = 3. |

**A008002C SAMPLE POINT Sample Point Register FF**

| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | SAMPLEPOINT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 1           | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

| Bit(s) | Name        | Description                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------|
| 7:0    | SAMPLEPOINT | SAMPLE_POINT is usually (SAMPLE_COUNT-1)/2 without decimal. Effective only when HIGHSPEED=3. |

**A0080030 AUTOBAUD RE G Auto Baud Monitor Register 00**

| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | BAUD_STAT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RU        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name      | Description                                                       |
|--------|-----------|-------------------------------------------------------------------|
| 7:4    | BAUD_STAT | Autobaud state (only true v value in standard autobaud detection) |
| 0:     | Autobaud  | is detecting.                                                     |
| 1:     |           | AT_7N1                                                            |
| 2:     |           | AT_7O1                                                            |
| 3:     |           | AT_7E1                                                            |
| 4:     |           | AT_8N1                                                            |
| 5:     |           | AT_8O1                                                            |
| 6:     |           | AT_8E1                                                            |
| 7:     |           | at_7N1                                                            |
| 8:     |           | at_7E1                                                            |
| 9:     |           | at_7O1                                                            |
| 10:    |           | at_8N1                                                            |

| Bit(s) | Name      | Description                                                                                                                                                                                  |
|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:    |           | at_8E1                                                                                                                                                                                       |
| 12:    |           | at_801                                                                                                                                                                                       |
| 13:    |           | Autobaud detection fails                                                                                                                                                                     |
| 3:0    | BAUD_RATE | Autobaud baud rate (only true value in standard autobaud detection)<br>0: 115,200<br>1: 57,600<br>2: 38,400<br>3: 19,200<br>4: 9,600<br>5: 4,800<br>6: 2,400<br>7: 1,200<br>8: 300<br>9: 110 |

**A0080034 RATEFIX\_AD Clock Rate Fix Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2        | 1          | 0        |    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|----------|------------|----------|----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |          | AUTOB      |          |    |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | FREQ_SEL | AUD_RATE_F | RATE_FIX |    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |          | RW         | RW       | RW |
|       |    |    |    |    |    |    |   |   |   |   |   |   |   |          | 0          | 0        | 0  |

| Bit(s) | Name              | Description                                                                                                                                          |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | FREQ_SEL          | 0: Select 26MHz as system clock<br>1: Select 13MHz as system clock                                                                                   |
| 1      | AUTOBAUD_RATE_FIX | 0: Use 52MHz as system clock for UART auto baud detection<br>1: Use 26MHz/13MHz (depending on FREQ_SEL) as system clock for UART auto baud detection |
| 0      | RATE_FIX          | 0: Use 52MHz as system clock for UART TX/RX<br>1: Use 26MHz/13MHz (depending on FREQ_SEL) as system clock for UART TX/RX                             |

**A0080038 AUTOBAUDSA\_MPLE Auto Baud Sample Register 0D**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1              | 0 |   |   |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----------------|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | AUTOBAUDSAMPLE |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW             |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0              | 0 | 1 | 1 | 0 | 1 |

| Bit(s)                                   | Name           | Description                                                                                                                                                 |
|------------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clk division for autobaud rate detection |                |                                                                                                                                                             |
| 5:0                                      | AUTOBAUDSAMPLE | For standard baud rate detection.<br>System clk 52m: 'd 27<br>System clk 26m: 'd 13<br>System dk 13m: 'd 6<br>For non-standard baud rate detection.<br>:15. |

**A008003C GUARD Guard Time Added Register 0F**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4        | 3         | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|----------|-----------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | GUARD_EN | GUARD_CNT |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW       | RW        |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0        | 1         | 1 | 1 | 1 |

| Bit(s) | Name      | Description                                                                                         |
|--------|-----------|-----------------------------------------------------------------------------------------------------|
| 4      | GUARD_EN  | Guard interval add enabling signal<br>0: No guard interval<br>1: Add guard interval after stop bit. |
| 3:0    | GUARD_CNT | Guard interval count value<br>Guard interval = [1/(system clock/div_step/div)]*GUARD_CNT.           |

**A0080040 ESCAPE\_DAT Escape Character Register FF**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2 | 1 | 0 |  |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|------------|---|---|---|--|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | ESCAPE_DAT |   |   |   |  |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | RW         |   |   |   |  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 1          | 1 | 1 | 1 |  |

| Bit(s) | Name       | Description                                                                                                                                                            |
|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | ESCAPE_DAT | Escape character added before software flow control data and escape character<br>If TX data are xon (31h), with esc_en=1, UART will transmit data as esc + CEh (~xon). |

**A0080044 ESCAPE\_EN Escape Enable Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | ESC_EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW     |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0      |

| Bit(s) | Name   | Description                                                                                                                                                                                                           |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | ESC_EN | Adds escape character in transmitter and removes escape character in receiver by UART<br>0: Does not deal with the escape character<br>1: Add escape character in transmitter and remove escape character in receiver |

**A0080048 SLEEP\_EN Sleep Enable Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SLEEP_EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0        |

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                             |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | SLEEP_EN | For sleep mode issue<br>0: Does not deal with sleep mode indicate signal<br>1: Activate hardware flow control or software control according to software initial setting when the chip enters sleep mode. Release hardware flow when the chip wakes up. However, for software control, UART sends xon when awaken and when FIFO does not |

| Bit(s) | Name | Description            |
|--------|------|------------------------|
|        |      | reach threshold level. |

**A008004C DMA\_EN DMA Enable Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4             | 3              | 2                | 1                | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---------------|----------------|------------------|------------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | FIFO_I_sr_sel | TO_CNT_AUTORST | TX_DM_RX_DM_A_EN | TX_DM_RX_DM_A_EN |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW            | RW             | RW               | RW               |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0             | 0              | 0                | 0                |   |

| Bit(s) | Name           | Description                                                                                                                                                                                                              |
|--------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3      | FIFO_Isr_sel   | Selects FIFO LSR mode<br>0: LSR will hold the first line status error state until you read the LSR register.<br>1: LSR will update automatically.                                                                        |
| 2      | TO_CNT_AUTORST | Time-out counter auto reset register<br>0: After RX time-out happens, SW shall reset the interrupt by reading UART 0x4C.<br>1: The time-out counter will be auto reset. Set this register when Rain's new DMA is used.   |
| 1      | TX_DMA_EN      | TX_DMA mechanism enabling signal<br>0: Does not use DMA in TX<br>1: Use DMA in TX. When this register is enabled, the flow control will be based on the DMA threshold and generate a time-out interrupt for DMA.for DMA. |
| 0      | RX_DMA_EN      | RX_DMA mechanism enabling signal<br>0: Does not use DMA in RX<br>1: Use DMA in RX. When this register is enabled, the flow control will be based on the DMA threshold and generate a time-out interrupt                  |

**A0080050 RXTRIG\_AD Rx Trigger Address 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RXTRIG |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW     |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0 | 0 | 0 | 0      |

| Bit(s) | Name   | Description                                                                                                                                    |
|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    | RXTRIG | When {rtm,rtl}=2'b11, the RX FIFO threshold will be Rxtrig. The value is suggested to be smaller than half of RX FIFO size, which is 32 bytes. |

**A0080054 FRACDIV\_L Fractional Divider LSB Address 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FRACDIV_L |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0 | 0 | 0 | 0         |

| Bit(s) | Name      | Description                                                                                                 |
|--------|-----------|-------------------------------------------------------------------------------------------------------------|
| 7:0    | FRACDIV_L | Adds sampling count (+1) from state data7 to data0 to contribute fractional divisor.only when high_speed=3. |

**A0080058 FRACDIV\_M Fractional Divider MSB Address 00**

| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | FRACDIV_M |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0 0       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Name      | Description                                                                                               |
|--------|-----------|-----------------------------------------------------------------------------------------------------------|
| 1:0    | FRACDIV_M | Adds sampling count when in state stop to parity to contribute fractional divisor.only when high_speed=3. |

**A008005C FCR\_RD FIFO Control Register 00**

| Bit   | 15    | 14 | 13 | 12 | 11    | 10 | 9 | 8 | 7     | 6 | 5 | 4 | 3     | 2 | 1 | 0 |
|-------|-------|----|----|----|-------|----|---|---|-------|---|---|---|-------|---|---|---|
| Name  | RFTL1 |    |    |    | RFTL0 |    |   |   | TFTL1 |   |   |   | TFTL0 |   |   |   |
| Type  | RO    |    |    |    | RO    |    |   |   | RO    |   |   |   | RO    |   |   |   |
| Reset | 0 0   |    |    |    | 0 0   |    |   |   | 0 0   |   |   |   | 0 0   |   |   |   |

| Bit(s) | Name        | Description                                                                                                                                                                                         |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6    | RFTL1_RFTL0 | <b>RX FIFO trigger threshold</b><br>RX FIFO contains total 32 bytes.<br>0:<br>1:<br>2:<br>3: RXTRIG 1<br>6<br>12                                                                                    |
| 5:4    | TFTL1_TFTL0 | <b>TX FIFO trigger threshold</b><br>TX FIFO contains total 32 bytes.<br>0:<br>1:<br>2:<br>3: 14 8<br>4                                                                                              |
| 2      | CLRT        | 0: TX FIFO is cleared.<br>1: TX FIFO is cleared. 1<br>not cleared.                                                                                                                                  |
| 1      | CLRR        | 0: RX FIFO is cleared.<br>1: RX FIFO is cleared. 1<br>not cleared.                                                                                                                                  |
| 0      | FIFOE       | <b>Enables FIFO</b><br>This bit must be set to 1 for any of other bits in the registers to have any effect.<br>0: RX and TX FIFOs are enabled.<br>1: RX and TX FIFOs are enabled. 1<br>not enabled. |

### 3.8 UART2

#### 3.8.1 General Description

The baseband chipset houses two UARTs. The UARTs provide full duplex serial communication channels between baseband chipset and external devices.

The UART has M16C450 and M16550A modes of operation, which are compatible with a range of standard software drivers. The extensions have been designed to be broadly software compatible with 16550A variants, but certain areas offer no consensus.

In common with the M16550A, the UART supports word lengths **from 5 to 8 bits**, an optional parity bit and one or two stop bits, and is fully programmable by an 8-bit CPU interface. A 16-bit programmable baud rate generator and an 8-bit scratch register are included, together with separate transmit and receive FIFOs. 8 modem control lines and a diagnostic loop-back mode are provided. UART also includes two DMA handshake lines, indicating when the FIFOs are ready to transfer data to the CPU. Interrupts can be generated from any of the 10 sources.

Note that UART is designed so that all internal operation is synchronized by the CLK signal. This synchronization results in minor timing differences between the UART and industry standard 16550A device, which means that the core is not clock for clock identical to the original device.

After a hardware reset, UART will be in M16C450 mode. Its FIFOs can then be enabled and UART can enter M16550A mode. UART has further functions beyond the M16550A mode. Each of the extended functions can be selected individually under software control.

UART provides more powerful enhancements than the industry-standard 16550:

- Hardware flow control. This feature is very useful when the ISR latency is hard to predict and control in the embedded applications. The MCU is relieved of having to fetch the received data within a fixed amount of time.

Note that in order to enable any of the enhancements, the Enhanced Mode bit, EFR[4], must be set. If EFR[4] is not set, IER[7:5], FCR[5:4], IIR[5:4] and MCR[7:6] cannot be written. The enhanced mode bit ensures that UART is backward compatible with the software that has been written for 16C450 and 16550A devices. **Figure 35** is the block diagram of the UART2 device.



**Figure 36. Block Diagram of UART2**

### 3.8.2 Register Definition

**Module name: UART2 Base address: (+A0090000h)**

| Address  | Name        | Width | Register Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0090000 | <u>RBR</u>  | 8     | <b>RX Buffer Register</b><br>Note: Only modified when LCR[7] = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| A0090000 | <u>THR</u>  | 8     | <b>TX Holding Register</b><br>Note: Only modified when LCR[7] = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| A0090000 | <u>DLL</u>  | 8     | <b>Divisor Latch (LS)</b><br>Divides the bclk frequency<br>Note: Modified when LCR[7]!=0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| A0090004 | <u>IER</u>  | 8     | <b>Interrupt Enable Register</b><br>Note: Only modified when LCR[7] = 0.<br>By storing 1 to a specific bit position, the interrupt associated with that bit is enabled. Otherwise, the interrupt will be disabled.<br>IER[3:0] are modified when LCR[7] = 0.<br>IER[7:4] are modified when LCR[7] = 0 & EFR[4] = 1.                                                                                                                                                                                                                                                                                                         |
| A0090004 | <u>DLM</u>  | 8     | <b>Divisor Latch (MS)</b><br>Used to divid the bclk frequency . *NOTE: modified when LCR[7]!=0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| A0090008 | <u>IIR</u>  | 8     | <b>Interrupt Identification Register</b><br>Note: Only modified when LCR!=BF'h. Priority is from high to low as the following.<br>IIR[5:0]=0X1: No interrupt pending<br>IIR[5:0]=0X6: Line status interrupt (under IER[2]=1)<br>IIR[5:0]=0Xc: RX data time-out interrupt (under IER[0]=1)<br>IIR[5:0]=0X4: RX data are placed in the RX buffer register or the RX trigger level is reached. (under IER[0]=1).<br>IIR[5:0]=0X2: TX holding register is empty or the contents of the TX FIFO have been reduced to its trigger level (under IER[1]=1).<br>IIR[5:0]=0X10: XOFF character received (under IER[5]=1, EFR[4] = 1). |
| A0090008 | <u>FCR</u>  | 8     | <b>FIFO Control Register</b><br>FCR is used to control the trigger levels of the FIFOs or flush the FIFOs.<br>FCR[7:6] is modified when LCR != BFh<br>FCR[5:4] is modified when LCR != BFh & EFR[4] = 1<br>FCR[4:0] is modified when LCR != BFh                                                                                                                                                                                                                                                                                                                                                                             |
| A0090008 | <u>EFR</u>  | 8     | <b>Enhanced Feature Register</b><br>Note: Only modified when LCR=BF'h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| A009000C | <u>LCR</u>  | 8     | <b>Line Control Register</b><br>Determines characteristics of serial communication signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| A0090010 | <u>MCR</u>  | 8     | <b>Modem Control Register</b><br>Controls interface signals of the UART.<br>MCR[5:0] are modified when LCR != 8'hBF, MCR[7] can be read when LCR != 8'hBF & EFR[4] = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| A0090010 | <u>XON1</u> | 8     | <b>XON1 Char Register</b><br>Note: XON1 is modified only when LCR=BF'h.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| A0090014 | <u>LSR</u>  | 8     | <b>Line Status Register</b><br>Modified when LCR != BFh.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Address  | Name                  | Width | Register Function                                                                                                                                                                                                                                                                                                                   |
|----------|-----------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0090018 | <u>XOFF1</u>          | 8     | <b>XOFF1 Char Register</b><br>*Note: XOFF1 is modified only when LCR=BFh.                                                                                                                                                                                                                                                           |
| A009001C | <u>SCR</u>            | 8     | <b>Scratch Register</b><br>A general purpose read/write register. After reset, its value will be un-defined. Modified when LCR != BFh.                                                                                                                                                                                              |
| A0090020 | <u>AUTOBAUD_EN</u>    | 8     | <b>Auto Baud Detect Enable Register</b>                                                                                                                                                                                                                                                                                             |
| A0090024 | <u>HIGHSPEED</u>      | 8     | <b>High Speed Mode Register</b>                                                                                                                                                                                                                                                                                                     |
| A0090028 | <u>SAMPLE_COUNT</u>   | 8     | <b>Sample Counter Register</b><br>When HIGHSPEED=3, sample_count will be the threshold value for UART sample counter (sample_num). Count from 0 to sample_count.                                                                                                                                                                    |
| A009002C | <u>SAMPLE_POINT</u>   | 8     | <b>Sample Point Register</b><br>When HIGHSPEED=3, UART gets the input data when sample_count=sample_num, e.g. system clock = 13MHz, 921600 = 13000000/14. Therefore, sample_count = 13, and sample point = 6 (sampling the central point to decrease the inaccuracy)<br>SAMPLE_POINT is usually (SAMPLE_COUNT-1)/2 without decimal. |
| A0090030 | <u>AUTOBAUD_REG</u>   | 8     | <b>Auto Baud Monitor Register</b><br>the autobaud detection state ,it will not change until enable the autobaud_en again.                                                                                                                                                                                                           |
| A0090034 | <u>RATEFIX_AD</u>     | 8     | <b>Clock Rate Fix Register</b>                                                                                                                                                                                                                                                                                                      |
| A0090038 | <u>AUTOBAUDSAMPLE</u> | 8     | <b>Auto Baud Sample Register</b><br>Since the system clock may change, autobaud sample duration should change as the system clock changes. When system clock = 13MHz, autobaudsample = 6; when system clock = 26MHz, autobaudsample = 13. When system clock = 52MHz, autobaudsample = 27.                                           |
| A009003C | <u>GUARD</u>          | 8     | <b>Guard Time Added Register</b>                                                                                                                                                                                                                                                                                                    |
| A0090040 | <u>ESCAPE_DAT</u>     | 8     | <b>Escape Character Register</b>                                                                                                                                                                                                                                                                                                    |
| A0090044 | <u>ESCAPE_EN</u>      | 8     | <b>Escape Enable Register</b>                                                                                                                                                                                                                                                                                                       |
| A0090048 | <u>SLEEP_EN</u>       | 8     | <b>Sleep Enable Register</b>                                                                                                                                                                                                                                                                                                        |
| A009004C | <u>DMA_EN</u>         | 8     | <b>DMA Enable Register</b>                                                                                                                                                                                                                                                                                                          |
| A0090050 | <u>RXTRI_AD</u>       | 8     | <b>Rx Trigger Address</b>                                                                                                                                                                                                                                                                                                           |
| A0090054 | <u>FRACTDIV_L</u>     | 8     | <b>Fractional Divider LSB Address</b>                                                                                                                                                                                                                                                                                               |
| A0090058 | <u>FRACTDIV_M</u>     | 8     | <b>Fractional Divider MSB Address</b>                                                                                                                                                                                                                                                                                               |
| A009005C | <u>FCR_RD</u>         | 8     | <b>FIFO Control Register</b>                                                                                                                                                                                                                                                                                                        |

| A0090000 <u>RBR</u> RX Buffer Register |                                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 00 |  |
|----------------------------------------|---------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----|--|
| Bit                                    | 15                              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |  |
| Name                                   | <u>RBR</u>                      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |    |  |
| Type                                   | <u>RU</u>                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |    |  |
| Reset                                  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |    |  |

| Bit(s) | Name | Description |
|--------|------|-------------|
|        |      |             |

| Bit(s) | Name | Description                                                                                                     |
|--------|------|-----------------------------------------------------------------------------------------------------------------|
| 7:0    | RBR  | <b>Read-only register</b><br>The received data can be read by accessing this register.<br>Only when LCR[7] = 0. |

| <b>A0090000    THR           TX Holding Register</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>00</b> |                   |
|------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|-------------------|
| Bit                                                  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |                   |
| <b>Name</b>                                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |           | <b>THR</b>        |
| <b>Type</b>                                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |           | <b>WO</b>         |
| <b>Reset</b>                                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |           | 0 0 0 0 0 0 0 0 0 |

| Bit(s) | Name | Description                                                                                                                                                                      |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | THR  | <b>TX Holding Register</b><br>Write-only register. The data to be transmitted are written to this register and sent to the PC via serial communication.<br>Only when LCR[7] = 0. |

| <b>A0090000    DLL           Divisor Latch (LS)</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>01</b> |                   |
|-----------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|-------------------|
| Bit                                                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |                   |
| <b>Name</b>                                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |           | <b>DLL</b>        |
| <b>Type</b>                                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |           | <b>RW</b>         |
| <b>Reset</b>                                        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |           | 0 0 0 0 0 0 0 0 1 |

| Bit(s) | Name | Description                                                                    |
|--------|------|--------------------------------------------------------------------------------|
| 7:0    | DLL  | <b>Divisor latch low 8-bit data</b><br><i>Note: Modified when LCR[7] != 0.</i> |

| <b>A0090004    IER           Interrupt Enable Register</b> |    |    |    |    |    |    |   |   |             |             |              |   |              |             |              | <b>00</b>    |  |
|------------------------------------------------------------|----|----|----|----|----|----|---|---|-------------|-------------|--------------|---|--------------|-------------|--------------|--------------|--|
| Bit                                                        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6           | 5            | 4 | 3            | 2           | 1            | 0            |  |
| <b>Name</b>                                                |    |    |    |    |    |    |   |   | <b>CTSI</b> | <b>RTSI</b> | <b>XOFFI</b> |   | <b>EDSSI</b> | <b>ELSI</b> | <b>ETBEI</b> | <b>ERBFI</b> |  |
| <b>Type</b>                                                |    |    |    |    |    |    |   |   | <b>RW</b>   | <b>RW</b>   | <b>RW</b>    |   | <b>RW</b>    | <b>RW</b>   | <b>RW</b>    | <b>RW</b>    |  |
| <b>Reset</b>                                               |    |    |    |    |    |    |   |   | 0           | 0           | 0            |   | 0            | 0           | 0            | 0            |  |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | CTSI | <b>Masks an interrupt that is generated when a rising edge is detected on the CTS modem control line.</b><br><i>Note: This interrupt is only enabled when hardware flow control is enabled.</i><br>0: Mask an interrupt that is generated when a rising edge is detected on the CTS modem control line.<br>1: Unmask an interrupt that is generated when a rising edge is detected on the CTS modem control line. |
| 6      | RTSI | <b>Masks an interrupt that is generated when a rising edge is detected on the RTS modem control line.</b><br><i>Note: This interrupt is only enabled when hardware flow control is enabled.</i><br>0: Mask an interrupt that is generated when a rising edge is detected on the RTS modem control line.<br>1: Unmask an interrupt that is generated when a rising edge is detected on the                         |

| Bit(s) | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | XOFFI | RTS modem control line.<br><br>Masks an interrupt that is generated when an XOFF character is received.<br><br>Note: This interrupt is only enabled when software flow control is enabled.<br>0: Mask an interrupt that is generated when an XOFF character is received.<br>1: Unmask an interrupt that is generated when an XOFF character is received.                                                                                                     |
| 3      | EDSSI | When set to 1, an interrupt will be generated if DCTS (MSR[0]) becomes set.<br><br>0: No interrupt is generated if DCTS (MSR[0]) becomes set.<br>1: An interrupt is generated if DCTS (MSR[0]) becomes set.                                                                                                                                                                                                                                                  |
| 2      | ELSI  | When set to 1, an interrupt will be generated if BI, FE, PE or OE (LSR[4:1]) becomes set.<br><br>0: No interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.<br>1: An interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.                                                                                                                                                                                                        |
| 1      | ETBEI | When set to 1, an interrupt will be generated if the TX holding register is empty or the contents of the TX FIFO have been reduced to its trigger level.<br><br>0: No interrupt will be generated if the TX holding register is empty or the contents of the TX FIFO have been reduced to its trigger level.<br>1: An interrupt will be generated if the TX holding register is empty or the contents of the TX FIFO have been reduced to its trigger level. |
| 0      | ERBFI | When set to 1, an interrupt will be generated if RX data are placed in RX buffer register or the RX trigger level is reached.<br><br>0: No interrupt will be generated if RX data are placed in the RX buffer register or the RX trigger level is reached.<br>1: An interrupt will be generated if RX Data are placed in the RX buffer register or the RX trigger level is reached.                                                                          |

| A0090004 DLM Divisor Latch (MS) 00 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit                                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>DLM</b>                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>RW</b>                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b>                       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s)                                                                                                                                                                                                                                                                                                                                                                                                                                               | Name | Description |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| <b>Divisor latch high 8-bit data</b>                                                                                                                                                                                                                                                                                                                                                                                                                 |      |             |
| <i>Note: Modified when LCR[7]! = 0. DLL &amp; DLM can only be updated when DLAB(LCR[7]) is set to 1. Division by 1 will generate a BAUD signal that is constantly high. DLL &amp; DLM setting formula is {DLH,DLL}=(system clock frequency/baud_pulse/baud_rate).</i>                                                                                                                                                                                |      |             |
| <i>When RATE_FIX(RATEFIX_AD[0])=0, system clock frequency = 52MHz.<br/>When RATE_FIX(RATEFIX_AD[0])=1 and RATE_FIX(RATEFIX_AD[2])=0, system clock frequency = 26MHz.<br/>When RATE_FIX(RATEFIX_AD[0])=1 and RATE_FIX(RATEFIX_AD[2])=1, system clock frequency = 13MHz.<br/>For baud_pulse value, refer to HIGH_SPEED(offset=24H) register<br/>For example, when at 52MHz, default speed mode and 115200 baud rate, {DLH,DLL}=52MHz/16/115200=28.</i> |      |             |
| 7:0                                                                                                                                                                                                                                                                                                                                                                                                                                                  | DLM  |             |

## A0090008 IIR

## Interrupt Identification Register

01

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6 | 5 | 4 | 3  | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|-------|---|---|---|----|---|---|---|
| Name  |    |    |    |    |    |    |   |   | FIFOE |   |   |   | ID |   |   |   |
| Type  |    |    |    |    |    |    |   |   | RO    |   |   |   | RU |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0     | 0 | 0 | 0 | 0  | 0 | 0 | 1 |

| Bit(s)                                               | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
|------------------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---|----------------------|--------|---|-----------------------------------------|------------------------------|---|------------------------------------|------------------------------------------|---|------------------------------------|------------------------------------------------------|---|---------------------------------------------|--------|---|---------------------------------------|------------------|---|------------------------------------------------------------------------------|--------|---|-----------------------------------------|--------------------------|--|------------------------|--------------------------------|--|------------------------------|
| 7:6                                                  | FIFOE |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| 5:0                                                  | ID    | <p><b>IIR[5:0] Priority level interrupt source</b></p> <table> <tbody> <tr><td>000001</td><td>-</td><td>No interrupt pending</td></tr> <tr><td>000110</td><td>1</td><td>Line status interrupt: (Under IER[2]=1)</td></tr> <tr><td>BI, FE, PE or OE set in LSR.</td><td>2</td><td>RX data time-out: (Under IER[0]=1)</td></tr> <tr><td>001100 Time-out on character in RX FIFO.</td><td>3</td><td>RX data received: (Under IER[0]=1)</td></tr> <tr><td>000100 RX data received or RX trigger level reached.</td><td>4</td><td>TX holding register empty: (Under IER[1]=1)</td></tr> <tr><td>000010</td><td>5</td><td>Modem status change: (Under IER[3]=1)</td></tr> <tr><td>DCTS set in MSR.</td><td>6</td><td>TX Holding Register empty or TX FIFO trigger level reached. (Under IER[1]=1)</td></tr> <tr><td>010000</td><td>7</td><td>Software flow control: (Under IER[5]=1)</td></tr> <tr><td>XOFF Character received.</td><td></td><td>Hardware flow control:</td></tr> <tr><td>100000 CTS or RTS Rising Edge.</td><td></td><td>(Under IER[7]=1 or IER[6]=1)</td></tr> </tbody> </table> | 000001 | - | No interrupt pending | 000110 | 1 | Line status interrupt: (Under IER[2]=1) | BI, FE, PE or OE set in LSR. | 2 | RX data time-out: (Under IER[0]=1) | 001100 Time-out on character in RX FIFO. | 3 | RX data received: (Under IER[0]=1) | 000100 RX data received or RX trigger level reached. | 4 | TX holding register empty: (Under IER[1]=1) | 000010 | 5 | Modem status change: (Under IER[3]=1) | DCTS set in MSR. | 6 | TX Holding Register empty or TX FIFO trigger level reached. (Under IER[1]=1) | 010000 | 7 | Software flow control: (Under IER[5]=1) | XOFF Character received. |  | Hardware flow control: | 100000 CTS or RTS Rising Edge. |  | (Under IER[7]=1 or IER[6]=1) |
| 000001                                               | -     | No interrupt pending                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| 000110                                               | 1     | Line status interrupt: (Under IER[2]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| BI, FE, PE or OE set in LSR.                         | 2     | RX data time-out: (Under IER[0]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| 001100 Time-out on character in RX FIFO.             | 3     | RX data received: (Under IER[0]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| 000100 RX data received or RX trigger level reached. | 4     | TX holding register empty: (Under IER[1]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| 000010                                               | 5     | Modem status change: (Under IER[3]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| DCTS set in MSR.                                     | 6     | TX Holding Register empty or TX FIFO trigger level reached. (Under IER[1]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| 010000                                               | 7     | Software flow control: (Under IER[5]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| XOFF Character received.                             |       | Hardware flow control:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |
| 100000 CTS or RTS Rising Edge.                       |       | (Under IER[7]=1 or IER[6]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |   |                      |        |   |                                         |                              |   |                                    |                                          |   |                                    |                                                      |   |                                             |        |   |                                       |                  |   |                                                                              |        |   |                                         |                          |  |                        |                                |  |                              |

**Line status interrupt:** A RX line status interrupt (IIR[5:0] = 000110b) will be generated if ELSI (IER[2]) is set and any of BI, FE, PE or OE (LSR[4:1]) becomes set. The interrupt is cleared by reading the line status register.

**RX data time-out interrupt:** When the virtual FIFO mode is disabled, RX data time-out interrupt will be generated if all of the following conditions are applied:

1. FIFO contains at least one character.
2. The most recent character is received longer than four character periods ago (including all start, parity and stop bits);
3. The most recent CPU read of the FIFO is longer than four character periods ago.

The timeout timer is restarted upon receipt of a new byte from the RX shift register or upon a CPU read from the RX FIFO. The RX data time-out interrupt is enabled by setting EFRBI (IER[0]) to 1 and is cleared by reading RX FIFO.

When the virtual FIFO mode is enabled, RX data time-out interrupt will be generated if all of the following conditions are applied:

1. FIFO is empty.
2. The most recent character is received longer than four character periods ago (including all start, parity and stop bits).
3. The most recent CPU read of the FIFO is longer than four character periods ago.

The timeout timer is restarted upon receipt of a new byte from the RX shift register or reading DMA\_EN register. The RX Data Timeout Interrupt is enabled by setting EFRBI (IER[0]) to 1 and is cleared by reading DMA\_EN register.

**RX data received interrupt:** A RX received interrupt (IER[5:0] = 000100b) is generated if EFRBI (IER[0]) is set and either RX data are placed in the RX buffer register or the RX trigger level is reached. The interrupt is cleared by

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                         |
|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | reading the RX buffer register or the RX FIFO (if enabled).                                                                                                                                                                                                                                                                                                                         |
|        |      | <b>TX holding register empty interrupt:</b> A TX holding register empty interrupt (IIR[5:0] = 000010b) is generated if ETRBI (IER[1]) is set and either the TX holding register is empty or the contents of the TX FIFO are reduced to its trigger level. The interrupt is cleared by writing to the TX holding register or TX FIFO if FIFO is enabled.                             |
|        |      | <b>Modem status change interrupt:</b> A modem status change Interrupt (IIR[5:0] = 000000b) will be generated if EDSSI (IER[3]) is set and e DCTS (MSR[3:0]) becomes set. The interrupt is cleared by reading the modem status register.                                                                                                                                             |
|        |      | <b>Software flow control interrupt:</b> A software flow control interrupt (IIR[5:0] = 010000b) will be generated if the software flow control is enabled and XOFFI (IER[5]) becomes set, indicating that an XOFF character has been received. The interrupt is cleared by reading the interrupt identification register.                                                            |
|        |      | <b>Hardware flow control interrupt:</b> A hardware flow control interrupt (IER[5:0] = 100000b) will be generated if the hardware flow control is enabled and either RTSI (IER[6]) or CTSI (IER[7]) becomes set indicating that a rising edge has been detected on either the RTS/CTS modem control line. The interrupt is cleared by reading the interrupt identification register. |

| A0090008 FCR FIFO Control Register |    |    |    |    |    |    |   |   |             |             |   |   |   |      |      |       |
|------------------------------------|----|----|----|----|----|----|---|---|-------------|-------------|---|---|---|------|------|-------|
| Bit                                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6           | 5 | 4 | 3 | 2    | 1    | 0     |
| Name                               |    |    |    |    |    |    |   |   | RFTL1_RFTL0 | TFTL1_TFTL0 |   |   |   | CLRT | CLRR | FIFOE |
| Type                               |    |    |    |    |    |    |   |   | WO          | WO          |   |   |   | WO   | WO   | WO    |
| Reset                              |    |    |    |    |    |    |   |   | 0           | 0           | 0 | 0 |   | 0    | 0    | 0     |

| Bit(s) | Name        | Description                                                                                                                                                                        |    |        |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------|
| 7:6    | RFTL1_RFTL0 | <b>RX FIFO trigger threshold</b><br>RX FIFO contains total 32 bytes.<br>0:<br>1:<br>2:<br>3: RXTRIG                                                                                | 1  | 6      |
| 5:4    | TFTL1_TFTL0 | <b>TX FIFO trigger threshold</b><br>TX FIFO contains total 32 bytes.<br>0:<br>1:<br>2:<br>3: 14                                                                                    | 1  | 4      |
| 2      | CLRT        | <b>Control bit to clear TX FIFO</b><br>0:<br>1: Clear TX FIFO                                                                                                                      | No | effect |
| 1      | CLRR        | <b>Control bit to clear RX FIFO</b><br>0:<br>1: Clear RX FIFO                                                                                                                      | No | effect |
| 0      | FIFOE       | <b>Enables FIFO</b><br>This bit must be set to 1 for any of other bits in the registers to have any effect.<br>0: Disable both RX and TX FIFOs.<br>1: Enable both RX and TX FIFOs. |    |        |

## A0090008 EFR

## Enhanced Feature Register

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6        | 5 | 4        | 3            | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|----------|----------|---|----------|--------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   | AUTO_CTS | AUTO_RTS |   | ENABLE_E | SW_FLOW_CONT |   |   |   |
| Type  |    |    |    |    |    |    |   |   | RW       | RW       |   | RW       | RW           |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0        | 0        | 0 | 0        | 0            | 0 | 0 | 0 |

| Bit(s) | Name         | Description                                       |                                          |            |      |         |         |
|--------|--------------|---------------------------------------------------|------------------------------------------|------------|------|---------|---------|
| 7      | AUTO_CTS     | <b>Enables hardware transmission flow control</b> | 0:                                       |            |      |         | Disable |
|        |              | 1: Enable                                         |                                          |            |      |         |         |
| 6      | AUTO_RTS     | <b>Enables hardware reception flow control</b>    | 0:                                       |            |      |         | Disable |
|        |              | 1: Enable                                         |                                          |            |      |         |         |
| 4      | ENABLE_E     | <b>Enables enhancement feature</b>                | 0:                                       |            |      |         | Disable |
|        |              | 1: Enable                                         |                                          |            |      |         |         |
| 3:0    | SW_FLOW_CONT | <b>Software flow control bits</b>                 | 00xx:                                    | No         | TX   | flow    | control |
|        |              | 01xx:                                             | No                                       | TX         | flow | control | control |
|        |              | 10xx:                                             | Transmit                                 | XON1/XOFF1 | as   | flow    | control |
|        |              | xx00:                                             | No                                       | RX         | flow | control | bytes   |
|        |              | xx01:                                             | No                                       | RX         | flow | control | control |
|        |              | xx10:                                             | Receive XON1/XOFF1 as flow control bytes |            |      |         | control |

## A009000C LCR

## Line Control Register

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6  | 5  | 4   | 3   | 2   | 1    | 0    |
|-------|----|----|----|----|----|----|---|---|------|----|----|-----|-----|-----|------|------|
| Name  |    |    |    |    |    |    |   |   | DLAB | SB | SP | EPS | PEN | STB | WLS1 | WLS0 |
| Type  |    |    |    |    |    |    |   |   | RW   | RW | RW | RW  | RW  | RW  |      | RW   |
| Reset |    |    |    |    |    |    |   |   | 0    | 0  | 0  | 0   | 0   | 0   | 0    | 0    |

| Bit(s) | Name | Description                                                                                                                                                                                                         |    |  |  |  |         |
|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|--|--|---------|
| 7      | DLAB | <b>Divisor latch access bit</b>                                                                                                                                                                                     | 0: |  |  |  |         |
|        |      | 0: RX and TX registers are read/written at Address 0 and the IER register is read/written at Address 4.                                                                                                             |    |  |  |  |         |
|        |      | 1: Divisor Latch LS is read/written at Address 0 and the Divisor Latch MS is read/written at Address 4.                                                                                                             |    |  |  |  |         |
| 6      | SB   | <b>Set break</b>                                                                                                                                                                                                    | 0: |  |  |  | effect  |
|        |      | 0: No                                                                                                                                                                                                               |    |  |  |  |         |
|        |      | 1: SOUT signal is forced to the 0 state.                                                                                                                                                                            |    |  |  |  |         |
| 5      | SP   | <b>Stick parity</b>                                                                                                                                                                                                 | 0: |  |  |  | effect. |
|        |      | 0: No                                                                                                                                                                                                               |    |  |  |  |         |
|        |      | 1: The parity bit is forced to a defined state, depending on the states of EPS and PEN: If EPS=1 & PEN=1, the parity bit will be set and checked = 0. If EPS=0 & PEN=1, the parity bit will be set and checked = 1. |    |  |  |  |         |
| 4      | EPS  | <b>Selects even parity</b>                                                                                                                                                                                          | 0: |  |  |  |         |
|        |      | 0: When EPS=0, an odd number of ones is sent and checked.                                                                                                                                                           |    |  |  |  |         |
|        |      | 1: When EPS=1, an even number of ones is sent and checked.                                                                                                                                                          |    |  |  |  |         |

| Bit(s) | Name      | Description                                                                                                                                                                           |
|--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3      | PEN       | <b>Enables parity</b><br>0: The parity is neither transmitted nor checked.<br>1: The parity is transmitted and checked.                                                               |
| 2      | STB       | <b>Number of STOP bits</b><br>0: One STOP bit is always added.<br>1: Two STOP bits are added after each character is sent; unless the character length is 5 when 1 STOP bit is added. |
| 1:0    | WLS1_WLS0 | <b>Selects word length</b><br>0: 5 bits<br>1: 6 bits<br>2: 7 bits<br>3: 8 bits                                                                                                        |

**A0090010 MCR Modem Control Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7            | 6 | 5 | 4    | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|--------------|---|---|------|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   | XOFF-STAT-US |   |   | Loop |   |   | RTS |   |
| Type  |    |    |    |    |    |    |   |   | RU           |   |   | RW   |   |   | RW  |   |
| Reset |    |    |    |    |    |    |   |   | 0            |   |   | 0    |   |   | 0   |   |

| Bit(s) | Name        | Description                                                                                                                                                       |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | XOFF_STATUS | <b>Read-only bit</b><br>0: When an XON character is received.<br>1: When an XOFF character is received.                                                           |
| 4      | Loop        | <b>Loop-back control bit</b><br>0: No loop-back is enabled.<br>1: Loop-back mode is enabled.                                                                      |
| 1      | RTS         | <b>Controls the state of the output NRTS, even in loop mode.</b><br>0: RTS will always output 1.<br>1: RTS's output will be controlled by flow control condition. |

**A0090010 XON1 XON1 Char Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | XON1 |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0    | 0 | 0 | 0 | 0 |

| Bit(s) | Name | Description                                                                     |
|--------|------|---------------------------------------------------------------------------------|
| 7:0    | XON1 | <b>XON1 character for software flow control</b><br>Modified only when LCR=BF'h. |

**A0090014 LSR Line Status Register 60**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6    | 5    | 4  | 3  | 2  | 1  | 0  |
|------|----|----|----|----|----|----|---|---|----------|------|------|----|----|----|----|----|
| Name |    |    |    |    |    |    |   |   | FIFOE-RR | TEMT | THRE | BI | FE | PE | OE | DR |

| Type  |  |  |  |  |  | RU |
|-------|--|--|--|--|--|----|----|----|----|----|----|----|----|
| Reset |  |  |  |  |  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | FIFOERR | <b>RX FIFO error indicator</b><br>0: No PE, FE, BI set in the RX FIFO.<br>1: Set to 1 when there is at least one PE, FE or BI in the RX FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6      | TEMPT   | <b>TX holding register (or TX FIFO) and the TX shift register are empty.</b><br>0: Empty conditions below are not met.<br>1: If FIFOs are enabled, the bit will be set whenever the TX FIFO and the TX shift register are empty. If FIFOs are disabled, the bit will be set whenever TX holding register and TX shift register are empty.                                                                                                                                                                                                                                                                |
| 5      | THRE    | <b>Indicates if there is room for TX holding register or TX FIFO is reduced to its trigger level</b><br>0: Reset whenever the contents of the TX FIFO are more than its trigger level (FIFOs are enabled), or whenever TX holding register is not empty (FIFOs are disabled).<br>1: Set whenever the contents of the TX FIFO are reduced to its trigger level (FIFOs are enabled), or whenever TX holding register is empty and ready to accept new data (FIFOs are disabled).                                                                                                                           |
| 4      | BI      | <b>Break interrupt</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit will be set whenever the SIN is held in the 0 state for more than one transmission time (START bit + DATA bits + PARITY + STOP bits). If the FIFOs are enabled, this error will be associated with a corresponding character in the FIFO and is flagged when this byte is at the top of the FIFO. When a break occurs, only one zero character is loaded into the FIFO: The next character transfer is enabled when SIN goes into the marking state and receives the next valid start bit. |
| 3      | FE      | <b>Framing error</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit will be set if the received data do not have a valid STOP bit. If the FIFOs are enabled, the state of this bit will be revealed when the byte it refers to is the next to be read.                                                                                                                                                                                                                                                                                                           |
| 2      | PE      | <b>Parity error</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit will be set if the received data do not have a valid parity bit. If the FIFOs are enabled, the state of this bit will be revealed when the referred byte is the next to be read.                                                                                                                                                                                                                                                                                                              |
| 1      | OE      | <b>Overrun error</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit will be set if the RX buffer is not read by the CPU before the new data from the RX shift register overwrites the previous contents. If the FIFOs are enabled, an overrun error will occur when the RX FIFO is full and the RX shift register becomes full. OE will be set as soon as this happens. The character in the shift register is then overwritten, but not transferred to the FIFO.                                                                                                |
| 0      | DR      | <b>Data ready</b><br>0: Cleared by the CPU reading the RX buffer or by reading all the FIFO bytes.<br>1: Set by the RX buffer becoming full or by the FIFO becoming no empty.                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | XOFF1 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW    |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0     |

| Bit(s) | Name  | Description                                                                     |
|--------|-------|---------------------------------------------------------------------------------|
| 7:0    | XOFF1 | <b>XOFF1 character for software flow control</b><br>Modified only when LCR=BFh. |

| A009001C <u>SCR</u> Scratch Register 00 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |
|-----------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Bit                                     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
| Name                                    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SCR |
| Type                                    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW  |
| Reset                                   |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0   |

| Bit(s) | Name | Description                                                                                                       |
|--------|------|-------------------------------------------------------------------------------------------------------------------|
| 7:0    | SCR  | <b>General purpose read/write register</b><br>After reset, its value will be undefined. Modified when LCR != BFh. |

| A0090020 <u>AUTOBAUD_EN</u> Auto Baud Detect Enable Register 00 |    |    |    |    |    |    |   |   |   |   |   |   |   |       |      |      |
|-----------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------|------|------|
| Bit                                                             | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2     | 1    | 0    |
| Name                                                            |    |    |    |    |    |    |   |   |   |   |   |   |   | SLEE  | AUTO | AUTO |
| Type                                                            |    |    |    |    |    |    |   |   |   |   |   |   |   | P_AC  | BAUD | BAUD |
| Reset                                                           |    |    |    |    |    |    |   |   |   |   |   |   |   | K_SEL | SEL  | EN   |
|                                                                 |    |    |    |    |    |    |   |   |   |   |   |   |   | RW    | RW   | RW   |
|                                                                 |    |    |    |    |    |    |   |   |   |   |   |   |   | 0     | 0    | 0    |

| Bit(s) | Name          | Description                                                                                                                                                                                                                                                                                                                                                                   |
|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | SLEEP_ACK_SEL | <b>Selects sleep ack when autobaud_en</b><br>0: Support sleep_ack when autobaud_en is opened .<br>1: Does not support sleep_ack when autobaud_en is opened .                                                                                                                                                                                                                  |
| 1      | AUTOBAUD_SEL  | <b>Selects auto-baud</b><br>0: Support standard baud rate detection<br>1: Support non-standard baud rate detection (support baud from 110 to 115200; recommended to use 52MHz to auto fix) .                                                                                                                                                                                  |
| 0      | AUTOBAUD_EN   | <b>Auto-baud enabling signal</b><br>0: Disable auto-baud function<br>1: Enable auto-baud function (UARTn+0024h SPEED should be set to 0.)<br>Note: When AUTOBAUD_EN is active, there should not be A*/a* char before the auto baud char AT/at. If A*/a* is inevitable, autobaud will fail and please disable AUTOBAUD_EN to reset the autobaud feature and autobaud_en again. |

| A0090024 <u>HIGHSPEED</u> High Speed Mode Register 00 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |       |   |
|-------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|---|
| Bit                                                   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |   |
| Name                                                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SPEED |   |
| Type                                                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW    |   |
| Reset                                                 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0     | 0 |

| Bit(s) | Name  | Description                                                                                                                                                                                                                                                                                                                                    |
|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |       | <b>UART sample counter base</b>                                                                                                                                                                                                                                                                                                                |
| 1:0    | SPEED | 0: Based on 16*baud_pulse, baud_rate = system clock frequency/16/{DLH, DLL}<br>1: Based on 8*baud_pulse, baud_rate = system clock frequency/8/{DLH, DLL}<br>2: Based on 4*baud_pulse, baud_rate = system clock frequency/4/{DLH, DLL}<br>3: Based on sampe_count * baud_pulse, baud_rate = system clock frequency / (sampe_count+1)/{DLM, DLL} |

**A0090028 SAMPLE\_COUNT** Sample Counter Register **00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                  |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>SAMPLECOUNT</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                 |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                  |

| Bit(s) | Name        | Description                          |
|--------|-------------|--------------------------------------|
| 7:0    | SAMPLECOUNT | Only useful when HIGHSPEED mode = 3. |

**A009002C SAMPLE\_POINT** Sample Point Register **FF**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                  |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>SAMPLEPOINT</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                 |
| Reset |    |    |    |    |    |    |   |   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1                  |

| Bit(s) | Name        | Description                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------|
| 7:0    | SAMPLEPOINT | SAMPLE_POINT is usually (SAMPLE_COUNT-1)/2 without decimal. Effective only when HIGHSPEED=3. |

**A0090030 AUTOBAUD\_REG** Auto Baud Monitor Register **00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>BAUD_STAT</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RU               |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                |

| Bit(s) | Name      | Description                                                     |
|--------|-----------|-----------------------------------------------------------------|
| 7:4    | BAUD_STAT | Autobaud state (only true value in standard autobaud detection) |
| 0:     | Autobaud  | is detecting.                                                   |
| 1:     |           | AT_7N1                                                          |
| 2:     |           | AT_7O1                                                          |
| 3:     |           | AT_7E1                                                          |
| 4:     |           | AT_8N1                                                          |
| 5:     |           | AT_8O1                                                          |
| 6:     |           | AT_8E1                                                          |
| 7:     |           | at_7N1                                                          |

| Bit(s) | Name                     | Description                                                         |
|--------|--------------------------|---------------------------------------------------------------------|
| 8:     |                          | at_7E1                                                              |
| 9:     |                          | at_7O1                                                              |
| 10:    |                          | at_8N1                                                              |
| 11:    |                          | at_8E1                                                              |
| 12:    |                          | at_8O1                                                              |
| 13:    | Autobaud detection fails |                                                                     |
| 3:0    | BAUD_RATE                | Autobaud baud rate (only true value in standard autobaud detection) |
| 0:     |                          | 115,200                                                             |
| 1:     |                          | 57,600                                                              |
| 2:     |                          | 38,400                                                              |
| 3:     |                          | 19,200                                                              |
| 4:     |                          | 9,600                                                               |
| 5:     |                          | 4,800                                                               |
| 6:     |                          | 2,400                                                               |
| 7:     |                          | 1,200                                                               |
| 8:     |                          | 300                                                                 |
| 9:     | 110                      |                                                                     |

**A0090034 RATEFIX\_AD Clock Rate Fix Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2        | 1                | 0        |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|----------|------------------|----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | FREQ_SEL | AUTOBAUDRATE_FIX | RATE_FIX |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | RW       | RW               | RW       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0        | 0                | 0        |

| Bit(s) | Name             | Description                                                                                                                                          |
|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | FREQ_SEL         | 0: Select 26MHz as system clock<br>1: Select 13MHz as system clock                                                                                   |
| 1      | AUTOBAUD_RATE_FI | 0: Use 52MHz as system clock for UART auto baud detection<br>X: Use 26MHz/13MHz (depending on FREQ_SEL) as system clock for UART auto baud detection |
| 0      | RATE_FIX         | 0: Use 52MHz as system clock for UART TX/RX<br>1: Use 26MHz/13MHz (depending on FREQ_SEL) as system clock for UART TX/RX                             |

**A0090038 AUTOBAUDSAMPLE Auto Baud Sample Register 0D**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1              | 0 |   |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----------------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | AUTOBAUDSAMPLE |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW             |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0 | 0              | 1 | 1 | 0 | 1 |

| Bit(s)                                   | Name           | Description                       |
|------------------------------------------|----------------|-----------------------------------|
| clk division for autobaud rate detection |                |                                   |
| 5:0                                      | AUTOBAUDSAMPLE | For standard baud rate detection. |
|                                          | System         | clk 52m: 'd 27                    |
|                                          | System         | clk 26m: 'd 13                    |
|                                          | System         | clk 13m: 'd 6                     |

| Bit(s) | Name | Description                                   |
|--------|------|-----------------------------------------------|
|        |      | For non-standard baud rate detection.<br>:15. |

**A009003C GUARD Guard Time Added Register** OF

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4        | 3 | 2         | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|----------|---|-----------|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | GUARD_EN |   | GUARD_CNT |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW       |   | RW        |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0        | 1 | 1         | 1 | 1 |

| Bit(s) | Name      | Description                                                                                               |
|--------|-----------|-----------------------------------------------------------------------------------------------------------|
| 4      | GUARD_EN  | Guard interval add enabling signal<br>0: No guard interval added<br>1: Add guard interval after stop bit. |
| 3:0    | GUARD_CNT | Guard interval count value<br>Guard interval = [1/(system clock/div_step/div)]*GUARD_CNT.                 |

**A0090040 ESCAPE\_DAT Escape Character Register** FF

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4          | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|------------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | ESCAPE_DAT |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW         |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 1          | 1 | 1 | 1 | 1 |

| Bit(s) | Name       | Description                                                                                                                                                             |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | ESCAPE_DAT | Escape character added before software flow control data and escape character<br>If TX data are xon (31h), with esc_en =1, UART will transmit data as esc + CEh (~xon). |

**A0090044 ESCAPE\_EN Escape Enable Register** 00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | ESC_EN |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW     |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0      |   |

| Bit(s) | Name   | Description                                                                                                                                                                                                           |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | ESC_EN | Adds escape character in transmitter and removes escape character in receiver by UART<br>0: Does not deal with the escape character<br>1: Add escape character in transmitter and remove escape character in receiver |

**A0090048 SLEEP\_EN Sleep Enable Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SLEEP_EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0        |

| Bit(s)                      | Name     | Description                                                                                                                                                                                                                                                                                                                            |
|-----------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>For sleep mode issue</b> |          |                                                                                                                                                                                                                                                                                                                                        |
| 0                           | SLEEP_EN | 0: Does not deal with sleep mode indicate signal<br>1: Activate hardware flow control or software control according to software initial setting when the chip enters sleep mode. Release hardware flow when the chip wakes up. However, for software control, UART sends xon when awaken and when FIFO does not reach threshold level. |

**A009004C DMA\_EN DMA Enable Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FIFO_sr_sel |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0           |

| Bit(s)                                      | Name           | Description                                                                                                                                                                           |
|---------------------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Selects FIFO LSR mode</b>                |                |                                                                                                                                                                                       |
| 3                                           | FIFO_lsr_sel   | 0: LSR will hold the first line status error state until you read the LSR register.<br>1: LSR will update automatically.                                                              |
| <b>Time-out counter auto reset register</b> |                |                                                                                                                                                                                       |
| 2                                           | TO_CNT_AUTORST | 0: After RX time-out happens, SW shall reset the interrupt by reading UART 0x4C.<br>1: The time-out counter will be auto reset. Set this register when Rain's new DMA is used.        |
| <b>TX_DMA mechanism enabling signal</b>     |                |                                                                                                                                                                                       |
| 1                                           | TX_DMA_EN      | 0: Does not use DMA in TX.<br>1: Use DMA in TX. When this register is enabled, the flow control will be based on the DMA threshold and generate a time-out interrupt for DMA_for DMA. |
| <b>RX_DMA mechanism enabling signal</b>     |                |                                                                                                                                                                                       |
| 0                                           | RX_DMA_EN      | 0: Does not use DMA in RX.<br>1: Use DMA in RX. When this register is enabled, the flow control will be based on the DMA threshold and generate a time-out interrupt                  |

**A0090050 RXTRIG\_AD Rx Trigger Address 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RXTRIG |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW     |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0      |

| Bit(s)                       | Name | Description |
|------------------------------|------|-------------|
| <b>MediaTek Confidential</b> |      |             |

| Bit(s) | Name   | Description                                                                                                                                    |
|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    | RXTRIG | When {rtm,rtl}=2'b11, the RX FIFO threshold will be Rxtrig. The value is suggested to be smaller than half of RX FIFO size, which is 32 bytes. |

| A0090054 <u>FRACDIV_L</u> Fractional Divider LSB Address 00 |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------------------------------------------|------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit                                                         | 15               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                                        | <u>FRACDIV_L</u> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type                                                        | RW               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset                                                       | 0                | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |

| Bit(s) | Name       | Description                                                                                                 |
|--------|------------|-------------------------------------------------------------------------------------------------------------|
| 7:0    | FRA CDIV_L | Adds sampling count (+1) from state data7 to data0 to contribute fractional divisor.only when high_speed=3. |

| A0090058 <u>FRACDIV_M</u> Fractional Divider MSB Address 00 |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------------------------------------------|------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit                                                         | 15               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                                        | <u>FRACDIV_M</u> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type                                                        | RW               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset                                                       | 0                | 0  |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Name       | Description                                                                                               |
|--------|------------|-----------------------------------------------------------------------------------------------------------|
| 1:0    | FRA CDIV_M | Adds sampling count when in state stop to parity to contribute fractional divisor.only when high_speed=3. |

| A009005C <u>FCR_RD</u> FIFO Control Register 00 |                                                                            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------------------------------|----------------------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit                                             | 15                                                                         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                            | <u>RFTL1_RFTL0</u> <u>TFTL1_TFTL0</u> <u>CLRT</u> <u>CLRR</u> <u>FIFOE</u> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type                                            | RO RO RO                                                                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset                                           | 0                                                                          | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |

| Bit(s) | Name        | Description                                                                                                |
|--------|-------------|------------------------------------------------------------------------------------------------------------|
| 7:6    | RFTL1_RFTL0 | <b>RX FIFO trigger threshold</b><br>RX FIFO contains total 32 bytes.<br>0: 1<br>1: 6<br>2: 12<br>3: RXTRIG |
| 5:4    | TFTL1_TFTL0 | <b>TX FIFO trigger threshold</b><br>TX FIFO contains total 32 bytes.<br>0: 1<br>1: 4<br>2: 8<br>3: 14      |
| 2      | CLRT        | 0: TX FIFO is cleared.<br>1: TX FIFO is cleared.                                                           |

| Bit(s) | Name  | Description                                                                          |                              |       |     |     |          |
|--------|-------|--------------------------------------------------------------------------------------|------------------------------|-------|-----|-----|----------|
| 1      | CLRR  | 0:                                                                                   | RX                           | FIFO  | is  | not | cleared. |
| 0      | FIFOE | 1:                                                                                   | RX FIFO is cleared.          |       |     |     |          |
|        |       | <b>Enables FIFO</b>                                                                  |                              |       |     |     |          |
|        |       | This bit must be set to 1 for any of other bits in the registers to have any effect. |                              |       |     |     |          |
|        |       | 0:                                                                                   | RX and TX                    | FIFOs | are | not | enabled. |
|        |       | 1:                                                                                   | RX and TX FIFOs are enabled. |       |     |     |          |

## 3.9 UART3

### 3.9.1 General Description

The baseband chipset houses two UARTs. The UARTs provide full duplex serial communication channels between baseband chipset and external devices.

The UART has M16C450 and M16550A modes of operation, which are compatible with a range of standard software drivers. The extensions have been designed to be broadly software compatible with 16550A variants, but certain areas offer no consensus.

In common with the M16550A, the UART supports word lengths **from 5 to 8 bits, an optional parity bit** and one or two stop bits, and is fully programmable by an 8-bit CPU interface. A 16-bit programmable baud rate generator and an 8-bit scratch register are included, together with separate transmit and receive FIFOs. Eight modem control lines and a diagnostic loop-back mode are provided. The UART also includes two DMA handshake lines, used to indicate when the FIFOs are ready to transfer data to the CPU. Interrupts can be generated from any of the 10 sources.

**Note:** The UART has been designed so that all internal operations are synchronized by the CLK signal. This synchronization results in minor timing differences between the UART and the industry standard 16550A device, which means that the core is not clock for clock identical to the original device.

After a hardware reset, the UART is in M16C450 mode. Its FIFOs can be enabled and the UART can then enter M16550A mode. The UART adds further functionality beyond M16550A mode. Each of the extended functions can be selected individually under software control.

The UART provides more powerful enhancements than the industry-standard 16550:

**Note:** In order to enable any of the enhancements, the Enhanced Mode bit, EFR[4], must be set. If EFR[4] is not set, IER[7:5], FCR[5:4], IIR[5:4] and MCR[7:6] cannot be written. The Enhanced Mode bit ensures that the UART is backward compatible with software that has been written for 16C450 and 16550A devices.

Figure 35 shows the block diagram of the UART3 device.



Figure 37. Block Diagram of UART3

### 3.9.2 Register Definitions

**Module name: UART3 Base address: (+A00A0000h)**

| Address  | Name       | Width | Register Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------|------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A00A0000 | <u>RBR</u> | 8     | <b>RX Buffer Register</b><br>*NOTE:only when LCR[7] = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| A00A0000 | <u>THR</u> | 8     | <b>TX Holding Register</b><br>*NOTE:only when LCR[7] = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| A00A0000 | <u>DLL</u> | 8     | <b>Divisor Latch (LS)</b><br>used to divid the bdk frequency .*NOTE: modified when LCR[7]!=0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| A00A0004 | <u>IER</u> | 8     | <b>Interrupt Enable Register</b><br>*NOTE:only when LCR[7] = 0.<br>By storing a '1' to a specific bit position, the interrupt associated with that bit is enabled. Otherwise, the interrupt is disabled.<br>IER[3:0] are modified when LCR[7] = 0.<br>IER[7:4] are modified when LCR[7] = 0 & EFR[4] = 1.                                                                                                                                                                                                                                                                                |
| A00A0004 | <u>DLM</u> | 8     | <b>Divisor Latch (MS)</b><br>used to divid the bdk frequency .*NOTE: modified when LCR[7]!=0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| A00A0008 | <u>IIR</u> | 8     | <b>Interrupt Identification Register</b><br>*NOTE:only when LCR!=BFh. priority is from high to low as following .IIR[5:0]==0X1: no interrupt pending .IIR[5:0]==0X6:line status interrup(Under IER[2]=1). IIR[5:0]==0Xc:rx data timeout interrup(Under IER[0]=1). IIR[5:0]==0X4:RX Data is placed in the RX Buffer Register or the RX Trigger Level is reached.(Under IER[0]=1) .IIR[5:0]==0X2: TX Holding Register is empty or the contents of the TX FIFO have been reduced to its Trigger Level(Under IER[1]=1). IIR[5:0]==0X10: XOFF character reieveed (Under IER[5]=1,EFR[4] = 1). |
| A00A0008 | <u>FCR</u> | 8     | <b>FIFO Control Register</b><br>FCR is used to control the trigger levels of the FIFOs, or flush the FIFOs. FCR[7:6] is modified when LCR != BFh FCR[5:4] is modified when LCR != BFh & EFR[4] = 1 FCR[4:0] is modified when LCR != BFh                                                                                                                                                                                                                                                                                                                                                  |
| A00A0008 | <u>EFR</u> | 8     | <b>Enhanced Feature Register</b><br>*NOTE: Only when LCR=BFh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| A00A000C | <u>LCR</u> | 8     | <b>Line Control Register</b><br>Line Control Register. Determines characteristics of serial communication signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|          |                       |   |                                                                                                                                                                                                                                                                                                                                      |
|----------|-----------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A00A0010 | <u>MCR</u>            | 8 | <b>Modem Control Register</b><br>Modem Control Register. Control interface signals of the UART. MCR[5:0] are modified when LCR != 8'hBF, MCR[7] can be read when LCR != 8'hBF & EFR[4] = 1.                                                                                                                                          |
| A00A0010 | <u>XON1</u>           | 8 | <b>XON1 Char Register</b><br>*Note: XON1modified only when LCR=BF'h.                                                                                                                                                                                                                                                                 |
| A00A0014 | <u>LSR</u>            | 8 | <b>Line Status Register</b><br>Line Status Register. Modified when LCR != BFh.                                                                                                                                                                                                                                                       |
| A00A0018 | <u>XOFF1</u>          | 8 | <b>XOFF1 Char Register</b><br>*Note: , XOFF1 modified only when LCR=BFh.                                                                                                                                                                                                                                                             |
| A00A001C | <u>SCR</u>            | 8 | <b>Scratch Register</b><br>A general purpose read/write register. After reset, its value is un-defined. Modified when LCR != BFh.                                                                                                                                                                                                    |
| A00A0020 | <u>AUTOBAUD_EN</u>    | 8 | <b>Auto Baud Detect Enable Register</b>                                                                                                                                                                                                                                                                                              |
| A00A0024 | <u>HIGHSPEED</u>      | 8 | <b>High Speed Mode Register</b>                                                                                                                                                                                                                                                                                                      |
| A00A0028 | <u>SAMPLE_COUNT</u>   | 8 | <b>Sample Counter Register</b><br>When HIGHSPEED=3, the sample_count is the threshold value for UART sample counter (sample_num). Count from 0 to sample_count.                                                                                                                                                                      |
| A00A002C | <u>SAMPLE_POINT</u>   | 8 | <b>Sample Point Register</b><br>When HIGHSPEED=3, UART gets the input data when sample_count=sample_num.<br>e.g. system clock = 13MHz, 921600 = 13000000 / 14 sample_count = 13 and sample point = 6 (sample the central point to decrease the inaccuracy)<br>The SAMPLE_POINT is usually (SAMPLE_COUNT-1)/2 and remove the decimal. |
| A00A0030 | <u>AUTOBAUD_REG</u>   | 8 | <b>Auto Baud Monitor Register</b><br>the autobaud detection state ,it will not change until enable the autobaud_en again.                                                                                                                                                                                                            |
| A00A0034 | <u>RATEFIX_AD</u>     | 8 | <b>Clock Rate Fix Register</b>                                                                                                                                                                                                                                                                                                       |
| A00A0038 | <u>AUTOBAUDSAMPLE</u> | 8 | <b>Auto Baud Sample Register</b><br>Since the system dock may change, autobaud sample duration should change as system dock changes.<br>When system clock = 13MHz, autobaudsample = 6; when system clock = 26MHz, autobaudsample = 13;When system dock = 52MHz, autobaudsample = 27.                                                 |
| A00A003C | <u>GUARD</u>          | 8 | <b>Guard time added register</b>                                                                                                                                                                                                                                                                                                     |
| A00A0040 | <u>ESCAPE_DAT</u>     | 8 | <b>Escape character register</b>                                                                                                                                                                                                                                                                                                     |
| A00A0044 | <u>ESCAPE_EN</u>      | 8 | <b>Escape enable register</b>                                                                                                                                                                                                                                                                                                        |
| A00A0048 | <u>SLEEP_EN</u>       | 8 | <b>Sleep enable register</b>                                                                                                                                                                                                                                                                                                         |
| A00A004C | <u>DMA_EN</u>         | 8 | <b>DMA enable register</b>                                                                                                                                                                                                                                                                                                           |
| A00A0050 | <u>RXTRI_AD</u>       | 8 | <b>Rx Trigger Address</b>                                                                                                                                                                                                                                                                                                            |
| A00A0054 | <u>FRACTDIV_L</u>     | 8 | <b>Fractional Divider LSB Address</b>                                                                                                                                                                                                                                                                                                |
| A00A0058 | <u>FRACTDIV_M</u>     | 8 | <b>Fractional Divider MSB Address</b>                                                                                                                                                                                                                                                                                                |
| A00A005C | <u>FCR_RD</u>         | 8 | <b>FIFO Control Register</b>                                                                                                                                                                                                                                                                                                         |

**A00A0000 RBR RX Buffer Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>RBR</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>RU</b>  |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0          |

| Bit(s) | Name | Description                                                                                            |
|--------|------|--------------------------------------------------------------------------------------------------------|
| 7:0    | RBR  | Read-only register. The received data can be read by accessing this register.<br>Only when LCR[7] = 0. |

| <b>A00A0000 THR TX Holding Register 00</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |
|--------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Bit                                        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
| Name                                       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | THR |
| Type                                       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | WO  |
| Reset                                      |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0   |

| Bit(s) | Name | Description                                                                                                                                                                  |
|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | THR  | TX Holding Register. Write-only register. The data to be transmitted is written to this register, and then sent to the PC via serial communication.<br>only when LCR[7] = 0. |

| <b>A00A0000 DLL Divisor Latch (LS) 01</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |
|-------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Bit                                       | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
| Name                                      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DLL |
| Type                                      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW  |
| Reset                                     |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1   |

| Bit(s) | Name | Description                                                    |
|--------|------|----------------------------------------------------------------|
| 7:0    | DLL  | divisor Latch low 8bit data.<br>*NOTE: modified when LCR[7]!=0 |

| <b>A00A0004 IER Interrupt Enable Register 00</b> |    |    |    |    |    |    |   |   |   |   |       |   |   |      |       |       |
|--------------------------------------------------|----|----|----|----|----|----|---|---|---|---|-------|---|---|------|-------|-------|
| Bit                                              | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4 | 3 | 2    | 1     | 0     |
| Name                                             |    |    |    |    |    |    |   |   |   |   | XOFFI |   |   | ELSI | ETBEI | ERBFI |
| Type                                             |    |    |    |    |    |    |   |   |   |   | RW    |   |   | RW   | RW    | RW    |
| Reset                                            |    |    |    |    |    |    |   |   |   | 0 |       |   |   | 0    | 0     | 0     |

| Bit(s) | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | XOFFI | Masks an interrupt that is generated when an XOFF character is received.<br>Note: This interrupt is only enabled when software flow control is enabled.<br>0: Mask an interrupt that is generated when an XOFF character is received.<br>1: Unmask an interrupt that is generated when an XOFF character is received.                                                                                                                     |
| 2      | ELSI  | When set ("1"), an interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.<br>0: No interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.<br>1: An interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.                                                                                                                                                                                             |
| 1      | ETBEI | When set ("1"), an interrupt is generated if the TX Holding Register is empty or the contents of the TX FIFO have been reduced to its Trigger Level.<br>0: No interrupt is generated if the TX Holding Register is empty or the contents of the TX FIFO have been reduced to its Trigger Level.<br>1: An interrupt is generated if the TX Holding Register is empty or the contents of the TX FIFO have been reduced to its Trigger Level |

0 ERBFI

**When set ("1"), an interrupt is generated if RX Data is placed in the RX Buffer Register or the RX Trigger Level is reached.**

0: No interrupt is generated if RX Data is placed in the RX Buffer Register or the RX Trigger Level is reached.

1: An interrupt is generated if RX Data is placed in the RX Buffer Register or the RX Trigger Level is reached.

**A00A0004 DLM****Divisor Latch (MS)****00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | DLM |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | RW  |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0   | 0 | 0 | 0 |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | DLM  | <p>divisor Latch high 8bit data..</p> <p>*NOTE: modified when LCR[7]!=0</p> <p>Note: DLL &amp; DLM can only be updated when DLAB(LCR[7]) is set to 1, Note to that division by 1 generates a BAUD signal that is constantly high.</p> <p>Note: DLL &amp; DLM setting formula is {DLH,DLL}=(system clock frequency/baud_pulse/baud_rate).</p> <p>When RATE_FIX(RATEFIX_AD[0])=0, system clock frequency = 52MHz.</p> <p>When RATE_FIX(RATEFIX_AD[0])=1 and RATE_FIX(RATEFIX_AD[2])=0, system clock frequency = 26MHz.</p> <p>When RATE_FIX(RATEFIX_AD[0])=1 and RATE_FIX(RATEFIX_AD[2])=1, system clock frequency = 13MHz.</p> <p>For baud_pulse value refer to HIGH_SPEED(offset=24H) register.<br/>e.g. When 52MHz,default speed mode and 115200 baud rate, the {DLH,DLL}=52MHz/16/115200=28.</p> |

**A00A0008 IIR****Interrupt Identification Register****01**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6 | 5 | 4  | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|-------|---|---|----|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   | FIFOE |   |   | ID |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   | RO    |   |   | RU |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0     | 0 | 0 | 0  | 0 | 0 | 0 | 1 |

| Bit(s)                                                      | Name                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
|-------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---|----------------------|--------|---|-------------------------------------------------------------------------|--------|---|------------------|---------|--------------------------|------------------|--------|---|-------------------|-----------------------------------------------|---|------------------|--------|---|----------------------------|--------|---|----------------------|------------------|---|------------------|-------------------------------------------------------------|---|------------------|--------|---|------------------------|--------------------------|---|------------------|--------|---|------------------------|-------------------------|---|------------------------------|
| 7:6                                                         | FIFOE                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| 5:0                                                         | ID                       | <p>IIR[5:0] Priority Level Interrupt Source</p> <table> <tbody> <tr><td>000001</td><td>-</td><td>No interrupt pending</td></tr> <tr><td>000110</td><td>1</td><td>Line Status Interrupt:<br/>BI, FE, PE or OE set in LSR. (Under IER[2]=1)</td></tr> <tr><td>001100</td><td>2</td><td>RX Data Timeout:</td></tr> <tr><td>TimeOut</td><td>on character in RX FIFO.</td><td>(Under IER[0]=1)</td></tr> <tr><td>000100</td><td>3</td><td>RX Data Received:</td></tr> <tr><td>RX Data received or RX Trigger Level reached.</td><td>4</td><td>(Under IER[0]=1)</td></tr> <tr><td>000010</td><td>4</td><td>TX Holding Register Empty:</td></tr> <tr><td>000000</td><td>5</td><td>Modem Status change:</td></tr> <tr><td>DCTS set in MSR.</td><td>6</td><td>(Under IER[3]=1)</td></tr> <tr><td>TX Holding Register empty or TX FIFO Trigger Level reached.</td><td>7</td><td>(Under IER[1]=1)</td></tr> <tr><td>010000</td><td>6</td><td>Software Flow Control:</td></tr> <tr><td>XOFF Character received.</td><td>7</td><td>(Under IER[5]=1)</td></tr> <tr><td>100000</td><td>7</td><td>Hardware Flow Control:</td></tr> <tr><td>CTS or RTS Rising Edge.</td><td>8</td><td>(Under IER[7]=1 or IER[6]=1)</td></tr> </tbody> </table> | 000001 | - | No interrupt pending | 000110 | 1 | Line Status Interrupt:<br>BI, FE, PE or OE set in LSR. (Under IER[2]=1) | 001100 | 2 | RX Data Timeout: | TimeOut | on character in RX FIFO. | (Under IER[0]=1) | 000100 | 3 | RX Data Received: | RX Data received or RX Trigger Level reached. | 4 | (Under IER[0]=1) | 000010 | 4 | TX Holding Register Empty: | 000000 | 5 | Modem Status change: | DCTS set in MSR. | 6 | (Under IER[3]=1) | TX Holding Register empty or TX FIFO Trigger Level reached. | 7 | (Under IER[1]=1) | 010000 | 6 | Software Flow Control: | XOFF Character received. | 7 | (Under IER[5]=1) | 100000 | 7 | Hardware Flow Control: | CTS or RTS Rising Edge. | 8 | (Under IER[7]=1 or IER[6]=1) |
| 000001                                                      | -                        | No interrupt pending                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| 000110                                                      | 1                        | Line Status Interrupt:<br>BI, FE, PE or OE set in LSR. (Under IER[2]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| 001100                                                      | 2                        | RX Data Timeout:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| TimeOut                                                     | on character in RX FIFO. | (Under IER[0]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| 000100                                                      | 3                        | RX Data Received:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| RX Data received or RX Trigger Level reached.               | 4                        | (Under IER[0]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| 000010                                                      | 4                        | TX Holding Register Empty:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| 000000                                                      | 5                        | Modem Status change:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| DCTS set in MSR.                                            | 6                        | (Under IER[3]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| TX Holding Register empty or TX FIFO Trigger Level reached. | 7                        | (Under IER[1]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| 010000                                                      | 6                        | Software Flow Control:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| XOFF Character received.                                    | 7                        | (Under IER[5]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| 100000                                                      | 7                        | Hardware Flow Control:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |
| CTS or RTS Rising Edge.                                     | 8                        | (Under IER[7]=1 or IER[6]=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |   |                      |        |   |                                                                         |        |   |                  |         |                          |                  |        |   |                   |                                               |   |                  |        |   |                            |        |   |                      |                  |   |                  |                                                             |   |                  |        |   |                        |                          |   |                  |        |   |                        |                         |   |                              |

Line Status Interrupt A RX Line Status Interrupt (IIR[5:0] == 000110b) is generated if ELSI (IER[2]) is set and any of BI, FE, PE or OE (LSR[4:1]) becomes set. The interrupt is cleared by reading the Line Status Register.

**RX Data Timeout Interrupt:** When virtual FIFO mode is disabled, RX Data Timeout Interrupt is generated if all of the following apply:

1. FIFO contains at least one character;
  2. The most recent character was received longer than four character periods ago (including all start, parity and stop bits);
  3. The most recent CPU read of the FIFO was longer than four character periods ago. The timeout timer is restarted on receipt of a new byte from the RX Shift Register, or on a CPU read from the RX FIFO.
- The RX Data Timeout Interrupt is enabled by setting EFRBI (IER[0]) to 1, and is cleared by reading RX FIFO. When virtual FIFO mode is enabled, RX Data Timeout Interrupt is generated if all of the following apply:

1. FIFO is empty;
  2. The most recent character was received longer than four character periods ago (including all start, parity and stop bits);
  3. The most recent CPU read of the FIFO was longer than four character periods ago. The timeout timer is restarted on receipt of a new byte from the RX Shift Register or reading DMA\_EN register.
- The RX Data Timeout Interrupt is enabled by setting EFRBI (IER[0]) to 1, and is cleared by reading DMA\_EN register.

**RX Data Received Interrupt:** A RX Received interrupt (IER[5:0] == 000100b) is generated if EFRBI (IER[0]) is set and either RX Data is placed in the RX Buffer Register or the RX Trigger Level is reached. The interrupt is cleared by reading the RX Buffer Register or the RX FIFO (if enabled).

**TX Holding Register Empty Interrupt:** A TX Holding Register Empty Interrupt (IIR[5:0] = 000010b) is generated if ETRBI (IER[1]) is set and either the TX Holding Register is empty or the contents of the TX FIFO have been reduced to its Trigger Level. The interrupt is cleared by writing to the TX Holding Register or TX FIFO if FIFO enabled.

**Modem Status Change Interrupt:** A Modem Status Change Interrupt (IIR[5:0] = 000000b) is generated if EDSSI (IER[3]) is set and e DCTS (MSR[3:0]) becomes set. The interrupt is cleared by reading the Modem Status Register.

**Software Flow Control Interrupt:** A Software Flow Control Interrupt (IIR[5:0] = 010000b) is generated if Software Flow Control is enabled and XOFFI (IER[5]) becomes set, indicating that an XOFF character has been received. The interrupt is cleared by reading the Interrupt Identification Register.

**Hardware Flow Control Interrupt:** A Hardware Flow Control Interrupt (IER[5:0] = 100000b) is generated if Hardware Flow Control is enabled and either RTSI (IER[6]) or CTSI (IER[7]) becomes set indicating that a rising edge has been detected on either the RTS/CTS Modem Control line. The interrupt is cleared by reading the Interrupt Identification Register.

| <b>A00A0008 FCR FIFO Control Register</b> |    |    |    |    |    |    |   |   |                    |                    |   |   |   |             | 00          |              |
|-------------------------------------------|----|----|----|----|----|----|---|---|--------------------|--------------------|---|---|---|-------------|-------------|--------------|
| <b>Bit</b>                                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                  | 6                  | 5 | 4 | 3 | 2           | 1           | 0            |
| <b>Name</b>                               |    |    |    |    |    |    |   |   | <b>RFTL1_RFTL0</b> | <b>TFTL1_TFTL0</b> |   |   |   | <b>CLRT</b> | <b>CLRR</b> | <b>FIFOE</b> |
| <b>Type</b>                               |    |    |    |    |    |    |   |   | WO                 | WO                 |   |   |   | WO          | WO          | WO           |
| <b>Reset</b>                              |    |    |    |    |    |    |   |   | 0                  | 0                  | 0 | 0 |   | 0           | 0           | 0            |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                            |    |
|---------------|-------------|---------------------------------------------------------------|----|
| 7:6           | RFTL1_RFTL0 | RX FIFO trigger threshold. (RX FIFO contains total 32 bytes.) |    |
| 0:            |             |                                                               | 1  |
| 1:            |             |                                                               | 6  |
| 2:            |             |                                                               | 12 |
| 3:            | RXTRIG      |                                                               |    |
| 5:4           | TFTL1_TFTL0 | TX FIFO trigger threshold (TX FIFO contains total 32 bytes.)  |    |
| 0:            |             |                                                               | 1  |
| 1:            |             |                                                               | 4  |
| 2:            |             |                                                               | 8  |
| 3:            | 14          |                                                               |    |

|   |       |                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
|---|-------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------|
| 2 | CLRT  | <b>control bit to clear tx fifo</b>                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
|   |       | 0:<br>1: dear TX FIFO                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | no effect |
| 1 | CLRR  | <b>control bit to clear rx fifo</b>                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | no effect |
|   |       | 0:<br>1: dear RX FIFO                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
| 0 | FIFOE | <b>FIFO Enabled. This bit must be set to 1 for any of the other bits in the registers to have any effect.</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
|   |       | 0: Disable both the RX and TX FIFOs.<br>1: Enable both the RX and TX FIFOs.                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |

**A00A0008 EFR Enhanced Feature Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4         | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|-----------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | ENAB LE_E |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW        |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0         | 0 | 0 | 0 | 0 |

| Bit(s) | Name         | Description                                                                                                                 |  |  |  |  |  |  |  |  |  |    |  |      |  |         |  |  |  |           |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|----|--|------|--|---------|--|--|--|-----------|
| 4      | ENABLE_E     | <b>Enables enhancement feature</b>                                                                                          |  |  |  |  |  |  |  |  |  |    |  |      |  |         |  |  |  | Disabled. |
|        |              | 0:<br>1: Enabled.                                                                                                           |  |  |  |  |  |  |  |  |  |    |  |      |  |         |  |  |  |           |
| 3:0    | SW_FLOW_CONT | <b>Software flow control bits.</b>                                                                                          |  |  |  |  |  |  |  |  |  |    |  |      |  |         |  |  |  |           |
|        |              | 00xx: No<br>01xx: No<br>10xx: Transmit XON1/XOFF1<br>xx00: No<br>xx01: No<br>xx10: Receive XON1/XOFF1 as flow control bytes |  |  |  |  |  |  |  |  |  | TX |  | Flow |  | Control |  |  |  |           |
|        |              |                                                                                                                             |  |  |  |  |  |  |  |  |  |    |  |      |  |         |  |  |  |           |
|        |              |                                                                                                                             |  |  |  |  |  |  |  |  |  |    |  |      |  |         |  |  |  |           |
|        |              |                                                                                                                             |  |  |  |  |  |  |  |  |  |    |  |      |  |         |  |  |  |           |

**A00A000C LCR Line Control Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3  | 2  | 1   | 0   |     |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|------|----|----|-----|-----|-----|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | DLAB | SB | SP | EPS | PEN | STB |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW   | RW | RW | RW  | RW  | RW  |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0    | 0  | 0  | 0   | 0   | 0   | 0 | 0 |

| Bit(s) | Name | Description                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |         |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|----|--|--|--|--|--|--|--|---------|
| 7      | DLAB | <b>Divisor Latch Access Bit.</b>                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |         |
|        |      | 0: The RX and TX Registers are read/written at Address 0 and the IER register is read/written at Address 4.                                                                                                          |  |  |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |         |
|        |      | 1: The Divisor Latch LS is read/written at Address 0 and the Divisor Latch MS is read/written at Address 4.                                                                                                          |  |  |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |         |
| 6      | SB   | <b>Set Break</b>                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  | No |  |  |  |  |  |  |  | effect  |
|        |      | 0:<br>1: SOUT signal is forced into the "0" state.                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |         |
| 5      | SP   | <b>Stick Parity</b>                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  | No |  |  |  |  |  |  |  | effect. |
|        |      | 0:<br>1: The Parity bit is forced into a defined state, depending on the states of EPS and PEN:<br>If EPS=1 & PEN=1, the Parity bit is set and checked = 0. If EPS=0 & PEN=1, the Parity bit is set and checked = 1. |  |  |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |         |
| 4      | EPS  | <b>Even Parity Select</b>                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |         |

0: When EPS=0, an odd number of ones is sent and checked.  
 1: When EPS=1, an even number of ones is sent and checked.

3 PEN

**Parity Enable**

0: The Parity is neither transmitted nor checked.  
 1: The Parity is transmitted and checked.

2 STB

**Number of STOP bits**

0: One STOP bit is always added.  
 1: Two STOP bits are added after each character is sent; unless the character length is 5 when 1 STOP bit is added.

1:0 WLS1\_WLS0

**Word Length Select.**

|           |   |      |
|-----------|---|------|
| 0:        | 5 | bits |
| 1:        | 6 | bits |
| 2:        | 7 | bits |
| 3: 8 bits |   |      |

**A00A0010 MCR****Modem Control Register**

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8           | 7 | 6 | 5  | 4    | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|-------------|---|---|----|------|---|---|---|---|
| Name  |    |    |    |    |    |    |   | XOFF_STATUS |   |   |    | Loop |   |   |   |   |
| Type  |    |    |    |    |    |    |   | RU          |   |   | RW |      |   |   |   |   |
| Reset |    |    |    |    |    |    |   | 0           |   |   | 0  |      |   |   |   |   |

| Bit(s) | Name        | Description                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------------------|
| 7      | XOFF_STATUS | This is a read-only bit.<br>0: When an XON character is received.<br>1: When an XOFF character is received. |
| 4      | Loop        | Loop-back control bit.<br>0: No loop-back is enabled.<br>1: Loop-back mode is enabled.                      |

**A00A0010 XON1****XON1 Char Register**

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4    | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|----|------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |    | XON1 |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | RW |      |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0  | 0    | 0 | 0 | 0 | 0 |

| Bit(s) | Name | Description                                                              |
|--------|------|--------------------------------------------------------------------------|
| 7:0    | XON1 | XON1 character for software flow control.<br>modified only when LCR=BFh. |

**A00A0014 LSR****Line Status Register**

60

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6     | 5    | 4  | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|---|---|----------|-------|------|----|----|----|----|----|
| Name  |    |    |    |    |    |    |   |   | FIFOE_RR | TEMFT | THRE | BI | FE | PE | OE | DR |
| Type  |    |    |    |    |    |    |   |   | RU       | RU    | RU   | RU | RU | RU | RU | RU |
| Reset |    |    |    |    |    |    |   |   | 0        | 1     | 1    | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name | Description |
|--------|------|-------------|
|        |      |             |

|   |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 | FIFOERR | <b>RX FIFO Error Indicator.</b><br>0: No PE, FE, BI set in the RX FIFO.<br>1: Set to 1 when there is at least one PE, FE or BI in the RX FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6 | TEMPT   | <b>TX Holding Register (or TX FIFO) and the TX Shift Register are empty.</b><br>0: Empty conditions below are not met.<br>1: If FIFOs are enabled, the bit is set whenever the TX FIFO and the TX Shift Register are empty. If FIFOs are disabled, the bit is set whenever TX Holding Register and TX Shift Register are empty.                                                                                                                                                                                                                                                                 |
| 5 | THRE    | <b>Indicates if there is room for TX Holding Register or TX FIFO is reduced to its Trigger Level.</b><br>0: Reset whenever the contents of the TX FIFO are more than its Trigger Level (FIFOs are enabled), or whenever TX Holding Register is not empty(FIFOs are disabled).<br>1: Set whenever the contents of the TX FIFO are reduced to its Trigger Level (FIFOs are enabled), or whenever TX Holding Register is empty and ready to accept new data (FIFOs are disabled).                                                                                                                  |
| 4 | BI      | <b>Break Interrupt.</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit is set whenever the SIN is held in the 0 state for more than one transmission time (START bit + DATA bits + PARITY + STOP bits). If the FIFOs are enabled, this error is associated with a corresponding character in the FIFO and is flagged when this byte is at the top of the FIFO. When a break occurs, only one zero character is loaded into the FIFO: the next character transfer is enabled when SIN goes into the marking state and receives the next valid start bit. |
| 3 | FE      | <b>Framing Error.</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit is set if the received data did not have a valid STOP bit. If the FIFOs are enabled, the state of this bit is revealed when the byte it refers to is the next to be read.                                                                                                                                                                                                                                                                                                          |
| 2 | PE      | <b>Parity Error</b><br>0: Reset by the CPU reading this register<br>1: If the FIFOs are disabled, this bit is set if the received data did not have a valid parity bit. If the FIFOs are enabled, the state of this bit is revealed when the referred byte is the next to be read.                                                                                                                                                                                                                                                                                                              |
| 1 | OE      | <b>Overrun Error.</b><br>0: Reset by the CPU reading this register.<br>1: If the FIFOs are disabled, this bit is set if the RX Buffer was not read by the CPU before new data from the RX Shift Register overwrote the previous contents. If the FIFOs are enabled, an overrun error occurs when the RX FIFO is full and the RX Shift Register becomes full. OE is set as soon as this happens. The character in the Shift Register is then overwritten, but not transferred to the FIFO.                                                                                                       |
| 0 | DR      | <b>Data Ready.</b><br>0: Cleared by the CPU reading the RX Buffer or by reading all the FIFO bytes.<br>1: Set by the RX Buffer becoming full or by the FIFO becoming no empty.                                                                                                                                                                                                                                                                                                                                                                                                                  |

| A00A0018 XOFF1 Char Register |                                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 00 |  |
|------------------------------|---------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----|--|
| Bit                          | 15                              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |  |
| Name                         | XOFF1                           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |    |  |
| Type                         | RW                              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |    |  |
| Reset                        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |    |  |

| Bit(s) | Name  | Description                                                               |
|--------|-------|---------------------------------------------------------------------------|
| 7:0    | XOFF1 | XOFF1 character for software flow control.<br>modified only when LCR=BFh. |

| A00A001C SCR Scratch Register |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 00 |  |
|-------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----|--|
| Bit                           | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |  |
|                               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |    |  |

|       |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|-------------------|--|
| Name  |  |  |  |  |  |  |  |  |  |  |  |  |  | SCR               |  |
| Type  |  |  |  |  |  |  |  |  |  |  |  |  |  | RW                |  |
| Reset |  |  |  |  |  |  |  |  |  |  |  |  |  | 0 0 0 0 0 0 0 0 0 |  |

| Bit(s) | Name | Description                                                                                               |
|--------|------|-----------------------------------------------------------------------------------------------------------|
| 7:0    | SCR  | A general purpose read/write register. After reset, its value is un-defined.<br>Modified when LCR != BFh. |

### A00A0020 AUTOBAUD\_EN Auto Baud Detect Enable Register 00

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |           |             |               |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|-----------|-------------|---------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2         | 1           | 0             |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | SLEEP_SEL | AUTO_AC_SEL | AUTO_BAUD_SEL |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | RW        | RW          | RW            |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0         | 0           | 0             |

| Bit(s) | Name          | Description                                                                                                                                                                                                                                                                                                                                                                      |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | SLEEP_ACK_SEL | <b>Sleep ack select when autobaud_en</b><br>0: support sleep_ack when autobaud_en is opened<br>1: not support sleep_ack when autobaud_en is opened.                                                                                                                                                                                                                              |
| 1      | AUTOBAUD_SEL  | <b>Auto-baud select</b><br>0: support standard baud rate detection<br>1: support non_standard baud rate detection(support baud from 110 to 115200, it is recommend to use 52MHz to auto fix).                                                                                                                                                                                    |
| 0      | AUTOBAUD_EN   | <b>Auto-baud enable signal</b><br>0: Auto-baud function disable<br>1: Auto-baud function enable (UARTn+0024h SPEED should be set 0)<br>Note: when AUTOBAUD_EN is active, there should not A*/a* char before the auto baud char AT/at, if the A*/a* is Inevitable, the autobaud will fail and please disable the AUTOBAUD_EN to reset the autobaud feature and autobaud_en again. |

### A00A0024 HIGHSPEED High Speed Mode Register 00

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |       |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | SPEED |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW    |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0 | 0     |   |

| Bit(s) | Name  | Description                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0    | SPEED | <b>UART sample counter base</b><br>0: based on 16*baud_pulse, baud_rate = system clock frequency/16/{DLH, DLL}<br>1: based on 8*baud_pulse, baud_rate = system clock frequency/8/{DLH, DLL}<br>2: based on 4*baud_pulse, baud_rate = system clock frequency/4/{DLH, DLL}<br>3: based on sampe_count * baud_pulse, baud_rate = system clock frequency / (sampe_count+1) / {DLM, DLL} |

### A00A0028 SAMPLE\_COUN Sample Counter Register T 00

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |             |    |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|----|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2           | 1  | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | SAMPLECOUNT |    |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |             | RW |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0           | 0  | 0 |

| Bit(s) | Name        | Description                             |
|--------|-------------|-----------------------------------------|
| 7:0    | SAMPLECOUNT | Just be useful when HIGHSPEED mode = 3. |

**A00A002C SAMPLE POINT Sample Point Register**

FF

| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | SAMPLEPOINT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |             |    |    |    |    |    |   |   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

| Bit(s) | Name        | Description                                                                                                              |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| 7:0    | SAMPLEPOINT | The SAMPLE_POINT is usually (SAMPLE_COUNT-1)/2 and remove the decimal. sample point , is effective only When HIGHSPEED=3 |

**A00A0030 AUTOBAUD RE Auto Baud Monitor Register G**

00

| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | BAUD_STAT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RU        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |           |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                         |
|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4    | BAUD_STAT | Autobaud state(only true value in standard autobaud detection)<br>0: Autobaud is detecting AT_7N1<br>1: AT_7O1<br>2: AT_7E1<br>3: AT_8N1<br>5: AT_8O1<br>6: AT_8E1<br>7: at_7N1<br>8: at_7E1<br>9: at_7O1<br>10: at_8N1<br>11: at_8E1<br>12: at_8O1<br>13: Autobaud detection fails |
| 3:0    | BAUD_RATE | Autobaud baud rate(only true value in standard autobaud detection)<br>0: 115200<br>1: 57600<br>2: 38400<br>3: 19200<br>4: 9600<br>5: 4800<br>6: 2400<br>7: 1200<br>8: 300<br>9: 110                                                                                                 |

**A00A0034 RATEFIX AD Clock Rate Fix Register**

00

| Bit  | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | FREQ AUTO RATE |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |    | _SEL | BAUD_RATE_FIX | _FIX |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----|------|---------------|------|
| Type  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RW | RW   | RW            |      |
| Reset |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0  | 0    | 0             |      |

| Bit(s) | Name              | Description                                                                                                                                 |
|--------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | FREQ_SEL          | 0: Select 26MHZ as system clock<br>1: Select 13MHZ as system dock                                                                           |
| 1      | AUTOBAUD_RATE_FIX | 0: Use 52MHZ as system clock for UART auto baud detect<br>1: Use 26MHZ/13MHZ(depends on FREQ_SEL) as system clock for UART auto baud detect |
| 0      | RATE_FIX          | 0: Use 52MHZ as system clock for UART TX/RX<br>1: Use 26MHZ/13MHZ(depends on FREQ_SEL) as system clock for UART TX/RX                       |

**A00A0038 AUTOBAUDSA Auto Baud Sample Register**

0D

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0              |   |   |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | AUTOBAUDSAMPLE |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW             |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0 | 0              | 1 | 1 | 0 | 1 |

| Bit(s) | Name           | Description                                                                                                                                                                             |
|--------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0    | AUTOBAUDSAMPLE | clk division for autobaud rate detection.<br>for standard baud rate detection.<br>system clk : 27<br>system clk : 13<br>system clk : 6<br>for non-standard baud rate detection.<br>:15. |
|        |                |                                                                                                                                                                                         |
|        |                |                                                                                                                                                                                         |
|        |                |                                                                                                                                                                                         |

**A00A003C GUARD Guard time added register**

0F

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |   |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | GUARD_EN |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW       |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0 | 1        | 1 | 1 | 1 |

| Bit(s) | Name      | Description                                                                                               |
|--------|-----------|-----------------------------------------------------------------------------------------------------------|
| 4      | GUARD_EN  | Guard interval add enable signal.<br>0: No guard interval added.<br>1: Add guard interval after stop bit. |
| 3:0    | GUARD_CNT | Guard interval count value. Guard interval = (1/(system clock / div_step / div )) * GUARD_CNT.            |

**A00A0040 ESCAPE\_DAT Escape character register**

FF

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |   |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | ESCAPE_DAT |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW         |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 1 | 1          | 1 | 1 | 1 |

| Bit(s) | Name       | Description                                                                                                                                                           |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | ESCAPE_DAT | Escape character added before software flow control data and escape character, i.e. if tx data is xon (31h), with esc_en =1, uart transmits data as esc + CEh (~xon). |

| A00A0044 <u>ESCAPE_EN</u> Escape enable register 00 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |        |
|-----------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| Bit                                                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
| Name                                                |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | ESC_EN |
| Type                                                |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW     |
| Reset                                               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0      |

| Bit(s) | Name   | Description                                                                                                                                                                                                          |
|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | ESC_EN | Add escape character in transmitter and remove escape character in receiver by UART.<br>0: Do not deal with the escape character.<br>1: Add escape character in transmitter and remove escape character in receiver. |

| A00A0048 <u>SLEEP_EN</u> Sleep enable register 00 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |          |
|---------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
| Bit                                               | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
| Name                                              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SLEEP_EN |
| Type                                              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW       |
| Reset                                             |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0        |

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                          |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | SLEEP_EN | For sleep mode issue<br>0: Do not deal with sleep mode indicate signal<br>1: To activate hardware flow control or software control according to software initial setting when chip enters sleep mode. Releasing hardware flow when chip wakes up; but for software control, uart sends xon when awaken and when FIFO does not reach threshold level. |

| A00A004C <u>DMA_EN</u> DMA enable register 00 |    |    |    |    |    |    |   |   |   |   |   |   |              |                |           |           |
|-----------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|--------------|----------------|-----------|-----------|
| Bit                                           | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3            | 2              | 1         | 0         |
| Name                                          |    |    |    |    |    |    |   |   |   |   |   |   | FIFO_Isr_sel | TO_CNT_AUTORST | TX_DMA_EM | RX_DMA_EM |
| Type                                          |    |    |    |    |    |    |   |   |   |   |   |   |              | RW             | RW        | RW        |
| Reset                                         |    |    |    |    |    |    |   |   |   |   |   |   |              | 0              | 0         | 0         |

| Bit(s) | Name           | Description                                                                                                                                                                                                        |
|--------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3      | FIFO_Isr_sel   | fifo Isr mode selection<br>0: Isr will hold the first line status error state until you read the Isr register.<br>1: Isr will update automatically.                                                                |
| 2      | TO_CNT_AUTORST | Timeout counter auto reset register<br>0: After RX timeout happen, SW shall reset the interrupt by reading UART 0x4C.<br>1: The timeout counter will be auto reset. Set this register when Rain's new DMA is used. |

|    |                                                                                                                                          |                                       |
|----|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| 1  | TX_DMA_EN                                                                                                                                | <b>TX_DMA mechanism enable signal</b> |
| 0: | Do not use DMA in TX.                                                                                                                    |                                       |
| 1: | Use DMA in TX. When this register is enabled, the flow control is based on the DMA threshold, and generates a timeout interrupt for DMA. |                                       |
| 0  | RX_DMA_EN                                                                                                                                | <b>RX_DMA mechanism enable signal</b> |
| 0: | Do not use DMA in RX.                                                                                                                    |                                       |
| 1: | Use DMA in RX. When this register is enabled, the flow control is based on the DMA threshold, and generates a timeout interrupt          |                                       |

**A00A0050 RXTRIG AD Rx Trigger Address 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RXTRIG  |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW      |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 |

| Bit(s) | Name   | Description                                                                                                                                    |
|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    | RXTRIG | When {rtm,rtl}=2'b11, The Rx FIFO threshold will be Rxtrig.<br>The value is suggested to be less than half of RX FIFO size, which is 32 Bytes. |

**A00A0054 FRACDIV\_L Fractional Divider LSB Address 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FRACDIV_L         |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 0 0 0 0 0 |

| Bit(s) | Name      | Description                                                                                                           |
|--------|-----------|-----------------------------------------------------------------------------------------------------------------------|
| 7:0    | FRACDIV_L | Add sampling count (+1) from state data7 to data0, in order to contribute fractional divisor.only when high_speed==3. |

**A00A0058 FRACDIV\_M Fractional Divider MSB Address 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FRACDIV_M |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0       |

| Bit(s) | Name      | Description                                                                                                         |
|--------|-----------|---------------------------------------------------------------------------------------------------------------------|
| 1:0    | FRACDIV_M | Add sampling count when in state stop to parity, in order to contribute fractional divisor.only when high_speed==3. |

**A00A005C FCR RD FIFO Control Register 00**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7            | 6            | 5 | 4 | 3    | 2    | 1     | 0 |
|-------|----|----|----|----|----|----|---|---|--------------|--------------|---|---|------|------|-------|---|
| Name  |    |    |    |    |    |    |   |   | RFTL1_RFTL_0 | TFTL1_TFTL_0 |   |   | CLRT | CLRR | FIFOE |   |
| Type  |    |    |    |    |    |    |   |   | RO           | RO           |   |   | RO   | RO   | RO    |   |
| Reset |    |    |    |    |    |    |   |   | 0 0          | 0 0          |   |   | 0 0  | 0 0  | 0     |   |

| Bit(s) | Name        | Description                                                                                            |          |     |     |           |    |
|--------|-------------|--------------------------------------------------------------------------------------------------------|----------|-----|-----|-----------|----|
| 7:6    | RFTL1_RFTL0 | RX FIFO trigger threshold. (RX FIFO contains total 32 bytes.)                                          |          |     |     |           |    |
|        |             | 0:                                                                                                     |          |     |     |           | 1  |
|        |             | 1:                                                                                                     |          |     |     |           | 6  |
|        |             | 2:                                                                                                     |          |     |     |           | 12 |
|        |             | 3: RXTRIG                                                                                              |          |     |     |           |    |
| 5:4    | TFTL1_TFTL0 | TX FIFO trigger threshold (TX FIFO contains total 32 bytes.)                                           |          |     |     |           |    |
|        |             | 0:                                                                                                     |          |     |     |           | 1  |
|        |             | 1:                                                                                                     |          |     |     |           | 4  |
|        |             | 2:                                                                                                     |          |     |     |           | 8  |
|        |             | 3: 14                                                                                                  |          |     |     |           |    |
| 2      | CLRT        | 0: TX FIFO is cleared                                                                                  | FIFO     | is  | not | cleared   |    |
| 1      | CLRR        | 0: RX FIFO is cleared                                                                                  | FIFO     | is  | not | cleared   |    |
| 0      | FIFOE       | FIFO Enabled. This bit must be set to 1 for any of the other bits in the registers to have any effect. |          |     |     |           |    |
|        |             | 0: the RX and TX FIFOs are enabled.                                                                    | TX FIFOs | are | not | enabled.. |    |
|        |             | 1: RX and TX FIFOs are enabled.                                                                        |          |     |     |           |    |

## 3.10 I2C/SCCB Controller

### 3.10.1 General Description

I2C (Inter-IC)/SCCB (Serial Camera Control Bus) is a two-wire serial interface. The two signals are SCL and SDA. SCL is a clock signal that is driven by the master. SDA is a bi-directional data signal that can be driven by either the master or the slave. This generic controller supports the master role and conforms to the I2C specification.

#### 3.10.1.1 Feature

- I2C compliant master mode operation
- Adjustable clock speed for LS/FS mode operation
- Supports 7-bit/10-bit addressing
- Supports high-speed mode
- Supports slave clock extension
- START/STOP/REPEATED START condition
- Manual transfer mode
- Multi-write per transfer (up to 8 data bytes for non-DMA mode)
- Multi-read per transfer (up to 8 data bytes for non-DMA mode)
- Multi-transfer per transaction
- Combined format transfer with length change capability
- Active drive/wired-and I/O configuration

#### 3.10.1.2 Manual Transfer Mode

The controller offers one transfer mode, the manual mode.

When the manual mode is selected, in addition to the slave address register, the controller has a built-in 8byte deep FIFO which allows MCU to prepare up to 8 bytes of data for a write transfer, or read up to 8 bytes of data for a read transfer.

### 3.10.1.3 Transfer Format Support

This controller has been designed to be as generic as possible in order to support a wide range of devices that may utilize different combinations of transfer formats. Here are the transfer format types that can be supported through different software configuration:

#### Wording convention note

- Transfer = Anything encapsulated within a Start and Stop or Repeated Start.
- Transfer length = Number of bytes within the transfer
- Transaction = This is the top unit. Everything combined equals 1 transaction.
- Transaction length = Number of transfers to be conducted.



#### Single-byte access

Single Byte Write



Single Byte Read



#### Multi-byte access

Multi Byte Write



Multi Byte Read



#### Multi-byte transfer + multi-transfer (same direction)

Multi Byte Write + Multi Transfer



Multi Byte Read + Multi Transfer



#### Multi-byte transfer + multi-transferw RS (same direction)

Multi Byte Write + Multi Transfer + Repeated Start



Multi Byte Read + Multi Transfer + Repeated Start



#### Combined write/read with Repeated Start (direction change)

Note: Only supports write and then read sequence. Read and then write is not supported.

Combined Multi Byte Write + Multi Byte Read



### 3.10.2 Programming Examples

#### Common transfer programmable parameters

## Programmable Parameters

Output waveform timing programmable parameters**3.10.3 Register Definition**

Module name: I2C\_SCCB\_Controller base address: (+A0120000h)

| Address  | Name                       | Width | Register function                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|----------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0120000 | <a href="#">DATA PORT</a>  | 16    | Data port register                                                                                                                                                                                                                                                                                                                                                                                                                    |
| A0120004 | <a href="#">SLAVE ADDR</a> | 16    | Slave address register                                                                                                                                                                                                                                                                                                                                                                                                                |
| A0120008 | <a href="#">INTR MASK</a>  | 16    | <b>Interrupt mask register</b><br>This register provides masks for the corresponding interrupt sources as indicated in the <code>intr_stat</code> register.<br>1 = Allow interrupt<br>0 = Disable interrupt<br><i>Note: While disabled, the corresponding interrupt will not be asserted, however <code>intr_stat</code> will still be updated with the status, i.e. mask does not affect <code>intr_stat</code> register values.</i> |
| A012000C | <a href="#">INTR STAT</a>  | 16    | <b>Interrupt status register</b><br>When an interrupt is issued by the I2C controller, this register will need to be read by MCU to determine the cause for the interrupt. After this status has been read and appropriate actions are taken, the corresponding interrupt source will need to be written 1 to clear.                                                                                                                  |
| A0120010 | <a href="#">CONTROL</a>    | 16    | Control register                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Address  | Name                                    | Width | Register function                                                                                                                                                                                                                    |
|----------|-----------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0120014 | <a href="#"><u>TRANSFER_LEN</u></a>     | 16    | Transfer length register (number of bytes per transfer)                                                                                                                                                                              |
| A0120018 | <a href="#"><u>TRANSAC_LEN</u></a>      | 16    | Transaction length register (number of transfers per transaction)                                                                                                                                                                    |
| A012001C | <a href="#"><u>DELAY_LEN</u></a>        | 16    | Inter delay length register                                                                                                                                                                                                          |
| A0120020 | <a href="#"><u>TIMING</u></a>           | 16    | <b>Timing control register</b><br>LS/FS only. This register is used to control the output waveform timing. Each half pulse width, i.e. each high or low pulse, is equal to $(step\_cnt\_div+1)*(sample\_cnt\_div + 1)/13MHz$         |
| A0120024 | <a href="#"><u>START</u></a>            | 16    | Start register                                                                                                                                                                                                                       |
| A0120030 | <a href="#"><u>FIFO_STAT</u></a>        | 16    | FIFO status register                                                                                                                                                                                                                 |
| A0120038 | <a href="#"><u>FIFO_ADDR_CLR</u></a>    | 16    | FIFO address clear register                                                                                                                                                                                                          |
| A0120040 | <a href="#"><u>IO_CONFIG</u></a>        | 16    | <b>IO config register</b><br>This register is used to configure the I/O for the SDA and SCL lines to select between normal I/O mode, or open-drain mode to support wired-and bus.                                                    |
| A0120048 | <a href="#"><u>HS</u></a>               | 16    | <b>High speed mode register</b><br>This register contains options for supporting high speed operation features. Each HS half pulse width, i.e. each high or low pulse, is equal to $(step\_cnt\_div+1)*(sample\_cnt\_div + 1)/13MHz$ |
| A0120050 | <a href="#"><u>SOFTRESET</u></a>        | 16    | Soft reset register                                                                                                                                                                                                                  |
| A0120060 | <a href="#"><u>SPARE</u></a>            | 16    | SPARE                                                                                                                                                                                                                                |
| A0120064 | <a href="#"><u>DEBUGSTAT</u></a>        | 16    | Debug status register                                                                                                                                                                                                                |
| A0120068 | <a href="#"><u>DEBUGCTRL</u></a>        | 16    | Debug control register                                                                                                                                                                                                               |
| A012006C | <a href="#"><u>TRANSFER_LEN_AXI</u></a> | 16    | Transfer length register (number of bytes per transfer)                                                                                                                                                                              |
| A0120074 | <a href="#"><u>TIMEOUT</u></a>          | 16    | Timeout timing register                                                                                                                                                                                                              |

**A0120000    [DATA\\_PORT](#)    Data Port Register    0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic                         | Name                             | Description                                                                                                                                                                                                                                                                |
|--------|----------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | <a href="#"><u>DATA_PORT</u></a> | <a href="#"><u>DATA_PORT</u></a> | <b>FIFO access port</b><br>During master write sequences (slave_addr[0] = 0), this port can be written by APB, and during master read sequences (slave_addr[0] = 1), this port can be read by APB.<br><i>Note: Slave_addr must be set correctly before accessing FIFO.</i> |
|        |                                  |                                  |                                                                                                                                                                                                                                                                            |

| Bit(s) | Mnemonic | Name | Description                                                                                    |
|--------|----------|------|------------------------------------------------------------------------------------------------|
|        |          |      | For debugging only: If the fifo_apb_debug bit is set, FIFO can be read and written by the APB. |

**A0120004    SLAVE\_ADDR    Slave Address Register                              00BF**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 1 | 0 | 1 | 1 | 1 |

| Bit(s) | Mnemonic         | Name       | Description                                                                                                                  |
|--------|------------------|------------|------------------------------------------------------------------------------------------------------------------------------|
|        |                  |            | Specifies the slave address of the device to be accessed                                                                     |
| 7:0    | <b>SLAVE_ADD</b> | SLAVE_ADDR | Bit 0 is defined by the I2C protocol as a bit that indicates the direction of transfer.<br>0: Master write<br>1: Master read |
|        | R                |            |                                                                                                                              |

**A0120008    INTR\_MASK    Interrupt Mask Register                              0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1  | 0  |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|----|---|----|----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |    |   |    |    |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |    |   |    |    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | RW |   | RW | RW |
|       |    |    |    |    |    |    |   |   |   |   |   |   | 0  |   | 0  | 0  |

**Overview:** This register provides masks for the corresponding interrupt sources as indicated in the intr\_stat register. 1 = allow interrupt; 0 = disable interrupt. Note that while disabled, the corresponding interrupt will not be asserted. However, intr\_stat will still be updated with the status, i.e. mask does not affect intr\_stat register values.

| Bit(s) | Mnemonic         | Name                  | Description                                                     |
|--------|------------------|-----------------------|-----------------------------------------------------------------|
| 4      | <b>MASK_TIM</b>  | <b>E MASK_TIMEOUT</b> | Setting this value to 0 will mask TIMEOUT interrupt signal.     |
|        | <b>OUT</b>       |                       |                                                                 |
| 2      | <b>MASK_HS_</b>  | <b>NACKERR</b>        | Setting this value to 0 will mask HS_NACKERR interrupt signal.  |
|        | <b>NACKERR</b>   | <b>RR</b>             |                                                                 |
| 1      | <b>MASK_ACK</b>  | <b>ERR</b>            | Setting this value to 0 will mask ACK_ERR interrupt signal.     |
|        | <b>ERR</b>       |                       |                                                                 |
| 0      | <b>MASK_TRA</b>  | <b>NSAC_COMP</b>      | Setting this value to 0 will mask TRNSAC_COMP interrupt signal. |
|        | <b>NSAC_COMP</b> | <b>P</b>              |                                                                 |

**A012000C    INTR\_STAT    Interrupt Status Register                              0000**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3       | 2        | 1          | 0      |           |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---------|----------|------------|--------|-----------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |         |          |            |        |           |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |         |          |            |        |           |
|      |    |    |    |    |    |    |   |   |   |   |   |   | TIMEOUT | ARB_LOST | HS_NACKERR | ACKERR | TRANSCOMP |
|      |    |    |    |    |    |    |   |   |   |   |   |   | W1C     | W1C      | W1C        | W1C    | W1C       |

|       |   |   |   |   |   |
|-------|---|---|---|---|---|
| Reset | 0 | 0 | 0 | 0 | 0 |
|-------|---|---|---|---|---|

**Overview:** When an interrupt is issued by the I2C controller, this register will need to be read by MCU to determine the cause for the interrupt. After this status has been read and appropriate actions are taken, the corresponding interrupt source will need to be written 1 to clear.

| Bit(s) | Mnemonic | Name                 | Description                                                                                                                                                                                                                                                                                        |
|--------|----------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | TIMEOUT  | TIMEOUT_IRQ          | This status is asserted if time-out is enabled and the timer expires. The internal master state machine will stop, and MCU will need to manually clear the state machine by either issuing software reset by disabling the transact_en bit. Time-out can be used to detect PCB or I2C malfunction. |
| 3      | ARB_LOST | SPARE                | <b>Reserved</b>                                                                                                                                                                                                                                                                                    |
| 2      | HS_NACKE | HS_NACKERR<br>RR     | This status is asserted if HS master code NACK error detection is enabled. If enabled, HS master code NACK err will cause transaction to end, and stop will be issued.                                                                                                                             |
| 1      | ACKERR   | ACKERR               | This status is asserted if ACK error detection is enabled. If enabled, ACKERR will cause transaction to end, and stop will be issued.                                                                                                                                                              |
| 0      | TRANSAC_ | TRANSAC_COMP<br>COMP | This status is asserted when a transaction is completed successfully.                                                                                                                                                                                                                              |

| A0120010 <u>CONTROL</u> Control Register 0000 |           |                |                   |               |      |      |      |       |           |   |   |   |   |   |         |   |
|-----------------------------------------------|-----------|----------------|-------------------|---------------|------|------|------|-------|-----------|---|---|---|---|---|---------|---|
| Bit                                           | 15        | 14             | 13                | 12            | 11   | 10   | 9    | 8     | 7         | 6 | 5 | 4 | 3 | 2 | 1       | 0 |
| Name                                          | TIMEOUT_E | RESET_BUSSY_EN | TRANSFER_LEN_CHAN | ACKERR_DET_EN | RESE | TRAN | ACKE | DIR_C | CLK_EXT_E |   |   |   |   |   | RS_STOP |   |
| Type                                          | N         | SYN            | GE                | N             | T_BU | SFER | RR_D | HANG  | E         |   |   |   |   |   |         |   |
| Reset                                         | 0         | 0              | 0                 | 0             | RW   | RW   | RW   | RW    | RW        |   |   |   |   |   | RW      |   |

| Bit(s) | Mnemonic          | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8      | TIMEOUT_E         | TIMEOUT_EN       | <b>Enables time-out mechanism</b><br>When enabled, if SCL stays at 0 for too long period of time due to I2C slave holds SCL at 0 for too long or SCL stuck at 0 due to PCB issue, the master shall terminate the transaction, stop the internal state machine and assert time-out interrupt. MCU shall handle this case appropriately and reset the master and FIFO address before reissuing the transaction again. If this option is disabled, the HW timer will not count and nor expire forever.<br>0: Disable<br>1: Enable |
| 7      | RESET_BUSSPARE    | _BUSY_EN         | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6      | TRANSFER_LEN_CHAN | TRANSFER_LEN_AUX | <b>Specifies whether or not to change the transfer length after the first transfer is completed</b><br>If enabled, the transfers after the first transfer will use the transfer_len_aux parameter.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                  |
| 5      | ACKERR_DET_EN     | ACKERR_DET_EN    | <b>Enables slave ACK error detection</b><br>When enabled, if slave ACK error is detected, the master shall                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit(s) | Mnemonic   | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | DIR_CHANGE | DIR_CHANGE | terminate the transaction by issuing a STOP condition and then assert the ACKERR interrupt. MCU handles this case appropriately then resets the FIFO address before reissuing transaction. If this option is disabled, the controller will ignore slave ACK error and keep on scheduled transaction.<br>0: Disable<br>1: Enable                                                                                                                                                                                                      |
| 3      | CLK_EXT_E  | CLK_EXT_EN | <b>Combined transfer format, where the direction of transfer is to be changed from write to read after the FIRST RS condition</b><br><i>Note: When set to 1, the transfers after the direction change will be based on the transfer_len_aux parameter.</i><br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                |
| 1      | RS_STOP    | RS_STOP    | I2C spec allows slaves to hold the SCL line low if it is not yet ready for further processing.<br>Therefore, if this bit is set to 1, the master controller will enter a high wait state until the slave releases the SCL line.<br><b>In LS/FS mode, this bit affects multi-transfer transaction only.</b><br>It controls whether or not the REPEATED-START condition is used between transfers. The last ending transfer always ends with a STOP.<br>In HS mode, this bit must be set to 1.<br>0: Use STOP<br>1: Use REPEATED-START |

A0120014 TRANSFER\_LEN Transfer Length Register (Number of Bytes per Transaction) 0001

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TRANSFER LEN AUX |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW               |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 1          |

| Bit(s) | Mnemonic         | Name         | Description                                                                                                                                                                                              |
|--------|------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    | TRANSFER_LEN_AUX | TRANSFER_LEN | Indicates the number of data bytes to be transferred in 1 transfer unit (excluding slave address byte)<br><i>Note: The value must be set to be bigger than 1; otherwise no transfer will take place.</i> |

A0120018 TRANSAC\_LEN Transaction Length Register (Number of Transfers per Transaction) 0001

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TRANSAC LEN     |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW              |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 0 0 0 1 |

| Bit(s) | Mnemonic    | Name        | Description                                                                                                                                  |
|--------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | TRANSAC_LEN | TRANSAC_LEN | Indicates the number of transfers to be transferred in 1 transaction<br><i>Note: The value must be set to be bigger than 1; otherwise no</i> |

| Bit(s)                           | Mnemonic | Name | Description |
|----------------------------------|----------|------|-------------|
| <i>transfer will take place.</i> |          |      |             |

**A012001C DELAY\_LEN Inter Delay Length Register 0002**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>DELAY_LEN</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW               |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 0 0 1 0  |

| Bit(s) | Mnemonic         | Name             | Description                                                                                                 |
|--------|------------------|------------------|-------------------------------------------------------------------------------------------------------------|
| 7:0    | <b>DELAY_LEN</b> | <b>DELAY_LEN</b> | Sets up wait delay between consecutive transfers when RS_STOP bit is set to 0<br>Unit: Half the pulse width |

**A0120020 TIMING Timing Control Register 1303**

| Bit   | 15                   | 14                    | 13 | 12 | 11 | 10                    | 9 | 8 | 7 | 6                   | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----------------------|-----------------------|----|----|----|-----------------------|---|---|---|---------------------|---|---|---|---|---|---|
| Name  | <b>DATA_READ_ADJ</b> | <b>DATA_READ_TIME</b> |    |    |    | <b>SAMPLE_CNT_DIV</b> |   |   |   | <b>STEP_CNT_DIV</b> |   |   |   |   |   |   |
| Type  | RW                   | RW                    |    |    |    | RW                    |   |   |   | RW                  |   |   |   |   |   |   |
| Reset | 0                    | 0                     | 0  | 1  |    | 0                     | 1 | 1 |   |                     | 0 | 0 | 0 | 0 | 1 | 1 |

**Overview:** LS/FS only. This register is used to control the output waveform timing. Each half pulse width, i.e. each high or low pulse, is equal to (step\_cnt\_div+1)\*(sample\_cnt\_div + 1)/13MHz

| Bit(s) | Mnemonic               | Name                   | Description                                                                                                                                                                                                                                                                               |
|--------|------------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | <b>DATA_READ_ADJ</b>   | <b>DATA_READ_ADJ</b>   | When set to 1, data latch in sampling time during master reads are adjusted according to the DATA_READ_TIME value. Otherwise, by default, the data are latched in at half of the high pulse width point. This value must be set to be smaller than or equal to half the high pulse width. |
| 14:12  | <b>DATA_READ_DTIME</b> | <b>DATA_READ_DTIME</b> | This value is valid only when DATA_READ_ADJ is set to 1. This can be used to adjust so that the data are latched in at earlier sampling points (assuming data are settled by then).                                                                                                       |
| 10:8   | <b>SAMPLE_CNT_DIV</b>  | <b>SAMPLE_CNT_DIV</b>  | Used for LS/FS only. This adjusts the width of each sample. Sample width = (sample_cnt_div + 1)/13MHz                                                                                                                                                                                     |
| 5:0    | <b>STEP_CNT_DIV</b>    | <b>STEP_CNT_DIV</b>    | Specifies the number of samples per half pulse width, i.e. each high or low pulse                                                                                                                                                                                                         |

**A0120024 START Start Register 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0            |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>START</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW           |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0            |

| Bit(s) | Mnemonic | Name  | Description                                                                                       |
|--------|----------|-------|---------------------------------------------------------------------------------------------------|
| 0      | START    | START | <b>Starts the transaction on the bus</b><br>It is auto de-asserted at the end of the transaction. |

**A0120030 FIFO\_STAT FIFO Status Register 0001**

| Bit   | 15      | 14 | 13 | 12 | 11      | 10 | 9 | 8 | 7           | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
|-------|---------|----|----|----|---------|----|---|---|-------------|---|---|---|---|---|---------|---------|
| Name  | RD_ADDR |    |    |    | WR_ADDR |    |   |   | FIFO_OFFSET |   |   |   |   |   | WR_FULL | RD_EMPT |
| Type  | RO      |    |    |    | RU      |    |   |   | RU          |   |   |   |   |   | RO      | RO      |
| Reset | 0       | 0  | 0  | 0  | 0       | 0  | 0 | 0 | 0           | 0 | 0 | 0 | 0 | 0 | 0       | 1       |

| Bit(s) | Mnemonic    | Name        | Description                                                                 |
|--------|-------------|-------------|-----------------------------------------------------------------------------|
| 15:12  | RD_ADDR     | RD_ADDR     | <b>Current RD address pointer</b><br>Only bit [2:0] have physical meanings. |
| 11:8   | WR_ADDR     | WR_ADDR     | <b>Current WR address pointer</b><br>Only bit [2:0] have physical meanings. |
| 7:4    | FIFO_OFFSET | FIFO_OFFSET | <b>wr_addr[3:0] - rd_addr[3:0]</b>                                          |
| 1      | WR_FULL     | WR_FULL     | <b>Indicates FIFO is full</b>                                               |
| 0      | RD_EMPTY    | RD_EMPTY    | <b>Indicates FIFO is empty</b>                                              |

**A0120038 FIFO\_ADDR\_CLR FIFO Address Clear Register 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 |

| Bit(s) | Mnemonic      | Name          | Description                                                                                       |
|--------|---------------|---------------|---------------------------------------------------------------------------------------------------|
| 0      | FIFO_ADDR_CLR | FIFO_ADDR_CLR | When written with 1'b1, a 1 pulse fifo_addr_clr is generated to clear the FIFO address back to 0. |

**A0120040 IO\_CONFIG IO Config Register 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 |

**Overview:** This register is used to configure the I/O for the SDA and SCL lines to select between normal I/O mode or open-drain mode to support wired-and bus.

| Bit(s) | Mnemonic   | Name       | Description                         |
|--------|------------|------------|-------------------------------------|
| 3      | IDLE_OE_EN | IDLE_OE_EN | 0: Does not drive bus in idle state |

| Bit(s) | Mnemonic          | Name          | Description                |                 |          |     |  |  |  |  |  |  |  |      |
|--------|-------------------|---------------|----------------------------|-----------------|----------|-----|--|--|--|--|--|--|--|------|
| N      |                   |               | 1: Drive bus in idle state |                 |          |     |  |  |  |  |  |  |  |      |
| 1      | SDA_IO_CO<br>NFIG | SDA_IO_CONFIG | 0:                         | Normal          | tristate | I/O |  |  |  |  |  |  |  | mode |
| 0      | SCL_IO_CO<br>NFIG | SCL_IO_CONFIG | 0:                         | Normal          | tristate | I/O |  |  |  |  |  |  |  | mode |
|        |                   |               | 1:                         | Open-drain mode |          |     |  |  |  |  |  |  |  |      |

**A0120048 HS High Speed Mode Register 0102**

| Bit   | 15 | 14 | 13                | 12 | 11 | 10              | 9 | 8 | 7 | 6           | 5 | 4 | 3 | 2 | 1                             | 0     |
|-------|----|----|-------------------|----|----|-----------------|---|---|---|-------------|---|---|---|---|-------------------------------|-------|
| Name  |    |    | HS_SAMPLE_CNT_DIV |    |    | HS_STEP_CNT_DIV |   |   |   | MASTER_CODE |   |   |   |   | HS_NACKE<br>RR_D<br>ET_E<br>N | HS_EN |
| Type  |    |    | RW                |    |    | RW              |   |   |   | RW          |   |   |   |   | RW                            | RW    |
| Reset | 0  | 0  | 0                 |    | 0  | 0               | 1 |   | 0 | 0           | 0 |   |   |   | 1                             | 0     |

**Overview:** This register contains options for supporting high speed operation features. Each HS half pulse width, i.e. each high or low pulse, is equal to (step\_cnt\_div+1)\*(sample\_cnt\_div + 1)/13MHz.

| Bit(s)                                 | Mnemonic          | Name              | Description                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------------|-------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 14:12                                  | HS_SAMPLE_CNT_DIV | HS_SAMPLE_CNT_DIV | When the high-speed mode is entered after the master code transfer is completed, the sample width will become dependent on this parameter.                       |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10:8                                   | HS_STEP_CNT_DIV   | HS_STEP_CNT_DIV   | When the high-speed mode is entered after the master code transfer is completed, the number of samples per half pulse width will become dependent on this value. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6:4                                    | MASTER_CODE       | MASTER_CODE       | This is the 3 bit programmable value for the master code to be transmitted.                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1                                      | HS_NACKERR_DE     | HS_NACKERR_DE     | Enables NACKERR detection during the master code transmission                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0                                      | HS_EN             | HS_EN             | Enables high-speed transaction                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <i>Note: rs_stop must be set to 1.</i> |                   |                   |                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**A0120050 SOFTRESET Soft Reset Register 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | SOFT_RESET |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | WO         |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0          |   |

| Bit(s) | Mnemonic   | Name       | Description                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|------------|------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0      | SOFT_RESET | SOFT_RESET | When written with 1'b1, a 1 pulse soft reset is used as synchronous reset to reset the I2C internal hardware circuits. |  |  |  |  |  |  |  |  |  |  |  |  |  |

A0120060 SPARE SPARE 0000 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0 |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | SPARE |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW    |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0     | 0 | 0 | 0 |

| Bit(s) | Mnemonic     | Name  | Description             |
|--------|--------------|-------|-------------------------|
| 3:0    | <b>SPARE</b> | SPARE | Reserved for future use |

 A0120064 DEBUGSTAT Debug Status Register 0020 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6            | 5           | 4 | 3 | 2 | 1 | 0  |
|-------|----|----|----|----|----|----|---|---|----------|--------------|-------------|---|---|---|---|----|
| Name  |    |    |    |    |    |    |   |   | BUS_BUSY | MASTER_WRITE | MASTER_READ |   |   |   |   |    |
| Type  |    |    |    |    |    |    |   |   | RO       | RO           | RO          |   |   |   |   | RO |
| Reset |    |    |    |    |    |    |   |   | 0        | 0            | 1           | 0 | 0 | 0 | 0 | 0  |

| Bit(s) | Mnemonic         | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | <b>BUS_BUSY</b>  | SPARE        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6      | <b>MASTER_W</b>  | MASTER_WRITE | <b>For debugging only</b><br>1: Current transfer is in the master write dir.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5      | <b>MASTER_R</b>  | MASTER_READ  | <b>For debugging only</b><br>1: Current transfer is in the master read dir.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4:0    | <b>MASTER_ST</b> | MASTER_STATE | <b>(For debugging only) Reads back the current master_state.</b><br>0: Idle state<br>1: I2C master is preparing to send out the start bit, SCL=1, SDA=1.<br>2: I2C master is sending out the start bit, SCL=1, SDA=0.<br>3: I2C master/slave is preparing to transmit data bit, SCL=0, SDA=data bit. (Data bit can be changed when SCL=0.)<br>4: I2C master/slave is transmitting data bit, SCL=1, SDA=data bit. (Data bit is stable when SCL=1.)<br>5: I2C master/slave is preparing to transmit the ACK bit, SCL=0, SDA=ack. (The ACK bit can be changed when SCL=0.)<br>6: I2C master/slave is transmitting the ACK bit, SCL=1, SDA=0. (The ACK bit is stable when SCL=1.)<br>7: I2C master is preparing to send out stop bit or repeated-start bit, SCL=0, SDA=0/1. (0: Stop bit; 1: Repeated-start bit)<br>8: I2C master is sending out stop bit or repeated-start bit, SCL=1, SDA=1/0. (0: Repeated-start bit; 1: Stop bit)<br>9: I2C master is in delay start between two transfers, SCL=1, SDA=1.<br>10: I2C master is in FIFO wait state; For writing transaction, it means FIFO is empty and I2C master is waiting for DMA controller to write data into FIFO. For reading transaction, it means FIFO is full and I2C master is waiting for DMA controller to read data from FIFO, SCL=0, SDA=don't care.<br>12: I2C master is preparing to send out data bit of master code. This state is used only in high-speed transaction, SCL=0, SDA=data bit of master code. (Data bit of master code can be changed when SCL=0.) |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                               |
|--------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:    |          |      | I2C master is sending out data bit of master code. This state is used only in high-speed transaction, SCL=1, SDA=data bit of master code. (Data bit of master code is stable when SCL=1.) |
| 14:    |          |      | I2C master/slave is preparing to transmit the NACK bit, SCL=0, SDA=nack bit. (The NACK bit can be changed when SCL=0.) This state is used only in high-speed transaction.                 |
| 15:    |          |      | I2C master/slave is transmitting the NACK bit, SCL=1, SDA=1. This state is used only in high-speed transaction.                                                                           |

**A0120068    DEBUGCTRL    Debug Control Register                                      0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                | 0              |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------------|----------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | APB_APB_DEBUG_RD | FIFO_APB_DEBUG |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | WO               | RW             |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0                | 0              |

| Bit(s) | Mnemonic       | Name           | Description                                                                                                                                                                                                                                             |
|--------|----------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | APB_DEBUG_G_RD | APB_DEBUG_RD   | Only valid when fifo_apb_debug is set to 1<br>Writing to this register will generate a 1 pulsed FIFO APB RD signal for reading the FIFO data.                                                                                                           |
| 0      | FIFO_APB_DEBUG | FIFO_APB_DEBUG | Used for trace 32 debugging<br>When using trace 32, and the memory map is shown, turning this bit on will block the normal APB read access. The APB read access to the FIFO will then be enabled by writing to apb_debug_rd.<br>0: Disable<br>1: Enable |

**A012006C    TRANSFER LE N\_AUX Transfer Length Register (Number of Bytes per Transfer)                                      0001**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1            | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | TRANSFER_LEN |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW           |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0            | 0 |

| Bit(s) | Mnemonic         | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    | TRANSFER_LEN_AUX | TRANSFER_LEN_AUX | Only valid when dir_change or transfer_len_change is set to 1. Indicates the number of data bytes to be transferred in 1 transfer unit (excluding slave address byte) for the transfers following the direction change or transfer_len_change<br>If dir_change =1, the first write transfer length will depend on transfer_len, while the second read transfer length will depend on transfer_len_aux. Dir change is always after the first transfer. Similarly, transfer length change is always after the first transfer.<br>Note: The value must be set to be bigger than 1; otherwise no transfer will take place. |

A0120074    **TIMEOUT****Timeout Timing Register****FFFF**

| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>TIMEOUT</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 1              | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                             |
|--------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | TIMEOUT  |      | <b>Indicates the number of steps to count before time-out</b><br>The time-out counter counts only when the time-out mechanism is enabled and has started a transaction. |

## 3.11 I2C/SCCB Controller (I2C\_SCCB\_Controller\_V18)

### 3.11.1 General Description

I2C (Inter-IC)/SCCB (Serial Camera Control Bus) is a two-wire serial interface. The two signals are SCL and SDA. SCL is a clock signal that is driven by the master. SDA is a bi-directional data signal that can be driven by either the master or the slave. This generic controller supports the master role and conforms to the I2C specification.

#### 3.11.1.1 Feature

- I2C compliant master mode operation
- Adjustable clock speed for LS/FS mode operation
- Supports 7-bit/10-bit addressing
- Supports high-speed mode
- Supports slave clock extension
- START/STOP/REPEATED START condition
- Manual transfer mode
- Multi-write per transfer (up to 8 data bytes for non-DMA mode)
- Multi-read per transfer (up to 8 data bytes for non-DMA mode)
- Multi-transfer per transaction
- Combined format transfer with length change capability
- Active drive/wired-and I/O configuration

#### 3.11.1.2 Manual Transfer Mode

The controller offers one transfer mode, the manual mode.

When the manual mode is selected, in addition to the slave address register, the controller has a built-in 8byte deep FIFO which allows MCU to prepare up to 8 bytes of data for a write transfer, or read up to 8 bytes of data for a read transfer.

### 3.11.1.3 Transfer Format Support

This controller has been designed to be as generic as possible in order to support a wide range of devices that may utilize different combinations of transfer formats. Here are the transfer format types that can be supported through different software configuration:

#### Wording convention note

- Transfer = Anything encapsulated within a Start and Stop or Repeated Start.
- Transfer length = Number of bytes within the transfer
- Transaction = This is the top unit. Everything combined equals 1 transaction.
- Transaction length = Number of transfers to be conducted.



Master to slave dir



Slave to master dir

#### Single-byte access

Single Byte Write



Single Byte Read



#### Multi-byte access

Multi Byte Write



Multi Byte Read



#### Multi-byte transfer + multi-transfer (same direction)

Multi Byte Write + Multi Transfer



Multi Byte Read + Multi Transfer



#### Multi-byte transfer + multi-transferw RS (same direction)

Multi Byte Write + Multi Transfer + Repeated Start



Multi Byte Read + Multi Transfer + Repeated Start



#### Combined write/read with Repeated Start (direction change)

Note: Only supports write and then read sequence. Read and then write is not supported.

Combined Multi Byte Write + Multi Byte Read



### 3.11.2 Programming Examples

#### Common transfer programmable parameters

Programmable Parameters



#### Output waveform timing programmable parameters



#### 3.11.3 Register Definition

Module name: I2C\_SCCB\_Controller\_V18 base address: (+A02A0000h)

| Address  | Name                       | Width | Register function                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|----------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A02A0000 | <a href="#">DATA PORT</a>  | 16    | Data port register                                                                                                                                                                                                                                                                                                                                                                                                                             |
| A02A0004 | <a href="#">SLAVE ADDR</a> | 16    | Slave address register                                                                                                                                                                                                                                                                                                                                                                                                                         |
| A02A0008 | <a href="#">INTR MASK</a>  | 16    | <b>Interrupt mask register</b><br>This register provides masks for the corresponding interrupt sources as indicated in the <a href="#">intr_stat</a> register.<br>1 = Allow interrupt<br>0 = Disable interrupt<br><i>Note: While disabled, the corresponding interrupt will not be asserted, however <a href="#">intr_stat</a> will still be updated with the status, i.e. mask does not affect <a href="#">intr_stat</a> register values.</i> |
| A02A000C | <a href="#">INTR STAT</a>  | 16    | <b>Interrupt status register</b><br>When an interrupt is issued by the I2C controller, this register will need to be read by MCU to determine the cause for the interrupt. After this status has been read and appropriate actions are taken, the corresponding interrupt source will need to be written 1 to clear.                                                                                                                           |
| A02A0010 | <a href="#">CONTROL</a>    | 16    | Control register                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Address  | Name                                   | Width | Register function                                                                                                                                                                                                                    |
|----------|----------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A02A0014 | <a href="#"><u>TRANSFER_LEN</u></a>    | 16    | Transfer length register (number of bytes per transfer)                                                                                                                                                                              |
| A02A0018 | <a href="#"><u>TRANSAC_LEN</u></a>     | 16    | Transaction length register (number of transfers per transaction)                                                                                                                                                                    |
| A02A001C | <a href="#"><u>DELAY_LEN</u></a>       | 16    | Inter delay length register                                                                                                                                                                                                          |
| A02A0020 | <a href="#"><u>TIMING</u></a>          | 16    | <b>Timing control register</b><br>LS/FS only. This register is used to control the output waveform timing. Each half pulse width, i.e. each high or low pulse, is equal to $(step\_cnt\_div+1)*(sample\_cnt\_div + 1)/13MHz$         |
| A02A0024 | <a href="#"><u>START</u></a>           | 16    | Start register                                                                                                                                                                                                                       |
| A02A0030 | <a href="#"><u>FIFO_STAT</u></a>       | 16    | FIFO status register                                                                                                                                                                                                                 |
| A02A0038 | <a href="#"><u>FIFO_ADDR_CLR</u></a>   | 16    | FIFO address clear register                                                                                                                                                                                                          |
| A02A0040 | <a href="#"><u>IO_CONFIG</u></a>       | 16    | <b>IO config register</b><br>This register is used to configure the I/O for the SDA and SCL lines to select between normal I/O mode, or open-drain mode to support wired-and bus.                                                    |
| A02A0048 | <a href="#"><u>HS</u></a>              | 16    | <b>High speed mode register</b><br>This register contains options for supporting high speed operation features. Each HS half pulse width, i.e. each high or low pulse, is equal to $(step\_cnt\_div+1)*(sample\_cnt\_div + 1)/13MHz$ |
| A02A0050 | <a href="#"><u>SOFTRESET</u></a>       | 16    | Soft reset register                                                                                                                                                                                                                  |
| A02A0060 | <a href="#"><u>SPARE</u></a>           | 16    | SPARE                                                                                                                                                                                                                                |
| A02A0064 | <a href="#"><u>DEBUGSTAT</u></a>       | 16    | Debug status register                                                                                                                                                                                                                |
| A02A0068 | <a href="#"><u>DEBUGCTRL</u></a>       | 16    | Debug control register                                                                                                                                                                                                               |
| A02A006C | <a href="#"><u>TRANSFER_LEN_AX</u></a> | 16    | Transfer length register (number of bytes per transfer)                                                                                                                                                                              |
| A02A0074 | <a href="#"><u>TIMEOUT</u></a>         | 16    | Timeout timing register                                                                                                                                                                                                              |

**A02A0000 [DATA\\_PORT](#) Data Port Register 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic                         | Name                             | Description                                                                                                                                                                                                                                                                |
|--------|----------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | <a href="#"><u>DATA_PORT</u></a> | <a href="#"><u>DATA_PORT</u></a> | <b>FIFO access port</b><br>During master write sequences (slave_addr[0] = 0), this port can be written by APB, and during master read sequences (slave_addr[0] = 1), this port can be read by APB.<br><i>Note: Slave_addr must be set correctly before accessing FIFO.</i> |
|        |                                  |                                  |                                                                                                                                                                                                                                                                            |

| Bit(s) | Mnemonic | Name | Description                                                                                    |
|--------|----------|------|------------------------------------------------------------------------------------------------|
|        |          |      | For debugging only: If the fifo_apb_debug bit is set, FIFO can be read and written by the APB. |

**A02A0004    SLAVE\_ADDR    Slave Address Register                                                  00BF**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Mnemonic         | Name              | Description                                                                                                                                                                                     |
|--------|------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | <b>SLAVE_ADD</b> | <b>SLAVE_ADDR</b> | <b>Specifies the slave address of the device to be accessed</b><br>Bit 0 is defined by the I2C protocol as a bit that indicates the direction of transfer.<br>0: Master write<br>1: Master read |

**A02A0008    INTR\_MASK    Interrupt Mask Register                                          0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Overview:** This register provides masks for the corresponding interrupt sources as indicated in the intr\_stat register. 1 = allow interrupt; 0 = disable interrupt Note that while disabled, the corresponding interrupt will not be asserted. However, intr\_stat will still be updated with the status, i.e. mask does not affect intr\_stat register values.

| Bit(s) | Mnemonic        | Name                  | Description                                                      |
|--------|-----------------|-----------------------|------------------------------------------------------------------|
| 4      | <b>MASK_TIM</b> | <b>E MASK_TIMEOUT</b> | Setting this value to 0 will mask TIMEOUT interrupt signal.      |
| 2      | <b>MASK_HS_</b> | <b>NACKERR</b>        | Setting this value to 0 will mask HS_NACKERR interrupt signal.   |
| 1      | <b>MASK_ACK</b> | <b>ERR</b>            | Setting this value to 0 will mask ACK_ERR interrupt signal.      |
| 0      | <b>MASK_TRA</b> | <b>NSAC_COMP</b>      | Setting this value to 0 will mask TRANSAC_COMP interrupt signal. |

**A02A000C    INTR\_STAT    Interrupt Status Register                                          0000**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|       |   |   |   |   |   |
|-------|---|---|---|---|---|
| Reset | 0 | 0 | 0 | 0 | 0 |
|-------|---|---|---|---|---|

**Overview:** When an interrupt is issued by the I2C controller, this register will need to be read by MCU to determine the cause for the interrupt. After this status has been read and appropriate actions are taken, the corresponding interrupt source will need to be written 1 to clear.

| Bit(s) | Mnemonic | Name                 | Description                                                                                                                                                                                                                                                                                        |
|--------|----------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | TIMEOUT  | TIMEOUT_IRQ          | This status is asserted if time-out is enabled and the timer expires. The internal master state machine will stop, and MCU will need to manually clear the state machine by either issuing software reset by disabling the transact_en bit. Time-out can be used to detect PCB or I2C malfunction. |
| 3      | ARB_LOST | SPARE                | <b>Reserved</b>                                                                                                                                                                                                                                                                                    |
| 2      | HS_NACKE | HS_NACKERR<br>RR     | This status is asserted if HS master code NACK error detection is enabled. If enabled, HS master code NACK err will cause transaction to end, and stop will be issued.                                                                                                                             |
| 1      | ACKERR   | ACKERR               | This status is asserted if ACK error detection is enabled. If enabled, ACKERR will cause transaction to end, and stop will be issued.                                                                                                                                                              |
| 0      | TRANSAC_ | TRANSAC_COMP<br>COMP | This status is asserted when a transaction is completed successfully.                                                                                                                                                                                                                              |

| A02A0010 <u>CONTROL</u> Control Register 0000 |           |                |                   |               |      |      |      |       |           |   |   |   |   |   |         |   |
|-----------------------------------------------|-----------|----------------|-------------------|---------------|------|------|------|-------|-----------|---|---|---|---|---|---------|---|
| Bit                                           | 15        | 14             | 13                | 12            | 11   | 10   | 9    | 8     | 7         | 6 | 5 | 4 | 3 | 2 | 1       | 0 |
| Name                                          | TIMEOUT_E | RESET_BUSSY_EN | TRANSFER_LEN_CHAN | ACKERR_DET_EN | RESE | TRAN | ACKE | DIR_C | CLK_EXT_E |   |   |   |   |   | RS_STOP |   |
| Type                                          | N         | SYN            | GE                | N             | T_BU | SFER | RR_D | HANG  | E         |   |   |   |   |   |         |   |
| Reset                                         | 0         | 0              | 0                 | 0             | RW   | RW   | RW   | RW    | RW        |   |   |   |   |   | RW      |   |

| Bit(s) | Mnemonic          | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8      | TIMEOUT_E         | TIMEOUT_EN       | <b>Enables time-out mechanism</b><br>When enabled, if SCL stays at 0 for too long period of time due to I2C slave holds SCL at 0 for too long or SCL stuck at 0 due to PCB issue, the master shall terminate the transaction, stop the internal state machine and assert time-out interrupt. MCU shall handle this case appropriately and reset the master and FIFO address before reissuing the transaction again. If this option is disabled, the HW timer will not count and nor expire forever.<br>0: Disable<br>1: Enable |
| 7      | RESET_BUSSPARE    | _BUSY_EN         | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6      | TRANSFER_LEN_CHAN | TRANSFER_LEN_AUX | <b>Specifies whether or not to change the transfer length after the first transfer is completed</b><br>If enabled, the transfers after the first transfer will use the transfer_len_aux parameter.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                  |
| 5      | ACKERR_DET_EN     | ACKERR_DET_EN    | <b>Enables slave ACK error detection</b><br>When enabled, if slave ACK error is detected, the master shall                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit(s) | Mnemonic   | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | DIR_CHANGE | DIR_CHANGE | terminate the transaction by issuing a STOP condition and then assert the ACKERR interrupt. MCU handles this case appropriately then resets the FIFO address before reissuing transaction. If this option is disabled, the controller will ignore slave ACK error and keep on scheduled transaction.<br>0: Disable<br>1: Enable                                                                                                                                                                                                      |
| 3      | CLK_EXT_E  | CLK_EXT_EN | <b>Combined transfer format, where the direction of transfer is to be changed from write to read after the FIRST RS condition</b><br><i>Note: When set to 1, the transfers after the direction change will be based on the transfer_len_aux parameter.</i><br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                |
| 1      | RS_STOP    | RS_STOP    | I2C spec allows slaves to hold the SCL line low if it is not yet ready for further processing.<br>Therefore, if this bit is set to 1, the master controller will enter a high wait state until the slave releases the SCL line.<br><b>In LS/FS mode, this bit affects multi-transfer transaction only.</b><br>It controls whether or not the REPEATED-START condition is used between transfers. The last ending transfer always ends with a STOP.<br>In HS mode, this bit must be set to 1.<br>0: Use STOP<br>1: Use REPEATED-START |

A02A0014 TRANSFER\_LEN Transfer Length Register (Number of Bytes per Transaction) 0001

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TRANSFER LEN AUX |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW               |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 1          |

| Bit(s) | Mnemonic         | Name         | Description                                                                                                                                                                                              |
|--------|------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    | TRANSFER_LEN_AUX | TRANSFER_LEN | Indicates the number of data bytes to be transferred in 1 transfer unit (excluding slave address byte)<br><i>Note: The value must be set to be bigger than 1; otherwise no transfer will take place.</i> |

A02A0018 TRANSAC\_LEN Transaction Length Register (Number of Transfers per Transaction) 0001

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TRANSAC LEN     |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW              |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 0 0 0 1 |

| Bit(s) | Mnemonic    | Name        | Description                                                                                                                                  |
|--------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | TRANSAC_LEN | TRANSAC_LEN | Indicates the number of transfers to be transferred in 1 transaction<br><i>Note: The value must be set to be bigger than 1; otherwise no</i> |

| Bit(s)                           | Mnemonic | Name | Description |
|----------------------------------|----------|------|-------------|
| <i>transfer will take place.</i> |          |      |             |

**A02A001C DELAY\_LEN Inter Delay Length Register 0002**

| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>DELAY_LEN</b>  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0 0 0 0 0 0 0 1 0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Mnemonic         | Name             | Description                                                                                                 |
|--------|------------------|------------------|-------------------------------------------------------------------------------------------------------------|
| 7:0    | <b>DELAY_LEN</b> | <b>DELAY_LEN</b> | Sets up wait delay between consecutive transfers when RS_STOP bit is set to 0<br>Unit: Half the pulse width |

**A02A0020 TIMING Timing Control Register 1303**

| Bit   | 15                  | 14                    | 13 | 12 | 11 | 10                    | 9 | 8 | 7 | 6                   | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-------|---------------------|-----------------------|----|----|----|-----------------------|---|---|---|---------------------|---|---|---|---|---|---|--|
| Name  | <b>DATA_READ_DJ</b> | <b>DATA_READ_TIME</b> |    |    |    | <b>SAMPLE_CNT_DIV</b> |   |   |   | <b>STEP_CNT_DIV</b> |   |   |   |   |   |   |  |
| Type  | RW                  | RW                    |    |    |    | RW                    |   |   |   | RW                  |   |   |   |   |   |   |  |
| Reset | 0                   | 0                     | 0  | 1  |    | 0                     | 1 | 1 |   | 0                   | 0 | 0 | 0 | 1 | 1 |   |  |

**Overview:** LS/FS only. This register is used to control the output waveform timing. Each half pulse width, i.e. each high or low pulse, is equal to (step\_cnt\_div+1)\*(sample\_cnt\_div + 1)/13MHz

| Bit(s) | Mnemonic               | Name                   | Description                                                                                                                                                                                                                                                                               |
|--------|------------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | <b>DATA_READ_DJ</b>    | <b>DATA_READ_DJ</b>    | When set to 1, data latch in sampling time during master reads are adjusted according to the DATA_READ_TIME value. Otherwise, by default, the data are latched in at half of the high pulse width point. This value must be set to be smaller than or equal to half the high pulse width. |
| 14:12  | <b>DATA_READ_DTIME</b> | <b>DATA_READ_DTIME</b> | This value is valid only when DATA_READ_DJ is set to 1. This can be used to adjust so that the data are latched in at earlier sampling points (assuming data are settled by then).                                                                                                        |
| 10:8   | <b>SAMPLE_CNT_DIV</b>  | <b>SAMPLE_CNT_DIV</b>  | Used for LS/FS only. This adjusts the width of each sample. Sample width = (sample_cnt_div + 1)/13MHz                                                                                                                                                                                     |
| 5:0    | <b>STEP_CNT_DIV</b>    | <b>STEP_CNT_DIV</b>    | Specifies the number of samples per half pulse width, i.e. each high or low pulse                                                                                                                                                                                                         |

**A02A0024 START Start Register 0000**

| Bit   | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>STAR T</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Mnemonic | Name  | Description                                                                                       |
|--------|----------|-------|---------------------------------------------------------------------------------------------------|
| 0      | START    | START | <b>Starts the transaction on the bus</b><br>It is auto de-asserted at the end of the transaction. |

**A02A0030 FIFO\_STAT FIFO Status Register 0001**

| Bit   | 15      | 14 | 13 | 12 | 11      | 10 | 9 | 8 | 7           | 6 | 5 | 4 | 3 | 2 | 1       | 0        |
|-------|---------|----|----|----|---------|----|---|---|-------------|---|---|---|---|---|---------|----------|
| Name  | RD_ADDR |    |    |    | WR_ADDR |    |   |   | FIFO_OFFSET |   |   |   |   |   | WR_FULL | RD_EMPTY |
| Type  | RO      |    |    |    | RU      |    |   |   | RU          |   |   |   |   |   | RO      | RO       |
| Reset | 0       | 0  | 0  | 0  | 0       | 0  | 0 | 0 | 0           | 0 | 0 | 0 | 0 | 0 | 0       | 1        |

| Bit(s) | Mnemonic    | Name        | Description                                                                 |
|--------|-------------|-------------|-----------------------------------------------------------------------------|
| 15:12  | RD_ADDR     | RD_ADDR     | <b>Current RD address pointer</b><br>Only bit [2:0] have physical meanings. |
| 11:8   | WR_ADDR     | WR_ADDR     | <b>Current WR address pointer</b><br>Only bit [2:0] have physical meanings. |
| 7:4    | FIFO_OFFSET | FIFO_OFFSET | <b>wr_addr[3:0] - rd_addr[3:0]</b>                                          |
| 1      | WR_FULL     | WR_FULL     | <b>Indicates FIFO is full</b>                                               |
| 0      | RD_EMPTY    | RD_EMPTY    | <b>Indicates FIFO is empty</b>                                              |

**A02A0038 FIFO\_ADDR\_CLR FIFO Address Clear Register 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FIFO_ADDR_CLR |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | WO            |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0             |

| Bit(s) | Mnemonic      | Name          | Description                                                                                       |
|--------|---------------|---------------|---------------------------------------------------------------------------------------------------|
| 0      | FIFO_ADDR_CLR | FIFO_ADDR_CLR | When written with 1'b1, a 1 pulse fifo_addr_clr is generated to clear the FIFO address back to 0. |

**A02A0040 IO\_CONFIG IO Config Register 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | IDLE_OE_EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW         |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0          |

**Overview:** This register is used to configure the I/O for the SDA and SCL lines to select between normal I/O mode or open-drain mode to support wired-and bus.

| Bit(s) | Mnemonic   | Name       | Description                         |
|--------|------------|------------|-------------------------------------|
| 3      | IDLE_OE_EN | IDLE_OE_EN | 0: Does not drive bus in idle state |

| Bit(s) | Mnemonic  | Name          | Description                |                 |          |     |  |  |  |  |  |  |  |  |
|--------|-----------|---------------|----------------------------|-----------------|----------|-----|--|--|--|--|--|--|--|--|
| N      |           |               | 1: Drive bus in idle state |                 |          |     |  |  |  |  |  |  |  |  |
| 1      | SDA_IO_CO | SDA_IO_CONFIG | 0:                         | Normal          | tristate | I/O |  |  |  |  |  |  |  |  |
|        | NFIG      |               | 1:                         | Open-drain mode |          |     |  |  |  |  |  |  |  |  |
| 0      | SCL_IO_CO | SCL_IO_CONFIG | 0:                         | Normal          | tristate | I/O |  |  |  |  |  |  |  |  |
|        | NFIG      |               | 1:                         | Open-drain mode |          |     |  |  |  |  |  |  |  |  |

**A02A0048 HS High Speed Mode Register 0102**

| Bit   | 15 | 14 | 13                | 12 | 11 | 10              | 9 | 8 | 7 | 6           | 5 | 4 | 3 | 2 | 1        | 0     |
|-------|----|----|-------------------|----|----|-----------------|---|---|---|-------------|---|---|---|---|----------|-------|
| Name  |    |    | HS_SAMPLE_CNT_DIV |    |    | HS_STEP_CNT_DIV |   |   |   | MASTER_CODE |   |   |   |   | HS_NACKE | HS_EN |
| Type  |    |    | RW                |    |    | RW              |   |   |   | RW          |   |   |   |   | RW       | RW    |
| Reset | 0  | 0  | 0                 |    | 0  | 0               | 1 |   | 0 | 0           | 0 |   |   | 1 | 0        |       |

**Overview:** This register contains options for supporting high speed operation features. Each HS half pulse width, i.e. each high or low pulse, is equal to (step\_cnt\_div+1)\*(sample\_cnt\_div + 1)/13MHz.

| Bit(s)                                 | Mnemonic                | Name              | Description                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------------|-------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 14:12                                  | HS_SAMPLE_CNT_E_CNT_DIV | HS_SAMPLE_CNT_DIV | When the high-speed mode is entered after the master code transfer is completed, the sample width will become dependent on this parameter.                       |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10:8                                   | HS_STEP_CNT_DIV         | HS_STEP_CNT_DIV   | When the high-speed mode is entered after the master code transfer is completed, the number of samples per half pulse width will become dependent on this value. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6:4                                    | MASTER_CODE             | MASTER_CODE       | This is the 3 bit programmable value for the master code to be transmitted.                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1                                      | HS_NACKERR_DE           | HS_NACKERR_DE     | Enables NACKERR detection during the master code transmission                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                        | RR_DET_EN               | T_EN              | When enabled, if NACK is not received after the master code is transmitted, the transaction will be terminated with a STOP condition.                            |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0                                      | HS_EN                   | HS_EN             | Enables high-speed transaction                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <i>Note: rs_stop must be set to 1.</i> |                         |                   |                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**A02A0050 SOFTRESET Soft Reset Register 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | SOFT_RESET |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | WO         |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0          |   |

| Bit(s) | Mnemonic   | Name       | Description                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|------------|------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0      | SOFT_RESET | SOFT_RESET | When written with 1'b1, a 1 pulse soft reset is used as synchronous reset to reset the I2C internal hardware circuits. |  |  |  |  |  |  |  |  |  |  |  |  |  |

A02A0060 SPARE SPARE 0000 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0 |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | SPARE |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW    |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0     | 0 | 0 | 0 |

| Bit(s) | Mnemonic     | Name  | Description             |
|--------|--------------|-------|-------------------------|
| 3:0    | <b>SPARE</b> | SPARE | Reserved for future use |

 A02A0064 DEBUGSTAT Debug Status Register 0020 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6            | 5           | 4 | 3 | 2 | 1 | 0  |
|-------|----|----|----|----|----|----|---|---|----------|--------------|-------------|---|---|---|---|----|
| Name  |    |    |    |    |    |    |   |   | BUS_BUSY | MASTER_WRITE | MASTER_READ |   |   |   |   |    |
| Type  |    |    |    |    |    |    |   |   | RO       | RO           | RO          |   |   |   |   | RO |
| Reset |    |    |    |    |    |    |   |   | 0        | 0            | 1           | 0 | 0 | 0 | 0 | 0  |

| Bit(s) | Mnemonic         | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | <b>BUS_BUSY</b>  | SPARE        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6      | <b>MASTER_W</b>  | MASTER_WRITE | <b>For debugging only</b><br>1: Current transfer is in the master write dir.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5      | <b>MASTER_R</b>  | MASTER_READ  | <b>For debugging only</b><br>1: Current transfer is in the master read dir.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4:0    | <b>MASTER_ST</b> | MASTER_STATE | <b>(For debugging only) Reads back the current master_state.</b><br>0: Idle state<br>1: I2C master is preparing to send out the start bit, SCL=1, SDA=1.<br>2: I2C master is sending out the start bit, SCL=1, SDA=0.<br>3: I2C master/slave is preparing to transmit data bit, SCL=0, SDA=data bit. (Data bit can be changed when SCL=0.)<br>4: I2C master/slave is transmitting data bit, SCL=1, SDA=data bit. (Data bit is stable when SCL=1.)<br>5: I2C master/slave is preparing to transmit the ACK bit, SCL=0, SDA=ack. (The ACK bit can be changed when SCL=0.)<br>6: I2C master/slave is transmitting the ACK bit, SCL=1, SDA=0. (The ACK bit is stable when SCL=1.)<br>7: I2C master is preparing to send out stop bit or repeated-start bit, SCL=0, SDA=0/1. (0: Stop bit; 1: Repeated-start bit)<br>8: I2C master is sending out stop bit or repeated-start bit, SCL=1, SDA=1/0. (0: Repeated-start bit; 1: Stop bit)<br>9: I2C master is in delay start between two transfers, SCL=1, SDA=1.<br>10: I2C master is in FIFO wait state; For writing transaction, it means FIFO is empty and I2C master is waiting for DMA controller to write data into FIFO. For reading transaction, it means FIFO is full and I2C master is waiting for DMA controller to read data from FIFO, SCL=0, SDA=don't care.<br>12: I2C master is preparing to send out data bit of master code. This state is used only in high-speed transaction, SCL=0, SDA=data bit of master code. (Data bit of master code can be changed when SCL=0.) |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                               |
|--------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13     |          |      | I2C master is sending out data bit of master code. This state is used only in high-speed transaction, SCL=1, SDA=data bit of master code. (Data bit of master code is stable when SCL=1.) |
| 14     |          |      | I2C master/slave is preparing to transmit the NACK bit, SCL=0, SDA=nack bit. (The NACK bit can be changed when SCL=0.) This state is used only in high-speed transaction.                 |
| 15     |          |      | I2C master/slave is transmitting the NACK bit, SCL=1, SDA=1. This state is used only in high-speed transaction.                                                                           |

**A02A0068    DEBUGCTRL    Debug Control Register                                  0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                | 0              |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------------|----------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | APB_APB_DEBUG_RD | FIFO_APB_DEBUG |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | WO               | RW             |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0                | 0              |

| Bit(s) | Mnemonic       | Name           | Description                                                                                                                                                                                                                                             |
|--------|----------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | APB_DEBUG_G_RD | APB_DEBUG_RD   | Only valid when fifo_apb_debug is set to 1<br>Writing to this register will generate a 1 pulsed FIFO APB RD signal for reading the FIFO data.                                                                                                           |
| 0      | FIFO_APB_DEBUG | FIFO_APB_DEBUG | Used for trace 32 debugging<br>When using trace 32, and the memory map is shown, turning this bit on will block the normal APB read access. The APB read access to the FIFO will then be enabled by writing to apb_debug_rd.<br>0: Disable<br>1: Enable |

**A02A006C    TRANSFER LE N\_AUX Transfer Length Register (Number of Bytes per Transfer)                                  0001**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1            | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | TRANSFER_LEN |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW           |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0            | 0 |

| Bit(s) | Mnemonic         | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    | TRANSFER_LEN_AUX | TRANSFER_LEN_AUX | Only valid when dir_change or transfer_len_change is set to 1. Indicates the number of data bytes to be transferred in 1 transfer unit (excluding slave address byte) for the transfers following the direction change or transfer_len_change<br>If dir_change =1, the first write transfer length will depend on transfer_len, while the second read transfer length will depend on transfer_len_aux. Dir change is always after the first transfer. Similarly, transfer length change is always after the first transfer.<br>Note: The value must be set to be bigger than 1; otherwise no transfer will take place. |

A02A0074 TIMEOUT**Timeout Timing Register**

FFFF

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                 |
|--------|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | TIMEOUT  |      | <p>Indicates the number of steps to count before time-out</p> <p>The time-out counter counts only when the time-out mechanism is enabled and has started a transaction.</p> |

## 3.12 Real Time Clock

### 3.12.1 General Descriptions

The Real-Time Clock (RTC) module provides time and data information, as well as 32.768kHz clock. By configuring pin XOSC32\_ENB, the use of the 32k crystal can be determined, i.e. using a 32k crystal, or not to use a 32k crystal. The RTC block has an independent power supply. When the mobile handset is powered off, a dedicated regulator supplies the RTC block. If the main battery is not present, a backup supply such as a small mercury cell battery or a large capacitor is used. In addition to providing timing data, an alarm interrupt is generated and can be used to power up the baseband core. Regulator interrupts corresponding to seconds, minutes, hours and days can be generated whenever the time counter value reaches a maximum value (e.g., 59 for seconds and minutes, 23 for hours, etc.). The year span is supported up to 2127. The maximum day-of-month values, which depend on the leap year condition, are stored in the RTC block.

### 3.12.2 Register Definition

Module name: RTC Base address: (+A0710000h)

| Address   | Name                | Width | Register function                                                                                                                                                                      |
|-----------|---------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0710000  | <u>RTC_BBPU</u>     | 16    | <b>Baseband power up</b>                                                                                                                                                               |
| A071 0004 | <u>RTC IRQ STA</u>  | 16    | <b>RTC IRQ status</b><br>This register is fixed to 0 when RTC_POWERKEY1 & RTC_POWERKEY2 unmatch the correct values.                                                                    |
| A071 0008 | <u>RTC IRQ EN</u>   | 16    | <b>RTC IRQ enable</b><br>This register is fixed to 0 when RTC_POWERKEY1 & RTC_POWERKEY2 unmatch the correct values.                                                                    |
| A071 000C | <u>RTC CII EN</u>   | 16    | <b>Counter increment IRQ enable</b><br>This register activates or de-activates the IRQ generation when the TC counter reaches its maximum value.                                       |
| A071 0010 | <u>RTC AL MAS K</u> | 16    | <b>RTC alarm mask</b><br>The alarm condition for alarm IRQ generation depends on whether or not the corresponding bit in this register is masked. Warning: If you set all bits to 1 in |

| Address   | Name                 | Width | Register function                                                                                                                                                                                                       |
|-----------|----------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |                      |       | RTC_AL_MASK (i.e. RTC_AL_MASK=0x7f) and PWREN=1 in RTC_BBPU, it means the alarm will come every second, not disabled.                                                                                                   |
| A071 0014 | <u>RTC_TC_SEC</u>    | 16    | RTC seconds time counter register                                                                                                                                                                                       |
| A071 0018 | <u>RTC_TC_MIN</u>    | 16    | RTC minutes time counter register                                                                                                                                                                                       |
| A071001C  | <u>RTC_TC_HOU</u>    | 16    | RTC hours time counter register                                                                                                                                                                                         |
| A0710020  | <u>RTC_TC_DOM</u>    | 16    | RTC day-of-month time counter register                                                                                                                                                                                  |
| A0710024  | <u>RTC_TC_DOW</u>    | 16    | RTC day-of-week time counter register                                                                                                                                                                                   |
| A0710028  | <u>RTC_TC_MTH</u>    | 16    | RTC month time counter register                                                                                                                                                                                         |
| A071002C  | <u>RTC_TC_YEA</u>    | 16    | RTC year time counter register                                                                                                                                                                                          |
| A0710030  | <u>RTC_AL_SEC</u>    | 16    | RTC second alarm setting register                                                                                                                                                                                       |
| A0710034  | <u>RTC_AL_MIN</u>    | 16    | RTC minute alarm setting register                                                                                                                                                                                       |
| A0710038  | <u>RTC_AL_HOU</u>    | 16    | RTC hour alarm setting register                                                                                                                                                                                         |
| A071003C  | <u>RTC_AL_DOM</u>    | 16    | RTC day-of-month alarm setting register                                                                                                                                                                                 |
| A0710040  | <u>RTC_AL_DOW</u>    | 16    | RTC day-of-week alarm setting register                                                                                                                                                                                  |
| A0710044  | <u>RTC_AL_MTH</u>    | 16    | RTC month alarm setting register                                                                                                                                                                                        |
| A0710048  | <u>RTC_AL_YEA</u>    | 16    | RTC year alarm setting register                                                                                                                                                                                         |
| A071004C  | <u>RTC_OSC32C_ON</u> | 16    | <b>OSC32 control</b><br>The function is only active when RTC_POWERKEY1 & RTC_POWERKEY2 match the correct values.                                                                                                        |
| A0710050  | <u>RTC_POWERKEY1</u> | 16    | RTC_POWERKEY1 register                                                                                                                                                                                                  |
| A0710054  | <u>RTC_POWERKEY2</u> | 16    | RTC_POWERKEY2 register                                                                                                                                                                                                  |
| A0710058  | <u>RTC_PDN1</u>      | 16    | PDN1                                                                                                                                                                                                                    |
| A071005C  | <u>RTC_PDN2</u>      | 16    | PDN2                                                                                                                                                                                                                    |
| A0710060  | <u>RTC_SPAR0</u>     | 16    | Spare register for specific purpose                                                                                                                                                                                     |
| A0710064  | <u>RTC_SPAR1</u>     | 16    | Spare register for specific purpose                                                                                                                                                                                     |
| A0710068  | <u>RTC_PROT</u>      | 16    | Lock/unlock scheme to prevent RTC miswriting                                                                                                                                                                            |
| A071006C  | <u>RTC_DIFF</u>      | 16    | <b>One-time calibration offset</b><br>This register is fixed to 0 when RTC_POWERKEY1 & RTC_POWERKEY2 unmatch the correct values.                                                                                        |
| A0710070  | <u>RTC_CALI</u>      | 16    | <b>Repeat calibration offset</b><br>This register is fixed to 0 when RTC_POWERKEY1 & RTC_POWERKEY2 unmatch the correct values.                                                                                          |
| A0710074  | <u>RTC_WRTGR</u>     | 16    | Enable transfers from core to RTC in queue                                                                                                                                                                              |
| A0710078  | <u>RTC_CON</u>       | 16    | <b>Other RTC control registers</b><br>Note: LPRST and LPEN are tied to 0 internally when RTC_POWERKEY1 & RTC_POWERKEY2 do not match the correct values. After changing RTC_CON, write WRTGR = 1 to make it take effect. |

## A0710000 RTC\_BBPU Baseband Power Up 0000

|       |          |    |    |    |    |    |   |   |        |         |         |      |      |   |       |   |
|-------|----------|----|----|----|----|----|---|---|--------|---------|---------|------|------|---|-------|---|
| Bit   | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7      | 6       | 5       | 4    | 3    | 2 | 1     | 0 |
| Mne   | KEY_BBPU |    |    |    |    |    |   |   | CBUS Y | RELO AD | CLRP KY | AUTO | BBPU |   | PWREN |   |
| Type  | WO       |    |    |    |    |    |   |   | RO     | WO      | WO      | RW   | RW   |   | RW    |   |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0      | 0       | 0       | 0    | 0    |   | 0     |   |

| Bit (s) | Mnemonic | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8    | KEY_BBPU | KEY_BBPU | A bus write is acceptable only when KEY_BBPU=0x43.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6       | CBUSY    | CBUSY    | The read/write channels between RTC/Core is busy. This bit indicates high after the software program sequence to anyone of RTC data registers and enables the transfer by RTC_WRTGR = 1. In addition, it is high after the reset from low to high due to RTC reload process.                                                                                                                                                                                                                     |
| 5       | RELOAD   | RELOAD   | <b>Reloads the values from RTC domain to core domain</b><br>Generally the RTC will reload and synchronize the data from RTC to core when being reset from 0 to 1. This bit can be treated as a debugging bit.                                                                                                                                                                                                                                                                                    |
| 4       | CLRPKY   | CLRPKY   | <b>Clears powerkey1 and powerkey2 at the same time</b><br>In some cases, the software may clear powerkey1 & powerkey2. BBWAKEUP depends on the matching specific patterns of powerkey1 and powerkey2. If any one of powerkey1 or powerkey2 or BBPU is cleared, BBWAKEUP will go low immediately. The software cannot program the other control bits without power. By programming RTC_BBPU with CLRPKY = 1 and BBPU = 0 condition, RTC can clear powerkey1, powerkey2 and BBPU at the same time. |
| 3       | AUTO     | AUTO     | <b>Controls if BBWAKEUP is automatically in the low state when SYSRST transitions from high to low.</b><br>0: BBWAKEUP is not automatically in the low state when SYSRST# transitions are from high to low.<br>1: BBWAKEUP is automatically in the low state when SYSRST# transitions are from high to low. The function is only active when RTC_POWERKEY1 & RTC_POWERKEY2 match the correct values.                                                                                             |
| 2       | BBPU     | BBPU     | <b>Controls the power of PMU</b><br>If powerkey1 = A357h and powerkey2 = 67D2h, PMU takes on the value programmed by software; otherwise PMU is low.<br>0: Power down<br>1: Power on                                                                                                                                                                                                                                                                                                             |
| 0       | PWREN    | PWREN    | 0: RTC alarm has no action on power switch.<br>1: When an RTC alarm occurs, BBPU is set to 1 and the system is powered on by RTC alarm wakeup.                                                                                                                                                                                                                                                                                                                                                   |

## A0710004 RTC IRQ STA RTC IRQ Status 0000

|       |    |    |    |    |    |    |   |   |   |   |   |   |       |   |         |       |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-------|---|---------|-------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3     | 2 | 1       | 0     |
| Mne   |    |    |    |    |    |    |   |   |   |   |   |   | LPSTA |   | TCS STA | ALSTA |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | RC    |   | RC      | RC    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0     |   | 0       | 0     |

**Overview:** This register is read-cleared and is fixed to 0 when RTC\_POWERKEY1 and RTC\_POWERKEY2 unmatch the correct values.

| Bit (s) | Mnemonic | Name  | Description                                                                                                                                                                                                                                                                                                               |
|---------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3       | LPSTA    | LPSTA | <b>Indicates the IRQ status and whether or not the LPD is asserted</b><br>(LPD function is either provided by XOSC32 or EOSC32 <sup>6</sup> , depending on XOSC32_ENB)<br>0: No IRQ occurred; the 32K clock is good.<br>1: IRQ occurred; the 32K clock stops. This can be masked by LP_EN or cleared by initializing LPD. |
| 1       | TCSTA    | TCSTA | <b>Indicates the IRQ status and whether or not the tick condition has been met.</b><br>0: No IRQ occurred; the tick condition has not been met.<br>1: IRQ occurred; the tick condition has been met.                                                                                                                      |
| 0       | ALSTA    | ALSTA | <b>Indicates the IRQ status and whether or not the alarm condition has been met.</b><br>0: No IRQ occurred; the alarm condition has not been met.<br>1: IRQ occurred; the alarm condition has been met.                                                                                                                   |

| A0710008 <u>RTC IRQ EN</u> RTC IRQ Enable    0000 |    |    |    |    |    |    |   |   |   |   |   |   |       |          |       |       |
|---------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|-------|----------|-------|-------|
| Bit                                               | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3     | 2        | 1     | 0     |
| Mne                                               |    |    |    |    |    |    |   |   |   |   |   |   | LP_EN | ONES HOT | TC_EN | AL_EN |
| Type                                              |    |    |    |    |    |    |   |   |   |   |   |   | RW    | RW       | RW    | RW    |
| Reset                                             |    |    |    |    |    |    |   |   |   |   |   |   | 0     | 0        | 0     | 0     |

**Overview:** This register is fixed to 0 when RTC\_POWERKEY1 and RTC\_POWERKEY2 unmatch the correct values.

| Bit (s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                 |
|---------|----------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3       | LP_EN    | LP_EN   | <b>Enables the control bit for IRQ generation if low power detected (32k clock off).</b><br>0: Disable IRQ generations<br>1: Enable LPD                                                                                                     |
| 2       | ONESHOT  | ONESHOT | <b>Controls automatic reset of AL_EN and TC_EN</b>                                                                                                                                                                                          |
| 1       | TC_EN    | TC_EN   | Enables the control bit for IRQ generation if the tick condition has been met.<br>0: Disable IRQ generations<br>1: Enable the tick time match interrupt. Clear the interrupt when ONESHOT is high upon generation of the corresponding IRQ. |
| 0       | AL_EN    | AL_EN   | <b>Enables the control bit for IRQ generation if the alarm condition has been met.</b><br>0: Disable IRQ generations                                                                                                                        |

| Bit (s) | Mnemonic | Name | Description                                                                                                                  |
|---------|----------|------|------------------------------------------------------------------------------------------------------------------------------|
|         |          |      | 1: Enable the alarm time match interrupt. Clear the interrupt when ONESHOT is high upon generation of the corresponding IRQ. |

| A071000C RTC_CII_EN Counter Increment IRQ Enable |    |    |    |    |    |    |           |           |           |        |        |        |        |        | 0000   |        |  |
|--------------------------------------------------|----|----|----|----|----|----|-----------|-----------|-----------|--------|--------|--------|--------|--------|--------|--------|--|
| Bit                                              | 15 | 14 | 13 | 12 | 11 | 10 | 9         | 8         | 7         | 6      | 5      | 4      | 3      | 2      | 1      | 0      |  |
| Mne                                              |    |    |    |    |    |    | 1/8SECCII | 1/4SECCII | 1/2SECCII | YEACII | MTHCII | DOWCII | DOMCII | HOUCCI | MINCII | SECCII |  |
| Type                                             |    |    |    |    |    |    | RW        | RW        | RW        | RW     | RW     | RW     | RW     | RW     | RW     | RW     |  |
| Reset                                            |    |    |    |    |    |    | 0         | 0         | 0         | 0      | 0      | 0      | 0      | 0      | 0      | 0      |  |

**Overview:** This register activates or de-activates the IRQ generation when the TC counter reaches its maximum value.

| Bit (s) | Mnemonic  | Name       | Description                                                         |
|---------|-----------|------------|---------------------------------------------------------------------|
| 9       | 1/8SECCII | SECCII_1_8 | Set the bit to 1 to activate the IRQ at each 1/8 of a second update |
| 8       | 1/4SECCII | SECCII_1_4 | Set the bit to 1 to activate the IRQ at each 1/4 of a second update |
| 7       | 1/2SECCII | SECCII_1_2 | Set the bit to 1 to activate the IRQ at each 1/2 of a second update |
| 6       | YEACII    | YEACII     | Set the bit to 1 to activate the IRQ at each year update            |
| 5       | MTHCII    | MTHCII     | Set the bit to 1 to activate the IRQ at each month update           |
| 4       | DOWCII    | DOWCII     | Set the bit to 1 to activate the IRQ at each day-of-week update     |
| 3       | DOMCII    | DOMCII     | Set the bit to 1 to activate the IRQ at each day-of-month update    |
| 2       | HOUCCI    | HOUCCI     | Set the bit to 1 to activate the IRQ at each hour update            |
| 1       | MINCII    | MINCII     | Set the bit to 1 to activate the IRQ at each minute update          |
| 0       | SECCII    | SECCII     | Set this bit to 1 to activate the IRQ at each second update         |

| A0710010 RTC_AL_MAS RTC Alarm Mask |    |    |    |    |    |    |   |   |   |         |         |         |         |         | 0000    |         |  |
|------------------------------------|----|----|----|----|----|----|---|---|---|---------|---------|---------|---------|---------|---------|---------|--|
| Bit                                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6       | 5       | 4       | 3       | 2       | 1       | 0       |  |
| Mne                                |    |    |    |    |    |    |   |   |   | YEA_MSK | MTH_MSK | DOW_MSK | DOM_MSK | HOU_MSK | MIN_MSK | SEC_MSK |  |
| Type                               |    |    |    |    |    |    |   |   |   | RW      |  |
| Reset                              |    |    |    |    |    |    |   |   |   | 0       | 0       | 0       | 0       | 0       | 0       | 0       |  |

**Overview:** The alarm condition for alarm IRQ generation depends on whether or not the corresponding bit in this register is masked. Note that if all bits 1 in RTC\_AL\_MASK are set (i.e. RTC\_AL\_MASK = 0x7f) and PWREN = 1 in RTC\_BBPU, it means the alarm will come every second, not disabled.

| Bit (s) | Mnemonic | Name    | Description                                                                     |
|---------|----------|---------|---------------------------------------------------------------------------------|
| 6       | YEA_MSK  | YEA_MSK | 0: Condition (RTC_TC_YEA = RTC_AL_YEA) is checked to generate the alarm signal. |

| Bit (s) | Mnemonic       | Name    | Description                                                                                                                                                                                                                                                                                                                             |
|---------|----------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5       | <b>MTH_MSK</b> | MTH_MSK | 1: Condition (RTC_TC_YEA = RTC_AL_YEA) is masked, i.e. the value of RTC_TC_YEA does not affect the alarm IRQ generation.<br>0: Condition (RTC_TC_MTH = RTC_AL_MTH) is checked to generate the alarm signal.<br>1: Condition (RTC_TC_MTH = RTC_AL_MTH) is masked, i.e. the value of RTC_TC_MTH does not affect the alarm IRQ generation. |
| 4       | <b>DOW_MSK</b> | DOW_MSK | 0: Condition (RTC_TC_DOW = RTC_AL_DOW) is checked to generate the alarm signal.<br>1: Condition (RTC_TC_DOW = RTC_AL_DOW) is masked, i.e. the value of RTC_TC_DOW does not affect the alarm IRQ generation.                                                                                                                             |
| 3       | <b>DOM_MSK</b> | DOM_MSK | 0: Condition (RTC_TC_DOM = RTC_AL_DOM) is checked to generate the alarm signal.<br>1: Condition (RTC_TC_DOM = RTC_AL_DOM) is masked, i.e. the value of RTC_TC_DOM does not affect the alarm IRQ generation.                                                                                                                             |
| 2       | <b>HOU_MSK</b> | HOU_MSK | 0: Condition (RTC_TC_HOU = RTC_AL_HOU) is checked to generate the alarm signal.<br>1: Condition (RTC_TC_HOU = RTC_AL_HOU) is masked, i.e. the value of RTC_TC_HOU does not affect the alarm IRQ generation.                                                                                                                             |
| 1       | <b>MIN_MSK</b> | MIN_MSK | 0: Condition (RTC_TC_MIN = RTC_AL_MIN) is checked to generate the alarm signal.<br>1: Condition (RTC_TC_MIN = RTC_AL_MIN) is masked, i.e. the value of RTC_TC_MIN does not affect the alarm IRQ generation.                                                                                                                             |
| 0       | <b>SEC_MSK</b> | SEC_MSK | 0: Condition (RTC_TC_SEC = RTC_AL_SEC) is checked to generate the alarm signal.<br>1: Condition (RTC_TC_SEC = RTC_AL_SEC) is masked, i.e. the value of RTC_TC_SEC does not affect the alarm IRQ generation.                                                                                                                             |

**A0710014    RTC\_TC\_SEC    RTC Seconds Time Counter Register                          0000**

| Bit          | 15                              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------|---------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Mne</b>   | <b>TC_SECOND</b>                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | RW                              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit (s) | Mnemonic         | Name      | Description                                                       |
|---------|------------------|-----------|-------------------------------------------------------------------|
| 5:0     | <b>TC_SECOND</b> | TC_SECOND | <b>Second initial value for the time counter</b><br>Range: 0 ~ 59 |

**A0710018    RTC\_TC\_MIN    RTC Minutes Time Counter Register                          0000**

| Bit         | 15               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Mne</b>  | <b>TC_MINUTE</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b> | RW               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| <b>Reset</b> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

| Bit (s) | Mnemonic         | Name      | Description                                                |
|---------|------------------|-----------|------------------------------------------------------------|
| 5:0     | <b>TC_MINUTE</b> | TC_MINUTE | Minute initial value for the time counter<br>Range: 0 ~ 59 |

**A071001C    RTC\_TC\_HOU    RTC Hours Time Counter Register                          0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0              |
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>TC_HOUR</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW             |
| <b>Reset</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 0      |

| Bit (s) | Mnemonic       | Name    | Description                                              |
|---------|----------------|---------|----------------------------------------------------------|
| 4:0     | <b>TC_HOUR</b> | TC_HOUR | Hour initial value for the time counter<br>Range: 0 ~ 23 |

**A0710020    RTC\_TC\_DOM    RTC Day-of-month Time Counter Register                          0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |               |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>TC_DOM</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW            |
| <b>Reset</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 0     |

| Bit (s) | Mnemonic      | Name   | Description                                                                                                                                                      |
|---------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0     | <b>TC_DOM</b> | TC_DOM | Day-of-month initial value for the time counter<br>The day-of-month maximum value depends on the leap year condition, i.e. 2 LSB of year time counter are zeros. |

**A0710024    RTC\_TC\_DO\_W    RTC Day-of-week Time Counter Register                          0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |               |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>TC_DOW</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW            |
| <b>Reset</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0         |

| Bit (s) | Mnemonic      | Name   | Description                                                    |
|---------|---------------|--------|----------------------------------------------------------------|
| 2:0     | <b>TC_DOW</b> | TC_DOW | Day-of-week initial value for the time counter<br>Range: 1 ~ 7 |

**A0710028    RTC\_TC\_MTH    RTC Month Time Counter Register                          0000**

|            |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Bit</b> | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

|       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|
| Mne   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | TC_MONTH |
| Type  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RW       |
| Reset |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0 0 0 0  |

| Bit (s) | Mnemonic | Name     | Description                                               |
|---------|----------|----------|-----------------------------------------------------------|
| 3:0     | TC_MONTH | TC_MONTH | Month initial value for the time counter<br>Range: 1 ~ 12 |

**A071002C    RTC\_TC\_YEA    RTC Year Time Counter Register                          0000**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                 |
| Mne   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TC_YEAR           |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 0 0 0 0 0 |

| Bit (s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:0     | TC_YEAR  | TC_YEAR | Year initial value for the time counter<br>Range: 0 ~ 127 (2000~2127).<br>The software can bias the year as multiples of 4 for the internal leap-year formula. Here are 3 examples: 2000 ~ 2127, 1972 ~ 2099 and 1904 ~ 2031. To simplify the process, the RTC hardware treats all 4-multiple as leap years. If the range you define includes non-leap 4-multiple year (e.g. 2100), please adjust it to the correct date by yourselves. (e.g. change Feb. 29th, 2100 to Mar. 1st, 2100). It is suggested to bias the range to be bigger than 1900 and smaller than 2100 to evade the manual adjustment, i.e. the bias values are suggested to be in the range of [-28, -96], that are (1972~ 2099) ~ (1904~ 2031).<br>The formal leap formula:<br>If year modulo 400 is 0 then leap<br>Else if year modulo 100 is 0 then no_leap<br>Else if year modulo 4 is 0 then leap<br>Else no_leap |

**A0710030    RTC\_AL\_SEC    RTC Second Alarm Setting Register                          0000**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                 |
| Mne   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | AL_SECOND         |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 0 0 0 0 0 |

| Bit (s) | Mnemonic  | Name      | Description                                                |
|---------|-----------|-----------|------------------------------------------------------------|
| 5:0     | AL_SECOND | AL_SECOND | Second value of the alarm counter setting<br>Range: 0 ~ 59 |

**A0710034    RTC\_AL\_MIN    RTC Minute Alarm Setting Register                          0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                  |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>AL_MINUTE</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW               |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                |

| <b>Bit (s)</b> | <b>Mnemonic</b>  | <b>Name</b>      | <b>Description</b>                                         |
|----------------|------------------|------------------|------------------------------------------------------------|
| 5:0            | <b>AL_MINUTE</b> | <b>AL_MINUTE</b> | Minute value of the alarm counter setting<br>Range: 0 ~ 59 |

**A0710038 RTC\_AL\_HOU RTC Hour Alarm Setting Register 0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0              |
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>AL_HOUR</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW             |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0              |

| <b>Bit (s)</b> | <b>Mnemonic</b>  | <b>Name</b>      | <b>Description</b>                                       |
|----------------|------------------|------------------|----------------------------------------------------------|
| 15:8           | <b>NEW_SPARE</b> | <b>NEW_SPARE</b> | New spare-register 0<br>0 0                              |
| 4:0            | <b>AL_HOUR</b>   | <b>AL_HOUR</b>   | Hour value of the alarm counter setting<br>Range: 0 ~ 23 |

**A071003C RTC\_AL\_DOM RTC Day-of-month Alarm Setting Register 0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |               |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>AL_DOM</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW            |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0             |

| <b>Bit (s)</b> | <b>Mnemonic</b>  | <b>Name</b>      | <b>Description</b>                                                                                                                                               |
|----------------|------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8           | <b>NEW_SPARE</b> | <b>NEW_SPARE</b> | New spare-register 1<br>1 1                                                                                                                                      |
| 4:0            | <b>AL_DOM</b>    | <b>AL_DOM</b>    | Day-of-month value of the alarm counter setting<br>The day-of-month maximum value depends on the leap year condition, i.e. 2 LSB of year time counter are zeros. |

**A0710040 RTC\_AL\_DOW RTC Day-of-week Alarm Setting Register 0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |               |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>AL_DOW</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW            |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0             |

| <b>Bit (s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b> |
|----------------|-----------------|-------------|--------------------|
|                |                 |             |                    |

| Bit (s) | Mnemonic  | Name      | Description                                                    |
|---------|-----------|-----------|----------------------------------------------------------------|
| 15:8    | NEW_SPARE | NEW_SPARE | New spare-register 2                                           |
| 2       |           | 2         |                                                                |
| 2:0     | AL_DOW    | AL_DOW    | Day-of-week value of the alarm counter setting<br>Range: 1 ~ 7 |

**A0710044 RTC\_AL\_MTH RTC Month Alarm Setting Register 0000**

| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3        | 2 | 1 | 0 |
|-------|------------|----|----|----|----|----|---|---|---|---|---|---|----------|---|---|---|
| Mne   | NEW_SPARE3 |    |    |    |    |    |   |   |   |   |   |   | AL_MONTH |   |   |   |
| Type  | RW         |    |    |    |    |    |   |   |   |   |   |   | RW       |   |   |   |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   |   |   | 0        | 0 | 0 | 0 |

| Bit (s) | Mnemonic  | Name      | Description                                             |
|---------|-----------|-----------|---------------------------------------------------------|
| 15:8    | NEW_SPARE | NEW_SPARE | New spare-register 3.                                   |
| 3       |           | 3         |                                                         |
| 3:0     | AL_MONTH  | AL_MONTH  | Month value of the alarm counter setting. Range: 1 ~ 12 |

**A0710048 RTC\_AL\_YEA RTC Year Alarm Setting Register 0000**

| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3       | 2 | 1 | 0 |
|-------|------------|----|----|----|----|----|---|---|---|---|---|---|---------|---|---|---|
| Mne   | NEW_SPARE4 |    |    |    |    |    |   |   |   |   |   |   | AL_YEAR |   |   |   |
| Type  | RW         |    |    |    |    |    |   |   |   |   |   |   | RW      |   |   |   |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   | 0 | 0 | 0 | 0       | 0 | 0 | 0 |

| Bit (s) | Mnemonic  | Name      | Description                                                           |
|---------|-----------|-----------|-----------------------------------------------------------------------|
| 15:8    | NEW_SPARE | NEW_SPARE | New spare-register 4                                                  |
| 4       |           | 4         |                                                                       |
| 6:0     | AL_YEAR   | AL_YEAR   | Year value of the alarm counter setting<br>Range: 0 ~ 127 (2000-2127) |

**A071004C RTC\_OSC32C OSC32 Control 0000**

| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2        | 1 | 0 |  |
|-------|------------|----|----|----|----|----|---|---|---|---|---|---|------------|----------|---|---|--|
| Mne   | EOSC32_RSV |    |    |    |    |    |   |   |   |   |   |   | XOSC32_ENE | XOSCCALI |   |   |  |
| Type  | RW         |    |    |    |    |    |   |   |   |   |   |   | RO         | RW       |   |   |  |
| Reset | -          | 0  | 0  | 0  | 0  | 1  | 0 | 0 | 0 | 0 | - | 0 | 1          | 1        | 1 | 1 |  |

**Overview:** The function is only active when RTC\_POWERKEY1 & RTC\_POWERKEY2 match the correct values.

| Bit (s) | Mnemonic  | Name      | Description                            |
|---------|-----------|-----------|----------------------------------------|
| 15:9    | OSC32_RSV | OSC32_RSV | OSC32 reserved bits<br>Keep it at 0x2. |
| 8:6     | EMB_MODE  | EMBCK_SEL | Mode setting for crystal removal case  |

| Bit (s) | Mnemonic   | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5       | XOSC32_ENB | XOSC32_ENB | <b>XOSC32_ENB</b><br>Reads pin XOSC32_ENB configuration to know the 32k crystal usage.<br>0: Use 32k crystal<br>1: Does not use 32k crystal.                                                                                                                                                                                                                                                                                                          |
| 4:0     | XOSCCALI   | XOSCCALI   | <b>Controls XOSC32/EOSC32 calibration</b><br>If XOSC32_ENB(RTC_OSC32CON[5]) = 0, XOSCCALI controls the bias current for 32k xtal in XOSC32. When powerkeys do not match, the default value is 0x7.<br>If XOSC32_ENB(RTC_OSC32CON[5]) = 1, XOSCCALI is the trimming value for EOSC32. SW needs to find the best trimming value for EOSC32 when the 1 <sup>st</sup> power-on by frequency meter. When powerkeys do not match, the default value is 0xf. |

OSC32CON is not protected by RTC\_PROT because RTC\_PROT needs 32.768kHz clock to unlock. Similarly, to modify RTC\_OSC32CON, writing RTC\_WRTGR is not needed, neither. To protect the OSC32 control bits, follow the *update sequence* to update RTC\_OSC32CON. After the updating sequence is completed, reload to acquire the internal RTC\_OSC32CON. This register needs to be initialized **before** writing powerkeys match.

Update sequence:

- Step 1: Write RTC\_OSC32CON = 0x1a57 and wait until CBUSY=0
- Step 2: Write RTC\_OSC32CON = 0x2b68 and wait until CBUSY=0
- Step 3: Write the real value you would like to write RTC\_OSC32CON and wait until CBUSY=0
- Step 4: Return to step 1 if you need to modify RTC\_OSC32CON again.

Note: RTC\_OSC32CON should be set before writing POWERKEY1 and POWERKEY2 to the correct value.

| A0710050 | RTC_POWERKEY<br>1               | RTC_POWERKEY1 Register | 0000 |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|---------------------------------|------------------------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit      | 15                              | 14                     | 13   | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Mne      | RTC_POWERKEY1                   |                        |      |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type     | RW                              |                        |      |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                        |      |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit (s) | Mnemonic          | Name              | Description |
|---------|-------------------|-------------------|-------------|
| 15:0    | RTC_POWER<br>KEY1 | RTC_POWER<br>KEY1 |             |

| A0710054 | RTC_POWERKE<br>Y2               | RTC_POWERKEY2 Register | 0000 |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|---------------------------------|------------------------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit      | 15                              | 14                     | 13   | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Mne      | RTC_POWERKEY2                   |                        |      |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type     | RW                              |                        |      |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                        |      |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit (s) | Mnemonic  | Name      | Description |
|---------|-----------|-----------|-------------|
| 15:0    | RTC_POWER | RTC_POWER |             |
|         | KEY2      | KEY2      |             |

These register sets are used to determine if the real-time clock has been programmed by the software, i.e. the time value in real time clock is correct. When the real-time clock is first powered on, the register contents are all undefined, and therefore the time values shown are incorrect. The software needs to know if the real-time clock has been programmed. Hence, the two registers are defined to solve this power-on issue. After the software programs the correct value, the two register sets will not need to be updated. In addition to programming the correct time value, when the contents of the register sets are wrong, the interrupt will not be generated. Therefore, the real-time clock will not generate the interrupts before the software programs the registers, and unwanted interrupt due to wrong time value will not occur. The correct values of these two register sets are:

RTC\_POWERKEY1 A357h  
RTC\_POWERKEY2 67D2h

| A0710058 RTC PDN1 PDN1 |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0000 |  |
|------------------------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|--|
| Bit                    | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |  |
| Mne                    | RTC_PDN1 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |  |
| Type                   | RW       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |  |
| Reset                  | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |  |

| Bit (s) | Mnemonic | Name     | Description                                                                       |
|---------|----------|----------|-----------------------------------------------------------------------------------|
| 15:0    | RTC_PDN1 | RTC_PDN1 | Spare registers for software to keep the power-on and power-off state information |

| A071005C RTC PDN2 PDN2 |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0000 |  |
|------------------------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|--|
| Bit                    | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |  |
| Mne                    | RTC_PDN2 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |  |
| Type                   | RW       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |  |
| Reset                  | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |  |

| Bit (s) | Mnemonic | Name     | Description                                                                   |
|---------|----------|----------|-------------------------------------------------------------------------------|
| 15:0    | RTC_PDN2 | RTC_PDN2 | Spare registers for software to keep power-on and power-off state information |

| A0710060 RTC SPAR0 Spare Register For Specific Purpose |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0000 |  |
|--------------------------------------------------------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|--|
| Bit                                                    | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |  |
| Mne                                                    | RTC_SPAR0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |  |
| Type                                                   | RW        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |  |

|              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| <b>Reset</b> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

| Bit (s) | Mnemonic         | Name      | Description                    |
|---------|------------------|-----------|--------------------------------|
| 15:0    | <b>RTC_SPAR0</b> | RTC_SPAR0 | Reserved for specific purposes |

**A0710064    RTC\_SPAR1    Spare Register For Specific Purpose                                  0000**

|              |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------|------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Bit</b>   | 15               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>Mne</b>   | <b>RTC_SPAR1</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | RW               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 0                | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit (s) | Mnemonic         | Name      | Description                    |
|---------|------------------|-----------|--------------------------------|
| 15:0    | <b>RTC_SPAR1</b> | RTC_SPAR1 | Reserved for specific purposes |

**A0710068    RTC\_PROT    Lock/Unlock Scheme to Prevent RTC Miswriting                                  0000**

|              |                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------|-----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Bit</b>   | 15              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>Mne</b>   | <b>RTC_PROT</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | RW              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit (s) | Mnemonic        | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0    | <b>RTC_PROT</b> | RTC_PROT | <p>Protects RTC write interface by RTC_PROT</p> <p>Whether the RTC writing interface is enabled or not is decided by RTC_PROT contents. When RTC_POWERKEY1 &amp; RTC_POWERKEY2 are not equal to the correct values, the RTC writing interface will always be enabled. However, when they match, the user has to perform the unlock flow to enable the writing interface.</p> <p>Unlock flow:</p> <ul style="list-style-type: none"> <li>Step1: *RTC_PROT=0x586a;</li> <li>Step2: *RTC_WRTGR=1;</li> <li>Step3: while(*RTC_BBPU &amp; 0x40) {}; // Timeout period: 120usec</li> <li>Step4: *RTC_PROT=0x9136;</li> <li>Step5: *RTC_WRTGR=1;</li> <li>Step6: while(*RTC_BBPU &amp; 0x40) {}; // Timeout period: 120usec</li> </ul> <p><i>Note: Always keep RTC in the unlock state in the power-on mode. Once the normal RTC content writing is completed, DO NOT modify the RTC_PROT content to lock RTC. The RTC_PROT contents will be cleared automatically when being powered off immediately.</i></p> |

**A071006C    RTC\_DIFF    One-time Calibration Offset                                  0000**

| Bit   | 15           | 14           | 13 | 12 | 11       | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|--------------|--------------|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| Mne   | RESE<br>RVED | RESE<br>RVED |    |    | RTC_DIFF |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW           | RO           |    |    | RW       |    |   |   |   |   |   |   |   |   |   |   |
| Reset | -            | -            |    |    | 0        | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Overview:** This register is fixed to 0 when RTC\_POWERKEY1 and RTC\_POWERKEY2 unmatch the correct values.

| Bit (s) | Mnemonic | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0    | RTC_DIFF | RTC_DIFF | <p><b>Adjusts internal counter of RTC</b></p> <p>It takes effect once and returns to 0 when done. In some cases, RTC is faster or slower than the standard. To change RTC_TC_SEC being coarse may cause alarm problem. RTC_DIFF provides a finer time unit. An internal 15-bit counter accumulates in each 32,768Hz clock. Entering a non-0 value to RTC_DIFF will cause the internal RTC counter to increase or decrease RTC_DIFF when RTC_DIFF changes to 0 again. RTC_DIFF represents 2's complement. For example, if you fill in 0xffff into RTC_DIFF, the internal counter will decrease by 1 when RTC_DIFF returns to 0. In other words, you can only use RTC_DIFF continuously if RTC_DIFF is equal to 0 now.</p> <p>Note: RTC_DIFF ranges from 0x800 (-2048) to 0x7fd (2045). 0x7ff &amp; 0x7fe are forbidden.</p> |

| A0710070 <u>RTC_CALI</u> Repeat Calibration Offset    0000 |              |              |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
|------------------------------------------------------------|--------------|--------------|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| Bit                                                        | 15           | 14           | 13 | 12 | 11       | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Mne                                                        | RESE<br>RVED | RESE<br>RVED |    |    | RTC_CALI |    |   |   |   |   |   |   |   |   |   |   |
| Type                                                       | RO           | RW           |    |    | RW       |    |   |   |   |   |   |   |   |   |   |   |
| Reset                                                      | 0            | -            | 0  | 0  | 0        | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Overview:** This register is fixed to 0 when RTC\_POWERKEY1 & RTC\_POWERKEY2 unmatch the correct values.

| Bit (s) | Mnemonic | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0    | RTC_CALI | RTC_CALI | <p><b>Provides a repeated calibration scheme</b></p> <p>RTC_CALI provides 7-bit calibration capability in 8-second duration, i.e. 5-bit calibration capability in each second. RTC_CALI represents 2's complement form for the user to adjust RTC increase or decrease. Due to RTC_CALI is revealed in 8 seconds, the resolution is less than a 1/32768 clock. Avg. resolution: 1/32768/8 = 3.81us Avg. adjust range: -0.244~0.240ms/sec in 2's complement: -0x2000 ~ 0x1fff (-8192 ~ 8191)</p> |

| A0710074 <u>RTC_WRTGR</u> Enable Transfers From Core to RTC in Queue    0000 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|
| Mne   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | WRTGR |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | WO    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0     |

| Bit (s) | Mnemonic | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | WRTGR    | WRTGR | <p><b>Enables the transfers from core to RTC</b></p> <p>After you modify all the RTC registers and would like to change it, write 1 to RTC_WRTGR to trigger the transfer. The prior writing operation is queued in the core power domain. The pending data will not be transferred to the RTC domain until WRTGR = 1.</p> <p>After WRTGR=1, the pending data will be transferred to the RTC domain sequentially in order of register addresses, from low to high. For example: RTC_BBPU -&gt; RTC_IRQ_EN -&gt; RTC_CII_EN -&gt; RTC_AL_MASK -&gt; RTC_TC_SEC -&gt; etc. CBUSY in RTC_BBPU is equal to 1 in the writing process. Observe CBUSY to determine when the transmission is completed.</p> |

| A0710078 RTC_CON Other RTC Control Register 0000 |             |           |           |                    |           |           |           |           |           |           |           |           |        |      |    |                  |
|--------------------------------------------------|-------------|-----------|-----------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--------|------|----|------------------|
| Bit                                              | 15          | 14        | 13        | 12                 | 11        | 10        | 9         | 8         | 7         | 6         | 5         | 4         | 3      | 2    | 1  | 0                |
| Mne                                              | LPST_A_RA_W | RESE_RVED | RESE_RVED | POW_EROF_F_SE_Q_EN | RESE_RVED | LPRS_T | LPEN |    | VBAT_LPS_TA_R_AW |
| Type                                             | W1C         | RW        | RW        | RW                 | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW     | RW   | RW | RW               |
| Reset                                            |             |           |           |                    |           |           |           |           |           |           |           |           |        |      |    |                  |

| Bit (s) | Mnemonic       | Name           | Description                                                                                                                                                                                                                                                                                                                                                                              |
|---------|----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15      | LPSTA_RAW      | LPSTA_RAW      | <p><b>Raw status of LP_STA</b></p> <p>Re-initialize LPD to clear this bit.</p> <p><i>Note: This bit is always high before LPD initialization sequence after the first power-on.</i></p>                                                                                                                                                                                                  |
| 3       | LPRST          | LPRST          | <b>Resets LPDET_B</b>                                                                                                                                                                                                                                                                                                                                                                    |
| 2:1     | LPEN           | LPEN           | <p>Only takes effect when LPEN = 1.</p> <p><b>Enables LPDET_B</b></p> <p>LP initialization sequence:</p> <ol style="list-style-type: none"> <li>1. Write LPEN = 1, LPRST = 0. Write RTC_WRTGR = 1. wait cbusy down.</li> <li>2. Write LPEN = 1, LPRST = 1. Write RTC_WRTGR = 1. wait cbusy down.</li> <li>3. Write LPEN = 1, LPRST = 0. Write RTC_WRTGR = 1. wait cbusy down.</li> </ol> |
| 0       | VBAT_LPSTA_RAW | VBAT_LPSTA_RAW | <p><b>Indicates the battery has been in LP state</b></p> <p>Software needs to clear this bit for the next time use</p> <p>0: VBAT has not been in LP state.<br/>1: VBAT has been in LP state.</p> <p><i>Note: VBAT LP state = VBAT &lt; 2.5V</i></p>                                                                                                                                     |

When Vcore always exists, the software can trust the registers and wait for the LP interrupt from RTC if the 32.768 kHz clock stopped or has been stopped.

However, nothing can be trusted after the battery is off (V<sub>RTC</sub> may drop). In every boot time, the software checks if LPSTA\_RAW = 1. (LP\_STA = LPSTA\_RAW & LP\_IRQ\_EN) If true, the RTC contents will no longer be trusted just like powerkeys do not match. You have to initialize the RTC contents in this case.

### 3.13 Auxiliary ADC Unit

The auxiliary ADC unit is used to monitor the status of the battery and charger, to identify the plugged peripheral, and to perform temperature measurement.



Figure 38. AUXADC architecture

Each channel operates in one of the two modes: immediate mode or timer-triggered mode. The mode of each channel can be individually selected through register AUXADC\_CON0. For example, if the flag SYNC0 in register AUXADC\_CON0 is set, channel 0 will be set in the timer-triggered mode. Otherwise, the channel will operate in the immediate mode.

In the immediate mode, the A/D converter samples the value once only when the flag in the AUXADC\_CON1 register is set. For example, if the flag IMM0 in AUXADC\_CON1 is set, the A/D converter will sample the data for channel 0. The IMM flags must be cleared and set again to initialize another sampling.

The value sampled for channel 0 is stored in register AUXADC\_DAT0, and the value for channel 1 is stored in register AUXADC\_DAT1, and so on.

If the AUTOSET flag in register AUXADC\_CON3 is set, the auto-sample function will be enabled. The A/D converter samples the data for the channel in which the corresponding data register is read. For

example, in the case where the SYN1 flag is not set, the AUTOSET flag is set. When the data register AUXADC\_DAT0 is read, the A/D converter will sample the next value for channel 1 immediately.

If multiple channels are selected at the same time, the task will be performed sequentially on every selected channel. For example, if AUXADC\_CON1 is set to 0x3f, i.e. 6 channels are selected, the state machine in the unit will start sampling from channel 6 to channel 0 and save the values of each input channel in respective registers. The same process also applies to the timer-triggered mode.

In the timer-triggered mode, the A/D converter samples the value for the channels in which the corresponding SYN flags are set when the TDMA timer counts to the value specified in register TDMA\_AUXEV1 placed in the TDMA timer. For example, if AUXADC\_CON0 is set to 0x3f, the 6 channels will be selected to be in the timer-triggered mode. The state machine will sample the 6 channels sequentially and save the values in registers from AUXADC\_DAT0 to AUXADC\_DAT5, as it does in the immediate mode.

AUTOCLRn in register AUXADC\_CON3 is set when it is intended to sample only once after setting up the timer-triggered mode. If the AUTOCLR1 flag is set, after the data for the channels in the timer-triggered mode are stored, the SYNn flags in register AUXADC\_CON0 will be cleared.

The uses of the immediate mode and timer-triggered mode are mutually exclusive in terms of individual channels.

There are only two external pins (channel 4 ~ 5) for voltage detection. Other channels (0 ~ 3) are for battery voltage, battery current, charger and battery temperature respectively. Channel 9 is used for audio.

#### Touch panel



Figure 39. Touch panel circuit structure

Besides the normal sampling of external input voltage, the AUXADC includes the sampling of the touch panel function. For specified axis, the software should program AUX\_TS\_CMD first then trigger the sample of touch panel in register AUX\_TS\_CON. The touch panel sampling waveform is shown as the following. After the software polls the status bit in register AUXADC\_CON3 to know that the touch panel sample is finished, the software can read back the specified axis value from register AUX\_TS\_DAT0.



Figure 40. Touch panel sampling waveform

S: Start bit

A2 ~ A0: Addressing bits

Mode: 10-bit or 8-bit

SE/DF: Single end or differential mode

PD1 ~ 0: Power down command

These values are defined in register AUX\_TS\_CMD. The table below shows the relationship between AUX\_TS\_CMD and touch panel control signals.

Table 49. Relationship between commands and touch panel control signals

| A2 | A1 | A0 | SE/DFB | CHN_SEL | ADC In | X switches      | Y switches      | +REF | -REF |
|----|----|----|--------|---------|--------|-----------------|-----------------|------|------|
| 0  | 0  | 1  | 0      | C       | X+     | OFF             | ON              | Y+   | Y-   |
| 0  | 1  | 0  | 0      | F       | X-     | OFF             | ON              | Y+   | Y-   |
| 0  | 1  | 1  | 0      | C       | X+     | X+ OFF<br>X- ON | Y+ ON<br>Y- OFF | Y+   | X-   |
| 1  | 0  | 0  | 0      | E       | Y-     | X+ OFF<br>X- ON | Y+ ON<br>Y- OFF | Y+   | X-   |
| 1  | 0  | 1  | 0      | D       | Y+     | ON              | OFF             | X+   | X-   |
| 1  | 1  | 0  | 0      | E       | Y-     | ON              | OFF             | X+   | X-   |

Table 2 AUXADC channel description

| AuxADC Channel ID | Description |
|-------------------|-------------|
| Channel 0         | VBAT        |

| AuxADC Channel ID | Description       |
|-------------------|-------------------|
| Channel 1         | ISENSE            |
| Channel 2         | CHRIN             |
| Channel 3         | BATON (BATtemp)   |
| Channel 4         | AUXIN4 (external) |
| Channel 5         | ACCDET (external) |
| Channel 9         | ClassAB           |
| Channel 12        | XP / External     |
| Channel 13        | YP / External     |
| Channel 14        | YM / External     |
| Channel 15        | XM / External     |

### 3.13.1 Register Definition

Module name: AUXADC Base address: (+A0790000h)

| Address  | Name                  | Width | Register Function                                                                                                                                                                                                                                                                                                                                          |
|----------|-----------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0790000 | <u>AUXADC_CON0</u>    | 16    | <b>AuxiliaryADC Control Register 0</b><br>These bits define whether the corresponding channel is sampled or not in the timer-triggered mode. It is associated with the timing offset register TDMA_AUXEV1. It supports multiple flags. The flags can be automatically cleared after those channels are sampled if AUTOCLR1 in register AUXADC_CON3 is set. |
| A0790004 | <u>AUXADC_CON1</u>    | 16    | <b>AuxiliaryADC Control Register 1</b><br>These bits are set individually to sample the data for the corresponding channel. It supports multiple flags.                                                                                                                                                                                                    |
| A079000C | <u>AUXADC_CON3</u>    | 16    | <b>AuxiliaryADC Control Register 3</b>                                                                                                                                                                                                                                                                                                                     |
| A0790010 | <u>AUXADC_DAT0</u>    | 16    | <b>AuxiliaryADC Channel 0 Register (VBAT)</b>                                                                                                                                                                                                                                                                                                              |
| A0790014 | <u>AUXADC_DAT1</u>    | 16    | <b>AuxiliaryADC Channel 1 Register (ISENSE)</b>                                                                                                                                                                                                                                                                                                            |
| A0790018 | <u>AUXADC_DAT2</u>    | 16    | <b>AuxiliaryADC Channel 2 Register (CHRIN)</b>                                                                                                                                                                                                                                                                                                             |
| A079001C | <u>AUXADC_DAT3</u>    | 16    | <b>AuxiliaryADC Channel 3 Register (VBATTMP)</b>                                                                                                                                                                                                                                                                                                           |
| A0790020 | <u>AUXADC_DAT4</u>    | 16    | <b>AuxiliaryADC Channel 4 Register (External)</b>                                                                                                                                                                                                                                                                                                          |
| A0790024 | <u>AUXADC_DAT5</u>    | 16    | <b>AuxiliaryADC Channel 5 Register (External/ACCDET)</b>                                                                                                                                                                                                                                                                                                   |
| A0790034 | <u>AUXADC_DAT9</u>    | 16    | <b>AuxiliaryADC Channel 9 Register (Class AB)</b>                                                                                                                                                                                                                                                                                                          |
| A0790040 | <u>AUXADC_DAT12</u>   | 16    | <b>AuxiliaryADC Channel 12 Register (External)</b>                                                                                                                                                                                                                                                                                                         |
| A0790044 | <u>AUXADC_DAT13</u>   | 16    | <b>AuxiliaryADC Channel 13 Register (External)</b>                                                                                                                                                                                                                                                                                                         |
| A0790048 | <u>AUXADC_DAT14</u>   | 16    | <b>AuxiliaryADC Channel 14 Register (External)</b>                                                                                                                                                                                                                                                                                                         |
| A079004C | <u>AUXADC_DAT15</u>   | 16    | <b>AuxiliaryADC Channel 15 Register (External)</b>                                                                                                                                                                                                                                                                                                         |
| A0790054 | <u>AUX_TS_CMD0</u>    | 16    | <b>Touch Screen Sample Command 0</b>                                                                                                                                                                                                                                                                                                                       |
| A0790058 | <u>AUX_TS_CON</u>     | 16    | <b>Touch Screen Control</b>                                                                                                                                                                                                                                                                                                                                |
| A079005C | <u>AUX_TS_DAT0</u>    | 16    | <b>Touch Screen Sample DATA 0</b>                                                                                                                                                                                                                                                                                                                          |
| A0790070 | <u>AUXADC_DAT_ZCV</u> | 16    | <b>AuxiliaryADC ZCV Sample DATA</b>                                                                                                                                                                                                                                                                                                                        |
| A07900D0 | <u>AUXADC_CON4</u>    | 16    | <b>AuxiliaryADC Control Register 4</b>                                                                                                                                                                                                                                                                                                                     |

| Address  | Name               | Width | Register Function             |
|----------|--------------------|-------|-------------------------------|
| A07900D4 | <u>AUX TS CMD1</u> | 16    | Touch Screen Sample Command 1 |
| A07900D8 | <u>AUX TS DAT1</u> | 16    | Touch Screen Sample DATA 1    |

**A0790000    AUXADC CON0 AuxiliaryADC Control Register 0                          0000**

| Bit   | 15    | 14    | 13    | 12    | 11 | 10 | 9    | 8 | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|-------|-------|-------|-------|----|----|------|---|---|---|------|------|------|------|------|------|
| Name  | SYN15 | SYN14 | SYN13 | SYN12 |    |    | SYN9 |   |   |   | SYN5 | SYN4 | SYN3 | SYN2 | SYN1 | SYN0 |
| Type  | R/W   | R/W   | R/W   | R/W   |    |    | R/W  |   |   |   | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset | 0     | 0     | 0     | 0     |    |    | 0    |   |   |   | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit(s) | Mnemonic     | Name  | Description                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|--------------|-------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 15     | <b>SYN15</b> | SYN15 | <b>Channel 15 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14     | <b>SYN14</b> | SYN14 | <b>Channel 14 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13     | <b>SYN13</b> | SYN13 | <b>Channel 13 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12     | <b>SYN12</b> | SYN12 | <b>Channel 12 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9      | <b>SYN9</b>  | SYN9  | <b>Channel 9 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected.  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5      | <b>SYN5</b>  | SYN5  | <b>Channel 5 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected.  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4      | <b>SYN4</b>  | SYN4  | <b>Channel 4 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected.  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3      | <b>SYN3</b>  | SYN3  | <b>Channel 3 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected.  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2      | <b>SYN2</b>  | SYN2  | <b>Channel 2 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected.  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1      | <b>SYN1</b>  | SYN1  | <b>Channel 1 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected.  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0      | <b>SYN0</b>  | SYN0  | <b>Channel 0 sync mode</b><br>0: The channel is not selected.<br>1: The channel is selected.  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**A0790004    AUXADC CON1 AuxiliaryADC Control Register 1                          0000**

| Bit   | 15    | 14    | 13    | 12    | 11 | 10 | 9    | 8 | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|-------|-------|-------|-------|----|----|------|---|---|---|------|------|------|------|------|------|
| Name  | IMM15 | IMM14 | IMM13 | IMM12 |    |    | IMM9 |   |   |   | IMM5 | IMM4 | IMM3 | IMM2 | IMM1 | IMM0 |
| Type  | R/W   | R/W   | R/W   | R/W   |    |    | R/W  |   |   |   | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset | 0     | 0     | 0     | 0     |    |    | 0    |   |   |   | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit(s) | Mnemonic | Name | Description |
|--------|----------|------|-------------|
|        |          |      |             |

|    |              |       |                                                                                   |    |     |           |
|----|--------------|-------|-----------------------------------------------------------------------------------|----|-----|-----------|
| 15 | <b>IMM15</b> | IMM15 | <b>Channel 15 immediate mode</b><br>0: The channel<br>1: The channel is selected. | is | not | selected. |
| 14 | <b>IMM14</b> | IMM14 | <b>Channel 14 immediate mode</b><br>0: The channel<br>1: The channel is selected. | is | not | selected. |
| 13 | <b>IMM13</b> | IMM13 | <b>Channel 13 immediate mode</b><br>0: The channel<br>1: The channel is selected. | is | not | selected. |
| 12 | <b>IMM12</b> | IMM12 | <b>Channel 12 immediate mode</b><br>0: The channel<br>1: The channel is selected. | is | not | selected. |
| 9  | <b>IMM9</b>  | IMM9  | <b>Channel 9 immediate mode</b><br>0: The channel<br>1: The channel is selected.  | is | not | selected. |
| 5  | <b>IMM5</b>  | IMM5  | <b>Channel 5 immediate mode</b><br>0: The channel<br>1: The channel is selected.  | is | not | selected. |
| 4  | <b>IMM4</b>  | IMM4  | <b>Channel 4 immediate mode</b><br>0: The channel<br>1: The channel is selected.  | is | not | selected. |
| 3  | <b>IMM3</b>  | IMM3  | <b>Channel 3 immediate mode</b><br>0: The channel<br>1: The channel is selected.  | is | not | selected. |
| 2  | <b>IMM2</b>  | IMM2  | <b>Channel 2 immediate mode</b><br>0: The channel<br>1: The channel is selected.  | is | not | selected. |
| 1  | <b>IMM1</b>  | IMM1  | <b>Channel 1 immediate mode</b><br>0: The channel<br>1: The channel is selected.  | is | not | selected. |
| 0  | <b>IMM0</b>  | IMM0  | <b>Channel 0 immediate mode</b><br>0: The channel<br>1: The channel is selected.  | is | not | selected. |

**A079000C AUXADC\_CON3 Auxiliary ADC Control Register 3 0010**

| Bit   | 15      | 14 | 13 | 12 | 11  | 10 | 9        | 8 | 7        | 6 | 5 | 4                       | 3 | 2 | 1 | 0          |
|-------|---------|----|----|----|-----|----|----------|---|----------|---|---|-------------------------|---|---|---|------------|
| Name  | AUTOSET |    |    |    | RSV |    | AUTOCLR1 |   | SOFT_RST |   |   | BYPASS_SI_P_ZCV_TRIGGER |   |   |   | AUXADC_STA |
| Type  | R/W     |    |    |    | R/W |    | R/W      |   | R/W      |   |   | R/W                     |   |   |   | RO         |
| Reset | 0       |    |    |    | 0   |    | 0        |   | 0        |   |   | 1                       |   |   |   | 0          |

| Bit(s) | Mnemonic        | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | <b>AUTOSET</b>  | AUTOSET  | Defines the auto-sample mode of the module. In auto-sample mode, each channel with its sample register being read can start sampling immediately without configuring the control register AUXADC_CON1 again.                                                                                                                                                                                                                             |
| 11     | <b>RSV</b>      | RSV      | Please keep 1'b0                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9      | <b>AUTOCLR1</b> | AUTOCLR1 | Defines the auto-clear mode of the module for event 1. In the auto-clear mode, each timer-triggered channel acquires samples of specified channels once the SYNn bit in register AUXADC_CON0 is set. The SYNn bits are automatically cleared and the channel is not enabled again by the timer event except when the SYNn flags are set again.<br>0: The automatic clear mode is not enabled.<br>1: The automatic clear mode is enabled. |

|    |                               |                               |                                                       |            |
|----|-------------------------------|-------------------------------|-------------------------------------------------------|------------|
| 7  | <b>SOFT_RST</b>               | <b>SOFT_RST</b>               | <b>Software reset AUXADC state machine</b>            |            |
| 0: |                               |                               | Normal                                                | function   |
| 1: |                               |                               | Reset AUXADC state machine                            |            |
| 4  | <b>BYPASS_SLP_ZCV_TRIGGER</b> | <b>BYPASS_SLP_ZCV_TRIGGER</b> | <b>Bypass zcv triggering after sleep mode setting</b> |            |
| 0: |                               |                               | trigger zcv measuring after sleep mode                | sleep mode |
| 1: |                               |                               | bypass zcv measuring trigger after sleep mode         |            |
| 0  | <b>AUXADC_STA</b>             | <b>AUXADC_STA</b>             | <b>Defines the state of the module</b>                |            |
| 0: |                               |                               | This module is idle.                                  |            |
| 1: |                               |                               | This module is busy.                                  |            |

**A0790010 AUXADC DAT0 AuxiliaryADC Channel 0 Register (VBAT) 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT0 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO   |
| Reset |    |    |    |    |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

| Bit(s) | Mnemonic    | Name  | Description               |
|--------|-------------|-------|---------------------------|
| 9:0    | <b>DAT0</b> | DA T0 | Sampled data for channel0 |

**A0790014 AUXADC DAT1 AuxiliaryADC Channel 1 Register (ISENSE) 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT1 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO   |
| Reset |    |    |    |    |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

| Bit(s) | Mnemonic    | Name  | Description               |
|--------|-------------|-------|---------------------------|
| 9:0    | <b>DAT1</b> | DA T1 | Sampled data for channel1 |

**A0790018 AUXADC DAT2 AuxiliaryADC Channel 2 Register (CHRIN) 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT2 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO   |
| Reset |    |    |    |    |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

| Bit(s) | Mnemonic    | Name  | Description               |
|--------|-------------|-------|---------------------------|
| 9:0    | <b>DAT2</b> | DA T2 | Sampled data for channel2 |

**A079001C AUXADC DAT3 AuxiliaryADC Channel 3 Register (VBATTMP) 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT3 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO   |
| Reset |    |    |    |    |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

| Bit(s) | Mnemonic    | Name  | Description               |
|--------|-------------|-------|---------------------------|
| 9:0    | <b>DAT3</b> | DA T3 | Sampled data for channel3 |

**A0790020 AUXADC DAT4 AuxiliaryADC Channel 4 Register (External) 0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT4 |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO   |
| <b>Reset</b> |    |    |    |    |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>        |
|---------------|-----------------|-------------|---------------------------|
| 9:0           | DAT4            | DAT4        | Sampled data for channel4 |

**A0790024    AUXADC DAT5 AuxiliaryADC Channel 5 Register (External/ACCDET)                          0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT5 |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO   |
| <b>Reset</b> |    |    |    |    |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>        |
|---------------|-----------------|-------------|---------------------------|
| 9:0           | DAT5            | DAT5        | Sampled data for channel5 |

**A0790034    AUXADC DAT9 AuxiliaryADC Channel 9 Register (ClassAB)                          0000**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT9 |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO   |
| <b>Reset</b> |    |    |    |    |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>        |
|---------------|-----------------|-------------|---------------------------|
| 9:0           | DAT9            | DAT9        | Sampled data for channel9 |

**A0790040    AUXADC DAT1 AuxiliaryADC Channel 12 Register (External)                          0000  
2**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |       |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT12 |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO    |
| <b>Reset</b> |    |    |    |    |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0     |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>         |
|---------------|-----------------|-------------|----------------------------|
| 9:0           | DAT12           | DAT12       | Sampled data for channel12 |

**A0790044    AUXADC DAT1 AuxiliaryADC Channel 13 Register (External)                          0000  
3**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |       |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT13 |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO    |
| <b>Reset</b> |    |    |    |    |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0     |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>         |
|---------------|-----------------|-------------|----------------------------|
| 9:0           | DAT13           | DAT13       | Sampled data for channel13 |

A0790048 AUXADC\_DAT1 AuxiliaryADC Channel 14 Register (External) 0000  
4

| Bit   | 15    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | DAT14 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0     | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic | Name   | Description                |
|--------|----------|--------|----------------------------|
| 9:0    | DAT14    | DATA14 | Sampled data for channel14 |

A079004C AUXADC DAT1 AuxiliaryADC Channel 15 Register (External) 0000  
5

| Bit   | 15    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | DAT15 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0     | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic | Name   | Description                |
|--------|----------|--------|----------------------------|
| 9:0    | DAT15    | DATA15 | Sampled data for channel15 |

A0790054 AUX\_TS\_CMD0 Touch Screen Sample Command 0 0000

| Bit   | 15     | 14           | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6       | 5 | 4 | 3    | 2    | 1   | 0 |
|-------|--------|--------------|----|----|----|----|---|---|---|---------|---|---|------|------|-----|---|
| Name  | TS_SPL | TS_MAGIC_KEY |    |    |    |    |   |   |   | ADDRESS |   |   | MODE | SEDF | PD  |   |
| Type  | R/W    | WO           |    |    |    |    |   |   |   | R/W     |   |   | R/W  | R/W  | R/W |   |
| Reset | 0      | 0            | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0       | 0 | 0 | 0    | 0    | 0   | 0 |

| Bit(s) | Mnemonic     | Name         | Description                                                                                                                                                                                                                                                                                                           |
|--------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | TS_SPL       | TS_SPL       | Touch screen sample trigger<br>For the touch screen status, please refer to PMU datasheet : "AUX_CON6" register bit 14 "ts_status"<br>0: No action<br>1: When software writes 1'b1, AUXADC will trigger the touch screen process. After the sampling process of touch screen is finished, this bit will be disserted. |
| 14:7   | TS_MAGIC_KEY | TS_MAGIC_KEY | The TS commands in AUX_TS_CMD0 can only take effect when the TS MAGIC KEY matches the correct value.<br>TS_MAGIC_KEY=0xaa .                                                                                                                                                                                           |
| 6:4    | ADDRESS      | ADDRESS      | Defines which x or y or z data will be sampled<br>001: Y position<br>011: Z1 position<br>100: Z2 position<br>101: X position<br>Others: Reserved                                                                                                                                                                      |
| 3      | MODE         | MODE         | Selects sample resolution<br>0: 8-bit<br>1: 10-bit                                                                                                                                                                                                                                                                    |
| 2      | SEDF         | SEDF         | Selects mode<br>0: Differential mode<br>1: Single-end mode                                                                                                                                                                                                                                                            |
| 1:0    | PD           | PD           | Power-down control for analog IRQ signal and touch screen sample control signal                                                                                                                                                                                                                                       |

00: Turn on Y\_drive signal and PDN\_sh\_ref  
 01: Turn on PDN\_IRQ and PDN\_sh\_ref  
 10: Reserved  
 11: Turn on PDN\_IRQ

**A0790058 AUX\_TS\_CON Touch Screen Control**

0000

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TS_SPL |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0      |

| Bit(s) | Mnemonic | Name   | Description                                                                                                                                                                                                                                                                                                                  |
|--------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | TS_SPL   | TS_SPL | <b>Touch screen sample trigger</b><br>For the touch screen status, please refer to PMU datasheet : "AUX_CON6" register bit 14 "ts_status"<br>0: No action<br>1: When software writes 1'b1, AUXADC will trigger the touch screen process. After the sampling process of touch screen is finished, this bit will be disserted. |

**A079005C AUX\_TS\_DAT0 Touch Screen Sample DATA 0**

0000

| Bit   | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| Name  | TS_SPL |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TS_DAT |
| Type  | RO     |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO     |
| Reset | 0      |    |    |    |    |    |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

| Bit(s) | Mnemonic | Name   | Description                                                                                                                               |
|--------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | TS_SPL   | TS_SPL | <b>Touch screen sample trigger</b><br>For the touch screen status, please refer to PMU datasheet : "AUX_CON6" register bit 14 "ts_status" |
| 9:0    | TS_DAT   | TS_DAT | <b>Touch screen sample result data</b>                                                                                                    |

**A0790070 AUXADC\_DAT AuxiliaryADC ZCV Sample DATA ZCV**

0000

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT_ZCV |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO      |
| Reset |    |    |    |    |    |    |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0       |

| Bit(s) | Mnemonic | Name    | Description                 |
|--------|----------|---------|-----------------------------|
| 9:0    | DAT_ZCV  | DAT_ZCV | <b>Sampled data for ZCV</b> |

**A07900D0 AUXADC\_CON4 AuxiliaryADC Control Register 4**

0000

| Bit   | 15     | 14          | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|--------|-------------|----|----|----|----|------|---|---|---|------|------|------|------|------|------|
| Name  | TS_SPL | AUXA_DC_STA |    |    |    |    | SYN9 |   |   |   | SYN5 | SYN4 | SYN3 | SYN2 | SYN1 | SYN0 |
| Type  | RO     | RO          |    |    |    |    | RO   |   |   |   | RO   | RO   | RO   | RO   | RO   | RO   |
| Reset | 0      | 0           |    |    |    |    | 0    |   |   |   | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit(s) | Mnemonic | Name             | Description                                                                                                                                                  |  |  |  |  |
|--------|----------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 15     | TS_SPL   | TS_SPL           | <b>Touch screen sample trigger</b>                                                                                                                           |  |  |  |  |
|        |          |                  | For the touch screen status, please refer to PMU datasheet : "AUX_CON6" register bit 14 "ts_status"                                                          |  |  |  |  |
| 0:     |          |                  | No action                                                                                                                                                    |  |  |  |  |
| 1:     |          |                  | When software writes 1'b1, AUXADC will trigger the touch screen process. After the sampling process of touch screen is finished, this bit will be disserted. |  |  |  |  |
| 14     | AUXADC_S | AUXADC_STA<br>TA | <b>Defines the state of the module</b>                                                                                                                       |  |  |  |  |
| 0:     |          |                  | This module is idle.                                                                                                                                         |  |  |  |  |
| 1:     |          |                  | This module is busy.                                                                                                                                         |  |  |  |  |
| 9      | SYN9     | SYN9             | <b>Channel 9 sync mode</b>                                                                                                                                   |  |  |  |  |
| 0:     |          |                  | The channel is not selected.                                                                                                                                 |  |  |  |  |
| 1:     |          |                  | The channel is selected.                                                                                                                                     |  |  |  |  |
| 5      | SYN5     | SYN5             | <b>Channel 5 sync mode</b>                                                                                                                                   |  |  |  |  |
| 0:     |          |                  | The channel is not selected.                                                                                                                                 |  |  |  |  |
| 1:     |          |                  | The channel is selected.                                                                                                                                     |  |  |  |  |
| 4      | SYN4     | SYN4             | <b>Channel 4 sync mode</b>                                                                                                                                   |  |  |  |  |
| 0:     |          |                  | The channel is not selected.                                                                                                                                 |  |  |  |  |
| 1:     |          |                  | The channel is selected.                                                                                                                                     |  |  |  |  |
| 3      | SYN3     | SYN3             | <b>Channel 3 sync mode</b>                                                                                                                                   |  |  |  |  |
| 0:     |          |                  | The channel is not selected.                                                                                                                                 |  |  |  |  |
| 1:     |          |                  | The channel is selected.                                                                                                                                     |  |  |  |  |
| 2      | SYN2     | SYN2             | <b>Channel 2 sync mode</b>                                                                                                                                   |  |  |  |  |
| 0:     |          |                  | The channel is not selected.                                                                                                                                 |  |  |  |  |
| 1:     |          |                  | The channel is selected.                                                                                                                                     |  |  |  |  |
| 1      | SYN1     | SYN1             | <b>Channel 1 sync mode</b>                                                                                                                                   |  |  |  |  |
| 0:     |          |                  | The channel is not selected.                                                                                                                                 |  |  |  |  |
| 1:     |          |                  | The channel is selected.                                                                                                                                     |  |  |  |  |
| 0      | SYN0     | SYN0             | <b>Channel 0 sync mode</b>                                                                                                                                   |  |  |  |  |
|        |          |                  | The channel is not selected.                                                                                                                                 |  |  |  |  |
|        |          |                  | The channel is selected.                                                                                                                                     |  |  |  |  |

**A07900D4 AUX\_TS\_CMD1 Touch Screen Sample Command 1 0000**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Mnemonic | Name    | Description                                                                            |  |  |  |  |
|--------|----------|---------|----------------------------------------------------------------------------------------|--|--|--|--|
| 6:4    | ADDRESS  | ADDRESS | <b>Defines which x or y or z data will be sampled</b>                                  |  |  |  |  |
| 001:   |          |         | Y position                                                                             |  |  |  |  |
| 011:   |          |         | Z1 position                                                                            |  |  |  |  |
| 100:   |          |         | Z2 position                                                                            |  |  |  |  |
| 101:   |          |         | X position                                                                             |  |  |  |  |
|        |          |         | Others: Reserved                                                                       |  |  |  |  |
| 3      | MODE     | MODE    | <b>Selects sample resolution</b>                                                       |  |  |  |  |
| 0:     |          |         | 8-bit                                                                                  |  |  |  |  |
| 1:     |          |         | 10-bit                                                                                 |  |  |  |  |
| 2      | SEDF     | SEDF    | <b>Selects mode</b>                                                                    |  |  |  |  |
| 0:     |          |         | Differential mode                                                                      |  |  |  |  |
| 1:     |          |         | Single-end mode                                                                        |  |  |  |  |
| 1:0    | PD       | PD      | <b>Power-down control for analog IRQ signal and touch screen sample control signal</b> |  |  |  |  |

00: Turn on Y-drive signal and PDN\_sh\_ref  
 01: Turn on PDN\_IRQ and PDN\_sh\_ref  
 10: Reserved  
 11: Turn on PDN\_IRQ

**A07900D8 AUX\_TS\_DAT1 Touch Screen Sample DATA 1 0000**

| Bit   | 15                              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | TS_DAT                          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO                              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Mnemonic | Name   | Description                     |
|--------|----------|--------|---------------------------------|
| 9:0    | TS_DAT   | TS_DAT | Touch screen sample result data |

※ Please refer to “**PMU**” datasheet for other AuxADC related settings:

- Sampling cycle control: Please see “AUX\_CON4” and “AUX\_CON5”

**3.13.2 General Programming Guide**

All register writes will occur in sequence. However, due to synchronization time, any reads after writes need to be delayed by three dummy reads.

**3.13.3 Usage Programming Guide**

There are two modes to program the AUXADC to sample: immediate mode and synchronous mode. The following are notes on programming each mode:

Immediate mode sampling is accomplished by programming AUXADC\_CON1 with the channels to be sampled. After programming, it is necessary to perform three dummy reads on AUXADC\_CON3. After the dummy reads, the next read of AUXADC\_CON3 will be valid. After sampling is done, it is necessary to program AUXADC\_CON1 back to zero before sampling again.

Synchronous mode sampling is accomplished by programming AUXADC\_CON0 with the channels to be sampled. Then it is necessary to program TDMA\_EVTENA7 to 0x2. After the sample is done, TDMA\_EVTENA7 must be programmed to 0x0 with waiting of two frames before sampling again.

**3.13.4 Performance Programming Guide**

For details on adjusting the performance of ADC sampling, please refer to registers AUX\_CON4, AUX\_CON5 and AUX\_CON6 in the **PMU** datasheet.

### 3.13.5 AUXADC PDN

AUXADC is located in A-die. Due to limitation, one of UART1,2,3 clocks must be turned on in order to use AUXADC. Please clear the corresponding PDN bits to enable the AUXADC clock (bit 2 or 3 of ACFG\_CLK\_CG).

### 3.13.6 Notice

The 4 TP pins – PAD\_XP, PAD\_XM, PAD\_YP, PAD\_YM, are used as EINT pins when no R-touch is used in the system. Therefore, please make sure the pin settings are correct.

## 3.14 USB Device Controller

### 3.14.1 General Description

This chip provides a USB function interface which complies with Universal Serial Bus Specification Rev 1.1. The USB device controller supports only full-speed (12Mbps) operation. The chip can make use of this widely available USB interface to transmit/receive data with USB hosts, typically PC/laptop. There are 6 endpoints in the USB device controller besides the mandatory control endpoint, 4 of which are for IN transactions and 2 endpoints are for OUT transactions. Word, half-word, and byte access are all allowed for loading and unloading the FIFO. The controller features 4 DMA channels to accelerate the data transfer for ACL and SCO data streams. The features of the endpoints are:

1. Endpoint 0: The control endpoint feature 64 bytes FIFO and accommodates maximum packet size of up to 64 bytes. DMA transfer is not supported.
2. IN endpoint 1: It features 64 bytes FIFO and accommodates maximum packet size of up to 64 bytes. GDMA Channel 4 Write Transfer is supported.
3. IN endpoint 2: It features 64 bytes FIFO and accommodates maximum packet size of up to 64 bytes. GDMA Channel 6 Write Transfer is supported.
4. IN endpoint 3: It features 16-byte FIFO and accommodates maximum packet size of 16 bytes. GDMA Transfer is not supported.
5. IN endpoint 4: It features 16-byte FIFO and accommodates maximum packet size of 16 bytes. GDMA Transfer is not supported.

6. OUT endpoint 1: It features 64 bytes FIFO and accommodates maximum packet size of 64 bytes.  
GDMA Channel 5 Read Transfer is supported.
7. OUT endpoint 2: It features 64 bytes FIFO and accommodates maximum packet size of 64 bytes.  
GDMA Channel 7 Read Transfer is supported.

For each endpoint except for the control endpoint, when the packet size is smaller than half the size of the FIFO, at most 2 packets can be buffered.

This unit is highly software configurable. All endpoints except for the control endpoint can be configured to be a bulk, interrupt or isochronous endpoints. Composite devices are also supported. IN endpoint 1 and OUT endpoint 1 share the same endpoint number but they can be used separately. So is the situation for the endpoint 2.

The USB device uses the cable-powered feature for the transceiver but only drains little current. An internal pull-up resistor is integrated across Vbus and D+ signal. The switch on/off of the pull-up resistor can be configured through the internal register. Two additional external serial resistors might be needed to place on the output of D+ and D- signals to make the output impedance equivalent to 28~44Ohm.



**Figure 1. USB11 controller system diagram**

### 3.14.2 Terminology

RW: Writable, Readable.

RO: Read-only. Value never changes.

WO: Write-only.

W1: Write-once. Readable.

RU: Read-only but value updated by the design.

W1C: Readable. Write 1 to bitwise-clear.

RC: Clear on read.

A1: Auto-set by the design. Can be read and write 0 to clear.

A0: Auto-cleared by the design. Can be read and write 1 to set.

DC: Don't care.

OTHER: Others. Mixed attribute. Refer to bit description.

RSV: Reserved. The read/write behavior to this bit is undefined.

### 3.14.3 Register Definition

| <u>USB FADDR</u> |    |    |    |    |    |    |   |   |   |   |   |   |   |   | USB Function Address Register |              |   |   |
|------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------------------------|--------------|---|---|
| Bit              | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                             | 0            |   |   |
| Name             |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                               | <u>FADDR</u> |   |   |
| Type             |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                               | RW           |   |   |
| Reset            |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                               | 0            | 0 | 0 |

| Bit(s) | Name  | Description                                                                                                                                                                                                                                                                                                                           |
|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | UPD   | This is an 8bit register that should be written with the functions 7-bit address (received through a SET_ADDRESS description). It is then used for decoding the function address in subsequent token packets.<br><br>When set by the MCU, the core will wait for an SOF token from the time INPKTRDY is set before sending the packet |
| 6:0    | FADDR | Function address of device                                                                                                                                                                                                                                                                                                            |

| <u>USB POWER</u> |    |    |    |    |    |    |   |   |   |   |   |   |   |   | USB Power Control Register |               |                  |                 |
|------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----------------------------|---------------|------------------|-----------------|
| Bit              | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                          | 0             |                  |                 |
| Name             |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                            | <u>ISOUPD</u> | <u>SWRSTENAB</u> | <u>SUSPMODE</u> |
| Type             |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                            | RW            | RU               | RU              |
| Reset            |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                            | 0             | 0                | 0               |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | ISOUPDATE | When set by the MCU, the core will wait for an SOF token from the time INPKTRDY is set before sending the packet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4      | SWRSTENAB | <b>Set by the MCU to enable the mode in which the device can only be reset by the software after reset signals are detected on the bus.</b><br><br>In case the software is delayed by other high priority processes and cannot make it to read the command from the buffer before the hardware reset the device after the reset signal is detected on the bus, the command will be lost. That is why the software reset mode is effective. When the flag is enabled, the hardware state machine cannot reset itself but by the software. In that sense, the software and hardware can keep synchronous detecting the reset signal. |
| 3      | RESET     | <b>The read-only bit is set when Reset signaling is present on the bus</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2      | RESUME    | <b>Set by the MCU to generate Resume signaling when the function is in the suspend mode.</b><br><br>The MCU should clear this bit after 10ms (maximum 15ms) to end Resume signaling                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1      | SUSPMODE  | <b>Set by the USB core when the Suspend mode is entered</b><br><br>Cleared when the Resume bit of this register is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0      | SUSPENAB  | <b>Set by the MCU to enable device into the Suspend mode when Suspend</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit(s)                           | Name | Description |
|----------------------------------|------|-------------|
| signaling is received on the bus |      |             |

| 0002 <u>USB_INTRIN</u> USB IN Endpoints Interrupt Register      0000 |    |    |    |    |    |    |   |   |   |   |   |        |        |        |        |     |
|----------------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|--------|--------|--------|--------|-----|
| Bit                                                                  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0   |
| Name                                                                 |    |    |    |    |    |    |   |   |   |   |   | EP4_IN | EP3_IN | EP2_IN | EP1_IN | EP0 |
| Type                                                                 |    |    |    |    |    |    |   |   |   |   |   | RC     | RC     | RC     | RC     | RC  |
|                                                                      |    |    |    |    |    |    |   |   |   |   |   | 0      | 0      | 0      | 0      | 0   |

| Bit(s) | Name   | Description                   |
|--------|--------|-------------------------------|
| 4      | EP4_IN | IN Endpoint 4 interrupt event |
| 3      | EP3_IN | IN Endpoint 3 interrupt event |
| 2      | EP2_IN | IN Endpoint 2 interrupt event |
| 1      | EP1_IN | IN Endpoint 1 interrupt event |
| 0      | EP0    | Endpoint 0 interrupt event    |

| 0004 <u>USB_INTROUT</u> USB OUT Endpoints InterruptRegister      0000 |    |    |    |    |    |    |   |   |   |   |   |    |         |         |   |   |
|-----------------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|----|---------|---------|---|---|
| Bit                                                                   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3       | 2       | 1 | 0 |
| Name                                                                  |    |    |    |    |    |    |   |   |   |   |   |    | EP2_OUT | EP1_OUT |   |   |
| Type                                                                  |    |    |    |    |    |    |   |   |   |   |   | RC | RC      |         |   |   |
| Reset                                                                 |    |    |    |    |    |    |   |   |   |   |   | 0  | 0       |         |   |   |

| Bit(s) | Name    | Description                    |
|--------|---------|--------------------------------|
| 2      | EP2_OUT | OUT Endpoint 2 interrupt event |
| 1      | EP1_OUT | OUT Endpoint 1 interrupt event |

| 06 <u>USB_INTRUSB</u> USB General Interrupt Register      00 |    |    |    |    |    |    |   |   |   |   |   |           |     |       |        |         |
|--------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|-----------|-----|-------|--------|---------|
| Bit                                                          | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4         | 3   | 2     | 1      | 0       |
| Name                                                         |    |    |    |    |    |    |   |   |   |   |   | POWERDWNN | SOF | RESET | RESUME | SUSPEND |
| Type                                                         |    |    |    |    |    |    |   |   |   |   |   | RC        | RC  | RC    | RC     | RC      |
| Reset                                                        |    |    |    |    |    |    |   |   |   |   |   | 0         | 0   | 0     | 0      | 0       |

| Bit(s) | Name      | Description                                                                                                                  |
|--------|-----------|------------------------------------------------------------------------------------------------------------------------------|
| 4      | POWERDWNN | Set at SUSPMODE and LineState is JState.<br>The programmer should have debounce scheme in SW code when using this interrupt. |
| 3      | SOF       | Set at the start of each frame                                                                                               |
| 2      | RESET     | Set when Reset signaling is detected on the bus                                                                              |
| 1      | RESUME    | Set when Resume signaling is detected on the bus while the USB core is                                                       |

| Bit(s)          | Name    | Description                                       |
|-----------------|---------|---------------------------------------------------|
| in suspend mode |         |                                                   |
| 0               | SUSPEND | Set when Suspend signaling is detected on the bus |

0007      USB\_INTRINE      USB IN Endpoints Interrupt Enable Register      00FF

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4       | 3       | 2       | 1       | 0     |
|-------|----|----|----|----|----|----|---|---|---|---|---|---------|---------|---------|---------|-------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | EP4_INE | EP3_INE | EP2_INE | EP1_INE | EP0_E |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW      | RW      | RW      | RW      | RW    |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 1       | 1       | 1       | 1       | 1     |

| Bit(s) | Name    | Description                                                                             |
|--------|---------|-----------------------------------------------------------------------------------------|
| 4      | EP4_INE | 1b0: Disable IN Endpoint 4 interrupt event<br>1b1: Enable IN Endpoint 4 interrupt event |
| 3      | EP3_INE | 1b0: Disable IN Endpoint 3 interrupt event<br>1b1: Enable IN Endpoint 3 interrupt event |
| 2      | EP2_INE | 1b0: Disable IN Endpoint 2 interrupt event<br>1b1: Enable IN Endpoint 2 interrupt event |
| 1      | EP1_INE | 1b0: Disable IN Endpoint 1 interrupt event<br>1b1: Enable IN Endpoint 1 interrupt event |
| 0      | EP0_E   | 1b0: Disable IN Endpoint 0 interrupt event<br>1b1: Enable IN Endpoint 0 interrupt event |

0009      USB\_INTRROUTE      USB OUT Endpoints Interrupt Enable Register      00FE

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4        | 3        | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|----------|----------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | EP2_OUTE | EP1_OUTE |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW       | RW       |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 1        | 1        |   |   |   |

| Bit(s) | Name     | Description                                                                               |
|--------|----------|-------------------------------------------------------------------------------------------|
| 2      | EP2_OUTE | 1b0: Disable OUT Endpoint 2 interrupt event<br>1b1: Enable OUT Endpoint 2 interrupt event |
| 1      | EP1_OUTE | 1b0: Disable OUT Endpoint 1 interrupt event<br>1b1: Enable OUT Endpoint 1 interrupt event |

0B      INTRUSBE      USB General Interrupt Enable Register      06

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4            | 3     | 2        | 1          | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|--------------|-------|----------|------------|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | POW_ERD_WN_E | SOF_E | RESE_T_E | RESE_SUM_E | SUSP_END_E |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RW           | RW    | RW       | RW         | RW         |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0            | 0     | 1        | 1          | 0          |

| Bit(s) | Name       | Description                  |
|--------|------------|------------------------------|
| 4      | POWERDWN_E | Enables power-down interrupt |

| Bit(s) | Name      | Description                    |
|--------|-----------|--------------------------------|
| 3      | SOF_E     | Enables SOF interrupt          |
| 2      | RESET_E   | Enables reset/babble interrupt |
| 1      | RESEUM_E  | Enables resume interrupt       |
| 0      | SUSPEND_E | Enables suspend interrupt      |

| 0C <u>USB FRAME1</u> USB Frame Count #1 Register            00 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                                 |
|----------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------------------------|
| Bit                                                            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                               |
| Name                                                           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | NUML                            |
| Type                                                           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RU                              |
| Reset                                                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |

| Bit(s) | Name | Description                          |
|--------|------|--------------------------------------|
| 7:0    | NUML | The lower 8 bits of the frame number |

| 0D <u>USB FRAME2</u> USB Frame Count #2 Register            00 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |       |
|----------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|
| Bit                                                            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
| Name                                                           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | NUM H |
| Type                                                           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RU    |
| Reset                                                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 |

| Bit(s) | Name | Description                          |
|--------|------|--------------------------------------|
| 2:0    | NUMH | The upper 3 bits of the frame number |

| 0E <u>USB INDEX</u> USB Endpoint Register Index            00 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |         |
|---------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------|
| Bit                                                           | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
| Name                                                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | INDEX   |
| Type                                                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW      |
| Reset                                                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0 0 0 |

The register determines which endpoint control/status registers are to be accessed at addresses USB+10h to USB+17h. Each IN endpoint and OUT endpoint has its own set of control/status registers. Only one set of IN control/status and one set of OUT control/status registers appear in the memory map at a time. Before accessing the control/status registers of an endpoint, the endpoint number should be written to the USB\_INDEX register to ensure that the correct control/status registers appear in the memory map.

| Bit(s) | Name  | Description           |
|--------|-------|-----------------------|
| 3:0    | INDEX | Index of the endpoint |

| 0F <u>USB_RSTCTRL</u> USB Reset Control            00 |    |    |    |    |    |    |   |   |        |   |   |   |   |   |   |         |
|-------------------------------------------------------|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---------|
| Bit                                                   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
| Name                                                  |    |    |    |    |    |    |   |   | SWR ST |   |   |   |   |   |   | RSTCNTR |
| Type                                                  |    |    |    |    |    |    |   |   | RW     |   |   |   |   |   |   | RW      |

|              |   |   |   |   |   |
|--------------|---|---|---|---|---|
| <b>Reset</b> | 0 | 0 | 0 | 0 | 0 |
|--------------|---|---|---|---|---|

| Bit(s) | Name    | Description                                                                                                                                                                                                                                                                                                                                     |
|--------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | SWRST   | If the flag SWRSTENAB in register USB_POWER is set to 1, the software enable mode will be enabled, and the device can be reset by writing 1 to this flag.                                                                                                                                                                                       |
| 3:0    | RSTCNTR | Signifies the duration of the reset operation after reset signal is detected on the bus. It is only enabled when software reset is not enabled. If the value is 0, the duration will be 2.5us. Otherwise, the duration will be this value multiplied by 341 then added by 2.5 in us unit. The range consequently starts from 2.5us to 5122.5us. |

| 11    | <u>USB_EP0_CSR</u> | USB Control/Status Register for Endpoint 0 | 00        |          |         |           |          |           |    |    |    |    |    |    |    |   |
|-------|--------------------|--------------------------------------------|-----------|----------|---------|-----------|----------|-----------|----|----|----|----|----|----|----|---|
| Bit   | 15                 | 14                                         | 13        | 12       | 11      | 10        | 9        | 8         | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0 |
| Name  | SSETUPEND          | SOUTPKTRDY                                 | SENDSTALL | SETUPEND | DATAEND | SENTSTALL | INPKTRDY | OUTPKTRDY |    |    |    |    |    |    |    |   |
| Type  | D                  | DY                                         | L         | A0       | RU      | A0        | A1       | A0        | A0 | A0 | A0 | A0 | A1 | A0 | RU |   |
| Reset | 0                  | 0                                          | 0         | 0        | 0       | 0         | 0        | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  |   |

| Bit(s) | Name       | Description                                                                                                                                                                                                                                                                                       |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | SSETUPEND  | <b>The MCU writes 1 to this bit to clear the SETUPEND bit.</b><br>It is cleared automatically. Only active when a transaction is started.                                                                                                                                                         |
| 6      | SOUTPKTRDY | <b>The MCU writes 1 to this bit to clear the OUTPKTRDY bit.</b><br>It is cleared automatically. Only active when an OUT transaction is started                                                                                                                                                    |
| 5      | SENDSTALL  | <b>The MCU writes 1 to this bit to terminate the current transaction.</b><br>The STALL handshake will be transmitted, and this bit will be cleared automatically.                                                                                                                                 |
| 4      | SETUPEND   | <b>This bit will be set when a control transaction ends before the DATAEND bit is set.</b><br>An interrupt will be generated and FIFO flushed at this time. The bit is cleared by the MCU writing 1 to the SSETUPEND bit.                                                                         |
| 3      | DATAEND    | <b>The MCU sets this bit:</b> <ol style="list-style-type: none"> <li>When setting INPKTRDY for the last data packet.</li> <li>When clearing OUTPKTRDY after unloading the last data packet.</li> <li>When setting INPKTRDY for a zero length data packet.</li> </ol> It is cleared automatically. |
| 2      | SENTSTALL  | <b>This bit is set when a STALL handshake is transmitted.</b><br>The MCU should clear this bit by writing 0 to it.                                                                                                                                                                                |
| 1      | INPKTRDY   | <b>The MCU sets up this bit after loading a data packet into the FIFO.</b><br>It is cleared automatically when the data packet is transmitted. An interrupt is generated when this bit is set                                                                                                     |
| 0      | OUTPKTRDY  | <b>This bit is set when a data packet is received.</b><br>An interrupt is generated when this bit is set. The MCU clears this bit by setting up the SOUTPKTRDY bit.                                                                                                                               |

| 16  | <u>USB_EP0_COUN</u> | EP0 Received Bytes Count Register | 00 |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|---------------------|-----------------------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit | 15                  | 14                                | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

|       |  |  |  |  |  |  |  |  |  |           |   |   |   |   |   |   |   |
|-------|--|--|--|--|--|--|--|--|--|-----------|---|---|---|---|---|---|---|
| Name  |  |  |  |  |  |  |  |  |  | EP0_COUNT |   |   |   |   |   |   |   |
| Type  |  |  |  |  |  |  |  |  |  | RU        |   |   |   |   |   |   |   |
| Reset |  |  |  |  |  |  |  |  |  | 0         | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

The register indicates the number of received data bytes in the endpoint 0. The value returned is valid while the OUTPKTRDY bit of the USB\_EP0\_CSR register is set. The register is active when the USB\_INDEX register is set to 0.

| Bit(s) | Name      | Description                                     |
|--------|-----------|-------------------------------------------------|
| 6:0    | EP0_COUNT | Number of received data bytes in the endpoint 0 |

|       |                                                                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |
|-------|-----------------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| 10    | <b>USB_EP_INMAXP</b> USB Maximum Packet Size Register for IN Endpoint |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 00   |
| Bit   | 15                                                                    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
| Name  |                                                                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   | MAXP |
| Type  |                                                                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW   |
| Reset |                                                                       |    |    |    |    |    |   |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

The register holds the maximum packet size for transactions through the currently selected IN endpoint - in units of one byte. When setting up the value, the programmer should note the constraints placed by the USB Specification on the packet size for bulk interrupt and isochronous transactions in full speed operation. There is an INMAXP register for each IN endpoint except for endpoint 0. The registers are active when the USB\_INDEX register is set to 1, 2, 3, and 4 respectively.

The value written to this register should match the wMaxPacketSize field of the standard endpoint descriptor for the associated endpoint. A mismatch may cause unexpected results. If a value is bigger than the configured IN FIFO size for the endpoint written to the register, the value will be automatically changed to the IN FIFO size. If the value written to the register is smaller than or equal to half the IN FIFO size, two IN packets can be buffered. The configured IN FIFO size for the endpoint 1, 2, and 3, are 16 bytes, 64 bytes, and 64 bytes respectively.

The register is reset to 0. If the register is changed after the packets are sent from the endpoint, the endpoint IN FIFO should be completely flushed after writing the new value to the register.

| Bit(s) | Name | Description                      |
|--------|------|----------------------------------|
| 7:0    | MAXP | Maximum packet size (unit: byte) |

|       |                                                                     |    |    |    |    |    |   |      |      |      |      |      |      |      |      |      |
|-------|---------------------------------------------------------------------|----|----|----|----|----|---|------|------|------|------|------|------|------|------|------|
| 11    | <b>USB_EP_INCSR1</b> USB Control/Status Register #1 for IN Endpoint |    |    |    |    |    |   |      |      |      |      |      |      |      |      | 00   |
| Bit   | 15                                                                  | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| Name  |                                                                     |    |    |    |    |    |   |      | ABO  | CLRD | SENT | SEND | FLUS | UNDE | FIFO | INPK |
|       |                                                                     |    |    |    |    |    |   | RTPK | ATAT | STAL | STAL | HIF  | RRU  | NOTE | TRDY |      |
| Type  |                                                                     |    |    |    |    |    |   | T_EN | OG   | L    | L    | O    | A1   | RU   | A0   |      |
| Reset |                                                                     |    |    |    |    |    |   |      | RW   | A0   | A1   | RW   | A0   | A1   | RU   | A0   |
|       |                                                                     |    |    |    |    |    |   |      | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit(s) | Name        | Description                                                                                                                                                                                                                                     |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | ABORTPKT_EN | When MCU writes 1 to ABORTPKT_EN, FLUSHFIFO switches to abort the packet function.<br><br>This bit should be enabled before FLUSHFIFO is set. If FLUSHFIFO is set and ABORTPKT_EN is enabled the data loaded into FIFO will be discarded. After |
|        |             |                                                                                                                                                                                                                                                 |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                         |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6      | CLRDATATOG   | the packet is aborted, EP will issue an interrupt. The programmer should wait for this interrupt to make sure the packet is aborted                                                                                                                                                                                                                                 |
| 5      | SENTSTALL    | The MCU writes 1 to this bit to reset the endpoint IN data toggle to 0                                                                                                                                                                                                                                                                                              |
| 4      | SENDSTALL    | The bit is set when a STALL handshake is transmitted.                                                                                                                                                                                                                                                                                                               |
| 3      | FLUSHFIFO    | The FIFO is flushed and the INPKTRDY bit is cleared. The MCU should clear this bit by writing 0 to this bit.                                                                                                                                                                                                                                                        |
| 2      | UNDERRUN     | The MCU writes 1 to this bit to issue a STALL handshake to an IN token. The MCU clears this bit to terminate the stall condition                                                                                                                                                                                                                                    |
| 1      | FIFONOTEMPTY | The MCU writes 1 to this bit to flush the next packet to be transmitted from the endpoint IN FIFO. The FIFO pointer is reset and the INPKTRDY bit is cleared. If the FIFO contains two packets, FLUSHFIFO will need to be set twice to completely clear the FIFO. FLUSHFIFO should only be used when INPKTRDY is set. At other times, it may cause data corruption. |
| 0      | INPKTRDY     | If ABORTPKT_EN is enabled and this bit is set, the function of this bit will become ABORTPKT to abort the next packet to be transmitted from the endpoint IN FIFO and does not need to set INPKTRDY. It is the same with the FLUSHFIFO function. This bit is only active when the endpoint is idle.                                                                 |

| USB EP INCSR2 USB Control/Status Register #2 for IN Endpoint |    |    |    |    |    |    |   |   |          |     |      |          |             |   |   |   |
|--------------------------------------------------------------|----|----|----|----|----|----|---|---|----------|-----|------|----------|-------------|---|---|---|
| Bit                                                          | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6   | 5    | 4        | 3           | 2 | 1 | 0 |
| Name                                                         |    |    |    |    |    |    |   |   | AUTO SET | ISO | MODE | DMA ENAB | FRC DATATOG |   |   |   |
| Type                                                         |    |    |    |    |    |    |   |   | RW       | RW  | RW   | RW       | RW          |   |   |   |
| Reset                                                        |    |    |    |    |    |    |   |   | 0        | 0   | 0    | 0        | 0           |   |   |   |

| Bit(s) | Name        | Description                                                                                                                                                                                                                                                    |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | AUTOSET     | If the MCU sets up the bit, INPKTRDY will be automatically set when the data of the maximum packet size (value in INMAXP) is loaded into the IN FIFO.                                                                                                          |
| 6      | ISO         | If a packet of smaller than the maximum packet size is loaded, INPKTRDY will have to be set manually. When 2 packets are in the IN FIFO, INPKTRDY will also be automatically set when the first packet is sent if the second packet is the maximum packet size |
| 5      | MODE        | The MCU sets up this bit to enable the IN endpoint for isochronous transfer and clears it to enable the IN endpoint for bulk/interrupt transfers                                                                                                               |
| 4      | DMAENAB     | The MCU sets up this bit to enable the endpoint direction as IN and clears it to enable the endpoint direction as OUT. It is valid only when the same endpoint FIFO is used for both IN and OUT transactions.                                                  |
| 3      | FRC DATATOG | The MCU sets up this bit to force the endpoints IN data toggle to switch after each data packet is sent regardless of whether an ACK has been received. This can be used by interrupt IN endpoints which are used to communicate                               |

| Bit(s) | Name | Description                             |
|--------|------|-----------------------------------------|
|        |      | rate feedback for isochronous endpoints |

|       |                                     |                                                   |    |    |    |    |   |   |   |   |   |   |   |   |   |             |
|-------|-------------------------------------|---------------------------------------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------|
| 13    | <a href="#">USB EP OUTMA<br/>XP</a> | USB Maximum Racket Size Register for OUT Endpoint | 00 |    |    |    |   |   |   |   |   |   |   |   |   |             |
| Bit   | 15                                  | 14                                                | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
| Name  |                                     |                                                   |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>MAXP</b> |
| Type  |                                     |                                                   |    |    |    |    |   |   |   |   |   |   |   |   |   | RW          |
| Reset |                                     |                                                   |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0           |

This register holds the maximum packet size for transactions through the currently selected OUT endpoint (unit: byte). When setting up this value, the programmer should note the constraints placed by the USB specification on packet sizes for bulk, interrupt, and isochronous transactions in full speed operations. There is an OUTMAXXP register for each OUT endpoint except for endpoint 0. The registers are active when the USB\_INDEX register is set to 1 and 2 respectively.

The value written to this register should match the wMaxPacketSize field of the standard endpoint descriptor for the associated endpoint. A mismatch may cause unexpected results. The total amount of data represented by the value written to this register must not exceed the FIFO size for the OUT endpoint and should not exceed half the FIFO size if double buffering is required. If a value bigger than the configured OUT FIFO size for the endpoint is written to the register, the value will be automatically changed to the OUT FIFO size. If the value written to the register is smaller than or equal to half the OUT FIFO size, two OUT packets can be buffered. The configured IN FIFO size for the endpoint 1, 2, and 3 are both 16, 64, and 64 bytes, respectively.

| Bit(s) | Name | Description                      |
|--------|------|----------------------------------|
| 7:0    | MAXP | Maximum packet size (unit: byte) |

|       |                                     |                                                 |    |    |    |    |   |   |                   |                   |                   |                   |                   |             |              |                  |
|-------|-------------------------------------|-------------------------------------------------|----|----|----|----|---|---|-------------------|-------------------|-------------------|-------------------|-------------------|-------------|--------------|------------------|
| 14    | <a href="#">USB EP OUTCS<br/>R1</a> | USB Control/Status Register #1 for OUT Endpoint | 00 |    |    |    |   |   |                   |                   |                   |                   |                   |             |              |                  |
| Bit   | 15                                  | 14                                              | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6                 | 5                 | 4                 | 3                 | 2           | 1            | 0                |
| Name  |                                     |                                                 |    |    |    |    |   |   | CLRD<br>TATO<br>G | SENT<br>STAL<br>L | SEND<br>STAL<br>L | FLUS<br>HFIF<br>O | DATA<br>ERR<br>OR | OVER<br>RUN | FIFO<br>FULL | RXP<br>KTRD<br>Y |
| Type  |                                     |                                                 |    |    |    |    |   |   | A0                | A1                | RW                | A0                | RU                | A1          | RU           | A1               |
| Reset |                                     |                                                 |    |    |    |    |   |   | 0                 | 0                 | 0                 | 0                 | 0                 | 0           | 0            | 0                |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                                         |
|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | CLRDATOG  | The MCU writes 1 to this bit to reset the endpoint data toggle to 0.                                                                                                                                                                                                                                |
| 6      | SENTSTALL | The bit is set when a STALL handshake is transmitted.<br>The MCU should clear this bit by writing 0 to it.                                                                                                                                                                                          |
| 5      | SENDSTALL | The MCU writes 1 to this bit to issue a STALL handshake. The MCU clears this bit to terminate the stall condition. This bit will have no effect if the OUT endpoint is in the isochronous mode                                                                                                      |
| 4      | FLUSHFIFO | The MCU writes 1 to this bit to flush the next packet to be read from the endpoint OUT FIFO. If the FIFO contains two packets, FLUSHFIFO will need to be set twice to completely clear the FIFO. FLUSHFIFO should only be used when OUTPKTRDY is set. At other times, it may cause data corruption. |
| 3      | DATAERROR | The bit is set when OUTPKTRDY is set if the data packet has a CRC or bit                                                                                                                                                                                                                            |

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                   |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          | stuff error.                                                                                                                                                                                                                                                                                                                                                                  |
| 2      | OVERRUN  | It is cleared when OUTPKTRDY is cleared. This bit is only valid in the isochronous mode.                                                                                                                                                                                                                                                                                      |
| 1      | FIFOFULL | The bit will be set if an OUT packet cannot be loaded into the OUT FIFO. The MCU should clear the bit by writing 0 to it. This bit is only valid in the isochronous mode.                                                                                                                                                                                                     |
| 0      | RXPKTRDY | This bit is set when no more packets can be loaded into the OUT FIFO<br>The bit is set when a data packet has been received.<br>The MCU should clear (write 0 to it) the bit when the packet is unloaded from the OUT FIFO. An interrupt will be generated when the bit is set. When the receiving null packet is received, OUTPKTRDY will be set after USB_INTROUT1 is high. |

15 **USB EP\_OUTCS** USB Control/Status Register #2 for OUT Endpoint **R2** 00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8           | 7   | 6         | 5         | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|-------------|-----|-----------|-----------|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   | AUTO CLEA R | ISO | DMA ENA B | DMA MOD E |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   | RW          | RW  | RW        | RW        |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   | 0           | 0   | 0         | 0         |   |   |   |   |   |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | AUTOCLEAR | If the MCU sets up this bit, the OUTPKTRDY bit will be automatically cleared when a packet of OUTMAXP bytes is unloaded from the OUT FIFO. When packets of smaller than the maximum packet size are unloaded, OUTPKTRDY will have to be cleared manually.                                                                                                                                                                                        |
| 6      | ISO       | The MCU sets up this bit to enable the OUT endpoint for isochronous transfers and clears it to enable the OUT endpoint for bulk/interrupt transfers                                                                                                                                                                                                                                                                                              |
| 5      | DMA ENAB  | The MCU sets up this bit to enable the DMA request for the OUT endpoint                                                                                                                                                                                                                                                                                                                                                                          |
| 4      | DMA MODE  | Two modes of DMA operation are supported: DMA mode 0 in which a DMA request is generated for all received packets, together with an interrupt (if enabled). DMA mode 1 in which a DMA request (but no interrupt) is generated for OUT packets of size OUTMAXP bytes and an interrupt (but no DMA request) is generated for OUT packets of any other size. The MCU sets up the bit to select DMA mode 1 and clears this bit to select DMA mode 0. |

16 **USB EP COUNT** USB OUT Endpoint Byte Counter Register LSB Part for **Endpoint 1** 00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

The register holds the lower 8 bits of the number of received data bytes in the packet in the FIFO associated with the currently selected OUT endpoint. The value returned is valid while OUTPKTRDY in register USB\_OUTCSR1 is set. The registers are active when the USB\_INDEX register is set to 1 and 2 respectively.

| Bit(s) | Name | Description |
|--------|------|-------------|
|        |      |             |

| Bit(s) | Name | Description                                                            |
|--------|------|------------------------------------------------------------------------|
| 7:0    | NUML | Lower 8 bits of the number of received data bytes for the OUT endpoint |

|              |                                 |                                                              |    |    |    |    |   |   |   |   |   |   |   |   |              |   |   |
|--------------|---------------------------------|--------------------------------------------------------------|----|----|----|----|---|---|---|---|---|---|---|---|--------------|---|---|
| 17           | <u>USB_EP_COUNT</u><br><u>2</u> | USB OUT Endpoint Byte Counter Register MSB Part for Endpoint | 00 |    |    |    |   |   |   |   |   |   |   |   |              |   |   |
| <b>Bit</b>   | 15                              | 14                                                           | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1            | 0 |   |
| <b>Name</b>  |                                 |                                                              |    |    |    |    |   |   |   |   |   |   |   |   | <b>NUM H</b> |   |   |
| <b>Type</b>  |                                 |                                                              |    |    |    |    |   |   |   |   |   |   |   |   | <b>RU</b>    |   |   |
| <b>Reset</b> |                                 |                                                              |    |    |    |    |   |   |   |   |   |   |   |   | 0            | 0 | 0 |

The register holds the upper 3 bits of the number of received data bytes in the packet in the FIFO associated with the currently selected OUT endpoint. The value returned is valid while OUTPKTRDY in register USB\_EP\_OUTCSR1 is set. The registers are active when the USB\_INDEX register is set to 1 and 2 respectively.

| Bit(s) | Name | Description                                                             |
|--------|------|-------------------------------------------------------------------------|
| 2:0    | NUMH | Upper 8 bits of the number of received data bytes for the OUT endpoint. |

|              |                                   |                                  |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |   |
|--------------|-----------------------------------|----------------------------------|----|----|----|----|---|---|---|---|---|---|---|---|------------------|---|---|
| 20           | <u>USB_EP0_FIFO</u><br><u>DB0</u> | USB Endpoint 0 FIFO Register DB0 | 00 |    |    |    |   |   |   |   |   |   |   |   |                  |   |   |
| <b>Bit</b>   | 15                                | 14                               | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                | 0 |   |
| <b>Name</b>  |                                   |                                  |    |    |    |    |   |   |   |   |   |   |   |   | <b>FIFO0_DB0</b> |   |   |
| <b>Type</b>  |                                   |                                  |    |    |    |    |   |   |   |   |   |   |   |   | Other            |   |   |
| <b>Reset</b> |                                   |                                  |    |    |    |    |   |   |   |   |   |   |   |   | 0                | 0 | 0 |

The register provides MCU access to the FIFO for the endpoint 0. Writing to this register will load data to the FIFO for the endpoint 0. Reading this register unloads data from the FIFO for the endpoint 0.

The register provides word, half word, and byte mode accesses. If word or half word accesses are performed, the less significant byte will correspond to the prior byte to load to or unload from the FIFO.

| Bit(s) | Name      | Description                                               |
|--------|-----------|-----------------------------------------------------------|
| 7:0    | FIFO0_DB0 | The first byte to be loaded to or unloaded from the FIFO. |

|              |                                   |                                  |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |   |
|--------------|-----------------------------------|----------------------------------|----|----|----|----|---|---|---|---|---|---|---|---|------------------|---|---|
| 21           | <u>USB_EP0_FIFO</u><br><u>DB1</u> | USB Endpoint 0 FIFO Register DB1 | 00 |    |    |    |   |   |   |   |   |   |   |   |                  |   |   |
| <b>Bit</b>   | 15                                | 14                               | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                | 0 |   |
| <b>Name</b>  |                                   |                                  |    |    |    |    |   |   |   |   |   |   |   |   | <b>FIFO0_DB1</b> |   |   |
| <b>Type</b>  |                                   |                                  |    |    |    |    |   |   |   |   |   |   |   |   | Other            |   |   |
| <b>Reset</b> |                                   |                                  |    |    |    |    |   |   |   |   |   |   |   |   | 0                | 0 | 0 |

| Bit(s) | Name      | Description                                                |
|--------|-----------|------------------------------------------------------------|
| 7:0    | FIFO0_DB1 | The second byte to be loaded to or unloaded from the FIFO. |

|    |                     |                                  |    |
|----|---------------------|----------------------------------|----|
| 22 | <u>USB_EP0_FIFO</u> | USB Endpoint 0 FIFO Register DB2 | 00 |
|----|---------------------|----------------------------------|----|

**DB2**

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                  |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>FIFO0_DB2</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other            |
| <b>Reset</b> |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                        |
|---------------|-------------|-----------------------------------------------------------|
| 7:0           | FIFO0_DB2   | The third byte to be loaded to or unloaded from the FIFO. |

23            **USB\_EP0\_FIFO\_DB3**    USB Endpoint 0 FIFO Register DB3            00

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                  |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>FIFO0_DB3</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other            |
| <b>Reset</b> |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                        |
|---------------|-------------|-----------------------------------------------------------|
| 7:0           | FIFO0_DB3   | The forth byte to be loaded to or unloaded from the FIFO. |

24            **USB\_EP1\_FIFO\_DB0**    USB Endpoint 1 FIFO Register DB0            00

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                  |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>FIFO1_DB0</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other            |
| <b>Reset</b> |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                |

The register provides MCU access to the FIFO for the endpoint 1. Writing to this register will load data to the FIFO for the endpoint 1. Reading this register will unload data from the FIFO for the endpoint 1.

The register provides word, half word, and byte mode accesses. If word or half word accesses are performed, the less significant byte will correspond to the prior byte to load to or unload from the FIFO.

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                        |
|---------------|-------------|-----------------------------------------------------------|
| 7:0           | FIFO1_DB0   | The first byte to be loaded to or unloaded from the FIFO. |

25            **USB\_EP1\_FIFO\_DB1**    USB Endpoint 1 FIFO Register DB1            00

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                  |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>FIFO1_DB1</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other            |
| <b>Reset</b> |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                         |
|---------------|-------------|------------------------------------------------------------|
| 7:0           | FIFO1_DB1   | The second byte to be loaded to or unloaded from the FIFO. |

26

USB\_EP1\_FIFO\_DB2 USB Endpoint 1 FIFO Register DB2

00

| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | FIFO1_DB2 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | Other     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name      | Description                                               |
|--------|-----------|-----------------------------------------------------------|
| 7:0    | FIFO1_DB2 | The third byte to be loaded to or unloaded from the FIFO. |

27

USB\_EP1\_FIFO\_DB3 USB Endpoint 1 FIFO Register DB3

00

| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | FIFO1_DB3 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | Other     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name      | Description                                               |
|--------|-----------|-----------------------------------------------------------|
| 7:0    | FIFO1_DB3 | The forth byte to be loaded to or unloaded from the FIFO. |

28

USB\_EP2\_FIFO\_DB0 USB Endpoint 2 FIFO Register DB0

00

| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | FIFO2_DB0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | Other     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

The register provides MCU access to the FIFO for the endpoint 2. Writing to this register will load data to the FIFO for the endpoint 2. Reading this register will unload data from the FIFO for the endpoint 2. The register provides word, half word, and byte mode accesses. If word or half word accesses are performed, the less significant byte will correspond to the prior byte to load to or unload from the FIFO.

| Bit(s) | Name      | Description                                               |
|--------|-----------|-----------------------------------------------------------|
| 7:0    | FIFO2_DB0 | The first byte to be loaded to or unloaded from the FIFO. |

29 USB\_EP2\_FIFO\_DB1 USB Endpoint 2 FIFO Register DB1 00

| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | FIFO2_DB1 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | Other     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name      | Description                                                |
|--------|-----------|------------------------------------------------------------|
| 7:0    | FIFO2_DB1 | The second byte to be loaded to or unloaded from the FIFO. |

2A

USB EP2 FIFO USB Endpoint 2 FIFO Register DB2

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FIFO2_DB2 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other     |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0         |

Bit(s)

Name

Description

7:0 FIFO2\_DB2 The third byte to be loaded to or unloaded from the FIFO.

2B

USB EP2 FIFO USB Endpoint 2 FIFO Register DB3

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FIFO2_DB3 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other     |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0         |

Bit(s)

Name

Description

7:0 FIFO2\_DB3 The forth byte to be loaded to or unloaded from the FIFO.

2C

USB EP3 FIFO USB Endpoint 3 FIFO Register DB0

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FIFO3_DB0 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other     |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0         |

The register provides MCU access to the FIFO for the endpoint 3. Writing to this register will load data to the FIFO for the endpoint 3. Reading this register will unload data from the FIFO for the endpoint 3.

The register provides word, half word, and byte mode accesses. If word or half word accesses are performed, the less significant byte will correspond to the prior byte to load to or unload from the FIFO.

Bit(s)

Name

Description

7:0 FIFO3\_DB0 The first byte to be loaded to or unloaded from the FIFO.

2D

USB EP3 FIFO USB Endpoint 3 FIFO Register DB1

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FIFO3_DB1 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other     |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0         |

Bit(s)

Name

Description

7:0 FIFO3\_DB1 The second byte to be loaded to or unloaded from the FIFO.

**2E      USB\_EP3\_FIFO    USB Endpoint 3 FIFO Register DB2**

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>FIFO3_DB2</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other            |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0 | 0 | 0 | 0 | 0                |

| Bit(s) | Name      | Description                                               |
|--------|-----------|-----------------------------------------------------------|
| 7:0    | FIFO3_DB2 | The third byte to be loaded to or unloaded from the FIFO. |

**2F      USB\_EP3\_FIFO    USB Endpoint 3 FIFO Register DB3**

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>FIFO3_DB3</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other            |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0 | 0 | 0 | 0 | 0                |

| Bit(s) | Name      | Description                                               |
|--------|-----------|-----------------------------------------------------------|
| 7:0    | FIFO3_DB3 | The forth byte to be loaded to or unloaded from the FIFO. |

**30      USB\_EP4\_FIFO    USB Endpoint 4 FIFO Register DB0**

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>FIFO4_DB0</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other            |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0 | 0 | 0 | 0 | 0                |

The register provides MCU access to the FIFO for the endpoint 4. Writing to this register will load data to the FIFO for the endpoint 4. Reading this register will unload data from the FIFO for the endpoint 4.

The register provides word, half word, and byte mode accesses. If word or half word accesses are performed, the less significant byte will correspond to the prior byte to load to or unload from the FIFO.

| Bit(s) | Name      | Description                                               |
|--------|-----------|-----------------------------------------------------------|
| 7:0    | FIFO4_DB0 | The first byte to be loaded to or unloaded from the FIFO. |

**31      USB\_EP4\_FIFO    USB Endpoint 4 FIFO Register DB1**

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>FIFO4_DB1</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Other            |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0 | 0 | 0 | 0 | 0                |

| Bit(s) | Name      | Description                                                |
|--------|-----------|------------------------------------------------------------|
| 7:0    | FIFO4_DB1 | The second byte to be loaded to or unloaded from the FIFO. |

| Bit(s) | Name      | Description                                                |
|--------|-----------|------------------------------------------------------------|
| 7:0    | FIFO4_DB1 | The second byte to be loaded to or unloaded from the FIFO. |

| 32          | <u>USB_EP4_FIFO_DB2</u> | USB Endpoint 4 FIFO Register DB2 | 00 |    |    |    |   |   |   |   |   |   |                  |   |   |   |
|-------------|-------------------------|----------------------------------|----|----|----|----|---|---|---|---|---|---|------------------|---|---|---|
| Bit         | 15                      | 14                               | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                | 2 | 1 | 0 |
| <b>Name</b> |                         |                                  |    |    |    |    |   |   |   |   |   |   | <b>FIFO4_DB2</b> |   |   |   |
| <b>Type</b> |                         |                                  |    |    |    |    |   |   |   |   |   |   | Other            |   |   |   |
|             |                         |                                  |    |    |    |    |   |   |   |   |   |   | 0                | 0 | 0 | 0 |
|             |                         |                                  |    |    |    |    |   |   |   |   |   |   | 0                | 0 | 0 | 0 |

| Bit(s) | Name      | Description                                               |
|--------|-----------|-----------------------------------------------------------|
| 7:0    | FIFO4_DB2 | The third byte to be loaded to or unloaded from the FIFO. |

| 33           | <u>USB_EP4_FIFO_DB3</u> | USB Endpoint 4 FIFO Register DB3 | 00 |    |    |    |   |   |   |   |   |   |                  |   |   |   |
|--------------|-------------------------|----------------------------------|----|----|----|----|---|---|---|---|---|---|------------------|---|---|---|
| Bit          | 15                      | 14                               | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                | 2 | 1 | 0 |
| <b>Name</b>  |                         |                                  |    |    |    |    |   |   |   |   |   |   | <b>FIFO4_DB3</b> |   |   |   |
| <b>Type</b>  |                         |                                  |    |    |    |    |   |   |   |   |   |   | Other            |   |   |   |
| <b>Reset</b> |                         |                                  |    |    |    |    |   |   |   |   |   |   | 0                | 0 | 0 | 0 |
|              |                         |                                  |    |    |    |    |   |   |   |   |   |   | 0                | 0 | 0 | 0 |

| Bit(s) | Name      | Description                                               |
|--------|-----------|-----------------------------------------------------------|
| 7:0    | FIFO4_DB3 | The forth byte to be loaded to or unloaded from the FIFO. |

| 240          | <u>USB_CON</u> | USB PHY Control | 20 |    |    |    |   |   |   |   |                    |   |   |   |                 |                 |
|--------------|----------------|-----------------|----|----|----|----|---|---|---|---|--------------------|---|---|---|-----------------|-----------------|
| Bit          | 15             | 14              | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                  | 4 | 3 | 2 | 1               | 0               |
| <b>Name</b>  |                |                 |    |    |    |    |   |   |   |   | <b>NULLPKT_FIX</b> |   |   |   | <b>DMPULLUP</b> | <b>DPPULLUP</b> |
| <b>Type</b>  |                |                 |    |    |    |    |   |   |   |   | RW                 |   |   |   | RW              | RW              |
| <b>Reset</b> |                |                 |    |    |    |    |   |   |   |   | 1                  |   |   |   | 0               | 0               |

| Bit(s) | Name        | Description                                                                                                      |
|--------|-------------|------------------------------------------------------------------------------------------------------------------|
| 5      | NULLPKT_FIX | If NULLPKT_FIX is set to 1, the USB controller will not issue a DMAreq when a null packet is received.           |
| 1      | DMPULLUP    | Pull-up enabling pin. Enables the pull-up 1.5KOhm pull-up on D pin as a full speed device by setting it to high  |
| 0      | DPPULLUP    | Pull-up enabling pin. Enables the pull-up 1.5KOhm pull-up on D+ pin as a full speed device by setting it to high |

### 3.14.4 System Integration Guide

#### 3.14.4.1 USB device configuration

The target audience of this section is the software engineer.

The USB device controller features one control endpoint and 6 other endpoints. The configuration of interfaces and endpoints can be accommodated by software for specific functions, basically supporting Bluetooth HCI, and device firmware upgrade.

Bluetooth HCI transport layer defines the configuration of endpoints and interfaces.

- ✓ One voice channel with 16-bit encoding.

| Endpoint             | Endpoint type  | Max. packet size (bytes) | Max. bandwidth (bytes/ms) | Min. bandwidth (bytes/ms) | Double buffer in controller | Generic DMA |
|----------------------|----------------|--------------------------|---------------------------|---------------------------|-----------------------------|-------------|
| Endpoint 0 (command) | Control        | 64                       |                           |                           | No                          | No          |
| Endpoint 1 IN        | Bulk (IN)      | 64                       |                           | 1024                      | No                          | Yes         |
| Endpoint 2 OUT       | Bulk (OUT)     | 64                       |                           | 1024                      | No                          | Yes         |
| Endpoint 2 IN        | Bulk (IN)      | 64                       | 1024                      |                           | No                          | Yes         |
| Endpoint 2 OUT       | Bulk (OUT)     | 64                       | 1024                      |                           | No                          | Yes         |
| Endpoint 3 IN        | Interrupt (IN) | 16                       |                           | 16                        | No                          | No          |
| Endpoint 4 IN        | Interrupt (IN) | 16                       |                           | 16                        | No                          | No          |

\*When the maximum packet size is smaller than one half of the device FIFO size (64 bytes), the double buffer will be automatically enabled by hardware.

The pull-up resistor on the USB transceiver is initially disconnected when boot-up. No external resistor is required. The software should enable it after performing the configuration of the USB device controller.

#### 3.14.4.2 System Infrastructure Configuration

The clock, interrupt and DMA are defined as the system infrastructure. It requires several steps to bring up the USB. Those steps should be done in sequence to prevent from malfunction.

##### Power-on

1. Enable USB PLL.
2. Enable USB clock after USB PLL is settled.
3. Unmask the USB interrupt in the interrupt controller.
4. Enable the pull-up resistor.

The USB device controller can generate the interrupt when conditions are met as defined in USB\_INTRINE, USB\_INTRROUTE, and USB\_INTRUSBE.

The generic DMA controller is used to move data from or to the USB device controller. The USB device controller will use at most 4 DMA channels for ACL and SCO. The user should use the half-channel DMA since only the half channel DMA has the hardware flow control.

The USB FIFO provides byte and word accesses to the read/write port of USB\_EP0\_FIFO, USB\_EP1\_FIFO, USB\_EP2\_FIFO, USB\_EP3\_FIFO and USB\_EP4\_FIFO. If the data buffer allocated in memory is word aligned, the user can enable word transfer in the DMA controller. If the data buffer allocated in memory is not word aligned, the user should set to byte aligned and set B2W in DMAx\_CON to 1 to enable fast byte-to-word transfer.

#### 3.14.4.3 Power On/Off USB PHY and Controller Sequence

##### Power-on sequence after plug-in

1. Turn on Vusb(PHY 3.3v power) – The control register is in PMIC document.
2. Turn on USB AHB clock(78MHz) – The control register is in config document.
3. Turn on internal 48MHz PLL – the control register is in clock document.
4. Wait for 50 usec. (PHY 3.3v power stable time)
5. Turn on USB PHY BIAS current control → reg[USB+08C1h] bit3 = 1. (RG\_USB11\_FSLSENBL).
6. Wait for 10 usec.
7. Set up D+ pull up register for connecting Host → reg[USB+0240h] bit 0=1(PUB)

##### Power-off sequence after plug-out

1. Release D+ pull up register for disconnecting Host → Setting reg[USB+0240h] bit 0=0 (PUB)
2. Turn off USB PHY BIAS current control → reg[USB+08C1h] bit3 = 0. (RG\_USB11\_FSLSENBL).
3. Turn off Vusb (PHY 3.3v power) – The control register is in PMIC document

### 3.15 Accessory Detector

#### 3.15.1 General Description

The hardware accessory detector (ACCDET) detects plug-in/out of multiple types of external components. Based on the suggested circuit (see **Figure 41**), this design supports 3 types of external components, which are microphone, hook-switch and TV-OUT line. This design uses the internal 2-bit comparator to separate external components. The de-bounce scheme is also supported to resist

uncertain input noises. When the plug-in/out state is stable, the PWM unit of ACCDET will enable the comparator, MBIAS and threshold voltage of the comparator periodically for the plugging detection. With suitable PWM settings, very low-power consumption can be achieved when the detection feature is enabled. In order to compensate the delay between the detection logic and comparator, the delay enabling scheme is adopted. Given the suitable delay number compared to the rising edge of PWM high pulse, the stable plugging state can be prorogated to digital detection logic. Then the correct plugging state can be detected and reported.

Figure 42 shows the state machine without TV-OUT mode. The state machine is executed by the software to control the ACCDET design. The ACCDET design will send one interrupt to acknowledge the software after the ACCDET input state is changed and the duration of the state is longer than debounce time. The software needs to read out the memorized ACCDET input state and follow the recommend state machine to program the register in it.



Figure 41. Suggested Accessory Detection Circuit.



Figure 42. The State machine between Microphone and Hook-Switch plug-in/out change.

### 3.15.2 Pulse Width Modulation

The ACCDET design also provides one Pulse-Width-Modulation (PWM) to enable the comparator, microphone's bias current and the threshold voltage of the comparator periodically. With suitable PWM and settings for delayed enabling, the ACCDET can achieve very low power consumption and accurate plug-in/out detection. Figure 43 shows a timing diagram example of such PWM design. The output from PWM keeps being at "0" until the value of the counter is smaller than the programmed threshold.



Figure 43. PWM waveform.

### 3.15.3 Register Definition

Module name: ACCDET base address: (+A0750000h)

| Address  | Name                                           | Width | Register function                           |
|----------|------------------------------------------------|-------|---------------------------------------------|
| A0750000 | <a href="#"><u>ACCDET_RSTB</u></a>             | 32    | ACCDET software reset register              |
| A0750004 | <a href="#"><u>ACCDET_CTRL</u></a>             | 32    | ACCDET control register                     |
| A0750008 | <a href="#"><u>ACCDET_STATE_SWCTRL</u></a>     | 32    | ACCDET state switch control register        |
| A075000C | <a href="#"><u>ACCDET_PWM_WIDTH</u></a>        | 32    | ACCDET PWM width register                   |
| A0750010 | <a href="#"><u>ACCDET_PWM_THRESH</u></a>       | 32    | ACCDET PWM threshold register               |
| A0750024 | <a href="#"><u>ACCDET_EN_DELAY_NUM</u></a>     | 32    | ACCDET enable delay number register         |
| A0750028 | <a href="#"><u>ACCDET_PWM_IDLE_VALUE</u></a>   | 32    | ACCDET PWM IDLE value register              |
| A075002C | <a href="#"><u>ACCDET_DEBOUNCE0</u></a>        | 32    | ACCDET debounce0 register                   |
| A0750030 | <a href="#"><u>ACCDET_DEBOUNCE1</u></a>        | 32    | ACCDET debounce1 register                   |
| A0750038 | <a href="#"><u>ACCDET_DEBOUNCE3</u></a>        | 32    | ACCDET debounce3 register                   |
| A075003C | <a href="#"><u>ACCDET_IRQ_STS</u></a>          | 32    | ACCDET interrupt status register            |
| A0750040 | <a href="#"><u>ACCDET_CURR_IN</u></a>          | 32    | ACCDET current input status register        |
| A0750044 | <a href="#"><u>ACCDET_SAMPLE_IN</u></a>        | 32    | ACCDET sampled input status register        |
| A0750048 | <a href="#"><u>ACCDET_MEMOIZED_IN</u></a>      | 32    | ACCDET memorized input status register      |
| A075004C | <a href="#"><u>ACCDET_LAST_MEMOIZED_IN</u></a> | 32    | ACCDET last memorized input status register |
| A0750050 | <a href="#"><u>ACCDET_FSM_STATE</u></a>        | 32    | ACCDET FSM status register                  |
| A0750054 | <a href="#"><u>ACCDET_CURR_DEBOUNCE</u></a>    | 32    | ACCDET current de-bounce status register    |
| A0750058 | <a href="#"><u>ACCDET_VERSION</u></a>          | 32    | ACCDET version code                         |
| A075005C | <a href="#"><u>ACCDET_IN_DEFAULT</u></a>       | 32    | default value of accdet_in                  |

#### A0750000 ACCDET\_RSTB ACCDET Software Reset Register 00000001

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0  |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RSTB |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW   |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      | 1  |

**Overview:** After applying the setting to register, software reset is necessary for state initialization. Without this process, ACCDET may detect incorrect plug state.

| Bit(s) | Mnemonic    | Name | Description                                                                                                                                                                                                                                            |
|--------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | <b>RSTB</b> | RSTB | <b>Set to 0 to reset the ACCDET unit and set to 1 after the reset process is finished.</b><br><br>This software reset will clear ACCDET's enable signal but keep all ACCDET's settings. After the reset process, ACCDET will return to the IDLE state. |

## A0750004 ACCDET\_CTRL ACCDET Control Register

00000001

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                 |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ACCD<br>ET_E<br>N |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1                 |

| Bit(s) | Mnemonic | Name | Description                         |
|--------|----------|------|-------------------------------------|
| 0      | ACCDET_E | EN   | Set to 1 to enable the ACCDET unit. |

## A0750008 ACCDET\_STAT E\_SWCTRL ACCDET State Switch Control Register 00000001

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MBIA<br>S_PWM<br>M_EN |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | VTH_PWM<br>EN         |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |

| Bit(s) | Mnemonic | Name         | Description                                  |
|--------|----------|--------------|----------------------------------------------|
| 4      | MBIAS_PW | MBIAS_PWM_EN | Enables PWM of ACCDET MBIAS unit             |
|        | M_EN     |              |                                              |
| 3      | VTH_PWM  | VTH_PWM_EN   | Enables PWM of ACCDET voltage threshold unit |
|        | EN       |              |                                              |
| 2      | CMP_PWM  | CMP_PWM_EN   | Enables PWM of ACCDET comparator             |
|        | EN       |              |                                              |

## A075000C ACCDET\_PWM\_WIDTH ACCDET PWM Width Register 00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16        |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0         |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PWM_WIDTH |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW        |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         |

| Bit(s) | Mnemonic      | Name      | Description                                                                                                                                                                                                                                                                                                                   |
|--------|---------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | PWM_WIDT<br>H | PWM_WIDTH | <b>ACCDET PWM width</b><br>It is PWM max. counter value. It will be the initial value for the internal counter. The PWM internal counter always counts down to zero to finish one complete period, and the value of the internal counter will return to the value of PWM_WIDTH.<br>PWM output frequency = (32k/PWM_WIDTH) Hz. |

A0750010 ACCDET\_PWM\_ THRESH ACCDET PWM Threshold Register 00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic       | Name       | Description                                                                                                                                                                                                                                                                          |
|--------|----------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | PWM_THRE<br>SH | PWM_THRESH | <b>ACCDET PWM threshold</b><br>When the internal counter value is bigger than or equal to PWM_THRESH, the PWM output signal will be "0". When the internal counter is smaller than PWM_THRESH, the PWM output signal will be "1".<br>PWM output duty cycle = (PWM_THRESH)x(1/32) ms. |

Figure 44 shows the PWM waveform with register value present.



Figure 44. PWM waveform with register value present

A0750024 ACCDET\_EN\_D ELAY\_NUM ACCDET Enable Delay Number Register 00000101

| Bit   | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Mne   |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Mne   | FALL_DELA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|       |       |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|-------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|       | Y_NUM |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Type  | RW    | RW |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Reset | 0     | 0  | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |

| Bit(s) | Mnemonic  | Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-----------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | FALL_DELA | FALL_DELAY_NUM | <b>Falling delay cycle compared to CMP PWM waveform</b><br>In order to make sure the plug state is stable after disabling ACCDET, the suitable delay cycle is necessary. This number indicates the clock cycle number between the point when the digital part of ACCDET stops receiving accdet_in and the point when the analog part of ACCDET stops working.                                                                                     |
| 14:0   | RISE_DELA | RISE_DELAY_NUM | <b>Rising delay cycle compared to PWM waveform</b><br>In order to make sure the plug state is stable before activating ACCDET, the suitable delay cycle is necessary. This number indicates the clock cycle number between the point when the analog part of ACCDET starts working and the point when the digital part of ACCDET starts receiving stable accdet_in. This number should be fine tuned depending on different project requirements. |

**A0750028 ACCDET\_PWM – ACCDET PWM IDLE Value Register** 00000001

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |       |     |     |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-----|-----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18    | 17  | 16  |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |       |     |     |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |       |     |     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |       |     |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2     | 1   | 0   |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    | MBIAS | VTH | CMP |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | RW    | RW  | RW  |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0     | 0   | 1   |

| Bit(s) | Mnemonic | Name  | Description             |
|--------|----------|-------|-------------------------|
| 2      | MBIAS    | MBIAS | IDLE value of MBIAS PWM |
| 1      | VTH      | VTH   | IDLE value of VTH PWM   |
| 0      | CMP      | CMP   | IDLE value of CMP PWM   |

**A075002C ACCDET\_DEBO UNCE0 ACCDET Debounce0 Register** 00000010

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  |

**Overview:** This register defines the waiting period before plug-in/out or release events are considered stable. If the de-bounce setting is too small, the plug-in/out will be too sensitive and detect too many unexpected plug-ins/outs. The suitable de-bounce time setting must be adjusted for the user's demand.

| Bit(s) | Mnemonic             | Name      | Description                                                                         |
|--------|----------------------|-----------|-------------------------------------------------------------------------------------|
| 15:0   | <b>DEBOUNCE</b><br>0 | DEBOUNCE0 | De-bounce time control of the next state = 2'b00<br>De-bounce time = DEBOUNCE/32 ms |

**A0750030 ACCDET\_DEBOUNCE1** ACCDET Debounce1 Register **00000010**

| Bit          | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Mne</b>   |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Mne</b>   | DEBOUNCE1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  |

**Overview:** This register defines the waiting period before plug-in/out or release events are considered stable. If the de-bounce setting is too small, the plug-in/out will be too sensitive and detect too many unexpected plug-ins/outs. The suitable de-bounce time setting must be adjusted for the user's demand.

| Bit(s) | Mnemonic             | Name      | Description                                                                         |
|--------|----------------------|-----------|-------------------------------------------------------------------------------------|
| 15:0   | <b>DEBOUNCE</b><br>1 | DEBOUNCE1 | De-bounce time control of the next state = 2'b01<br>De-bounce time = DEBOUNCE/32 ms |

**A0750034 ACCDET\_DEBOUNCE2** ACCDET Debounce2 Register **00000010**

| Bit          | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Mne</b>   |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Mne</b>   | DEBOUNCE2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  |

**Overview:** This register defines the waiting period before plug-in/out or release events are considered stable. If the de-bounce setting is too small, the plug-in/out will be too sensitive and detect too many unexpected plug-ins/outs. The suitable de-bounce time setting must be adjusted for the user's demand.

| Bit(s) | Mnemonic             | Name      | Description                                                                         |
|--------|----------------------|-----------|-------------------------------------------------------------------------------------|
| 15:0   | <b>DEBOUNCE</b><br>2 | DEBOUNCE2 | De-bounce time control of the next state = 2'b10<br>De-bounce time = DEBOUNCE/32 ms |

**A0750038 ACCDET\_DEBO UNCE3 ACCDET Debounce3 Register 00000010**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16        |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0         |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DEBOUNCE3 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW        |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0         |

**Overview:** This register defines the waiting period before plug-in/out or release events are considered stable. If the de-bounce setting is too small, the plug-in/out will be too sensitive and detect too many unexpected plug-ins/outs. The suitable de-bounce time setting must be adjusted for the user's demand.

| Bit(s) | Mnemonic   | Name      | Description                                                                         |
|--------|------------|-----------|-------------------------------------------------------------------------------------|
| 15:0   | DEBOUNCE 3 | DEBOUNCE3 | De-bounce time control of the next state = 2'b11<br>De-bounce time = DEBOUNCE/32 ms |

**A075003C ACCDET\_IRQ\_STS ACCDET Interrupt Status Register 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQ_C_LR |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW       |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0        |

**Overview:** When the interrupt of ACCDET is asserted, IRQ\_CLR must be set to 1 to clear the interrupt status. This bit will pause all activities in the ACCDET design until both interrupt status and IRQ\_CLR are cleared. The software should write 1 to IRQ\_CLR first to clear the interrupt (IRQ). After that, if pclk gating is enabled, the software should read ACCDET\_IRQ\_STS again to make IRQ\_CLR self-reset to 0.

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                  |
|--------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8      | IRQ_CLR  | IRQ_CLR | Clears interrupt status of ACCDET unit                                                                                                                       |
| 0      | IRQ      | IRQ     | Interrupt status of ACCDET unit<br>Because this register will be cleared by hardware, the interrupt edge-sensitive scheme should be adopted for this design. |

**A0750040 ACCDET\_CURR\_IN ACCDET Current Input Status Register 00000003**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Mne   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |         |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------|
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | CURR_IN |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO      |
| <b>Reset</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 1 1 1   |

| Bit(s) | Mnemonic       | Name    | Description                         |
|--------|----------------|---------|-------------------------------------|
| 1:0    | <b>CURR_IN</b> | CURR_IN | Current input status of ACCDET unit |

**A0750044 ACCDET\_SAMP LE\_IN ACCDET Sampled Input Status Register 00000003**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16        |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0         |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SAMPLE_IN |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO        |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1 1 1     |

| Bit(s) | Mnemonic         | Name      | Description                                                                                                     |
|--------|------------------|-----------|-----------------------------------------------------------------------------------------------------------------|
| 1:0    | <b>SAMPLE_IN</b> | SAMPLE_IN | Samples input status of ACCDET unit<br>When the plug-in/out state is changed, the ACCDET unit will do sampling. |

**A0750048 ACCDET\_MEM\_OIZED\_IN ACCDET Memorized Input Status Register 00000003**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MEMORIZED_IN |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO           |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1 1 1        |

| Bit(s) | Mnemonic             | Name         | Description                                                                                                                                                                                                                                                        |
|--------|----------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0    | <b>MEMORIZE_D_IN</b> | MEMORIZED_IN | Memorized input status of ACCDET unit<br>When the plug-in/out states is changed and held longer than the debounce time, the ACCDET unit will save the sampled input state to the memorized state. The interrupt will also be asserted to acknowledge the software. |

**A075004C ACCDET\_LAST \_MEMOIZED\_IN ACCDET Last Memorized Input Status Register 00000003**

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b> | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                               |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------------------|
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                               |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                               |
| <b>Reset</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                               |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                             |
| <b>Mne</b>   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>LAST_MEMO<br/>RIZED_IN</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>RO</b>                     |
| <b>Reset</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 1 1                           |

| <b>Bit(s)</b> | <b>Mnemonic</b>               | <b>Name</b>               | <b>Description</b>                         |
|---------------|-------------------------------|---------------------------|--------------------------------------------|
| 1:0           | <b>LAST_MEM<br/>ORIZED_IN</b> | <b>LAST_MEMORIZE_D_IN</b> | Last memorized input status of ACCDET unit |

**A0750050 ACCDET\_FSM\_STATE ACCDET FSM Status Register 00000000**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16               |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>FSM_STATE</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RO</b>        |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 0 0            |

| <b>Bit(s)</b> | <b>Mnemonic</b>  | <b>Name</b>     | <b>Description</b>                         |
|---------------|------------------|-----------------|--------------------------------------------|
| 2:0           | <b>FSM_STATE</b> | <b>FSM_SATE</b> | State of ACCDET unit finite -state-machine |
| 0:            |                  |                 | ACCDet_IDLE                                |
| 1:            |                  |                 | ACCDet_SAMPLE                              |
| 2:            |                  |                 | ACCDet_DEBOUNCE                            |
| 3:            |                  |                 | ACCDet_CHECK                               |
| 4:            |                  |                 | ACCDet_MEMORIZED                           |
| 5:            |                  |                 | ACCDet_IRQ                                 |

**A0750054 ACCDET\_CURR\_DEBOUNCE ACCDET Current De-bounce Status Register 00000004**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CURR_DEBOUNCE</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RO</b>            |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0 0                  |

| <b>Bit(s)</b> | <b>Mnemonic</b>           | <b>Name</b>               | <b>Description</b>                    |
|---------------|---------------------------|---------------------------|---------------------------------------|
| 15:0          | <b>CURR_DEB<br/>OUNCE</b> | <b>CURR_DEBOUNC<br/>E</b> | Currently used de-bounce time setting |

**A0750058 ACCDET\_VERSION ACCDET Version Code 0000000 03**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|----|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                    | 16 |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                     | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ACCDET_VERSION</b> |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1                     | 1  |

| Bit(s) | Mnemonic              | Name               | Description             |
|--------|-----------------------|--------------------|-------------------------|
| 1:0    | <b>ACCDET_VERSION</b> | ACCDET_VERSI<br>ON | Version code for ACCDET |

**A075005C ACCDET\_IN\_DEFAULT Default Value of accdet\_in 00000000**

|              |    |    |    |    |    |    |    |    |    |    |    |                                                                             |    |    |    |                               |
|--------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------|----|----|----|-------------------------------|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20                                                                          | 19 | 18 | 17 | 16                            |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |                                                                             |    |    |    |                               |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |                                                                             |    |    |    |                               |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |                                                                             |    |    |    |                               |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4                                                                           | 3  | 2  | 1  | 0                             |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    | <b>ACC<br/>DET_<br/>IN_D<br/>EFA<br/>ULT_<br/>REF<br/>RES<br/>H_E<br/>N</b> |    |    |    | <b>ACCDET_IN<br/>_DEFAULT</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    | RW                                                                          |    |    |    | RW                            |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    | 0                                                                           |    |    | 0  | 0                             |

**Overview:** The default value of sample\_accdet\_in and memorised\_accdet\_in can be set by software instead of using the default value set by hardware(i.e. 3). ACCDET\_DEFALT\_REFRESH\_EN is the enable bit controlling whether to use this additional function. The value of sample\_accdet\_in and memorized\_accdet\_in will change when accdet\_en rises from low to high. Note that if software reset is applied when accdet\_en is high, the default value of sample\_accdet\_in and memorized\_accdet\_in will also be loaded when the software reset is de-asserted.

| Bit(s) | Mnemonic                                   | Name                                               | Description                                                                                                                                    |
|--------|--------------------------------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | <b>ACCDET_I_N_DEFAU<br/>LT_REFR_ESH_EN</b> | ACCDET_IN_DE<br>FAULT_REFRESH<br>LT_REFRES<br>H_EN | <b>Enable signal for whether to load accdet_in_default</b><br>0: accdet_in_default will not be loaded.<br>1: accdet_in_default will be loaded. |
| 1:0    | <b>ACCDET_I_N_DEFAU<br/>LT</b>             | ACCDET_IN_DE<br>FAULT                              | <b>Default value of accdet_in set by software</b>                                                                                              |

## 3.16 SD Memory Card Controller (MSDC0)

### 3.16.1 Introduction

The controller fully supports the SD memory card bus protocol as defined in SD Memory Card Specification Part 1 Physical Layer Specification version 2.0.

Furthermore, the controller also partially supports the SDIO card specification version 2.0. However, the controller can only be configured as the host of the SD memory card. Hereafter, the controller is also abbreviated as the SD controller. The following are the main features of the controller.

- Interface with MCU by APB bus
- 16/32-bit access on APB bus
- 16/32-bit access for control registers
- 32-bit access for FIFO
- Built-in 32 bytes FIFO buffers for transmit and receive, FIFO is shared for transmit and receive
- Built-in CRC circuit
- CRC generation can be disabled
- DMA supported
- Interrupt capabilities
- Data rate up to 48 Mbps in serial mode, 48x4 Mbps in parallel model, the module is targeted at 48 MHz operating clock
- Serial clock rate on SD bus is programmable
- Card detection capabilities during sleep mode
- Controllability of power for memory card
- Does not support SPI mode for SD memory card
- Does not support multiple SD memory cards

### 3.16.2 Overview

#### 3.16.2.1 Pin Assignment

The following lists pins required for the SD memory card. Table 50 shows how the pins are shared. Note that all I/O pads have embedded both pull-up and pull-down resistors because they are shared by the SD memory card. The pull-down resistors for these pins can be used for power saving. If optimal pull-up or pull-down resistors are required on the system board, all embedded pull-up and pull-down resistors can be disabled by programming the corresponding control registers. The VDDPD pin is used for power saving. Power for the SD memory card can be shut down by programming the corresponding control register. The WP (Write Protection) pin is used to detect the status of the Write Protection Switch on the SD memory card.

**Table 50. Sharing of pins for SD memory card controller**

| No. | Name | Type | MMC | SD | Description |
|-----|------|------|-----|----|-------------|
|-----|------|------|-----|----|-------------|

| No. | Name     | Type   | MMC  | SD      | Description                   |
|-----|----------|--------|------|---------|-------------------------------|
| 1   | SD_CLK   | O      | CLK  | CLK     | Clock                         |
| 2   | SD_DAT3  | I/O/PP |      | CD/DAT3 | Data Line [Bit 3]             |
| 3   | SD_DAT0  | I/O/PP | DAT0 | DAT0    | Data Line [Bit 0]             |
| 4   | SD_DAT1  | I/O/PP |      | DAT1    | Data Line [Bit 1]             |
| 5   | SD_DAT2  | I/O/PP |      | DAT2    | Data Line [Bit 2]             |
| 6   | SD_CMD   | I/O/PP | CMD  | CMD     | Command Or Bus State          |
| 7   | SD_PWRON | O      |      |         | VDD ON/OFF                    |
| 8   | SD_WP    | I      |      |         | Write Protection Switch in SD |
| 9   | SD_INS   | I      | VSS2 | VSS2    | Card Detection                |

### 3.16.2.2 Card Detection

For SD memory card, detection of card insertion/removal by hardware is supported, and a dedicated pin “INS” is used to perform card insertion and removal for SD. The pin “INS” will be connected to the pin “VSS2” of a SD connector (see **Figure 45**).



**Figure 45. Card detection for SD memory card**

### 3.16.3 Register Definition

Module name: **MSDC0** base address: (+A0130000h)

| Address | Name | Width | Register function |
|---------|------|-------|-------------------|
|         |      |       |                   |

| Address  | Name               | Width | Register function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|--------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0130000 | <u>MSDC_CFG</u>    | 32    | <b>SD memory card controller configuration register</b><br>For general configuration of the SD controller.<br><i>Note: MSDC_CFG[31:16] can be accessed by 16-bit APB bus access.</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| A0130004 | <u>MSDC_STA</u>    | 32    | <b>SD memory card controller status register</b><br>Contains the status of FIFO, interrupts and data requests.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| A0130008 | <u>MSDC_INT</u>    | 32    | <b>SD memory card controller interrupt register</b><br>Contains the status of interrupts. Note that the register still shows the status of interrupt even though the interrupt is disabled, that is, register bit INTEN of register MSDC_CFG is set to 0. It implies that software interrupt can be implemented by polling register bit INT of register MSDC_STA and this register. However, if hardware interrupt is desired, be sure to clear the register before setting up register bit INTEN of register MSDC_CFG to 1, or undesired hardware interrupt arisen from the previous interrupt status may take place.                                                         |
| A013000C | <u>MSDC_PS</u>     | 32    | <b>SD memory card pin status register</b><br>Used for card detection. When the memory card controller and system are powered on, the power for the memory card will still be off unless the power is supplied by the PMIC. Meanwhile, the pad for card detection defaults to pull down when the system is powered on. The scheme of card detection for MS is the same as that for SD.<br>For detecting card insertion, first pull up the INS pin and then enable card detection and the input pin at the same time. After 32 cycles of controller clock, the status of pin changes will emerge. To detect card removal, simply keep enabling card detection and the input pin. |
| A0130010 | <u>MSDC_DAT</u>    | 32    | <b>SD memory card controller data register</b><br>Reads/Writes data from/to FIFO inside SD controller.<br>Data access unit: 32 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| A0130014 | <u>MSDC_IOCON</u>  | 32    | <b>SD memory card controller IO control register</b><br>Specifies output driving capability and slew rate of IO pads for MSDC. The reset value is suggested setting. If the output driving capability of pins DAT0, DAT1, DAT2 and DAT3 is too large, it is possible to arise ground bounce and thus result in glitch on SCLK. The actual driving current will depend on the PAD type selected for the chip.                                                                                                                                                                                                                                                                   |
| A0130018 | <u>MSDC_IOCON1</u> | 32    | <b>SD memory card controller IO control register 1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| A0130020 | <u>SDC_CFG</u>     | 32    | <b>SD memory card controller configuration register</b><br>Configures the SD memory card controller when it is configured as the host of SD. If the controller is configured as the host of memory stick, the contents of the register will have no impact on the operation of the                                                                                                                                                                                                                                                                                                                                                                                             |

| Address  | Name              | Width | Register function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------|-------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                   |       | <p>controller.</p> <p><i>Note: SDC_CFG[31:16] can be accessed by 16-bit APB bus access.</i></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| A0130024 | <u>SDC_CMD</u>    | 32    | <p><b>SD memory card controller command register</b></p> <p>Defines a SD memory card command and its attribute. Before the SD controller issues a transaction onto the SD bus, application shall specify other relative settings such as argument for command. After application writes the register, the SD controller will issue the corresponding transaction onto SD serial bus. If the command is GO_IDLE_STATE, the controller will have serial clock on SD bus run 128 cycles before issuing the command.</p>                                                   |
| A0130028 | <u>SDC_ARG</u>    | 32    | <p><b>SD memory card controller argument register</b></p> <p>Contains argument of the SD memory card command.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| A013002C | <u>SDC_STA</u>    | 32    | <p><b>SD memory card controller status register</b></p> <p>Contains various statuses of SD controller as the controller is configured as the host of SD memory card.</p>                                                                                                                                                                                                                                                                                                                                                                                               |
| A0130030 | <u>SDC_RESP0</u>  | 32    | <p><b>SD memory card controller response register 0</b></p> <p>Contains parts of the last SD memory card bus response. See descriptions of register field SDC_RESP3.</p>                                                                                                                                                                                                                                                                                                                                                                                               |
| A0130034 | <u>SDC_RESP1</u>  | 32    | <p><b>SD memory card controller response register 1</b></p> <p>Contains parts of the last SD memory card bus response. See descriptions of register field SDC_RESP3.</p>                                                                                                                                                                                                                                                                                                                                                                                               |
| A0130038 | <u>SDC_RESP2</u>  | 32    | <p><b>SD memory card controller response register 2</b></p> <p>Contains parts of the last SD memory card bus response. See descriptions of register field SDC_RESP3.</p>                                                                                                                                                                                                                                                                                                                                                                                               |
| A013003C | <u>SDC_RESP3</u>  | 32    | <p><b>SD memory card controller response register 3</b></p> <p>Contains parts of the last SD memory card bus response. Register fields SDC_RESP0, SDC_RESP1, SDC_RESP2 and SDC_RESP3 compose the last SD memory card bus response. For response of type R2, that is, response of the command ALL_SEND_CID, SEND_CSD and SEND_CID, only bit 127 to 0 of the response token are stored in register field SDC_RESP0, SDC_RESP1, SDC_RESP2 and SDC_RESP3. For responses of other types, only bit 39 to 8 of the response token are stored in register field SDC_RESP0.</p> |
| A0130040 | <u>SDC_CMDSTA</u> | 32    | <p><b>SD memory card controller command status register</b></p> <p>Contains the status of SD controller during command execution and that of SD bus protocol after command execution when the SD controller is configured as the host of SD memory card. The register will also be used as the interrupt source. The register is cleared when</p>                                                                                                                                                                                                                      |

| Address  | Name                | Width | Register function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|---------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                     |       | being read. Meanwhile, if interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| A0130044 | <u>SDC_DATSTA</u>   | 32    | <b>SD memory card controller data status register</b><br>Contains the status of SD controller during data transfer on DAT line(s) when the SD controller is configured as the host of SD memory card. The register is also used as the interrupt source. The register is cleared when being read. Meanwhile, if interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.                                                                                                                                                                                                                                                                                             |
| A0130048 | <u>SDC_CSTA</u>     | 32    | <b>SD memory card status register</b><br>After commands with R1 and R1b response this register containing the status of the SD card, it will be used as the response interrupt source. In all register fields, logic high indicates error, and logic low indicates there is no error. The register is cleared when being read. Meanwhile, if interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.                                                                                                                                                                                                                                                                |
| A013004C | <u>SDC_IRQMASK0</u> | 32    | <b>SD memory card IRQ mask register 0</b><br>Contains parts of SD memory card interrupt mask register. See the descriptions of register SDC_IRQMASK1 for reference. The register masks interrupt sources from register SDC_CMDSTA and SDC_DATSTA. IRQMASK[3:0] is for SDC_CMDSTA, and IRQMASK[18:16] for SDC_DATSTA. Note that IRQMASK[18] masks SDC_DATSTA[9:2] together. '1' in some bits of the register masks the corresponding interrupt source with the same bit position. For example, if IRQMASK[0] is 1, then the interrupt source from register field CMDRDY of register SDC_CMDSTA will be masked. '0' in some bits does not cause interrupt mask on the corresponding interrupt source from register SDC_CMDSTA and SDC_DATSTA. |
| A0130050 | <u>SDC_IRQMASK1</u> | 32    | <b>SD memory card IRQ mask register 1</b><br>Contains parts of SD memory card interrupt mask register. Registers SDC_IRQMASK1 and SDC_IRQMASK0 compose the SD memory card interrupt mask register. The register masks interrupt sources from register SDC_CSTA. '1' in some bits of the register masks the corresponding interrupt source with the same bit position. For example, if IRQMASK[63] is 1, then interrupt source from register field OUT_OF_RANGE of register SDC_CSTA will be masked. '0' in some bit does not cause interrupt mask on the corresponding interrupt source from register SDC_CSTA.                                                                                                                             |
| A0130054 | <u>SDIO_CFG</u>     | 32    | <b>SDIO configuration register</b><br>Configures functions for SDIO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Address  | Name                | Width | Register function                                                                                                                                                                                                                |
|----------|---------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0130058 | <u>SDIO STA</u>     | 32    | <b>SDIO status register</b><br>Identifies if there is SDIO interrupt during the interrupt period on data line.                                                                                                                   |
| A0130080 | <u>CLK RED</u>      | 32    | <b>CLK latch configuration register</b><br>Configures the MSDC sample data/response clock.<br><i>Note: When MSDC_I0CON[19] = 1, the host will latch response; otherwise MSDC FSM will handle the response from PAD directly.</i> |
| A0130098 | <u>DAT CHECKSUM</u> | 32    | <b>MSDC Rx data checksum register</b><br>Compares the checksum value of Rx read data                                                                                                                                             |

### A0130000 MSDC\_CFG SD Memory Card Controller Configuration Register 04000020

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23          | 22   | 21        | 20        | 19         | 18    | 17        | 16    |
|--------------|----|----|----|----|----|----|----|----|-------------|------|-----------|-----------|------------|-------|-----------|-------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |             |      | VDDP<br>D | RCDE<br>N | DIRQE<br>N | PINEN | DMAE<br>N | INTEN |
| <b>Type</b>  |    |    |    |    |    |    |    |    |             |      | RW        | RW        | RW         | RW    | RW        | RW    |
| <b>Reset</b> |    |    |    |    | 0  |    | 0  | 0  |             |      | 0         | 0         | 0          | 0     | 0         | 0     |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7           | 6    | 5         | 4         | 3          | 2     | 1         | 0     |
| <b>Name</b>  |    |    |    |    |    |    |    |    | SCLKF<br>ON | CRED | STDB<br>Y | CLKSRC    | NOCR<br>C  | RST   | MSDC      |       |
| <b>Type</b>  |    |    |    |    |    |    |    |    | RW          | RW   | RW        | RW        | RW         | W1C   | RW        |       |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0    | 1         | 0         | 0          | 0     | 0         | 0     |

**Overview:** For general configuration of the SD controller. Note that MSDC\_CFG[31:16] can be accessed by 16-bit APB bus access.

| Bit(s) | Mnemonic       | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24  | <b>FIFOTHD</b> | FIFOTHD | <b>FIFO threshold</b><br>The register field determines when to issue a DMA request. For write transactions, DMA requests will be asserted if the number of free entries in FIFO are bigger than or equal to the value in the register field. For read transactions, DMA requests will be asserted if the number of valid entries in FIFO are bigger than or equal to the value in the register field. The register field must be set according to the setting of data transfer count in DMA burst mode. If single mode for DMA transfer is used, the register field shall be set to 0b0001.<br>0000: Invalid<br>0001: Threshold value is 1.<br>0010: Threshold value is 2.<br>0011~01111: ...<br>1000: Threshold value is 8.<br>Others: Invalid |
| 21     | <b>VDDPD</b>   | VDDPD   | <b>Controls output pin VDDPD used for power saving</b><br>Output pin VDDPD controls the power for memory card.<br>0: Output pin VDDPD outputs logic low. The power for memory card will be turned off.<br>1: Output pin VDDPD outputs logic high. The power for memory card will be turned on.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 20     | <b>RCDEN</b>   | RCDEN   | <b>Controls output pin RC DEN used for card identification process when the controller is for SD memory card</b><br>Its output controls the pull-down resistor on the system board to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Bit(s) | Mnemonic | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          |        | connect to or disconnect from signal CD/DAT3.<br>0: The output pin RCDEN outputs logic low.<br>1: The output pin RCDEN outputs logic high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19     | DIRQEN   | DIRQEN | <b>Enables data request interrupt</b><br>The register bit is used to control if data request is used as an interrupt source.<br>0: Data request is not used as an interrupt source.<br>1: Data request is used as an interrupt source.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 18     | PINEN    | PINEN  | <b>Enables pin interrupt</b><br>The register bit is used to control if the pin for card detection is used as an interrupt source.<br>0: The pin for card detection is not used as an interrupt source.<br>1: The pin for card detection is used as an interrupt source.                                                                                                                                                                                                                                                                                                                                                                                        |
| 17     | DMAEN    | DMA EN | <b>Enables DMA</b><br><i>Note: If DMA capability is disabled, the application software must poll the status of register MSDC_STA to check on any data transfer request. If DMA is desired, the register bit must be set up before command register is written.</i><br>0: DMA request induced by various conditions is disabled, no matter the controller is configured as the host of either SD memory card or memory stick.<br>1: DMA request induced by various conditions is enabled, no matter the controller is configured as the host of either SD memory card or memory stick.                                                                          |
| 16     | INTEN    | INTEN  | <b>Enables interrupt</b><br><i>Note: If interrupt capability is disabled, the application software must poll the status of register MSDC_STA to check on any interrupt request.</i><br>0: Interrupt induced by various conditions is disabled, no matter the controller is configured as the host of either SD memory card or memory stick.<br>1: Interrupt induced by various conditions is enabled, no matter the controller is configured as the host of either SD memory card or memory stick.                                                                                                                                                             |
| 15:8   | SCLKF    | SCLKF  | <b>Controls clock frequency of serial clock on SD bus and denotes clock frequency of SD bus serial clock as fslave and clock frequency of the SD controller as fhost which is 98.3 or 96.2 MHz</b><br><i>Note: The allowed maximum frequency of fslave is 49.15MHz.</i><br>While changing the clock rate, "1T clock period before change + 1T clock period after change" is required for HW signal to re-synchronize.<br>00000000b: fslave = $(1/2)*fhost$<br>00000001b: fslave = $[1/(4^1)]*fhost$<br>00000010b: fslave = $[1/(4^2)]*fhost$<br>00000011b: fslave = $[1/(4^3)]*fhost$<br>00000100b~11111110b: ...<br>11111111b: fslave = $[1/(4^{255})]*fhost$ |
| 7      | SCLKON   | SCLKON | <b>Serial clock always on</b><br>For debugging.<br>0: Serial clock not always on<br>1: Serial clock always on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6      | CRED     | CRED   | <b>Rising edge data</b><br>The register bit is used to determine the serial data input is latched at the falling edge or rising edge of the serial clock. The default                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit(s) | Mnemonic      | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|---------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | <b>STDBY</b>  | STDBY  | <p>setting is at the rising edge. If the serial data have bad timing, set the register bit to 1. When the memory card has bad timing on returned read data, set the register bit to 1.</p> <p>0: Serial data input is latched at the rising edge of serial clock.<br/>1: Serial data input is latched at the falling edge of serial clock.</p> <p><b>Standby mode</b></p> <p>If the module is powered down, operating clock to the module will be stopped. At the same time, the clock to card detection circuitry will also be stopped. If detection on memory card insertion and removal is desired, write 1 to the register bit. If interrupt for detection on memory card insertion and removal is enabled, the interrupt will take place whenever the memory is inserted or removed.</p> <p>0: Standby mode is disabled.<br/>1: Standby mode is enabled.</p>                                                                                                                                                                                                          |
| 4:3    | <b>CLKSRC</b> | CLKSRC | <p><b>Specifies which clock is used as source clock of memory card</b></p> <p>00 : MPLL/5.5MHz clock<br/>     01 : MPLL/7MHz dock (this divider is default off, before switch controller source clock to this clock, you should switch controller source clock to 26MHz first, and then enable divider MPLL/7, after a moment you can switch controller source clock to MPLL/7 to void source clock glitch. For detail setting please refer to configsys document)<br/>     10 : MPLL/8MHz dock<br/>     11 : MPLL/10MHz dock<br/>     For phone<br/>     00 : 94.5MHz dock<br/>     Need to keep BT_APP_DIV_EN= 1'b0 in CLK_CONDA[15].<br/>     01 : 74.3MHz dock<br/>     NOTE: Need to set POWERFUL_DIV_EN1 = 1'b1 first in CLK_CONDA[10].<br/>     10 : 65MHz dock<br/>     11 : Forbidden app.<br/>     For<br/>     00 : BT<br/>     01 : 89.1MHz dock<br/>     NOTE: Need to set POWERFUL_DIV_EN1 = 1'b1 first in CLK_CONDA[10].<br/>     10 : 78MHz dock<br/>     11 : 62.4MHz clock<br/>     NOTE: Need to set POWERFUL_DIV_EN2 = 1'b1 first in CLK_CONDA[9].</p> |
| 2      | <b>NOCRC</b>  | NOCRC  | <p><b>Disable CRC</b></p> <p>'1' indicates data transfer without CRC is desired. For write data block, the data are transmitted without CRC. For read data block, CRC will not be checked. For testing purpose.</p> <p>0: Data transfer with CRC is desired.<br/>1: Data transfer without CRC is desired.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1      | <b>RST</b>    | RST    | <p><b>Software reset</b></p> <p>Writing 1 to the register bit will cause internal synchronous reset of SD controller but will not reset register settings, RST should only be set when RST equal to 0.</p> <p>0: Read 0 stands for the reset process is finished.<br/>1: Write 1 to reset SD controller.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0      | <b>MSDC</b>   | MSDC   | <p><b>Configures the controller as SD memory card mode</b></p> <p>CLK/CMD/DAT line is pulled low when SD memory card mode is disable.</p> <p>0: Disable SD memory card<br/>1: Enable SD memory card</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

A0130004 [MSDC STA](#) SD Memory Card Controller Status Register 00000000

| Bit   | 31   | 30      | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19      | 18  | 17  | 16 |    |
|-------|------|---------|----|----|----|----|----|----|----|----|----|----|---------|-----|-----|----|----|
| Name  |      |         |    |    |    |    |    |    |    |    |    |    |         |     |     |    |    |
| Type  |      |         |    |    |    |    |    |    |    |    |    |    |         |     |     |    |    |
| Reset |      |         |    |    |    |    |    |    |    |    |    |    |         |     |     |    |    |
| Bit   | 15   | 14      | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3       | 2   | 1   | 0  |    |
| Name  | BUSY | FIFOCLR |    |    |    |    |    |    |    |    |    |    | FIFOCNT | INT | DRQ | BE | BF |
| Type  | R    | W1C     |    |    |    |    |    |    |    |    |    |    | RO      | RO  | RO  | RO |    |
| Reset | 0    | 0       |    |    |    |    |    |    |    |    |    |    | 0       | 0   | 0   | 0  |    |

**Overview:** The register contains the status of FIFO, interrupts and data requests.

| Bit(s) | Mnemonic       | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|----------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | <b>BUSY</b>    | BUSY    | <b>Status of the controller</b><br>If the controller is in busy state, the register bit will be 1; otherwise 0.<br>0: The controller is in busy state.<br>1: The controller is in idle state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14     | <b>FIFOCLR</b> | FIFOCLR | <b>Clears FIFO</b><br><b>Writing 1 to the register bit will cause the content of FIFO clear and reset the status of FIFO controller.</b><br>0: Read 0 stands for the FIFO clear process is finished.<br>1: Write 1 to clear the content of FIFO clear and reset the status of FIFO controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7:4    | <b>FIFOCNT</b> | FIFOCNT | <b>FIFO count</b><br>The register field shows how many valid entries are there in FIFO.<br>0000: 0 valid entry in FIFO<br>0001: 1 valid entry in FIFO<br>0010: 2 valid entries in FIFO<br>0011~0111: ...<br>1000: 8 valid entries in FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3      | <b>INT</b>     | INT     | <b>Indicates if there is any interrupt existing</b><br>When there is interrupt existing, the register bit will still be active even if register bit INTEN in register MSDC_CFG is disabled. The SD controller can interrupt MCU by issuing interrupt request to the interrupt controller, or the software/application will poll the register endlessly to check if there is any interrupt request existing in the SD controller. When register bit INTEN in register MSDC_CFG is disabled, the second method is used. For read commands, it is possible that time-out error takes place. The software can read the status register to check if the time-out error takes place without OS time tick support or data request asserted.<br><i>Note: The register bit will be cleared when register MSDC_INT is read.</i><br>0: No interrupt request existing.<br>1: Interrupt request exists. |
| 2      | <b>DRQ</b>     | DRQ     | <b>Indicates if any data transfer is required</b><br>When a data transfer is required, the register bit will still be active even if register bit DIRQEN in register MSDC_CFG is disabled. Data transfer can be achieved by DMA channel alleviating MCU loading, or by polling the register bit to check if any data transfer is requested. When register bit DIRQEN in register MSDC_CFG is disabled, the second method is used.<br>0: No DMA request existing.<br>1: DMA request exists.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1      | <b>BE</b>      | BE      | <b>Indicates if FIFO in SD controller is empty</b><br>0: FIFO in SD controller is not empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                           |
|--------|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | BF       | BF   | 1: FIFO in SD controller is empty.<br><b>Indicates if FIFO in SD controller is full</b><br>0: FIFO in SD controller is not full.<br>1: FIFO in SD controller is full. |

## A0130008 MSDC INT SD Memory Card Controller Interrupt Register 00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23          | 22           | 21 | 20          | 19           | 18           | 17         | 16   |
|-------|----|----|----|----|----|----|----|----|-------------|--------------|----|-------------|--------------|--------------|------------|------|
| Name  |    |    |    |    |    |    |    |    |             |              |    |             |              |              |            |      |
| Type  |    |    |    |    |    |    |    |    |             |              |    |             |              |              |            |      |
| Reset |    |    |    |    |    |    |    |    |             |              |    |             |              |              |            |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7           | 6            | 5  | 4           | 3            | 2            | 1          | 0    |
| Name  |    |    |    |    |    |    |    |    | SDIOI<br>RQ | SDR1<br>BIRQ |    | SDMC<br>IRQ | SDDA<br>TIRQ | SDCM<br>DIRQ | PINIR<br>Q | DIRQ |
| Type  |    |    |    |    |    |    |    |    | RC          | RC           |    | RC          | RC           | RC           | RC         | RC   |
| Reset |    |    |    |    |    |    |    |    | 0           | 0            |    | 0           | 0            | 0            | 0          | 0    |

**Overview:** The register contains the status of interrupts. Note that the register still show status of interrupt even though interrupt is disabled, that is, register bit INTEN of register MSDC\_CFG is set to 0. It implies that software can be implemented by polling register bit INT of register MSDC\_STA and this register. However, if hardware interrupt is desired, be sure to clear the register before setting register bit INTEN of register MSDC\_CFG to 1, or undesired hardware interrupt arisen from the previous interrupt status may take place.

| Bit(s) | Mnemonic | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | SDIOIRQ  | SDIOIRQ  | <b>SDIO interrupt</b><br>The register bit indicates if there is any interrupt for SDIO existing. Whenever an interrupt for SDIO exists, the register bit will be set to 1 if the interrupt is enabled. It will be reset when the register is read.<br>0: No SDIO interrupt<br>1: Interrupt for SDIO exists.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6      | SDR1BIRQ | SDR1BIRQ | <b>SD R1b response interrupt</b><br>The register bit will be active when a SD command with R1b response is finished and the DAT0 line is transited from busy to idle state. Single block write commands with R1b response will cause interrupt when the command is completed either successfully or with CRC error. However, multi-block write commands with R1b response do not cause interrupt because multi-block write commands are always stopped by STOP_TRANS commands. STOP_TRANS commands (with R1b response) behind multi-block write commands will cause interrupt. Single block read command with R1b response will cause interrupt when the command is completed, but multi-block read commands do not.<br><i>Note: STOP_TRANS commands (with R1b response) behind multi-block read commands will cause interrupt.</i><br>0: No interrupt for SD R1b response.<br>1: Interrupt for SD R1b response exists. |
| 4      | SDMCIRQ  | SDMCIRQ  | <b>SD memory card interrupt</b><br>The register bit indicates if there is any interrupt for SD memory card existing. Whenever an interrupt for SD memory card exists, i.e. any bit in register SDC_CSTA is active, the register bit will be set to 1 if interrupt is enabled. It will be reset when the register is read.<br><i>Note: This bit will not trigger MSDC hardware interrupt.</i><br>0: No SD memory card interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit(s) | Mnemonic        | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3      | <b>SDDATIRQ</b> | SDDATIRQ | 1: SD memory card interrupt exists.<br><br><b>SD bus DAT interrupt</b><br>The register bit indicates if there is any interrupt for SD DAT line existing. Whenever interrupt for SD DAT line exists, i.e. any bit in register SDC_DATSTA is active, the register bit will be set to 1 if interrupt is enabled. It will be reset when the register is read.<br>0: No SD DAT line interrupt<br>1: SD DAT line interrupt exists.                                                                                                                                                        |
| 2      | <b>SDCMDIRQ</b> | SDCMDIRQ | The register bit indicates if there is any interrupt for SD CMD line existing. Whenever interrupt for SD CMD line exists, i.e. any bit in the register SDC_CMDSTA is active, the register bit will be set to 1 if interrupt is enabled. It will be reset when the register is read.<br>0: No SD CMD line interrupt<br>1: SD CMD line interrupt exists.                                                                                                                                                                                                                              |
| 1      | <b>PINIRQ</b>   | PINIRQ   | <b>Pin change interrupt</b><br>The register bit indicates if there is any interrupt for memory card insertion/removal existing. Whenever the memory card is inserted or removed and card detection interrupt is enabled, i.e. register bit PINEN in register MSDC_CFG is set to 1, the register bit will be set to 1. It will be reset when the register is read.<br>0: Otherwise<br>1: Card is inserted or removed.                                                                                                                                                                |
| 0      | <b>DIRQ</b>     | DIRQ     | <b>Data request interrupt</b><br>The register bit indicates if there is any interrupt for data request existing. Whenever data request exists and data request as an interrupt source is enabled, i.e. register bit DIRQEN in register MSDC_CFG is set to 1, the register bit will be active. It will be reset when being read. For software, data requests can be recognized by polling register bit DRQ or by data request interrupt. Data request interrupts will be generated every FIFOHD data transfers.<br>0: No data request interrupt<br>1: Data request interrupt occurs. |

| A013000C |            | MSDC | PS | SD Memory Card Pin Status Register |    |    |    |     |    |    |    |        |      |       |       | 00000008 |   |   |   |
|----------|------------|------|----|------------------------------------|----|----|----|-----|----|----|----|--------|------|-------|-------|----------|---|---|---|
| Bit      | 31         | 30   | 29 | 28                                 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20     | 19   | 18    | 17    | 16       |   |   |   |
| Name     |            |      |    |                                    |    |    |    | CMD |    |    |    | DAT    |      |       |       |          |   |   |   |
| Type     |            |      |    |                                    |    |    |    | RO  |    |    |    | RO     |      |       |       |          |   |   |   |
| Reset    |            |      |    |                                    |    |    |    | 0   | 0  | 0  | 0  | 0      | 0    | 0     | 0     | 0        | 0 | 0 | 0 |
| Bit      | 15         | 14   | 13 | 12                                 | 11 | 10 | 9  | 8   | 7  | 6  | 5  | 4      | 3    | 2     | 1     | 0        |   |   |   |
| Name     | CDDEBOUNCE |      |    |                                    |    |    |    |     |    |    |    | PINCHG | PIN0 | POEN0 | PIENO | CDEN     |   |   |   |
| Type     | RW         |      |    |                                    |    |    |    |     |    |    |    | RC     | RO   | RW    | RW    | RW       |   |   |   |
| Reset    | 0          | 0    | 0  | 0                                  |    |    |    |     |    |    |    | 0      | 1    | 0     | 0     | 0        |   |   |   |

**Overview:** The register is used for card detection. When the memory card controller and system are powered on, the power for the memory card will still be off unless the power is supplied by the PMIC. Meanwhile, the pad for card detection defaults to pull-down when the system is powered on. The scheme of card detection for MS is the same as that for SD. To detect card insertion, first pull up the INS pin and then enable card detection and the input pin at the same time. After 32 cycles of controller clock, the status of pin changes will emerge. To detect card removal, simply keep enabling card detection and the input pin.

| Bit(s) | Mnemonic       | Name       | Description                                                                                                                                                                                                                                                                                                            |
|--------|----------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | CMD            | CMD        | <b>Memory card/SDIO card/MMC card command lines</b>                                                                                                                                                                                                                                                                    |
| 23:16  | DAT            | DAT        | <b>Memory card/SDIO card/MMC card data lines</b>                                                                                                                                                                                                                                                                       |
| 15:12  | CDDEBOUN<br>CE | CDDEBOUNCE | <b>Specifies the time interval for card detection de-bounce</b><br>Default value: 0. It means the de-bounce interval is 32-cycle time at 32kHz. The interval can extend one cycle time at 32kHz by increasing the counter by 1.                                                                                        |
| 4      | PINCHG         | PINCHG     | <b>Pin change</b><br>The register bit indicates the status of card insertion/removal. If the memory card is inserted or removed, the register bit will be set to 1 no matter pin change interrupt is enabled or not. It will be cleared when the register is read.<br>0: Otherw ise<br>1: Card is inserted or removed. |
| 3      | PINO           | PINO       | <b>Shows the value of input pin for card detection</b><br>0: The value of input pin for card detection is logic low.<br>1: The value of input pin for card detection is logic high.                                                                                                                                    |
| 2      | POEN0          | POEN0      | <b>Controls output of input pin for card detection</b><br>0: Output of input pin for card detection is disabled.<br>1: Output of input pin for card detection is enabled.                                                                                                                                              |
| 1      | PIEN0          | PIEN0      | <b>Controls input pin for card detection</b><br>0: Input pin for card detection is disabled.<br>1: Input pin for card detection is enabled.                                                                                                                                                                            |
| 0      | CDEN           | CDEN       | <b>Enables card detection</b><br>The register bit is used to enable or disable card detection.<br>0: Card detection is disabled.<br>1: Card detection is enabled.                                                                                                                                                      |

**A0130010 MSDC\_DAT SD Memory Card Controller Data Register 00000000**

| Bit          | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>DATA[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>DATA[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** The register is used to read/w rite data from/to FIFO inside the SD controller. Data access unit: 32 bits.

| Bit(s) | Mnemonic | Name | Description                                                                             |
|--------|----------|------|-----------------------------------------------------------------------------------------|
| 31:0   | DATA     | DATA | <b>Reads/Writes data from/to FIFO inside SD controller</b><br>Data access unit: 32 bits |

**A0130014 MSDC IOCON SD Memory Card Controller IO Control Register 010000C3**

| Bit          | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>SAMPLEDLY</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Name</b>  | <b>FIXDLY</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Name</b>  | <b>SAMPON</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Name</b>  | <b>CRCDIS</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Name</b>  | <b>CMDS</b>      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Name</b>  | <b>INTLH</b>     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Name</b>  | <b>DSW</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Reset |       |    |    |    |    | 0          | 1        | 0       | 0       | 0       | 0 | 0 | 0 | 0       | 0 | 0 | 0 |
|-------|-------|----|----|----|----|------------|----------|---------|---------|---------|---|---|---|---------|---|---|---|
| Bit   | 15    | 14 | 13 | 12 | 11 | 10         | 9        | 8       | 7       | 6       | 5 | 4 | 3 | 2       | 1 | 0 |   |
| Name  | CMDRE |    |    |    |    | HIGH_SPEED | DMABURST | SRCF G1 | SRCF G0 | ODCCFG1 |   |   |   | ODCCFG0 |   |   |   |
| Type  | RW    |    |    |    |    | RW         | RW       | RW      | RW      | RW      |   |   |   | RW      |   |   |   |
| Reset | 0     |    |    |    |    | 0          | 0        | 0       | 1       | 1       | 0 | 0 | 0 | 0       | 1 | 1 | 1 |

**Overview:** The register specifies the output driving capability and slew rate of IO pads for MSDC. The reset value is suggested setting. If the output driving capability of pins DAT0, DAT1, DAT2 and DAT3 is too large, it is possible to arise ground bounce and thus result in glitch on SCLK. The actual driving current depends on the PAD type selected for the chip.

| Bit(s) | Mnemonic | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24  | SAMPLEDL | SAMPLEDLY | <b>Used for SW to select the turn-around delay cycle between write data end bit and CRC status for SD card</b><br><br>Y<br>00: 0-T delay<br>01: 1-T delay<br>10: 2-T delay<br>11: 3-T delay                                                                                                                                                                                                                                                                                                                                                                             |
| 23:22  | FIXDLY   | FIXDLY    | <b>Used for SW to select the delay cycle after clock fix high for the host controller to SD card</b><br><br>00: 0-T delay<br>01: 1-T delay<br>10: 2-T delay<br>11: 3-T delay                                                                                                                                                                                                                                                                                                                                                                                            |
| 21     | SAMPON   | SAMPON    | <b>Data sample enabling always on</b><br><br>The bit is suggested to be set to 1 when the feedback clock is used and to 0 when the multiple phase clock is used.<br>0: Data sample enabling not always on<br>1: Data sample enabling always on                                                                                                                                                                                                                                                                                                                          |
| 20     | CRCDIS   | CRCDIS    | <b>Switches off data CRC check for SD read data</b><br><br>0: CRC check is on.<br>1: CRC check is off.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 19     | CMDSEL   | CMDSEL    | <b>Determines whether the host should delay 1-T to latch response from card</b><br><br>0: Host latches response without 1-T delay<br>1: Host latches response with 1-T delay.                                                                                                                                                                                                                                                                                                                                                                                           |
| 18:17  | INTLH    | INTLH     | <b>Selects latch timing for SDIO multi-block read interrupt</b><br><br>00: Host latches INT at the second backend clock after the end bit of the current data block from card is received. (Default)<br>01: Host latches INT at the first backend clock after the end bit of the current data block from card is received.<br>10: Host latches INT at the second backend clock after the end bit of the current data block from card is received.<br>11: Host latches INT at the third backend clock after the end bit of the current data block from card is received. |
| 16     | DSW      | DSW       | <b>Determines whether the host should latch data with 1-T delay or not</b><br><br>For SD card, this bit is suggested to be 0. For MSPRO cards, it is suggested to be 1.<br>0: Host latches the data with 1-T delay.<br>1: Host latches the data without 1-T delay.                                                                                                                                                                                                                                                                                                      |
| 15     | CMDRE    | CMDRE     | <b>Determines whether the host should latch response token (sent from card on CMD line) at rising edge or falling edge of serial</b>                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bit(s) | Mnemonic         | Name              | Description                                                                                                                                                                                                                                                                 |
|--------|------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                  | <b>clock</b>      | (T.B.D this bit is un-useful)                                                                                                                                                                                                                                               |
| 10     | <b>HIGH_SPEE</b> | <b>HIGH_SPEED</b> | 0: Host latches response at rising edge of serial clock.<br>1: Host latches response at falling edge of serial clock.                                                                                                                                                       |
|        | <b>D</b>         |                   | <b>For high-speed mode when internal sample clock is used</b><br>High-speed mode means the SD/MMC serial bus clock rate is bigger than 25MHz. The default speed mode means that the SD/MMC serial bus clock rate is bigger than 25MHz.<br>0: Default speed<br>1: High speed |
| 9:8    | <b>DMABURST</b>  | <b>DMA BURST</b>  | <b>Used for SW to select burst type when data are transferred by DMA</b><br><i>Note: Only single mode can support non-4N bytes data transfer in read operation.</i><br>00: Single mode<br>01: 4-beat burst<br>10: 8-beat burst<br>11: Reserved                              |
| 7      | <b>SRCFG1</b>    | <b>SRCFG1</b>     | <b>Output driving capability for pins DAT0, DAT1, DAT2 and DAT3</b><br>0: Fast slew rate<br>1: Slow slew rate                                                                                                                                                               |
| 6      | <b>SRCFG0</b>    | <b>SRCFG0</b>     | <b>Output driving capability for pins CMD/BS and SCLK</b><br>0: Fast slew rate<br>1: Slow slew rate                                                                                                                                                                         |
| 5:3    | <b>ODCCFG1</b>   | <b>ODCCFG1</b>    | <b>Output driving capability for pins DAT0, DAT1, DAT2 and DAT3</b><br>000: 4mA<br>001: 8mA<br>010: 12mA<br>011: 16mA                                                                                                                                                       |
| 2:0    | <b>ODCCFG0</b>   | <b>ODCCFG0</b>    | <b>Output driving capability for pins CMD/BS and SCLK</b><br>000: 4mA<br>001: 8mA<br>010: 12mA<br>011: 16mA                                                                                                                                                                 |

**A0130018 MSDC IOCON1 SD Memory Card Controller IO Control Register 1 00022022**

|              |           |          |    |    |           |          |    |    |           |          |    |    |    |    |    |    |
|--------------|-----------|----------|----|----|-----------|----------|----|----|-----------|----------|----|----|----|----|----|----|
| <b>Bit</b>   | 31        | 30       | 29 | 28 | 27        | 26       | 25 | 24 | 23        | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>  |           |          |    |    |           |          |    |    |           |          |    |    |    |    |    |    |
| <b>Type</b>  |           |          |    |    |           |          |    |    |           |          |    |    |    |    |    |    |
| <b>Reset</b> |           |          |    |    |           |          |    |    |           |          |    |    |    |    |    |    |
| <b>Bit</b>   | 15        | 14       | 13 | 12 | 11        | 10       | 9  | 8  | 7         | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | PRCF_G_CK | PRVAL_CK |    |    | PRCF_G_CM | PRVAL_CM |    |    | PRCF_G_DA | PRVAL_DA |    |    |    |    |    |    |
| <b>Type</b>  | RW        | RW       |    |    | RW        | RW       |    |    | RW        | RW       |    |    |    |    |    |    |
| <b>Reset</b> | 0         | 1        | 0  |    | 0         | 0        | 0  |    | 0         | 1        | 0  |    |    |    |    |    |

| Bit(s) | Mnemonic        | Name            | Description                                                                                                                                                                                         |
|--------|-----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14     | <b>PRCFG_CK</b> | <b>PRCFG_CK</b> | <b>Pull-up/down register configuration for pin CK</b><br>Default value: 0<br>0: Pull-up resistor in the I/O pad of pin CK is enabled.<br>1: Pull-down resistor in the I/O pad of pin CK is enabled. |

| Bit(s) | Mnemonic        | Name     | Description                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-----------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12  | <b>PRVAL_CK</b> | PRVAL_CK | <b>Pull-up/down register value for pin CLK</b><br>Default value: 10<br>00: Pull-up/down resistor in the I/O pad of pin CLK are all disabled.<br>01: Pull-up/down resistor in the I/O pad of pin CLK value is 47k.<br>10: Pull-up/down resistor in the I/O pad of pin CLK value is 47k.<br>11: Pull-up/down resistor in the I/O pad of pin CLK value is 23.5k.                        |
| 10     | <b>PRCFG_CM</b> | PRCFG_CM | <b>Pull-up/down register configuration for pin CM</b><br>Default value is 0.<br>0: Pull-up resistor in the I/O pad of pin CM is enabled.<br>1: Pull-down resistor in the I/O pad of pin CM is enabled.                                                                                                                                                                               |
| 9:8    | <b>PRVAL_CM</b> | PRVAL_CM | <b>Pull-up/down register value for pin CMD/BS</b><br>Default value: 00<br>00: Pull-up/down resistor in the I/O pad of pin CMD/BS are all disabled.<br>01: Pull-up/down resistor in the I/O pad of pin CMD/BS value is 47k.<br>10: Pull-up/down resistor in the I/O pad of pin CMD/BS value is 47k.<br>11: Pull-up/down resistor in the I/O pad of pin CMD/BS value is 23.5k.         |
| 6      | <b>PRCFG_DA</b> | PRCFG_DA | <b>Pull-up/down register configuration for pin DAT0, DAT1, DAT2 and DAT3</b><br>Default value: 0<br>0: Pull-up resistor in the I/O pad of pin DAT is enabled.<br>1: Pull-down resistor in the I/O pad of pin DAT is enabled.                                                                                                                                                         |
| 5:4    | <b>PRVAL_DA</b> | PRVAL_DA | <b>Pull-up/down register value for pin DAT0, DAT1, DAT2 and DAT3</b><br>Default value: 10<br>00: Pull-up/ down resistor in the I/O pad of pin DAT are all disabled.<br>01: Pull-up/down resistor in the I/O pad of pin DAT value is 47k.<br>10: Pull-up/down resistor in the I/O pad of pin DAT value is 47k.<br>11: Pull-up/down resistor in the I/O pad of pin DAT value is 23.5k. |

| A0130020 SDC_CFG SD Memory Card Controller Configuration Register 00008000 |        |    |    |    |        |    |    |    |    |    |      |    |      |       |      |    |
|----------------------------------------------------------------------------|--------|----|----|----|--------|----|----|----|----|----|------|----|------|-------|------|----|
| Bit                                                                        | 31     | 30 | 29 | 28 | 27     | 26 | 25 | 24 | 23 | 22 | 21   | 20 | 19   | 18    | 17   | 16 |
| Name                                                                       | DTOC   |    |    |    |        |    |    |    |    |    | WDOD |    | SDIO | MDLEN | SIEN |    |
| Type                                                                       | RW     |    |    |    |        |    |    |    |    |    | RW   |    | RW   | RW    | RW   |    |
| Reset                                                                      | 0      | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0    | 0     | 0    | 0  |
| Bit                                                                        | 15     | 14 | 13 | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5    | 4  | 3    | 2     | 1    | 0  |
| Name                                                                       | BSYDLY |    |    |    | BLKLEN |    |    |    |    |    |      |    |      |       |      |    |
| Type                                                                       | RW     |    |    |    | RW     |    |    |    |    |    |      |    |      |       |      |    |
| Reset                                                                      | 1      | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0    | 0     | 0    | 0  |

**Overview:** The register is used to configure the SD memory card controller when it is configured as the host of SD. If the controller is configured as the host of memory stick, the contents of the register will have no impact on the operation of the controller. Note that SDC\_CFG[31:16] can be accessed by 16-bit APB bus access.

| Bit(s) | Mnemonic    | Name | Description                                                                                                                                                                                                                                                                                                             |
|--------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24  | <b>DTOC</b> | DTOC | <b>Data time-out counter</b><br>The period from finish of the initial host read command or the last read data block in a multiple block read operation to the start bit of the next read data block requires at least two serial clock cycles. The counter is used to extend the period (Read Data Access Time) in unit |

| Bit(s) | Mnemonic      | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|---------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:20  | <b>WDOD</b>   | WDOD    | <p>of 65,536 serial clock. See the register field descriptions of register bit RDINT for reference.</p> <p>00000000: Extend 65,536 more serial clock cycles<br/>     00000001: Extend 65,536x2 more serial clock cycles<br/>     00000010: Extend 65,536x3 more serial clock cycles<br/>     00000011~11111110:<br/>     11111111: Extend 65,536x 256 more serial clock cycles</p> <p><b>Write data output delay</b></p> <p>The period from finish of the response for the initial host write command or the last write data block in a multiple block write operation to the start bit of the next write data block requires at least two serial clock cycles. The register field is used to extend the period (Write Data Output Delay) in unit of one serial clock.</p> <p>0000: No extension<br/>     0001: Extend 1 more serial clock cycle<br/>     0010: Extend 2 more serial clock cycles<br/>     0011~1110:<br/>     1111: Extend 15 more serial clock cycle</p> |
| 19     | <b>SDIO</b>   | SDIO    | <p><b>Enables SDIO</b></p> <p>0: Disable SDIO mode<br/>     1: Enable SDIO mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 17     | <b>MDLEN</b>  | MDLEN   | <p><b>Enables multiple data line</b></p> <p>The register can be enabled only when SD memory card is applied and detected by software application. It is the responsibility of the application to program the bit correctly when an multi-media card is applied. If an multi-media card is applied and 4-bit data line is enabled, the 4 bits will be output every serial clock. Therefore, data integrity will fail.</p> <p>0: Disable 4-bit data line<br/>     1: Enable 4-bit data line</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 16     | <b>SIEN</b>   | SIEN    | <p><b>Enables serial interface</b></p> <p>It should be enabled as soon as possible before any command.</p> <p>0: Disable serial interface for SD<br/>     1: Enable serial interface for SD</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15:12  | <b>BSYDLY</b> | BSY DLY | <p><b>Only valid for the commands with R1b response</b></p> <p>If the command has a response of R1b type, the SD controller must monitor the data line 0 for card busy status from the bit time that is two serial clock cycles after the command end bit to check if the operation in SD memory card have finished. The register field is used to expand the time between the command end bit and end of detection period to detect card busy status. If time is up and there is no card busy status on data line 0, the controller will abandon the detection.</p> <p>0000: No extension<br/>     0001: Extend 1 more serial clock cycle<br/>     0010: Extend 2 more serial clock cycles<br/>     0011~1110:<br/>     1111: Extend 15 more serial clock cycle</p>                                                                                                                                                                                                       |
| 11:0   | <b>BLKLEN</b> | BLKLEN  | <p><b>Block length</b></p> <p>The register field is used to define the length of one block in unit of byte in a data transaction. The maximum value of block length is 2,048 bytes.</p> <p>000000000000:<br/>     000000000001: Block length is 1 byte.<br/>     000000000010: Block length is 2 bytes.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Bit(s) | Mnemonic | Name | Description                                |
|--------|----------|------|--------------------------------------------|
|        |          |      | 000000000011~011111111110: ...             |
|        |          |      | 011111111111: Block length is 2,047 bytes. |
|        |          |      | 100000000000: Block length is 2,048 bytes. |

**A0130024 SDC\_CMD SD Memory Card Controller Command Register 00000000**

| Bit   | 31   | 30   | 29 | 28    | 27   | 26     | 25    | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|------|------|----|-------|------|--------|-------|----|----|----|----|----|----|----|----|---------|
| Name  |      |      |    |       |      |        |       |    |    |    |    |    |    |    |    | CMDFAIL |
| Type  |      |      |    |       |      |        |       |    |    |    |    |    |    |    |    | RW      |
| Reset |      |      |    |       |      |        |       |    |    |    |    |    |    |    |    | 0       |
| Bit   | 15   | 14   | 13 | 12    | 11   | 10     | 9     | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| Name  | INTC | STOP | RW | DTYPE | IDRT | RSPTYP | BREAK |    |    |    |    |    |    |    |    | CMD     |
| Type  | RW   | RW   | RW | RW    | RW   | RW     | RW    |    |    |    |    |    |    |    |    | RW      |
| Reset | 0    | 0    | 0  | 0     | 0    | 0      | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       |

**Overview:** The register defines a SD memory card command and its attribute. Before the SD controller issues a transaction onto the SD bus, application shall specify other relative settings such as argument for command. After application writes the register, the SD controller will issue the corresponding transaction onto the SD serial bus. If the command is GO\_IDLE\_STATE, the controller will have serial clock on SD bus run 128 cycles before issuing the command.

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                                   |
|--------|----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | CMDFAIL  | CMDFAIL | If 4-bit SDIO mode is enabled and when CMD/DAT error occurs, set this bit to select whether to "wait stop command" or "wait data state machine idle".<br>0: Wait stop command<br>1: Wait data state machine idle                                                                              |
| 15     | INTC     | INTC    | Indicates if the command is GO_IRQ_STATE<br>If the command is GO_IRQ_STATE, the period between command token and response token will not be limited.<br>0: The command is not GO_IRQ_STATE.<br>1: The command is GO_IRQ_STATE.                                                                |
| 14     | STOP     | STOP    | Indicates if the command is a stop transmission command<br>0: The command is not a stop transmission command.<br>1: The command is a stop transmission command.                                                                                                                               |
| 13     | RW       | RW      | Defines the command is a read command or write command<br>The register bit is valid only when the command causes a transaction with data token.<br>0: The command is a read command.<br>1: The command is a write command.                                                                    |
| 12:11  | DTYPE    | DTYPE   | Defines data token type for the command<br>00: No data token for the command<br>01: Single block transaction<br>10: Multiple block transaction, i.e. the command is a multiple block read or write command.<br>11: Stream operation. It can only be used when an multi-media card is applied. |
| 10     | IDRT     | IDRT    | Identification response time<br>The register bit indicates if the command has a response with NID (i.e. 5 serial clock cycles as defined in SD Memory Card                                                                                                                                    |

| Bit(s) | Mnemonic      | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|---------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:7    | <b>RSPTYP</b> | RSPTYP | <p>Specification Part 1 Physical Layer Specification version 1.0) response time. The register bit is valid only when the command has a response token. Thus the register bit must be set to 1 for CMD2 (ALL_SEND_CID) and ACMD41 (SD_APP_OP_CMD).</p> <p>0: Otherwise</p> <p>1: The command has a response with NID response time.</p> <p><b>Defines response type for the command</b></p> <p>For commands with R1 and R1b response, register SDC_CSTA (not SDC_STA) updates after response token is received. This register SDC_CSTA contains the status of the SD, and it can be used as a response interrupt source.</p> <p><i>Note: If CMD7 is used with all 0's RCA, then RSPTYP must be "000". Command "GO_TO_IDLE" also has RSPTYP='000'.</i></p> <p>000: There is no response for the command, e.g. broadcast command without response and GO_INACTIVE_STATE command.</p> <p>001: The command has R1 response. R1 response token is 48-bit.</p> <p>010: The command has R2 response. R2 response token is 136-bit.</p> <p>011: The command has R3 response. Even though R3 is 48-bit response, it does not contain CRC checksum.</p> <p>100: The command has R4 response. R4 response token is 48-bit.</p> <p>(only for MMC)</p> <p>101: The command has R5 response. R5 response token is 48-bit.</p> <p>(only for MMC)</p> <p>110: The command has R6 response. R6 response token is 48-bit.</p> <p>111: The command has R1b response. If the command has a response of R1b type, SD controller must monitor the data line 0 for card busy status from the bit time that is 2 or 4 serial clock cycles after the command end bit to check if the operation in SD memory card has finished. There are two cases for detection of card busy status. The first case is that the host stops the data transmission during an active write data transfer. The card will assert busy signal after the stop transmission command end bit followed by 4 serial clock cycles. The second case is that the card is in idle state or receiving a stop transmission command between data blocks when multiple block write command is in progress. The register bit will be valid only when the command has a response token.</p> <p><b>Aborts pending MMC GO_IRQ_MODE command</b></p> <p>It is only valid for a pending GO_IRQ_MODE command waiting for MMC interrupt response.</p> <p>0: Other fields are valid.</p> <p>1: Break a pending MMC GO_IRQ_MODE command in the controller. Other fields are invalid.</p> <p><b>SD memory card command</b></p> <p>Total 6 bits.</p> |
| 6      | <b>BREAK</b>  | BREAK  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5:0    | <b>CMD</b>    | CMD    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| A0130028 <u>SDC ARG</u> SD Memory Card Controller Argument Register 00000000 |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------------------------------------------------------------------------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                                          | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                                  | <u>ARG[31:16]</u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                                  | RW                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                                 | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| <b>Bit</b>                                                                   | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  |    |
| <b>Name</b>                                                                  | <u>ARG[15:0]</u>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                                  | RW                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                                 | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

**Overview:** The register contains the argument of the SD memory card command.

| Bit(s) | Mnemonic   | Name | Description                                      |
|--------|------------|------|--------------------------------------------------|
| 31:0   | <b>ARG</b> | ARG  | Contains argument of the SD memory card command. |

### A013002C SDC\_STA SD Memory Card Controller Status Register 00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19   | 18   | 17   | 16   |
|--------------|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3    | 2    | 1    | 0    |
| <b>Name</b>  | WP |    |    |    |    |    |    |    |    |    |    | FEDA | FECM | BEDA | BECM | BESD |
|              |    |    |    |    |    |    |    |    |    |    |    | TBUS | DBUS | TBUS | DBUS | CBUS |
|              |    |    |    |    |    |    |    |    |    |    |    | Y    | Y    | Y    | Y    | Y    |
| <b>Type</b>  | RO |    |    |    |    |    |    |    |    |    |    | RO   | RO   | RO   | RO   | RO   |
| <b>Reset</b> | 0  |    |    |    |    |    |    |    |    |    |    | 0    | 0    | 0    | 0    | 0    |

**Overview:** The register contains various statuses of SD controller as the controller is configured as the host of SD memory card.

| Bit(s) | Mnemonic        | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-----------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | <b>WP</b>       | WP        | Detects the status of write protection switch on SD memory card<br><br>The register bit shows the status of write protection switch on SD memory card. There is no default reset value. Pin WP (Write Protection) is only useful when the controller is configured for SD memory card.<br><br>1: Write protection switch on, i.e. memory card is desired to be write-protected.<br>0: Write protection switch off, i.e. memory card is writable.                                                                                                                         |
| 4      | <b>FEDATBUS</b> | FEDATBUSY | Indicates if there is any transmission going on DAT line on SD bus<br><br>This bit indicates directly the CMD line at card clock domain. For those commands without data but still involving DAT line, the register bit is useless. For example, if an erase command is issued, checking if the register bit is 0 before issuing the next command with data will not guarantee that the controller is idle. In this case, use register bit BESDCBUSY.<br><br>0: No transmission is going on DAT line on SD bus.<br>1: There is transmission going on DAT line on SD bus. |
| 3      | <b>FECMDBUS</b> | FECMDBUSY | Indicates if there is any transmission going on CMD line on SD bus<br><br>This bit indicates directly the CMD line at card clock domain.<br>0: No transmission is going on CMD line on SD bus.<br>1: There is transmission going on CMD line on SD bus.                                                                                                                                                                                                                                                                                                                  |
| 2      | <b>BEDATBUS</b> | BEDATBUSY | Indicates if there is any transmission going on DAT line on SD bus<br><br>0: Backend SDC controller gets the info that no transmission is going on DAT line on SD bus.<br>1: Backend SDC controller gets the info that there is transmission going on DAT line on SD bus.                                                                                                                                                                                                                                                                                                |
| 1      | <b>BECMDBUS</b> | BECMDBUSY | Indicates if there is any transmission going on CMD line on SD bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bit(s) | Mnemonic        | Name             | Description                                                                                                                                                                                                                                                                                                                 |
|--------|-----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Y      |                 | bus              | This bit shows backend controller's CMD busy state. The busy state is synced from card clock domain to bus clock domain.<br>0: Backend SDC controller gets the info that no transmission is going on CMD line on SD bus.<br>1: Backend SDC controller gets the info that there is transmission going on CMD line on SD bus. |
| 0      | <b>BESDCBUS</b> | <b>BESDCBUSY</b> | <b>Indicates if SD controller is busy, i.e. is there any transmission going on CMD or DAT line on SD bus</b><br>This bit shows backend controller's SDC busy state. The busy state is synced from card clock domain to bus clock domain.<br>0: Backend SD controller is idle.<br>1: Backend SD controller is busy.          |

**A0130030 SDC RESP0 SD Memory Card Controller Response Register 0 00000000**

| Bit                             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>RESP[31:0][31:16]</b>        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>RESP[31:0][15:0]</b>         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Overview:** The register contains parts of the last SD memory card bus response. See descriptions of register field SDC\_RESP3.

| Bit(s) | Mnemonic          | Name             | Description |
|--------|-------------------|------------------|-------------|
| 31:0   | <b>RESP[31:0]</b> | <b>RESP_31_0</b> |             |

**A0130034 SDC RESP1 SD Memory Card Controller Response Register 1 00000000**

| Bit                             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>RESP[63:32][31:16]</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>RESP[63:32][15:0]</b>        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Overview:** The register contains parts of the last SD memory card bus response. See descriptions of register field SDC\_RESP3.

| Bit(s) | Mnemonic           | Name              | Description |
|--------|--------------------|-------------------|-------------|
| 31:0   | <b>RESP[63:32]</b> | <b>RESP_63_32</b> |             |

**A0130038 SDC\_RESP2 SD Memory Card Controller Response Register 2 00000000**

| Bit   | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESP[95:64][31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESP[95:64][15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** The register contains parts of the last SD memory card bus response. See descriptions of register field SDC\_RESP3.

| Bit(s) | Mnemonic    | Name       | Description |
|--------|-------------|------------|-------------|
| 31:0   | RESP[95:64] | RESP_95_64 |             |

**A013003C SDC\_RESP3 SD Memory Card Controller Response Register 3 00000000**

| Bit   | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESP[127:96][31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESP[127:96][15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** The register contains parts of the last SD memory card bus response. Register fields SDC\_RESP0, SDC\_RESP1, SDC\_RESP2 and SDC\_RESP3 compose the last SD memory card bus response. For response of type R2, i.e. response of commands ALL\_SEND\_CID, SEND\_CSD and SEND\_CID, only bit 127 to 0 of the response token are stored in register fields SDC\_RESP0, SDC\_RESP1, SDC\_RESP2 and SDC\_RESP3. For response of other types, only bit 39 to 8 of the response token are stored in register field SDC\_RESP0.

| Bit(s) | Mnemonic     | Name        | Description |
|--------|--------------|-------------|-------------|
| 31:0   | RESP[127:96] | RESP_127_96 |             |

**A0130040 SDC\_CMDSTA SD Memory Card Controller Command Status Register 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1    | 0    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    | RSPC | CMDT | CMDR |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    | RCE  | O    | DY   |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    | RC   | RC   | RC   |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    | 0    | 0    | 0    |

**Overview:** The register contains the status of SD controller during command execution and that of SD bus protocol after command execution when the SD controller is configured as the host of SD memory card. The

register can also be used as an interrupt source. The register is cleared when being read. Meanwhile, if the interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.

| Bit(s) | Mnemonic | Name      | Description                                                                                                                                                                                                                                                                                                                                                                   |
|--------|----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | RSPCRCER | RSPCRCERR | <b>CRC error on CMD detected</b><br>'1' indicates the SD controller detects a CRC error after reading a response from the CMD line.<br>0: Otherwise<br>1: SD controller detects a CRC error after reading a response from the CMD line.                                                                                                                                       |
| 1      | CMDTO    | CMDTO     | <b>Time-out on CMD detected</b><br>'1' indicates the SD controller detects a time-out condition while waiting for a response on the CMD line.<br>0: Otherwise<br>1: SD controller detects a timeout condition while waiting for a response on the CMD line.                                                                                                                   |
| 0      | CMDRDY   | CMDRDY    | <b>For command without response, the register bit will be 1 once the command is completed on SD bus</b><br>For command with response, the register bit will be 1 whenever the command is issued onto the SD bus and its corresponding response is received without CRC error.<br>0: Otherwise<br>1: Command with/without response is finished successfully without CRC error. |

A0130044 SDC DATSTA SD Memory Card Controller Data Status Register 00000000

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |          |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |          |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1      | 0        |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DATT O | BLKD ONE |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RC     | RC       |
| Reset |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0        |

**Overview:** The register contains the status of SD controller during data transfer on DAT line(s) when the SD controller is configured as the host of SD memory card. The register can be used as an interrupt source. The register is cleared when being read. Meanwhile, if the interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.

| Bit(s) | Mnemonic | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:2    | DATCRCER | DATCRCERR | <b>CRC error on DAT detected</b><br>'1' indicates that the SD controller detects a CRC error for bit n after reading a block of data from the DAT line or SD signals a CRC error after writing a block of data to the DAT line.<br>0: Otherwise<br>1: SD controller detects a CRC error after reading a block of data from the DAT line or SD signals a CRC error after writing a block of data to the DAT line.<br><i>Note: n is 7 ~ 1 for 8-bits mode. Each bit is read and cleared</i> |

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                      |
|--------|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | DATTO    | DATTO   | <i>individually</i><br><b>Time-out on DAT detected</b><br>A '1' indicates that the SD controller detects a time-out condition while waiting for data token on the DAT line.<br>0:<br>1: SD controller detects a time-out condition while waiting for data token on the DAT line. |
| 0      | BLKDONE  | BLKDONE | <b>Indicates the status of data block transfer</b><br>0:<br>1: A data block is successfully transferred.                                                                                                                                                                         |
|        |          |         | Otherwise                                                                                                                                                                                                                                                                        |

| <b>A0130048 SDC_CSTA SD Memory Card Status Register</b> |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000000</b> |   |  |  |
|---------------------------------------------------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|---|--|--|
| Bit                                                     | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |   |  |  |
| <b>Name</b>                                             | <b>CSTA [31:0][31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| <b>Type</b>                                             | RC                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| <b>Reset</b>                                            | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0 |  |  |
| <b>Bit</b>                                              | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |   |  |  |
| <b>Name</b>                                             | <b>CSTA [31:0][15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| <b>Type</b>                                             | RC                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| <b>Reset</b>                                            | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0 |  |  |

**Overview:** After commands with R1 and R1b respond this register containing the status of the SD card, it will be used as a response interrupt source. In all register fields, logic high indicates error, and logic low indicates no error. The register is cleared when being read. Meanwhile, if the interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.

| Bit(s) | Mnemonic           | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|--------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>CSTA [31:0]</b> | <b>CSTA_31_0</b> | CSTA31: OUT_OF_RANGE. The command's argument is out of the allowed range for this card.<br>CSTA30: ADDRESS_ERROR. A misaligned address that does not match the block length is used in the command.<br>CSTA29: BLOCK_LEN_ERROR. The transferred block length is not allowed for this card, or the number of transferred bytes does not match the block length.<br>CSTA28: ERASE_SEQ_ERROR. An error in the sequence of erase commands occurs.<br>CSTA27: ERASE_PARAM. An invalid selection of write-blocks for erase occurs.<br>CSTA26: WP_VIOLATION. Attempt to program a write-protected block.<br>CSTA25: Reserved. Return to 0.<br>CSTA24: LOCK_UNLOCK_FAILED. Set when a sequence or password error is detected in lock/unlock card command or if there is an attempt to access a locked card.<br>CSTA23: COM_CRC_ERROR. The CRC check of the previous command fails.<br>CSTA22: ILLEGAL_COMMAND. Command not legal for the card state.<br>CSTA21: CARD_ECC_FAILED. Card internal ECC is applied but fails to correct the data.<br>CSTA20: CC_ERROR. Internal card controller error. |

CSTA19: ERROR. A general or unknown error occurs during the operation.  
 CSTA18: UNDERRUN. The card cannot sustain data transfer in stream read mode.  
 CSTA17: OVERRUN. The card cannot sustain data programming in stream write mode.  
 CSTA16: CID/CSD\_OVERWRITE. It can be either one of the following errors: 1) The CID register has been already written and cannot be overwritten; 2) The read-only section of the CSD does not match the card; 3) An attempt to reverse the copy (set as the original) or permanent WP (unprotected) bits is made.  
 CSTA[15:4]: Reserved. Return to 0.  
 CSTA3: AKE\_SEQ\_ERROR. Error in the sequence of authentication process  
 CSTA[2:0]: Reserved. Return to 0.

**A013004C    SDC\_IRQMASK0    SD Memory Card IRQ Mask Register 0    00000000**

| Bit                                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Name</b>                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** The register contains parts of SD memory card interrupt mask register. See the register descriptions of register SDC\_IRQMASK1 for reference. The register masks interrupt sources from register SDC\_CMDSTA and SDC\_DATSTA. IRQMASK[3:0] is for SDC\_CMDSTA, and IRQMASK[18:16] for SDC\_DATSTA. Note that IRQMASK[18] masks SDC\_DATSTA[9:2] together. '1' in some bits of the register masks the corresponding interrupt source with the same bit position. For example, if IRQMASK[0] is 1, then the interrupt source from register field CMDRDY of register SDC\_CMDSTA will be masked. '0' in some bits does not cause interrupt mask on the corresponding interrupt source from registers SDC\_CMDSTA and SDC\_DATSTA.

| Bit(s) | Mnemonic              | Name         | Description |
|--------|-----------------------|--------------|-------------|
| 31:0   | <b>IRQMASK [31:0]</b> | IRQMASK_31_0 |             |

**A0130050    SDC\_IRQMASK1    SD Memory Card IRQ Mask Register 1    00000000**

| Bit                                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Name</b>                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** The register contains parts of SD memory card interrupt mask register. Registers SDC\_IRQMASK1 and SDC\_IRQMASK0 compose the SD memory card interrupt mask register. The register masks interrupt

sources from register SDC\_CSTA. '1' in some bits of the register masks the corresponding interrupt source with the same bit position. For example, if IRQMASK[63] is 1, then the interrupt source from register field OUT\_OF\_RANGE of register SDC\_CSTA will be masked. '0' in some bits does not cause interrupt mask on the corresponding interrupt source from register SDC\_CSTA.

| Bit(s) | Mnemonic           | Name          | Description |
|--------|--------------------|---------------|-------------|
| 31:0   | IRQMASK<br>[63:32] | IRQMASK_63_32 |             |

| <b>A0130054 SDIO CFG SDIO Configuration Register</b> |    |    |    |    |    |    |    |    |    |    |               |    |                |               |    | 00000000     |  |
|------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----------------|---------------|----|--------------|--|
| Bit                                                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21            | 20 | 19             | 18            | 17 | 16           |  |
| <b>Name</b>                                          |    |    |    |    |    |    |    |    |    |    |               |    |                |               |    |              |  |
| <b>Type</b>                                          |    |    |    |    |    |    |    |    |    |    |               |    |                |               |    |              |  |
| <b>Reset</b>                                         |    |    |    |    |    |    |    |    |    |    |               |    |                |               |    |              |  |
| Bit                                                  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5             | 4  | 3              | 2             | 1  | 0            |  |
| <b>Name</b>                                          |    |    |    |    |    |    |    |    |    |    | <b>DISSEL</b> |    | <b>INTCSEL</b> | <b>DSBSEL</b> |    | <b>INTEN</b> |  |
| <b>Type</b>                                          |    |    |    |    |    |    |    |    |    |    | <b>RW</b>     |    | <b>RW</b>      | <b>RW</b>     |    | <b>RW</b>    |  |
| <b>Reset</b>                                         |    |    |    |    |    |    |    |    |    |    | 0             |    | 0              | 0             |    | 0            |  |

**Overview:** The register is used to configure functions for SDIO.

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                          |
|--------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | DISSEL   | DISSEL  | <b>Selects data block interrupt source</b><br>0: The host detects SDIO interrupt during interrupt period between two data blocks of multiple block data access.<br>1: The host ignores SDIO interrupt during interrupt period between two data blocks of multiple block data access. |
| 3      | INTCSEL  | INTCSEL | <b>Selects interrupt control</b><br>0: The host detects DAT1 low as SDIO interrupt.<br>1: The host detects DAT3/DAT2/DAT1/DAT0 4'b1101 as SDIO interrupt.                                                                                                                            |
| 2      | DSBSEL   | DSBSEL  | <b>Selects data block start bit</b><br>0: Use data line 0 as start bit of data block. Other data lines are ignored.<br>1: Start bit of a data block is received only when all data line 0-3 become low.                                                                              |
| 0      | INTEN    | INTEN   | <b>Enables interrupt for SDIO</b><br>0: Disable<br>1: Enable                                                                                                                                                                                                                         |

| <b>A0130058 SDIO STA SDIO Status Register</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00000000   |  |
|-----------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|--|
| Bit                                           | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |  |
| <b>Name</b>                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |
| <b>Type</b>                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |
| <b>Reset</b>                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |
| Bit                                           | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |  |
| <b>Name</b>                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>IRQ</b> |  |
| <b>Type</b>                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RO</b>  |  |
| <b>Reset</b>                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |  |

**Overview:** This register is used to identify if there is SDIO interrupt during the interrupt period on data line.

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                                                                                                                                                                                                                             |
|--------|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | IRQ      | IRQ  | <p><b>SDIO interrupt exists on the data line.</b></p> <p>For example, when in the interrupt period or the 1-bit data line mode and DAT1/5 goes low from high, this bit will become 1 from 0. If DAT1/5 goes high from low, this bit will become 0 from 1.</p> <p>0: There is no SDIO interrupt existing on the data line.<br/>1: There is SDIO interrupt existing on the data line.</p> |

**A0130080 CLK\_RED CLK Latch Configuration Register 00000000**

| Bit          | 31 | 30 | 29      | 28 | 27 | 26 | 25 | 24 | 23                 | 22             | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|---------|----|----|----|----|----|--------------------|----------------|----|----|----|----|----|----|
| <b>Name</b>  |    |    | CMD_RED |    |    |    |    |    |                    |                |    |    |    |    |    |    |
| <b>Type</b>  |    |    | RW      |    |    |    |    |    |                    |                |    |    |    |    |    |    |
| <b>Reset</b> |    |    | 0       |    |    |    |    |    |                    |                |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13      | 12 | 11 | 10 | 9  | 8  | 7                  | 6              | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    | DAT_RED |    |    |    |    |    | CLKP<br>AD_R<br>ED | CLK_LATCH<br>H |    |    |    |    |    |    |
| <b>Type</b>  |    |    | RW      |    |    |    |    |    | RW                 | RW             |    |    |    |    |    |    |
| <b>Reset</b> |    |    | 0       |    |    |    |    |    | 0                  | 0              |    |    |    |    |    |    |

**Overview:** The register is used to configure the MSDC sample data/response clock. Note that only when MSDC\_IOCON[19] = 1 will the host latch response; otherwise MSDC FSM will handle the response from PAD directly.

| Bit(s) | Mnemonic  | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-----------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29     | CMD_RED   | CMD_RED    | <p><b>Determines the command response from card output is latched at falling edge or rising edge of internal clock</b></p> <p>Only effective when CLK_LATCH = 1</p> <p>0: Internal clock rising edge to latch response<br/>1: Internal clock falling edge to latch response</p>                                                                                                                                                                                                                                                                                   |
| 13     | DAT_RED   | DAT_RED    | <p><b>Determines the input data from card output is latched at falling edge or rising edge of internal sample clock</b></p> <p>Only effective when CLK_LATCH = 1</p> <p>0: Internal clock rising edge to latch data<br/>1: Internal clock falling edge to latch data</p>                                                                                                                                                                                                                                                                                          |
| 7      | CLKPAD_R  | CLKPAD_RED | <p><b>Determines the input data from card is latched at falling edge or rising edge of the feedback clock from pad</b></p> <p>The suggested setting is 0 when SD serial clock is lower than 25MHz. The suggestion setting is 1 when SD serial clock is higher than 25MHz. The suggestion setting is 0 for MMC card no matter the serial clock rate is high speed or default speed. Only effective when CLK_LATCH = 0.</p> <p>0: Internal feedback clock rising edge to latch data/response<br/>1: Internal feedback clock falling edge to latch data/response</p> |
| 6      | CLK_LATCH | CLK_LATCH  | <p><b>Determines which clock to latch data from card</b></p> <p>The suggested setting is 1 if SCLKF in register field MSDC_CFG is 0x0. Otherwise, the suggested setting is 0.</p> <p>0: Internal feedback clock is used to latch data/response from card.</p>                                                                                                                                                                                                                                                                                                     |

| Bit(s) | Mnemonic | Name | Description                                                 |
|--------|----------|------|-------------------------------------------------------------|
|        |          |      | 1: Internal clock is used to latch data/response from card. |

| <b>A0130098 DAT_CHECKSUM MSDC Rx Data Checksum Register</b> |                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000000</b> |   |  |  |
|-------------------------------------------------------------|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|---|--|--|
| Bit                                                         | 31                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |   |  |  |
| <b>Name</b>                                                 | <b>DAT_CHECKSUM[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| <b>Type</b>                                                 | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| <b>Reset</b>                                                | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0 |  |  |
| <b>Bit</b>                                                  | 15                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |   |  |  |
| <b>Name</b>                                                 | <b>DAT_CHECKSUM[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| <b>Type</b>                                                 | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| <b>Reset</b>                                                | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0 |  |  |

**Overview :** The register is used to compute the checksum value of Rx read data

| Bit(s) | Mnemonic                 | Name                | Description                           |
|--------|--------------------------|---------------------|---------------------------------------|
| 31:0   | <b>DAT_CHEC<br/>KSUM</b> | <b>DAT_CHECKSUM</b> | The checksum algorithm is 32-bit XOR. |

## 3.17 SD Memory Card Controller (MSDC1)

### 3.17.1 Introduction

The controller fully supports the SD memory card bus protocol as defined in SD Memory Card Specification Part 1 Physical Layer Specification version 2.0.

Furthermore, the controller also partially supports the SDIO card specification version 2.0. However, the controller can only be configured as the host of the SD memory card. Hereafter, the controller is also abbreviated as the SD controller. The following are the main features of the controller.

- Interface with MCU by APB bus
- 16/32-bit access on APB bus
- 16/32-bit access for control registers
- 32-bit access for FIFO
- Built-in 32 bytes FIFO buffers for transmit and receive, FIFO is shared for transmit and receive
- Built-in CRC circuit
- CRC generation can be disabled
- DMA supported
- Interrupt capabilities
- Data rate up to 48 Mbps in serial mode, 48x4 Mbps in parallel model, the module is targeted at 48 MHz operating clock
- Serial clock rate on SD bus is programmable
- Card detection capabilities during sleep mode
- Controllability of power for memory card
- Does not support SPI mode for SD memory card

- Does not support multiple SD memory cards

### 3.17.2 Overview

#### 3.17.2.1 Pin Assignment

The following lists pins required for the SD memory card. Table 51 shows how the pins are shared. Note that all I/O pads have embedded both pull-up and pull-down resistors because they are shared by the SD memory card. The pull-down resistors for these pins can be used for power saving. If optimal pull-up or pull-down resistors are required on the system board, all embedded pull-up and pull-down resistors can be disabled by programming the corresponding control registers. The VDDPD pin is used for power saving. Power for the SD memory card can be shut down by programming the corresponding control register. The WP (Write Protection) pin is used to detect the status of the Write Protection Switch on the SD memory card.

**Table 51. Sharing of pins for SD memory card controller**

| No. | Name     | Type   | MMC  | SD      | Description                   |
|-----|----------|--------|------|---------|-------------------------------|
| 1   | SD_CLK   | O      | CLK  | CLK     | Clock                         |
| 2   | SD_DAT3  | I/O/PP |      | CD/DAT3 | Data Line [Bit 3]             |
| 3   | SD_DAT0  | I/O/PP | DAT0 | DAT0    | Data Line [Bit 0]             |
| 4   | SD_DAT1  | I/O/PP |      | DAT1    | Data Line [Bit 1]             |
| 5   | SD_DAT2  | I/O/PP |      | DAT2    | Data Line [Bit 2]             |
| 6   | SD_CMD   | I/O/PP | CMD  | CMD     | Command Or Bus State          |
| 7   | SD_PWRON | O      |      |         | VDD ON/OFF                    |
| 8   | SD_WP    | I      |      |         | Write Protection Switch in SD |
| 9   | SD_INS   | I      | VSS2 | VSS2    | Card Detection                |

#### 3.17.2.2 Card Detection

For SD memory card, detection of card insertion/removal by hardware is supported, and a dedicated pin "INS" is used to perform card insertion and removal for SD. The pin "INS" will be connected to the pin "VSS2" of a SD connector (see **Figure 45**).



Figure 46. Card detection for SD memory card



Figure 47. Card detection for SD memory card (Scheme 2)

### 3.17.3 Register Definition

Module name: MSDC1 base address: (+A0270000h)

| Address  | Name            | Width | Register function                                                                                                                                                                    |
|----------|-----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0270000 | <u>MSDC_CFG</u> | 32    | <b>SD memory card controller configuration register</b><br>For general configuration of the SD controller.<br>Note: <i>MSDC_CFG[31:16]</i> can be accessed by 16-bit APB bus access. |
| A0270004 | <u>MSDC_STA</u> | 32    | <b>SD memory card controller status register</b>                                                                                                                                     |

| Address  | Name               | Width | Register function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|--------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                    |       | Contains the status of FIFO, interrupts and data requests.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| A0270008 | <u>MSDC_INT</u>    | 32    | <b>SD memory card controller interrupt register</b><br>Contains the status of interrupts. Note that the register still shows the status of interrupt even though the interrupt is disabled, that is, register bit INTEN of register MSDC_CFG is set to 0. It implies that software interrupt can be implemented by polling register bit INT of register MSDC_STA and this register. However, if hardware interrupt is desired, be sure to clear the register before setting up register bit INTEN of register MSDC_CFG to 1, or undesired hardware interrupt arisen from the previous interrupt status may take place.                                                         |
| A027000C | <u>MSDC_PS</u>     | 32    | <b>SD memory card pin status register</b><br>Used for card detection. When the memory card controller and system are powered on, the power for the memory card will still be off unless the power is supplied by the PMIC. Meanwhile, the pad for card detection defaults to pull down when the system is powered on. The scheme of card detection for MS is the same as that for SD.<br>For detecting card insertion, first pull up the INS pin and then enable card detection and the input pin at the same time. After 32 cycles of controller clock, the status of pin changes will emerge. To detect card removal, simply keep enabling card detection and the input pin. |
| A0270010 | <u>MSDC_DAT</u>    | 32    | <b>SD memory card controller data register</b><br>Reads/Writes data from/to FIFO inside SD controller.<br>Data access unit: 32 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| A0270014 | <u>MSDC_IOCON</u>  | 32    | <b>SD memory card controller IO control register</b><br>Specifies output driving capability and slew rate of IO pads for MSDC. The reset value is suggested setting. If the output driving capability of pins DAT0, DAT1, DAT2 and DAT3 is too large, it is possible to arise ground bounce and thus result in glitch on SCLK. The actual driving current will depend on the PAD type selected for the chip.                                                                                                                                                                                                                                                                   |
| A0270018 | <u>MSDC_IOCON1</u> | 32    | <b>SD memory card controller IO control register 1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| A0270020 | <u>SDC_CFG</u>     | 32    | <b>SD memory card controller configuration register</b><br>Configures the SD memory card controller when it is configured as the host of SD. The register is used to configure the SD memory card controller when it is configured as the host of SD memory card. If the controller is configured as the host of memory stick, the contents of the register will have no impact on the operation of the controller.<br><i>Note: SDC_CFG[31:16] can be accessed by 16-bit APB bus access.</i>                                                                                                                                                                                   |
| A0270024 | <u>SDC_CMD</u>     | 32    | <b>SD memory card controller command register</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Address  | Name              | Width | Register function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|-------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                   |       | Defines a SD memory card command and its attribute. Before the SD controller issues a transaction onto the SD bus, application shall specify other relative settings such as argument for command. After application writes the register, the SD controller will issue the corresponding transaction onto SD serial bus. If the command is GO_IDLE_STATE, the controller will have serial clock on SD bus run 128 cycles before issuing the command.                                                                                                        |
| A0270028 | <u>SDC_ARG</u>    | 32    | <b>SD memory card controller argument register</b><br>Contains argument of the SD memory card command.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| A027002C | <u>SDC_STA</u>    | 32    | <b>SD memory card controller status register</b><br>Contains various statuses of SD controller as the controller is configured as the host of SD memory card.                                                                                                                                                                                                                                                                                                                                                                                               |
| A0270030 | <u>SDC_RESP0</u>  | 32    | <b>SD memory card controller response register 0</b><br>Contains parts of the last SD memory card bus response. See descriptions of register field SDC_RESP3.                                                                                                                                                                                                                                                                                                                                                                                               |
| A0270034 | <u>SDC_RESP1</u>  | 32    | <b>SD memory card controller response register 1</b><br>Contains parts of the last SD memory card bus response. See descriptions of register field SDC_RESP3.                                                                                                                                                                                                                                                                                                                                                                                               |
| A0270038 | <u>SDC_RESP2</u>  | 32    | <b>SD memory card controller response register 2</b><br>Contains parts of the last SD memory card bus response. See descriptions of register field SDC_RESP3.                                                                                                                                                                                                                                                                                                                                                                                               |
| A027003C | <u>SDC_RESP3</u>  | 32    | <b>SD memory card controller response register 3</b><br>Contains parts of the last SD memory card bus response. Register fields SDC_RESP0, SDC_RESP1, SDC_RESP2 and SDC_RESP3 compose the last SD memory card bus response. For response of type R2, that is, response of the command ALL_SEND_CID, SEND_CSD and SEND_CID, only bit 127 to 0 of the response token are stored in register field SDC_RESP0, SDC_RESP1, SDC_RESP2 and SDC_RESP3. For responses of other types, only bit 39 to 8 of the response token are stored in register field SDC_RESP0. |
| A0270040 | <u>SDC_CMDSTA</u> | 32    | <b>SD memory card controller command status register</b><br>Contains the status of SD controller during command execution and that of SD bus protocol after command execution when the SD controller is configured as the host of SD memory card. The register will also be used as the interrupt source. The register is cleared when being read. Meanwhile, if interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.                                                            |
| A0270044 | <u>SDC_DATSTA</u> | 32    | <b>SD memory card controller data status register</b><br>Contains the status of SD controller during data                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Address  | Name                | Width | Register function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|---------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                     |       | transfer on DAT line(s) when the SD controller is configured as the host of SD memory card. The register is also used as the interrupt source. The register is cleared when being read. Meanwhile, if interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.                                                                                                                                                                                                                                                                                                                                                                                                       |
| A0270048 | <u>SDC_CSTA</u>     | 32    | <b>SD memory card status register</b><br>After commands with R1 and R1b response this register containing the status of the SD card, it will be used as the response interrupt source. In all register fields, logic high indicates error, and logic low indicates there is no error. The register is cleared when being read. Meanwhile, if interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.                                                                                                                                                                                                                                                                |
| A027004C | <u>SDC_IRQMASK0</u> | 32    | <b>SD memory card IRQ mask register 0</b><br>Contains parts of SD memory card interrupt mask register. See the descriptions of register SDC_IRQMASK1 for reference. The register masks interrupt sources from register SDC_CMDSTA and SDC_DATSTA. IRQMASK[3:0] is for SDC_CMDSTA, and IRQMASK[18:16] for SDC_DATSTA. Note that IRQMASK[18] masks SDC_DATSTA[9:2] together. '1' in some bits of the register masks the corresponding interrupt source with the same bit position. For example, if IRQMASK[0] is 1, then the interrupt source from register field CMDRDY of register SDC_CMDSTA will be masked. '0' in some bits does not cause interrupt mask on the corresponding interrupt source from register SDC_CMDSTA and SDC_DATSTA. |
| A0270050 | <u>SDC_IRQMASK1</u> | 32    | <b>SD memory card IRQ mask register 1</b><br>Contains parts of SD memory card interrupt mask register. Registers SDC_IRQMASK1 and SDC_IRQMASK0 compose the SD memory card interrupt mask register. The register masks interrupt sources from register SDC_CSTA. '1' in some bits of the register masks the corresponding interrupt source with the same bit position. For example, if IRQMASK[63] is 1, then interrupt source from register field OUT_OF_RANGE of register SDC_CSTA will be masked. '0' in some bit does not cause interrupt mask on the corresponding interrupt source from register SDC_CSTA.                                                                                                                             |
| A0270054 | <u>SDIO_CFG</u>     | 32    | <b>SDIO configuration register</b><br>Configures functions for SDIO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| A0270058 | <u>SDIO_STA</u>     | 32    | <b>SDIO status register</b><br>Identifies if there is SDIO interrupt during the interrupt period on data line.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| A0270080 | <u>CLK_RED</u>      | 32    | <b>CLK latch configuration register</b><br>Configures the MSDC sample data/response clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Address  | Name                | Width | Register function                                                                                                           |
|----------|---------------------|-------|-----------------------------------------------------------------------------------------------------------------------------|
|          |                     |       | Note: When MSDC_IOCON[19] = 1, the host will latch response; otherwise MSDC FSM will handle the response from PAD directly. |
| A0270098 | <b>DAT_CHECKSUM</b> | 32    | <b>MSDC Rx data checksum register</b><br>Compares the checksum value of Rx read data                                        |

 A0270000 **MSDC\_CFG** SD Memory Card Controller Configuration Register 04000020 

| Bit   | 31           | 30 | 29 | 28 | 27             | 26 | 25 | 24 | 23         | 22        | 21         | 20     | 19         | 18    | 17   | 16 |
|-------|--------------|----|----|----|----------------|----|----|----|------------|-----------|------------|--------|------------|-------|------|----|
| Name  |              |    |    |    | <b>FIFOTHD</b> |    |    |    | VDDP<br>D  | RCDE<br>N | DIRQE<br>N | PINEN  | DMAE<br>N  | INTEN |      |    |
| Type  |              |    |    |    | RW             |    |    |    | RW         | RW        | RW         | RW     | RW         | RW    | RW   |    |
| Reset |              |    |    |    | 0              | 1  | 0  | 0  |            | 0         | 0          | 0      | 0          | 0     | 0    | 0  |
| Bit   | 15           | 14 | 13 | 12 | 11             | 10 | 9  | 8  | 7          | 6         | 5          | 4      | 3          | 2     | 1    | 0  |
| Name  | <b>SCLKF</b> |    |    |    |                |    |    |    | SCLK<br>ON | CRED      | STDB<br>Y  | CLKSRC | NOCCR<br>C | RST   | MSDC |    |
| Type  | RW           |    |    |    |                |    |    |    | RW         | RW        | RW         | RW     | RW         | W1C   | RW   |    |
| Reset | 0            | 0  | 0  | 0  | 0              | 0  | 0  | 0  | 0          | 0         | 1          | 0      | 0          | 0     | 0    | 0  |

**Overview:** For general configuration of the SD controller. Note that MSDC\_CFG[31:16] can be accessed by 16-bit APB bus access.

| Bit(s) | Mnemonic       | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24  | <b>FIFOTHD</b> | FIFOTHD | <b>FIFO threshold</b><br>The register field determines when to issue a DMA request. For write transactions, DMA requests will be asserted if the number of free entries in FIFO are bigger than or equal to the value in the register field. For read transactions, DMA requests will be asserted if the number of valid entries in FIFO are bigger than or equal to the value in the register field. The register field must be set according to the setting of data transfer count in DMA burst mode. If single mode for DMA transfer is used, the register field shall be set to 0b0001.<br>0000: Invalid<br>0001: Threshold value is 1.<br>0010: Threshold value is 2.<br>0011~01111: ...<br>1000: Threshold value is 8.<br>Others: Invalid |
| 21     | <b>VDDPD</b>   | VDDPD   | <b>Controls output pin VDDPD used for power saving</b><br>Output pin VDDPD controls the power for memory card.<br>0: Output pin VDDPD outputs logic low. The power for memory card will be turned off.<br>1: Output pin VDDPD outputs logic high. The power for memory card will be turned on.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 20     | <b>RCDEN</b>   | RCDEN   | <b>Controls output pin RCDEN used for card identification process when the controller is for SD memory card</b><br>Its output controls the pull-down resistor on the system board to connect to or disconnect from signal CD/DAT3.<br>0: The output pin RCDEN outputs logic low.<br>1: The output pin RCDEN outputs logic high.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 19     | <b>DIRQEN</b>  | DIRQEN  | <b>Enables data request interrupt</b><br>The register bit is used to control if data request is used as an                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit(s)              | Mnemonic            | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
|---------------------|---------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------|--------------|------------|--------|-------------------|------------|--------|-------------------|------------|--------|-------------------|---------------------|--|-----|------------------|---------------------|--|
| 18                  | PINEN               | PINEN             | <p>interrupt source.</p> <p>0: Data request is not used as an interrupt source.</p> <p>1: Data request is used as an interrupt source.</p> <p><b>Enables pin interrupt</b></p> <p>The register bit is used to control if the pin for card detection is used as an interrupt source.</p> <p>0: The pin for card detection is not used as an interrupt source.</p> <p>1: The pin for card detection is used as an interrupt source.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 17                  | DMAEN               | DMA EN            | <p><b>Enables DMA</b></p> <p><i>Note: If DMA capability is disabled, the application software must poll the status of register MSDC_STA to check on any data transfer request. If DMA is desired, the register bit must be set up before command register is written.</i></p> <p>0: DMA request induced by various conditions is disabled, no matter the controller is configured as the host of either SD memory card or memory stick.</p> <p>1: DMA request induced by various conditions is enabled, no matter the controller is configured as the host of either SD memory card or memory stick.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 16                  | INTEN               | INTEN             | <p><b>Enables interrupt</b></p> <p><i>Note: If interrupt capability is disabled, the application software must poll the status of register MSDC_STA to check on any interrupt request.</i></p> <p>0: Interrupt induced by various conditions is disabled, no matter the controller is configured as the host of either SD memory card or memory stick.</p> <p>1: Interrupt induced by various conditions is enabled, no matter the controller is configured as the host of either SD memory card or memory stick.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 15:8                | SCLKF               | SCLKF             | <p><b>Controls clock frequency of serial clock on SD bus and denotes clock frequency of SD bus serial clock as fslave and clock frequency of the SD controller as fhost which is 98.3 or 96.2 MHz</b></p> <p><i>Note: The allowed maximum frequency of fslave is 49.15MHz.</i></p> <p>While changing the clock rate, "1T clock period before change + 1T clock period after change" is required for HW signal to re-synchronize.</p> <table style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 30%;">00000000b:</td> <td style="width: 30%;">fslave</td> <td style="width: 40%;">=(1/2)*fhost</td> </tr> <tr> <td>00000001b:</td> <td>fslave</td> <td>= [1/(4*1)]*fhost</td> </tr> <tr> <td>00000010b:</td> <td>fslave</td> <td>= [1/(4*2)]*fhost</td> </tr> <tr> <td>00000011b:</td> <td>fslave</td> <td>= [1/(4*3)]*fhost</td> </tr> <tr> <td>0000100b~11111110b:</td> <td></td> <td>...</td> </tr> <tr> <td>1111111b: fslave</td> <td>= [1/(4*255)]*fhost</td> <td></td> </tr> </table> <p><b>Serial clock always on</b></p> <p>For debugging.</p> <p>0: Serial clock not always on</p> <p>1: Serial clock always on</p> <p><b>Rising edge data</b></p> <p>The register bit is used to determine the serial data input is latched at the falling edge or rising edge of the serial clock. The default setting is at the rising edge. If the serial data have bad timing, set the register bit to 1. When the memory card has bad timing on returned read data, set the register bit to 1.</p> <p>0: Serial data input is latched at the rising edge of serial clock.</p> <p>1: Serial data input is latched at the falling edge of serial clock.</p> | 00000000b: | fslave | =(1/2)*fhost | 00000001b: | fslave | = [1/(4*1)]*fhost | 00000010b: | fslave | = [1/(4*2)]*fhost | 00000011b: | fslave | = [1/(4*3)]*fhost | 0000100b~11111110b: |  | ... | 1111111b: fslave | = [1/(4*255)]*fhost |  |
| 00000000b:          | fslave              | =(1/2)*fhost      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 00000001b:          | fslave              | = [1/(4*1)]*fhost |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 00000010b:          | fslave              | = [1/(4*2)]*fhost |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 00000011b:          | fslave              | = [1/(4*3)]*fhost |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 0000100b~11111110b: |                     | ...               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 1111111b: fslave    | = [1/(4*255)]*fhost |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 7                   | SCLKON              | SCLKON            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |
| 6                   | CRED                | CRED              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |        |              |            |        |                   |            |        |                   |            |        |                   |                     |  |     |                  |                     |  |

| Bit(s) | Mnemonic | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | STDBY    | STDBY  | <b>Standby mode</b><br>If the module is powered down, operating clock to the module will be stopped. At the same time, the clock to card detection circuitry will also be stopped. If detection on memory card insertion and removal is desired, write 1 to the register bit. If interrupt for detection on memory card insertion and removal is enabled, the interrupt will take place whenever the memory is inserted or removed.<br>0: Standby mode is disabled.<br>1: Standby mode is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4:3    | CLKSRC   | CLKSRC | <b>Specifies which clock is used as source clock of memory card</b><br>00 : MPLL/5.5MHz clock<br>01 : MPLL/7MHz clock (this divider is default off, before switch controller source clock to this clock, you should switch controller source clock to 26MHz first, and then enable divider MPLL/7, after a moment you can switch controller source clock to MPLL/7 to void source clock glitch. For detail setting please refer to configsys document)<br>10 : MPLL/8MHz clock<br>11 : MPLL/10MHz clock<br>For phone<br>00 : 94.5MHz clock<br>Need to keep BT_APP_DIV_EN= 1'b0 in CLK_CONDA[15].<br>01 : 74.3MHz clock<br>NOTE: Need to set POWERFUL_DIV_EN1 = 1'b1 first in CLK_CONDA[10].<br>10 : 65MHz clock<br>11 : Forbidden<br>For app.<br>00 : BT<br>01 : 89.1MHz clock<br>NOTE: Need to set POWERFUL_DIV_EN1 = 1'b1 first in CLK_CONDA[10].<br>10 : 78MHz clock<br>11 : 62.4MHz clock<br>NOTE: Need to set POWERFUL_DIV_EN2 = 1'b1 first in CLK_CONDA[9]. |
| 2      | NOCRC    | NOCRC  | <b>Disable CRC</b><br>'1' indicates data transfer without CRC is desired. For write data block, the data are transmitted without CRC. For read data block, CRC will not be checked. For testing purpose.<br>0: Data transfer with CRC is desired.<br>1: Data transfer without CRC is desired.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1      | RST      | RST    | <b>Software reset</b><br>Writing 1 to the register bit will cause internal synchronous reset of SD controller but will not reset register settings, RST should only be set when RST equal to 0.<br>0: Read 0 stands for the reset process is finished.<br>1: Write 1 to reset SD controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0      | MSDC     | MSDC   | <b>Configures the controller as SD memory card mode</b><br>CLK/CMD/DAT line is pulled low when SD memory card mode is disable.<br>0: Disable SD memory card<br>1: Enable SD memory card                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| A0270004 MSDC STA SD Memory Card Controller Status Register |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00000000 |    |  |  |
|-------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|--|--|
| Bit                                                         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16 |  |  |
| Name                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |  |  |
| Type                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |  |  |
| Reset                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |  |  |
| Bit                                                         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1        | 0  |  |  |

| Name  | BUSY | FIFOCLR |  |  |  |  |  |         | FIFOCNT | INT | DRQ | BE | BF |
|-------|------|---------|--|--|--|--|--|---------|---------|-----|-----|----|----|
| Type  | R    | W1C     |  |  |  |  |  | RO      | RO      | RO  | RO  | RO | RO |
| Reset | 0    | 0       |  |  |  |  |  | 0 0 0 0 | 0 0 0 0 |     |     |    |    |

**Overview:** The register contains the status of FIFO, interrupts and data requests.

| Bit(s) | Mnemonic       | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|----------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | <b>BUSY</b>    | BUSY    | <b>Status of the controller</b><br>If the controller is in busy state, the register bit will be 1; otherwise 0.<br>0: The controller is in busy state.<br>1: The controller is in idle state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14     | <b>FIFOCLR</b> | FIFOCLR | <b>Clears FIFO</b><br><b>Writing 1 to the register bit will cause the content of FIFO clear and reset the status of FIFO controller.</b><br>0: Read 0 stands for the FIFO clear process is finished.<br>1: Write 1 to clear the content of FIFO clear and reset the status of FIFO controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7:4    | <b>FIFOCNT</b> | FIFOCNT | <b>FIFO count</b><br>The register field shows how many valid entries are there in FIFO.<br>0000: 0 valid entry in FIFO<br>0001: 1 valid entry in FIFO<br>0010: 2 valid entries in FIFO<br>0011~0111: ...<br>1000: 8 valid entries in FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3      | <b>INT</b>     | INT     | <b>Indicates if there is any interrupt existing</b><br>When there is interrupt existing, the register bit will still be active even if register bit INTEN in register MSDC_CFG is disabled. The SD controller can interrupt MCU by issuing interrupt request to the interrupt controller, or the software/application will poll the register endlessly to check if there is any interrupt request existing in the SD controller. When register bit INTEN in register MSDC_CFG is disabled, the second method is used. For read commands, it is possible that time-out error takes place. The software can read the status register to check if the time-out error takes place without OS time tick support or data request asserted.<br><i>Note: The register bit will be cleared when register MSDC_INT is read.</i><br>0: No interrupt request existing.<br>1: Interrupt request exists. |
| 2      | <b>DRQ</b>     | DRQ     | <b>Indicates if any data transfer is required</b><br>When a data transfer is required, the register bit will still be active even if register bit DIRQEN in register MSDC_CFG is disabled. Data transfer can be achieved by DMA channel alleviating MCU loading, or by polling the register bit to check if any data transfer is requested. When register bit DIRQEN in register MSDC_CFG is disabled, the second method is used.<br>0: No DMA request existing.<br>1: DMA request exists.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1      | <b>BE</b>      | BE      | <b>Indicates if FIFO in SD controller is empty</b><br>0: FIFO in SD controller is not empty.<br>1: FIFO in SD controller is empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0      | <b>BF</b>      | BF      | <b>Indicates if FIFO in SD controller is full</b><br>0: FIFO in SD controller is not full.<br>1: FIFO in SD controller is full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

A0270008 **MSDC\_INT** SD Memory Card Controller Interrupt Register **00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23      | 22       | 21 | 20      | 19       | 18       | 17     | 16   |
|-------|----|----|----|----|----|----|----|----|---------|----------|----|---------|----------|----------|--------|------|
| Name  |    |    |    |    |    |    |    |    |         |          |    |         |          |          |        |      |
| Type  |    |    |    |    |    |    |    |    |         |          |    |         |          |          |        |      |
| Reset |    |    |    |    |    |    |    |    |         |          |    |         |          |          |        |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7       | 6        | 5  | 4       | 3        | 2        | 1      | 0    |
| Name  |    |    |    |    |    |    |    |    | SDIOIRQ | SDR1BIRQ |    | SDMCIRQ | SDDATIRQ | SDCMDIRQ | PINIRQ | DIRQ |
| Type  |    |    |    |    |    |    |    |    | RC      | RC       |    | RC      | RC       | RC       | RC     | RC   |
| Reset |    |    |    |    |    |    |    |    | 0       | 0        |    | 0       | 0        | 0        | 0      | 0    |

**Overview:** The register contains the status of interrupts. Note that the register still show status of interrupt even though interrupt is disabled, that is, register bit INTEN of register MSDC\_CFG is set to 0. It implies that software interrupt can be implemented by polling register bit INT of register MSDC\_STA and this register. However, if hardware interrupt is desired, be sure to clear the register before setting register bit INTEN of register MSDC\_CFG to 1, or undesired hardware interrupt arisen from the previous interrupt status may take place.

| Bit(s) | Mnemonic        | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | <b>SDIOIRQ</b>  | SDIOIRQ  | <b>SDIO interrupt</b><br>The register bit indicates if there is any interrupt for SDIO existing. Whenever an interrupt for SDIO exists, the register bit will be set to 1 if the interrupt is enabled. It will be reset when the register is read.<br>0: No SDIO interrupt<br>1: Interrupt for SDIO exists.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6      | <b>SDR1BIRQ</b> | SDR1BIRQ | <b>SD R1b response interrupt</b><br>The register bit will be active when a SD command with R1b response is finished and the DAT0 line is transited from busy to idle state. Single block write commands with R1b response will cause interrupt when the command is completed either successfully or with CRC error. However, multi-block write commands with R1b response do not cause interrupt because multi-block write commands are always stopped by STOP_TRANS commands. STOP_TRANS commands (with R1b response) behind multi-block write commands will cause interrupt. Single block read command with R1b response will cause interrupt when the command is completed, but multi-block read commands do not.<br><i>Note: STOP_TRANS commands (with R1b response) behind multi-block read commands will cause interrupt.</i><br>0: No interrupt for SD R1b response.<br>1: Interrupt for SD R1b response exists. |
| 4      | <b>SDMCIRQ</b>  | SDMCIRQ  | <b>SD memory card interrupt</b><br>The register bit indicates if there is any interrupt for SD memory card existing. Whenever an interrupt for SD memory card exists, i.e. any bit in register SDC_CSTA is active, the register bit will be set to 1 if interrupt is enabled. It will be reset when the register is read.<br><i>Note: This bit will not trigger MSDC hardware interrupt.</i><br>0: No SD memory card interrupt<br>1: SD memory card interrupt exists.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3      | <b>SDDATIRQ</b> | SDDATIRQ | <b>SD bus DAT interrupt</b><br>The register bit indicates if there is any interrupt for SD DAT line existing. Whenever interrupt for SD DAT line exists, i.e. any bit in register SDC_DATSTA is active, the register bit will be set to 1 if                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Bit(s) | Mnemonic        | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |
|--------|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
|        |                 |          | interrupt is enabled. It will be reset when the register is read.                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |
| 0:     |                 |          | No SD DAT line interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
| 1:     |                 |          | SD DAT line interrupt exists.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |
| 2      | <b>SDCMDIRQ</b> | SDCMDIRQ | <b>SD bus CMD interrupt</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |
|        |                 |          | The register bit indicates if there is any interrupt for SD CMD line existing. Whenever interrupt for SD CMD line exists, i.e. any bit in the register SDC_CMDSTA is active, the register bit will be set to 1 if interrupt is enabled. It will be reset when the register is read.                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |
| 0:     |                 |          | No SD CMD line interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
| 1:     |                 |          | SD CMD line interrupt exists.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |
| 1      | <b>PINIRQ</b>   | PINIRQ   | <b>Pin change interrupt</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |
|        |                 |          | The register bit indicates if there is any interrupt for memory card insertion/removal existing. Whenever the memory card is inserted or removed and card detection interrupt is enabled, i.e. register bit PINEN in register MSDC_CFG is set to 1, the register bit will be set to 1. It will be reset when the register is read.                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |
| 0:     |                 |          | Otherwise                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |
| 1:     |                 |          | Card is inserted or removed.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |
| 0      | <b>DIRQ</b>     | DIRQ     | <b>Data request interrupt</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |
|        |                 |          | The register bit indicates if there is any interrupt for data request existing. Whenever data request exists and data request as an interrupt source is enabled, i.e. register bit DIRQEN in register MSDC_CFG is set to 1, the register bit will be active. It will be reset when being read. For software, data requests can be recognized by polling register bit DRQ or by data request interrupt. Data request interrupts will be generated every FIFOHD data transfers. |  |  |  |  |  |  |  |  |  |  |  |
| 0:     |                 |          | No data request                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |
| 1:     |                 |          | Data request interrupt occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |

| A027000C MSDC_PS SD Memory Card Pin Status Register 00000008 |                   |    |    |    |    |    |    |            |            |    |    |               |             |              |              |             |
|--------------------------------------------------------------|-------------------|----|----|----|----|----|----|------------|------------|----|----|---------------|-------------|--------------|--------------|-------------|
| Bit                                                          | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23         | 22 | 21 | 20            | 19          | 18           | 17           | 16          |
| <b>Name</b>                                                  |                   |    |    |    |    |    |    | <b>CMD</b> | <b>DAT</b> |    |    |               |             |              |              |             |
| <b>Type</b>                                                  |                   |    |    |    |    |    |    | RO         | RO         |    |    |               |             |              |              |             |
| <b>Reset</b>                                                 |                   |    |    |    |    |    |    | 0          | 0          | 0  | 0  | 0             | 0           | 0            | 0            |             |
| <b>Bit</b>                                                   | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7          | 6  | 5  | 4             | 3           | 2            | 1            | 0           |
| <b>Name</b>                                                  | <b>CDDEBOUNCE</b> |    |    |    |    |    |    |            |            |    |    | <b>PINCHG</b> | <b>PIN0</b> | <b>POEN0</b> | <b>PIENO</b> | <b>CDEN</b> |
| <b>Type</b>                                                  | RW                |    |    |    |    |    |    |            |            |    |    | RC            | RO          | RW           | RW           | RW          |
| <b>Reset</b>                                                 | 0                 | 0  | 0  | 0  |    |    |    |            |            |    |    | 0             | 1           | 0            | 0            | 0           |

**Overview:** The register is used for card detection. When the memory card controller and system are powered on, the power for the memory card will still be off unless the power is supplied by the PMIC. Meanwhile, the pad for card detection defaults to pull-down when the system is powered on. The scheme of card detection for MS is the same as that for SD. To detect card insertion, first pull up the INS pin and then enable card detection and the input pin at the same time. After 32 cycles of controller clock, the status of pin changes will emerge. To detect card removal, simply keep enabling card detection and the input pin.

| Bit(s) | Mnemonic        | Name       | Description                                              |  |  |  |  |  |  |  |  |  |  |  |
|--------|-----------------|------------|----------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| 24     | <b>CMD</b>      | CMD        | Memory card/SDIO card/MMC card command lines             |  |  |  |  |  |  |  |  |  |  |  |
| 23:16  | <b>DAT</b>      | DAT        | Memory card/SDIO card/MMC card data lines                |  |  |  |  |  |  |  |  |  |  |  |
| 15:12  | <b>CDDEBOUN</b> | CDDEBOUNCE | Specifies the time interval for card detection de-bounce |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Mnemonic      | Name   | Description                                                                                                                                                                                                                                                                                                                            |
|--------|---------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | <b>CE</b>     |        | Default value: 0. It means the de-bounce interval is 32-cycle time at 32kHz. The interval can extend one cycle time at 32kHz by increasing the counter by 1.                                                                                                                                                                           |
| 4      | <b>PINCHG</b> | PINCHG | <p><b>Pin change</b></p> <p>The register bit indicates the status of card insertion/removal. If the memory card is inserted or removed, the register bit will be set to 1 no matter pin change interrupt is enabled or not. It will be cleared when the register is read.</p> <p>0: Otherw ise<br/>1: Card is inserted or removed.</p> |
| 3      | <b>PINO</b>   | PINO   | <p><b>Shows the value of input pin for card detection</b></p> <p>0: The value of input pin for card detection is logic low.<br/>1: The value of input pin for card detection is logic high.</p>                                                                                                                                        |
| 2      | <b>POEN0</b>  | POEN0  | <p><b>Controls output of input pin for card detection</b></p> <p>0: Output of input pin for card detection is disabled.<br/>1: Output of input pin for card detection is enabled.</p>                                                                                                                                                  |
| 1      | <b>PIEN0</b>  | PIEN0  | <p><b>Controls input pin for card detection</b></p> <p>0: Input pin for card detection is disabled.<br/>1: Input pin for card detection is enabled.</p>                                                                                                                                                                                |
| 0      | <b>CDEN</b>   | CDEN   | <p><b>Enables card detection</b></p> <p>The register bit is used to enable or disable card detection.</p> <p>0: Card detection is disabled.<br/>1: Card detection is enabled.</p>                                                                                                                                                      |

**A0270010 MSDC DAT SD Memory Card Controller Data Register 00000000**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview :** The register is used to read/write data from/to FIFO inside the SD controller. Data access unit: 32 bits.

| Bit(s) | Mnemonic    | Name | Description                                                                                        |
|--------|-------------|------|----------------------------------------------------------------------------------------------------|
| 31:0   | <b>DATA</b> | DATA | <p><b>Reads/Writes data from/to FIFO inside SD controller</b></p> <p>Data access unit: 32 bits</p> |

**A0270014 MSDC IOCON SD Memory Card Controller IO Control Register 010000C3**

| Bit          | 31     | 30 | 29 | 28 | 27 | 26        | 25       | 24      | 23      | 22 | 21      | 20 | 19      | 18 | 17 | 16 |
|--------------|--------|----|----|----|----|-----------|----------|---------|---------|----|---------|----|---------|----|----|----|
| <b>Name</b>  |        |    |    |    |    |           |          |         |         |    |         |    |         |    |    |    |
| <b>Type</b>  |        |    |    |    |    |           |          |         |         |    |         |    |         |    |    |    |
| <b>Reset</b> |        |    |    |    |    |           |          |         |         |    |         |    |         |    |    |    |
| Bit          | 15     | 14 | 13 | 12 | 11 | 10        | 9        | 8       | 7       | 6  | 5       | 4  | 3       | 2  | 1  | 0  |
| <b>Name</b>  |        |    |    |    |    |           |          |         |         |    |         |    |         |    |    |    |
| <b>Type</b>  |        |    |    |    |    |           |          |         |         |    |         |    |         |    |    |    |
| Reset        | CMDR E |    |    |    |    | HIGH SPEE | DMABURST | SRCF G1 | SRCF G0 |    | ODCCFG1 |    | ODCCFG0 |    |    |    |

| Type  | RW |  |  |  | D | RW |
|-------|----|--|--|--|---|----|----|----|----|----|----|----|
| Reset | 0  |  |  |  | 0 | 0  | 0  | 1  | 1  | 0  | 0  | 0  |

**Overview:** The register specifies the output driving capability and slew rate of IO pads for MSDC. The reset value is suggested setting. If the output driving capability of pins DAT0, DAT1, DAT2 and DAT3 is too large, it is possible to arise ground bounce and thus result in glitch on SCLK. The actual driving current depends on the PAD type selected for the chip.

| Bit(s) | Mnemonic        | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-----------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24  | <b>SAMPLEDL</b> | SAMPLEDLY | <b>Used for SW to select the turn-around delay cycle between write data end bit and CRC status for SD card</b><br>Y<br>00: 0-T delay<br>01: 1-T delay<br>10: 2-T delay<br>11: 3-T delay                                                                                                                                                                                                                                                                                                                                                                             |
| 23:22  | <b>FIXDLY</b>   | FIXDLY    | <b>Used for SW to select the delay cycle after clock fix high for the host controller to SD card</b><br>00: 0-T delay<br>01: 1-T delay<br>10: 2-T delay<br>11: 3-T delay                                                                                                                                                                                                                                                                                                                                                                                            |
| 21     | <b>SAMPON</b>   | SAMPON    | <b>Data sample enabling always on</b><br>The bit is suggested to be set to 1 when the feedback clock is used and to 0 when the multiple phase clock is used.<br>0: Data sample enabling not always on<br>1: Data sample enabling always on                                                                                                                                                                                                                                                                                                                          |
| 20     | <b>CRCDIS</b>   | CRCDIS    | <b>Switches off data CRC check for SD read data</b><br>0: CRC check is on.<br>1: CRC check is off.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 19     | <b>CMDSEL</b>   | CMDSEL    | <b>Determines whether the host should delay 1-T to latch response from card</b><br>0: Host latches response without 1-T delay<br>1: Host latches response with 1-T delay.                                                                                                                                                                                                                                                                                                                                                                                           |
| 18:17  | <b>INTLH</b>    | INTLH     | <b>Selects latch timing for SDIO multi-block read interrupt</b><br>00: Host latches INT at the second backend clock after the end bit of the current data block from card is received. (Default)<br>01: Host latches INT at the first backend clock after the end bit of the current data block from card is received.<br>10: Host latches INT at the second backend clock after the end bit of the current data block from card is received.<br>11: Host latches INT at the third backend clock after the end bit of the current data block from card is received. |
| 16     | <b>DSW</b>      | DSW       | <b>Determines whether the host should latch data with 1-T delay or not</b><br>For SD card, this bit is suggested to be 0. For MSPRO cards, it is suggested to be 1.<br>0: Host latches the data with 1-T delay.<br>1: Host latches the data without 1-T delay.                                                                                                                                                                                                                                                                                                      |
| 15     | <b>CMDRE</b>    | CMDRE     | <b>Determines whether the host should latch response token (sent from card on CMD line) at rising edge or falling edge of serial clock</b><br>(T.B.D this bit is un-useful)<br>0: Host latches response at rising edge of serial clock.                                                                                                                                                                                                                                                                                                                             |

| Bit(s) | Mnemonic         | Name              | Description                                                                                                                                                                                                                                                                                         |
|--------|------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10     | <b>HIGH_SPEE</b> | <b>HIGH_SPEED</b> | 1: Host latches response at falling edge of serial clock.<br><b>For high-speed mode when internal sample clock is used</b><br>High-speed mode means the SD/MMC serial bus clock rate is bigger than 25MHz. The default speed mode means that the SD/MMC serial bus clock rate is bigger than 25MHz. |
|        | <b>D</b>         |                   | 0: Default speed<br>1: High speed                                                                                                                                                                                                                                                                   |
| 9:8    | <b>DMABURST</b>  | <b>DMA BURST</b>  | <b>Used for SW to select burst type when data are transferred by DMA</b><br><i>Note: Only single mode can support non-4N bytes data transfer in read operation.</i>                                                                                                                                 |
|        |                  |                   | 00: Single mode<br>01: 4-beat incrementing burst<br>10: 8-beat incrementing burst<br>11: Reserved                                                                                                                                                                                                   |
| 7      | <b>SRCFG1</b>    | <b>SRCFG1</b>     | <b>Output driving capability for pins DAT0, DAT1, DAT2 and DAT3</b><br>0: Fast slew rate<br>1: Slow slew rate                                                                                                                                                                                       |
| 6      | <b>SRCFG0</b>    | <b>SRCFG0</b>     | <b>Output driving capability for pins CMD/BS and SCLK</b><br>0: Fast slew rate<br>1: Slow slew rate                                                                                                                                                                                                 |
| 5:3    | <b>ODCCFG1</b>   | <b>ODCCFG1</b>    | <b>Output driving capability for pins DAT0, DAT1, DAT2 and DAT3</b><br>000: 4mA<br>001: 8mA<br>010: 12mA<br>011: 16mA                                                                                                                                                                               |
| 2:0    | <b>ODCCFG0</b>   | <b>ODCCFG0</b>    | <b>Output driving capability for pins CMD/BS and SCLK</b><br>000: 4mA<br>001: 8mA<br>010: 12mA<br>011: 16mA                                                                                                                                                                                         |

**A0270018 MSDC IOCON1 SD Memory Card Controller IO Control Register 1 00022022**

| Bit   | 31 | 30               | 29              | 28 | 27 | 26               | 25              | 24 | 23 | 22               | 21              | 20 | 19 | 18 | 17 | 16 |
|-------|----|------------------|-----------------|----|----|------------------|-----------------|----|----|------------------|-----------------|----|----|----|----|----|
| Name  |    |                  |                 |    |    |                  |                 |    |    |                  |                 |    |    |    |    |    |
| Type  |    |                  |                 |    |    |                  |                 |    |    |                  |                 |    |    |    |    |    |
| Reset |    |                  |                 |    |    |                  |                 |    |    |                  |                 |    |    |    |    |    |
| Bit   | 15 | 14               | 13              | 12 | 11 | 10               | 9               | 8  | 7  | 6                | 5               | 4  | 3  | 2  | 1  | 0  |
| Name  |    | <b>PRCF_G_CK</b> | <b>PRVAL_CK</b> |    |    | <b>PRCF_G_CM</b> | <b>PRVAL_CM</b> |    |    | <b>PRCF_G_DA</b> | <b>PRVAL_DA</b> |    |    |    |    |    |
| Type  | RW | RW               |                 |    |    | RW               | RW              |    |    | RW               | RW              |    |    |    |    |    |
| Reset | 0  | 1                | 0               |    |    | 0                | 0               | 0  |    | 0                | 1               | 0  |    |    |    |    |

| Bit(s) | Mnemonic        | Name            | Description                                                                                                                                                                                         |
|--------|-----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14     | <b>PRCFG_CK</b> | <b>PRCFG_CK</b> | <b>Pull-up/down register configuration for pin CK</b><br>Default value: 0<br>0: Pull-up resistor in the I/O pad of pin CK is enabled.<br>1: Pull-down resistor in the I/O pad of pin CK is enabled. |
| 13:12  | <b>PRVAL_CK</b> | <b>PRVAL_CK</b> | <b>Pull-up/down register value for pin CLK</b><br>Default value: 10                                                                                                                                 |

| Bit(s) | Mnemonic | Name     | Description                                                                                                                                                                                                                                                                                                                                                                         |
|--------|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10     | PRCFG_CM | PRCFG_CM | 00: Pull-up/down resistor in the I/O pad of pin CLK are all disabled.<br>01: Pull-up/down resistor in the I/O pad of pin CLK value is 47k.<br>10: Pull-up/down resistor in the I/O pad of pin CLK value is 47k.<br>11: Pull-up/down resistor in the I/O pad of pin CLK value is 23.5k.                                                                                              |
| 9:8    | PRVAL_CM | PRVAL_CM | <b>Pull-up/down register configuration for pin CM</b><br>Default value is 0.<br>0: Pull-up resistor in the I/O pad of pin CM is enabled.<br>1: Pull-down resistor in the I/O pad of pin CM is enabled.                                                                                                                                                                              |
| 6      | PRCFG_DA | PRCFG_DA | <b>Pull-up/down register value for pin CMD/BS</b><br>Default value: 00<br>00: Pull-up/down resistor in the I/O pad of pin CMD/BS are all disabled.<br>01: Pull-up/down resistor in the I/O pad of pin CMD/BS value is 47k.<br>10: Pull-up/down resistor in the I/O pad of pin CMD/BS value is 47k.<br>11: Pull-up/down resistor in the I/O pad of pin CMD/BS value is 23.5k.        |
| 5:4    | PRVAL_DA | PRVAL_DA | <b>Pull-up/down register configuration for pin DAT0, DAT1, DAT2 and DAT3</b><br>Default value: 0<br>0: Pull-up resistor in the I/O pad of pin DAT is enabled.<br>1: Pull-down resistor in the I/O pad of pin DAT is enabled.                                                                                                                                                        |
|        |          |          | <b>Pull-up/down register value for pin DAT0, DAT1, DAT2 and DAT3</b><br>Default value: 10<br>00: Pull-up/down resistor in the I/O pad of pin DAT are all disabled.<br>01: Pull-up/down resistor in the I/O pad of pin DAT value is 47k.<br>10: Pull-up/down resistor in the I/O pad of pin DAT value is 47k.<br>11: Pull-up/down resistor in the I/O pad of pin DAT value is 23.5k. |

| A0270020 SDC_CFG SD Memory Card Controller Configuration Register |        |    |    |    |    |    |    |    |        |    |    |    |      |       | 00008000 |    |  |
|-------------------------------------------------------------------|--------|----|----|----|----|----|----|----|--------|----|----|----|------|-------|----------|----|--|
| Bit                                                               | 31     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19   | 18    | 17       | 16 |  |
| Name                                                              | DTOC   |    |    |    |    |    |    |    | WDOD   |    |    |    | SDIO | MDLEN | SIEN     |    |  |
| Type                                                              | RW     |    |    |    |    |    |    |    | RW     |    |    |    | RW   | RW    | RW       | RW |  |
| Reset                                                             | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0    | 0     | 0        | 0  |  |
| Bit                                                               | 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3    | 2     | 1        | 0  |  |
| Name                                                              | BSYDLY |    |    |    |    |    |    |    | BLKLEN |    |    |    |      |       |          |    |  |
| Type                                                              | RW     |    |    |    |    |    |    |    | RW     |    |    |    |      |       |          |    |  |
| Reset                                                             | 1      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0    | 0     | 0        | 0  |  |

**Overview:** The register is used to configure the SD memory card controller when it is configured as the host of SD. The register is used to configure the SD memory card controller when it is configured as the host of SD memory card. If the controller is configured as the host of memory stick, the contents of the register will have no impact on the operation of the controller. Note that SDC\_CFG[31:16] can be accessed by 16-bit A PB bus access.

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24  | DTOC     | DTOC | <b>Data time-out counter</b><br>The period from finish of the initial host read command or the last read data block in a multiple block read operation to the start bit of the next read data block requires at least two serial clock cycles. The counter is used to extend the period (Read Data Access Time) in unit of 65,536 serial clock. See the register field descriptions of register |

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          |         | bit RDINT for reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|        |          |         | 00000000: Extend 65,536 more serial clock cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|        |          |         | 00000001: Extend 65,536x2 more serial clock cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|        |          |         | 00000010: Extend 65,536x3 more serial clock cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|        |          |         | 00000011~11111110: ...                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |          |         | 11111111: Extend 65,536x 256 more serial clock cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 23:20  | WDOD     | WDOD    | <b>Write data output delay</b><br>The period from finish of the response for the initial host write command or the last write data block in a multiple block write operation to the start bit of the next write data block requires at least two serial clock cycles. The register field is used to extend the period (Write Data Output Delay) in unit of one serial clock.<br>0000: No extension<br>0001: Extend 1 more serial clock cycle<br>0010: Extend 2 more serial clock cycles<br>0011~1110: ...<br>1111: Extend 15 more serial clock cycle                                                                                                                                                                              |
| 19     | SDIO     | SDIO    | <b>Enables SDIO</b><br>0: Disable SDIO mode<br>1: Enable SDIO mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 17     | MDLEN    | MDLEN   | <b>Enables multiple data line</b><br>The register can be enabled only when SD memory card is applied and detected by software application. It is the responsibility of the application to program the bit correctly when an multi-media card is applied. If an multi-media card is applied and 4-bit data line is enabled, the 4 bits will be output every serial clock. Therefore, data integrity will fail.<br>0: Disable 4-bit data line<br>1: Enable 4-bit data line                                                                                                                                                                                                                                                          |
| 16     | SIEN     | SIEN    | <b>Enables serial interface</b><br>It should be enabled as soon as possible before any command.<br>0: Disable serial interface for SD<br>1: Enable serial interface for SD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15:12  | BSYDLY   | BSY DLY | <b>Only valid for the commands with R1b response</b><br>If the command has a response of R1b type, the SD controller must monitor the data line 0 for card busy status from the bit time that is two serial clock cycles after the command end bit to check if the operation in SD memory card have finished. The register field is used to expand the time between the command end bit and end of detection period to detect card busy status. If time is up and there is no card busy status on data line 0, the controller will abandon the detection.<br>0000: No extension<br>0001: Extend 1 more serial clock cycle<br>0010: Extend 2 more serial clock cycles<br>0011~1110: ...<br>1111: Extend 15 more serial clock cycle |
| 11:0   | BLKLEN   | BLKLEN  | <b>Block length</b><br>The register field is used to define the length of one block in unit of byte in a data transaction. The maximum value of block length is 2,048 bytes.<br>000000000000: Reserved<br>000000000001: Block length is 1 byte.<br>000000000010: Block length is 2 bytes.<br>000000000011~01111111110: ...                                                                                                                                                                                                                                                                                                                                                                                                        |

| Bit(s) | Mnemonic | Name | Description                                                                              |
|--------|----------|------|------------------------------------------------------------------------------------------|
|        |          |      | 011111111111: Block length is 2,047 bytes.<br>100000000000: Block length is 2,048 bytes. |
|        |          |      |                                                                                          |

## A0270024    SDC\_CMD    SD Memory Card Controller Command Register    00000000

| Bit   | 31   | 30   | 29 | 28    | 27   | 26     | 25    | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|------|------|----|-------|------|--------|-------|----|----|----|----|----|----|----|----|---------|
| Name  |      |      |    |       |      |        |       |    |    |    |    |    |    |    |    | CMDFAIL |
| Type  |      |      |    |       |      |        |       |    |    |    |    |    |    |    |    | RW      |
| Reset |      |      |    |       |      |        |       |    |    |    |    |    |    |    |    | 0       |
| Bit   | 15   | 14   | 13 | 12    | 11   | 10     | 9     | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| Name  | INTC | STOP | RW | DTYPE | IDRT | RSPTYP | BREAK |    |    |    |    |    |    |    |    | CMD     |
| Type  | RW   | RW   | RW | RW    | RW   | RW     | RW    |    |    |    |    |    |    |    |    | RW      |
| Reset | 0    | 0    | 0  | 0     | 0    | 0      | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       |

**Overview:** The register defines a SD memory card command and its attribute. Before the SD controller issues a transaction onto the SD bus, application shall specify other relative settings such as argument for command. After application writes the register, the SD controller will issue the corresponding transaction onto the SD serial bus. If the command is GO\_IDLE\_STATE, the controller will have serial clock on SD bus run 128 cycles before issuing the command.

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                                          |
|--------|----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | CMDFAIL  | CMDFAIL | If 4-bit SDIO mode is enabled and when CMD/DAT error occurs, set this bit to select whether to "wait stop command" or "wait data state machine idle".<br>0: Wait stop command<br>1: Wait data state machine idle                                                                                     |
| 15     | INTC     | INTC    | <b>Indicates if the command is GO_IRQ_STATE</b><br>If the command is GO_IRQ_STATE, the period between command token and response token will not be limited.<br>0: The command is not GO_IRQ_STATE.<br>1: The command is GO_IRQ_STATE.                                                                |
| 14     | STOP     | STOP    | <b>Indicates if the command is a stop transmission command</b><br>0: The command is not a stop transmission command.<br>1: The command is a stop transmission command.                                                                                                                               |
| 13     | RW       | RW      | <b>Defines the command is a read command or write command</b><br>The register bit is valid only when the command causes a transaction with data token.<br>0: The command is a read command.<br>1: The command is a write command.                                                                    |
| 12:11  | DTYPE    | DTYPE   | <b>Defines data token type for the command</b><br>00: No data token for the command<br>01: Single block transaction<br>10: Multiple block transaction, i.e. the command is a multiple block read or write command.<br>11: Stream operation. It can only be used when an multi-media card is applied. |
| 10     | IDRT     | IDRT    | <b>Identification response time</b><br>The register bit indicates if the command has a response with NID (i.e. 5 serial clock cycles as defined in SD Memory Card Specification Part 1 Physical Layer Specification version 1.0)                                                                     |

| Bit(s) | Mnemonic      | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:7    | <b>RSPTYP</b> | RSPTYP | <p>response time. The register bit is valid only when the command has a response token. Thus the register bit must be set to 1 for CMD2 (ALL_SEND_CID) and A CMD41 (SD_APP_OP_CMD).</p> <p>0: Otherw ise<br/>1: The command has a response w ith NID response time.</p> <p><b>Defines response type for the command</b></p> <p>For commands w ith R1 and R1b response, register SDC_CSTA (not SDC_STA) updates after response token is received. This register SDC_CSTA contains the status of the SD, and it can be used as a response interrupt source.</p> <p><i>Note: If CMD7 is used with all 0's RCA, then RSPTYP must be "000". Command "GO_TO_IDLE" also has RSPTYP='000'.</i></p> <p>000: There is no response for the command, e.g. broadcast command w ithout response and GO_INACTIVE_STATE command.<br/>001: The command has R1 response. R1 response token is 48-bit.<br/>010: The command has R2 response. R2 response token is 136-bit.<br/>011: The command has R3 response. Even though R3 is 48-bit response, it does not contain CRC checksum.<br/>100: The command has R4 response. R4 response token is 48-bit.<br/>(only for MMC)<br/>101: The command has R5 response. R5 response token is 48-bit.<br/>(only for MMC)<br/>110: The command has R6 response. R6 response token is 48-bit.<br/>111: The command has R1b response. If the command has a response of R1b type, SD controller must monitor the data line 0 for card busy status from the bit time that is 2 or 4 serial clock cycles after the command end bit to check if the operation in SD memory card has finished. There are two cases for detection of card busy status. The first case is that the host stops the data transmission during an active write data transfer. The card w ill assert busy signal after the stop transmission command end bit followed by 4 serial clock cycles. The second case is that the card is in idle state or receiving a stop transmission command between data blocks w hen multiple block write command is in progress. The register bit w ill be valid only w hen the command has a response token.</p> <p><b>Aborts pending MMC GO_IRQ_MODE command</b></p> <p>It is only valid for a pending GO_IRQ_MODE command waiting for MMC interrupt response.</p> <p>0: Other fields are valid.<br/>1: Break a pending MMC GO_IRQ_MODE command in the controller. Other fields are invalid.</p> <p><b>SD memory card command</b></p> <p>Total 6 bits.</p> |
| 6      | <b>BREAK</b>  | BREAK  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5:0    | <b>CMD</b>    | CMD    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| A0270028 <u>SDC_ARG</u> SD Memory Card Controller Argument Register |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00000000 |   |  |  |
|---------------------------------------------------------------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|---|--|--|
| Bit                                                                 | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |   |  |  |
| <b>Name</b>                                                         | <u>ARG[31:16]</u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |   |  |  |
| <b>Type</b>                                                         | RW                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |   |  |  |
| <b>Reset</b>                                                        | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0 |  |  |
| Bit                                                                 | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |   |  |  |
| <b>Name</b>                                                         | <u>ARG[15:0]</u>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |   |  |  |
| <b>Type</b>                                                         | RW                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |   |  |  |
| <b>Reset</b>                                                        | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0 |  |  |

**Overview:** The register contains the argument of the SD memory card command.

| Bit(s) | Mnemonic   | Name | Description                                      |
|--------|------------|------|--------------------------------------------------|
| 31:0   | <b>ARG</b> | ARG  | Contains argument of the SD memory card command. |

### A027002C SDC\_STA SD Memory Card Controller Status Register 00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19   | 18   | 17   | 16   |
|--------------|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3    | 2    | 1    | 0    |
| <b>Name</b>  | WP |    |    |    |    |    |    |    |    |    |    | FEDA | FECM | BEDA | BECM | BESD |
|              |    |    |    |    |    |    |    |    |    |    |    | TBUS | DBUS | TBUS | DBUS | CBUS |
|              |    |    |    |    |    |    |    |    |    |    |    | Y    | Y    | Y    | Y    | Y    |
| <b>Type</b>  | RO |    |    |    |    |    |    |    |    |    |    | RO   | RO   | RO   | RO   | RO   |
| <b>Reset</b> | 0  |    |    |    |    |    |    |    |    |    |    | 0    | 0    | 0    | 0    | 0    |

**Overview:** The register contains various statuses of SD controller as the controller is configured as the host of SD memory card.

| Bit(s) | Mnemonic        | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-----------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | <b>WP</b>       | WP        | Detects the status of write protection switch on SD memory card<br><br>The register bit shows the status of write protection switch on SD memory card. There is no default reset value. Pin WP (Write Protection) is only useful when the controller is configured for SD memory card.<br><br>1: Write protection switch on, i.e. memory card is desired to be write-protected.<br>0: Write protection switch off, i.e. memory card is writable.                                                                                                                         |
| 4      | <b>FEDATBUS</b> | FEDATBUSY | Indicates if there is any transmission going on DAT line on SD bus<br><br>This bit indicates directly the CMD line at card clock domain. For those commands without data but still involving DAT line, the register bit is useless. For example, if an erase command is issued, checking if the register bit is 0 before issuing the next command with data will not guarantee that the controller is idle. In this case, use register bit BESDCBUSY.<br><br>0: No transmission is going on DAT line on SD bus.<br>1: There is transmission going on DAT line on SD bus. |
| 3      | <b>FECMDBUS</b> | FECMDBUSY | Indicates if there is any transmission going on CMD line on SD bus<br><br>This bit indicates directly the CMD line at card clock domain.<br>0: No transmission is going on CMD line on SD bus.<br>1: There is transmission going on CMD line on SD bus.                                                                                                                                                                                                                                                                                                                  |
| 2      | <b>BEDATBUS</b> | BEDATBUSY | Indicates if there is any transmission going on DAT line on SD bus<br><br>0: Backend SDC controller gets the info that no transmission is going on DAT line on SD bus.<br>1: Backend SDC controller gets the info that there is transmission going on DAT line on SD bus.                                                                                                                                                                                                                                                                                                |
| 1      | <b>BECMDBUS</b> | BECMDBUSY | Indicates if there is any transmission going on CMD line on SD bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bit(s) | Mnemonic        | Name             | Description                                                                                                                                                                                                                                                                                                                 |
|--------|-----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Y      |                 | bus              | This bit shows backend controller's CMD busy state. The busy state is synced from card clock domain to bus clock domain.<br>0: Backend SDC controller gets the info that no transmission is going on CMD line on SD bus.<br>1: Backend SDC controller gets the info that there is transmission going on CMD line on SD bus. |
| 0      | <b>BESDCBUS</b> | <b>BESDCBUSY</b> | <b>Indicates if SD controller is busy, i.e. is there any transmission going on CMD or DAT line on SD bus</b><br>This bit shows backend controller's SDC busy state. The busy state is synced from card clock domain to bus clock domain.<br>0: Backend SD controller is idle.<br>1: Backend SD controller is busy.          |

**A0270030 SDC RESP0 SD Memory Card Controller Response Register 0 00000000**

| Bit                             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>RESP[31:0][31:16]</b>        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>RESP[31:0][15:0]</b>         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Overview:** The register contains parts of the last SD memory card bus response. See descriptions of register field SDC\_RESP3.

| Bit(s) | Mnemonic          | Name             | Description |
|--------|-------------------|------------------|-------------|
| 31:0   | <b>RESP[31:0]</b> | <b>RESP_31_0</b> |             |

**A0270034 SDC RESP1 SD Memory Card Controller Response Register 1 00000000**

| Bit                             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>RESP[63:32][31:16]</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>RESP[63:32][15:0]</b>        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Overview:** The register contains parts of the last SD memory card bus response. See descriptions of register field SDC\_RESP3.

| Bit(s) | Mnemonic           | Name              | Description |
|--------|--------------------|-------------------|-------------|
| 31:0   | <b>RESP[63:32]</b> | <b>RESP_63_32</b> |             |

**A0270038 SDC\_RESP2 SD Memory Card Controller Response Register 2 00000000**

| Bit   | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESP[95:64][31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESP[95:64][15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** The register contains parts of the last SD memory card bus response. See descriptions of register field SDC\_RESP3.

| Bit(s) | Mnemonic    | Name       | Description |
|--------|-------------|------------|-------------|
| 31:0   | RESP[95:64] | RESP_95_64 |             |

**A027003C SDC\_RESP3 SD Memory Card Controller Response Register 3 00000000**

| Bit   | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESP[127:96][31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESP[127:96][15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** The register contains parts of the last SD memory card bus response. Register fields SDC\_RESP0, SDC\_RESP1, SDC\_RESP2 and SDC\_RESP3 compose the last SD memory card bus response. For response of type R2, i.e. response of commands ALL\_SEND\_CID, SEND\_CSD and SEND\_CID, only bit 127 to 0 of the response token are stored in register fields SDC\_RESP0, SDC\_RESP1, SDC\_RESP2 and SDC\_RESP3. For response of other types, only bit 39 to 8 of the response token are stored in register field SDC\_RESP0.

| Bit(s) | Mnemonic     | Name        | Description |
|--------|--------------|-------------|-------------|
| 31:0   | RESP[127:96] | RESP_127_96 |             |

**A0270040 SDC\_CMDSTA SD Memory Card Controller Command Status Register 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1    | 0    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    | RSPC | CMDT | CMDR |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    | RCE  | O    | DY   |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    | RC   | RC   | RC   |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    | 0    | 0    | 0    |

**Overview:** The register contains the status of SD controller during command execution and that of SD bus protocol after command execution when the SD controller is configured as the host of SD memory card. The

register can also be used as an interrupt source. The register is cleared when being read. Meanwhile, if the interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.

| Bit(s) | Mnemonic | Name      | Description                                                                                                                                                                                                                                                                                                                                                                   |
|--------|----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | RSPCRCER | RSPCRCERR | <b>CRC error on CMD detected</b><br>'1' indicates the SD controller detects a CRC error after reading a response from the CMD line.<br>0: Otherwise<br>1: SD controller detects a CRC error after reading a response from the CMD line.                                                                                                                                       |
| 1      | CMDTO    | CMDTO     | <b>Time-out on CMD detected</b><br>'1' indicates the SD controller detects a time-out condition while waiting for a response on the CMD line.<br>0: Otherwise<br>1: SD controller detects a timeout condition while waiting for a response on the CMD line.                                                                                                                   |
| 0      | CMDRDY   | CMDRDY    | <b>For command without response, the register bit will be 1 once the command is completed on SD bus</b><br>For command with response, the register bit will be 1 whenever the command is issued onto the SD bus and its corresponding response is received without CRC error.<br>0: Otherwise<br>1: Command with/without response is finished successfully without CRC error. |

**A0270044 SDC DATSTA SD Memory Card Controller Data Status Register 00000000**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |          |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |          |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1      | 0        |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DATT O | BLKD ONE |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RC     | RC       |
| Reset |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0        |

**Overview:** The register contains the status of SD controller during data transfer on DAT line(s) when the SD controller is configured as the host of SD memory card. The register can be used as an interrupt source. The register is cleared when being read. Meanwhile, if the interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.

| Bit(s) | Mnemonic | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:2    | DATCRCER | DATCRCERR | <b>CRC error on DAT detected</b><br>'1' indicates that the SD controller detects a CRC error for bit n after reading a block of data from the DAT line or SD signals a CRC error after writing a block of data to the DAT line.<br>0: Otherwise<br>1: SD controller detects a CRC error after reading a block of data from the DAT line or SD signals a CRC error after writing a block of data to the DAT line.<br><i>Note: n is 7 ~ 1 for 8-bits mode. Each bit is read and cleared</i> |

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                      |
|--------|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | DATTO    | DATTO   | <i>individually</i><br><b>Time-out on DAT detected</b><br>A '1' indicates that the SD controller detects a time-out condition while waiting for data token on the DAT line.<br>0:<br>1: SD controller detects a time-out condition while waiting for data token on the DAT line. |
| 0      | BLKDONE  | BLKDONE | <b>Indicates the status of data block transfer</b><br>0:<br>1: A data block is successfully transferred.                                                                                                                                                                         |
|        |          |         | Otherwise                                                                                                                                                                                                                                                                        |

| <b>A0270048 SDC_CSTA SD Memory Card Status Register</b> |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000000</b> |   |  |  |
|---------------------------------------------------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|---|--|--|
| Bit                                                     | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |   |  |  |
| Name                                                    | <b>CSTA [31:0][31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| Type                                                    | RC                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| Reset                                                   | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0 |  |  |
| Bit                                                     | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |   |  |  |
| Name                                                    | <b>CSTA [31:0][15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| Type                                                    | RC                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |   |  |  |
| Reset                                                   | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0 |  |  |

**Overview:** After commands with R1 and R1b respond this register containing the status of the SD card, it will be used as a response interrupt source. In all register fields, logic high indicates error, and logic low indicates no error. The register is cleared when being read. Meanwhile, if the interrupt is enabled and thus interrupt caused by the register is generated, reading the register will de-assert the interrupt.

| Bit(s) | Mnemonic           | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|--------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>CSTA [31:0]</b> | <b>CSTA_31_0</b> | CSTA31: OUT_OF_RANGE. The command's argument is out of the allowed range for this card.<br>CSTA30: ADDRESS_ERROR. A misaligned address that does not match the block length is used in the command.<br>CSTA29: BLOCK_LEN_ERROR. The transferred block length is not allowed for this card, or the number of transferred bytes does not match the block length.<br>CSTA28: ERASE_SEQ_ERROR. An error in the sequence of erase commands occurs.<br>CSTA27: ERASE_PARAM. An invalid selection of write-blocks for erase occurs.<br>CSTA26: WP_VIOLATION. Attempt to program a write-protected block.<br>CSTA25: Reserved. Return to 0.<br>CSTA24: LOCK_UNLOCK_FAILED. Set when a sequence or password error is detected in lock/unlock card command or if there is an attempt to access a locked card.<br>CSTA23: COM_CRC_ERROR. The CRC check of the previous command fails.<br>CSTA22: ILLEGAL_COMMAND. Command not legal for the card state.<br>CSTA21: CARD_ECC_FAILED. Card internal ECC is applied but fails to correct the data.<br>CSTA20: CC_ERROR. Internal card controller error. |

CSTA19: ERROR. A general or unknown error occurs during the operation.  
 CSTA18: UNDERRUN. The card cannot sustain data transfer in stream read mode.  
 CSTA17: OVERRUN. The card cannot sustain data programming in stream write mode.  
 CSTA16: CID/CSD\_OVERWRITE. It can be either one of the following errors: 1) The CID register has been already written and cannot be overwritten; 2) The read-only section of the CSD does not match the card; 3) An attempt to reverse the copy (set as the original) or permanent WP (unprotected) bits is made.  
 CSTA[15:4]: Reserved. Return to 0.  
 CSTA3: AKE\_SEQ\_ERROR. Error in the sequence of authentication process  
 CSTA[2:0]: Reserved. Return to 0.

**A027004C    SDC\_IRQMASK0    SD Memory Card IRQ Mask Register 0    00000000**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** The register contains parts of SD memory card interrupt mask register. See the register descriptions of register SDC\_IRQMASK1 for reference. The register masks interrupt sources from register SDC\_CMDSTA and SDC\_DATSTA. IRQMASK[3:0] is for SDC\_CMDSTA, and IRQMASK[18:16] for SDC\_DATSTA. Note that IRQMASK[18] masks SDC\_DATSTA[9:2] together. '1' in some bits of the register masks the corresponding interrupt source with the same bit position. For example, if IRQMASK[0] is 1, then the interrupt source from register field CMDRDY of register SDC\_CMDSTA will be masked. '0' in some bits does not cause interrupt mask on the corresponding interrupt source from registers SDC\_CMDSTA and SDC\_DATSTA.

| Bit(s) | Mnemonic              | Name         | Description |
|--------|-----------------------|--------------|-------------|
| 31:0   | <b>IRQMASK [31:0]</b> | IRQMASK_31_0 |             |

**A0270050    SDC\_IRQMASK1    SD Memory Card IRQ Mask Register 1    00000000**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview:** The register contains parts of SD memory card interrupt mask register. Registers SDC\_IRQMASK1 and SDC\_IRQMASK0 compose the SD memory card interrupt mask register. The register masks interrupt

sources from register SDC\_CSTA. '1' in some bits of the register masks the corresponding interrupt source with the same bit position. For example, if IRQMASK[63] is 1, then the interrupt source from register field OUT\_OF\_RANGE of register SDC\_CSTA will be masked. '0' in some bits does not cause interrupt mask on the corresponding interrupt source from register SDC\_CSTA.

| Bit(s) | Mnemonic           | Name          | Description |
|--------|--------------------|---------------|-------------|
| 31:0   | IRQMASK<br>[63:32] | IRQMASK_63_32 |             |

| <b>A0270054 SDIO CFG SDIO Configuration Register</b> |    |    |    |    |    |    |    |    |    |    |               |    |                |               |    | 00000000     |  |
|------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----------------|---------------|----|--------------|--|
| Bit                                                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21            | 20 | 19             | 18            | 17 | 16           |  |
| <b>Name</b>                                          |    |    |    |    |    |    |    |    |    |    |               |    |                |               |    |              |  |
| <b>Type</b>                                          |    |    |    |    |    |    |    |    |    |    |               |    |                |               |    |              |  |
| <b>Reset</b>                                         |    |    |    |    |    |    |    |    |    |    |               |    |                |               |    |              |  |
| Bit                                                  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5             | 4  | 3              | 2             | 1  | 0            |  |
| <b>Name</b>                                          |    |    |    |    |    |    |    |    |    |    | <b>DISSEL</b> |    | <b>INTCSEL</b> | <b>DSBSEL</b> |    | <b>INTEN</b> |  |
| <b>Type</b>                                          |    |    |    |    |    |    |    |    |    |    | <b>RW</b>     |    | <b>RW</b>      | <b>RW</b>     |    | <b>RW</b>    |  |
| <b>Reset</b>                                         |    |    |    |    |    |    |    |    |    |    | 0             |    | 0              | 0             |    | 0            |  |

**Overview:** The register is used to configure functions for SDIO.

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                          |
|--------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | DISSEL   | DISSEL  | <b>Selects data block interrupt source</b><br>0: The host detects SDIO interrupt during interrupt period between two data blocks of multiple block data access.<br>1: The host ignores SDIO interrupt during interrupt period between two data blocks of multiple block data access. |
| 3      | INTCSEL  | INTCSEL | <b>Selects interrupt control</b><br>0: The host detects DAT1 low as SDIO interrupt.<br>1: The host detects DAT3/DAT2/DAT1/DAT0 4'b1101 as SDIO interrupt.                                                                                                                            |
| 2      | DSBSEL   | DSBSEL  | <b>Selects data block start bit</b><br>0: Use data line 0 as start bit of data block. Other data lines are ignored.<br>1: Start bit of a data block is received only when all data line 0-3 become low.                                                                              |
| 0      | INTEN    | INTEN   | <b>Enables interrupt for SDIO</b><br>0: Disable<br>1: Enable                                                                                                                                                                                                                         |

| <b>A0270058 SDIO STA SDIO Status Register</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00000000   |  |
|-----------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|--|
| Bit                                           | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |  |
| <b>Name</b>                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |
| <b>Type</b>                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |
| <b>Reset</b>                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |
| Bit                                           | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |  |
| <b>Name</b>                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>IRQ</b> |  |
| <b>Type</b>                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RO</b>  |  |
| <b>Reset</b>                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |  |

**Overview:** This register is used to identify if there is SDIO interrupt during the interrupt period on data line.

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                                                                                                                                                                                                                             |
|--------|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | IRQ      | IRQ  | <p><b>SDIO interrupt exists on the data line.</b></p> <p>For example, when in the interrupt period or the 1-bit data line mode and DAT1/5 goes low from high, this bit will become 1 from 0. If DAT1/5 goes high from low, this bit will become 0 from 1.</p> <p>0: There is no SDIO interrupt existing on the data line.<br/>1: There is SDIO interrupt existing on the data line.</p> |

**A0270080 CLK\_RED CLK Latch Configuration Register 00000000**

| Bit          | 31 | 30 | 29      | 28 | 27 | 26 | 25 | 24 | 23                 | 22             | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|---------|----|----|----|----|----|--------------------|----------------|----|----|----|----|----|----|
| <b>Name</b>  |    |    | CMD_RED |    |    |    |    |    |                    |                |    |    |    |    |    |    |
| <b>Type</b>  |    |    | RW      |    |    |    |    |    |                    |                |    |    |    |    |    |    |
| <b>Reset</b> |    |    | 0       |    |    |    |    |    |                    |                |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13      | 12 | 11 | 10 | 9  | 8  | 7                  | 6              | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    | DAT_RED |    |    |    |    |    | CLKP<br>AD_R<br>ED | CLK_LATCH<br>H |    |    |    |    |    |    |
| <b>Type</b>  |    |    | RW      |    |    |    |    |    | RW                 | RW             |    |    |    |    |    |    |
| <b>Reset</b> |    |    | 0       |    |    |    |    |    | 0                  | 0              |    |    |    |    |    |    |

**Overview:** The register is used to configure the MSDC sample data/response clock. Note that only when MSDC\_IOCON[19] = 1 will the host latch response; otherwise MSDC FSM will handle the response from PAD directly.

| Bit(s) | Mnemonic  | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-----------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29     | CMD_RED   | CMD_RED    | <p><b>Determines the command response from card output is latched at falling edge or rising edge of internal clock</b></p> <p>Only effective when CLK_LATCH = 1</p> <p>0: Internal clock rising edge to latch response<br/>1: Internal clock falling edge to latch response</p>                                                                                                                                                                                                                                                                                   |
| 13     | DAT_RED   | DAT_RED    | <p><b>Determines the input data from card output is latched at falling edge or rising edge of internal sample clock</b></p> <p>Only effective when CLK_LATCH = 1</p> <p>0: Internal clock rising edge to latch data<br/>1: Internal clock falling edge to latch data</p>                                                                                                                                                                                                                                                                                          |
| 7      | CLKPAD_R  | CLKPAD_RED | <p><b>Determines the input data from card is latched at falling edge or rising edge of the feedback clock from pad</b></p> <p>The suggested setting is 0 when SD serial clock is lower than 25MHz. The suggestion setting is 1 when SD serial clock is higher than 25MHz. The suggestion setting is 0 for MMC card no matter the serial clock rate is high speed or default speed. Only effective when CLK_LATCH = 0.</p> <p>0: Internal feedback clock rising edge to latch data/response<br/>1: Internal feedback clock falling edge to latch data/response</p> |
| 6      | CLK_LATCH | CLK_LATCH  | <p><b>Determines which clock to latch data from card</b></p> <p>The suggested setting is 1 if SCLKF in register field MSDC_CFG is 0x0. Otherwise, the suggested setting is 0.</p> <p>0: Internal feedback clock is used to latch data/response from card.</p>                                                                                                                                                                                                                                                                                                     |

| Bit(s) | Mnemonic | Name | Description                                                 |
|--------|----------|------|-------------------------------------------------------------|
|        |          |      | 1: Internal clock is used to latch data/response from card. |

### A0270098 DAT\_CHECKSUM MSDC Rx Data Checksum Register 00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Overview:** The register is used to compute the checksum value of Rx read data

| Bit(s) | Mnemonic         | Name         | Description                           |
|--------|------------------|--------------|---------------------------------------|
| 31:0   | DAT_CHEC<br>KSUM | DAT_CHECKSUM | The checksum algorithm is 32-bit XOR. |

## 3.18 BTIF

### 3.18.1 General Description

Bluetooth Interface (BTIF) is designed in SOC (BT+GSM) as the UART interface between the BT chip and baseband chip. As in the UART design, BTIF is an APB slave which transmits or receives data by MCU access or through DMA/VFIFO.



Figure 48. Interface connection between BT and baseband system

## 3.18.2 Register Definition

**BTIF+0000h Rx Buffer Register****BTIF\_RBR**

| Bit  | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | RBR[7:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | RO       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**RBR** Rx buffer register. A read-only register. The received data can be read by accessing this register. This register is valid only when BTIF\_FAKELCR[7] (0x0C) is 0.

**BTIF+0000h Tx Holding Register****BTIF\_THR**

| Bit  | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | THR[7:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | WO       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**THR** Tx holding register. A write-only register. The data to be transmitted are written to this register and sent to the Bluetooth via BTIF. This register is valid only when BTIF\_FAKELCR[7] (0x0C) is 0.

**BTIF+0004h Interrupt Enable Register****BTIF\_IER**

| Bit   | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | TXEE N RXFE N |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | W/R W/R       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0 0           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

This register is valid only when BTIF\_FAKELCR[7] is 0.

**TXEN** Enables Tx empty interrupt. When set to 1, an interrupt will be generated if the Tx holding register is empty.

- 0** No interrupt will be generated if the Tx holding register is empty.
- 1** An interrupt will be generated if the Tx holding register is empty

**RXFEN** Enables Rx full interrupt. When set to 1, an interrupt will be generated if the Rx buffer contains data.

- 0** No interrupt will be generated if the Rx buffer contains data.
- 1** An interrupt will be generated if the Rx buffer contains data.

**BTIF+0008h Interrupt Identification Register****BTIF\_IIR**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----|-----|-----|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | ID2 | ID1 | ID0 | NINT |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | RO  | RO  | RO  | RO   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0   | 0   | 0   | 1    |

This register is valid only when BTIF\_FAKELCR (0x0C) is not 0xBF.

**IIR** Identifies if there are pending interrupts. The following table lists the IIR[5:0] codes associated with the possible interrupts:

**Table 52. IIR[5:0] codes associated with the possible interrupts**

| IIR[3:0] | Priority level | Interrupt                 | Source                             |
|----------|----------------|---------------------------|------------------------------------|
| 0001     | -              | No pending interrupt      |                                    |
| 0100     | 1              | Rx data received          | Rx data received                   |
| 1100     | 2              | Rx data time-out          | Time-out on character in Rx buffer |
| 0010     | 3              | Tx holding register empty | Tx holding register empty.         |

#### Rx data received interrupt

A Rx received interrupt (IIR[3:0] = 0x04) is generated when RXFEN (IER[0]) is set and Rx data are placed in the Rx buffer register. The interrupt is cleared by reading the Rx buffer register.

#### Rx data time-out interrupt

The Rx data time-out interrupt will be generated if all of the following conditions are applied:

1. Rx buffer is empty.
2. The most recent character is received longer than (RTOCNT\*bclk period\*4).
3. RXFEN (IER[0]) is set to 1.

The time-out timer is restarted upon receipt of a new byte from the Rx shift register. This interrupt is only valid while VFIFO is used. This register is cleared by reading the VFIFO status register (0x4C).

#### Tx holding register empty

A Tx holding register empty interrupt (IIR[3:0] = 0x02) is generated when TXEEN(IER[1]) is set and no data are placed in the Tx holding register. This interrupt is cleared by writing data into BTIF\_THR (0x00).

**BTIF+0008h FIFO\_CTRL****BTIF\_FIFOCT**  
**RL**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2           | 1           | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|-------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>CLRT</b> | <b>CLRR</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>WO</b>   | <b>WO</b>   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0           | 0           |   |

This register is valid only when BTIF\_FAKELCR (0x0C) is not 0xBF.

**CLRT** Clears transmit FIFO. This bit is self-clearing.

- 0** Leave Tx FIFO intact.
- 1** Clear all the bytes in Tx FIFO.

**CLRR** Clears receive FIFO. This bit is self-clearing.

- 0** Leave Rx FIFO intact.
- 1** Clear all the bytes in Rx FIFO.

**BTIF+000Ch FAKE LCR****BTIF\_FAKEL**  
**CR**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2                   | 1 | 0 |  |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---------------------|---|---|--|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>FAKELCR[7:0]</b> |   |   |  |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>R/W</b>          |   |   |  |
| Reset |    |    |    |    |    |    |   |   |   | 0 | 0 | 0 | 0 | 0                   | 0 | 0 |  |

**FAKELCR** This register is added to synchronize the software control method of UART. When FAKELCR[7] is 1, RBR(0x00), THR(0x00) and IER(0x04) will not be readable/writable. When FAKELCR is 0xBF, RBR(0x00), THR(0x00), IER(0x04), IIR(0x08) and LSR(0x14) will not be readable/writable.

**BTIF+0014h Line Status Register****BTIF\_LSR**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6           | 5           | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|-------------|-------------|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   | <b>TEMT</b> | <b>THRE</b> |   |   |   |   | <b>DR</b> |
| Type  |    |    |    |    |    |    |   |   |   | <b>RO</b>   | <b>RO</b>   |   |   |   |   | <b>RO</b> |
| Reset |    |    |    |    |    |    |   |   |   | 1           | 1           |   |   |   |   | 0         |

**LSR** Line status register. Readable when LCR  $\neq$  0xBF.

**TEMT** Tx holding register is empty.

- 0** Empty conditions are not met.
- 1** This bit is set when the Tx holding register is empty.

|             |                                                                                            |
|-------------|--------------------------------------------------------------------------------------------|
| <b>THRE</b> | Indicates if Tx FIFO is reduced to its trigger level                                       |
| 0           | Reset whenever the contents of Tx FIFO are more than its trigger level (FIFOs are enabled) |
| 1           | Set whenever the contents of Tx FIFO are reduced to its trigger level (FIFOs are enabled)  |
| <b>DR</b>   | Data Ready                                                                                 |
| 0           | Cleared by reading the Rx buffer.                                                          |
| 1           | Set by the Rx buffer becoming full.                                                        |

**BTIF+0048h Sleep Enable Register****BTIF\_SLEEP\_EN**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | SLEEP_EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | R/W      |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0        |

**SLEEP\_EN** For sleep mode issue

- 0 Does not deal with sleep mode indication signal
- 1 Activate flow control according to software initial settings when the chip enters the sleep mode. Release hardware flow when the chip wakes up.

**BTIFn+004C h DMA Enable Register****BTIF\_DMA\_EN**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-----------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | TO_CNT_AUTOR_ST |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | R/W             |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0 0 0           |

**RX\_DMA\_EN**

RX\_DMA mechanism enabling signal

- 0 Does not use DMA in Rx.
- 1 Use DMA in Rx. When this register is enabled, the flow control is based on the DMA threshold and generates a time-out interrupt

**TX\_DMA\_EN**

TX\_DMA mechanism enabling signal

- 0 Does not use DMA in Tx.
- 1 Use DMA in Tx. When this register is enabled, the flow control is based on the DMA threshold and generates a time-out interrupt for DMA.

**TO\_CNT\_AUTORST** Time-out counter auto reset register

- 0** After Rx time-out takes place, the software shall reset the interrupt by reading BTIF 0x4C.
- 1** The time-out counter will be auto reset.

**BTIF+0054h Rx Time-out Count****BTIF\_RTOCNT**

| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | RTOCNT[7:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0x40        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**RTOCNT** Used for Rx time-out interrupt. The Rx time-out interrupt will be generated when:

1. RXFEN (0x04[0]) is set to 1.
2. Rx buffer is empty.
3. The most recent character is received longer than (RTOCNT\*bclk period\*4).

**BTIF+0060h TRX\_TRIGGER\_LEVEL****BTIF\_TRI\_LVL**

| Bit   | 15                              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | BTIF_LOOP RX_TRI_LVL TX_TRI_LVL |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W R/W R/W                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0x0 0x5 0xa                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**TX\_TRI\_LVL** Used for Tx FIFO trigger threshold. THRE(0x14[5]) will be set if the data in the TXFIFO are less than TX\_TRI\_LVL.

**RX\_TRI\_LVL** Used for Rx FIFO trigger threshold. A Rx trigger interrupt (IIR(0x08) = 4) might be set if the data in the RXFIFO are more than RX\_TRI\_LVL. The output flow control signal will also be set if the data in the RXFIFO are more than RX\_TRI\_LVL.

**BTIF\_LOOP** Enables BTIF loop back mode. The data output from Tx will be received by Rx.

**BTIF+0064h SLEEP\_WAKEUP****BTIF\_WAK**

| Bit  | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | SLEEP_WAKE |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |    |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----|
| Type  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | WO |
| Reset |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1  |

**SLEEP\_WAKE** ARM9 side btif\_sleep\_wakeup\_in\_b is connected to eint[16] (ARM9 has eint[19:0]. ARM7 side btif\_sleep\_wakeup\_in\_b is connected to eint[0] (ARM7 has eint[3:0])

### BTIF+0068h ASYNC\_WAIT\_TIME

### BTIF\_WAT\_TIME

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                 | 2 | 1                 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-------------------|---|-------------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>WAT_TIME_2</b> |   | <b>WAT_TIME_1</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W               |   | R/W               |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0x2               |   | 0x2               |   |

**ASYNC\_WAIT\_TIME** Sets up waiting time of RX read-out.

**WAT\_TIME\_1** The first level of wait time.

**WAT\_TIME\_2** The second level of wait time.

Notes: The value of WAT\_TIME\_1/ WAT\_TIME\_1 cannot be smaller than 0x2.

### BTIF+006C h NEW\_HANDSHAKE

### BTIF\_HANDSHAKE

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3              | 2                    | 1                   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|----------------|----------------------|---------------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>RTO_EXT</b> | <b>HIGH_SPEED_EN</b> | <b>HANDSHAKE_EN</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W            | R/W                  | R/W                 |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0              | 0                    | 1                   |   |

**NEW\_HANDSHAKE** The default value of handshake is 0. The function of handshake is disabled. The function of BTIF has limitation. The ratio of bclk cannot be bigger than 2; otherwise, two system data transmissions will be wrong. If the value of handshake is 1, the ratio of bclk will be free.

**HANDSHAKE\_EN** Enables handshake mode.

**high\_speed\_en** Enables high speed mode. Reserved.

**RTO\_EXT** Extends the value of RX time-out counter (16\*rto\_time).

## 4 GPS

### 4.1 RF Part

#### 4.1.1 LNA/Mixer

Upon receiving RF input signal in through either multi-GNSS antenna to internal LNA or external antenna and LNA, the mixer down converts the amplified signal (GPS/Galileo=1575.42MHz, Beidou=1561.098-MHz, GLONASS=1601.71-MHz). The current chip provides 2 configurations to choose from, which are high-gain LNA and low-gain LNA. The high-gain LNA is used for low-cost solution without external LNA. The low-gain LNA offers high linearity to allow high external LNA gain, with much worsen noise figure performance. In the application with external LNA, the external LNA gain ranging from 15 to 20 dB is recommended. The down-conversion mixer is single-ended passive mixer with current mode interface between the mixer and multi-modes low pass filter.

#### 4.1.2 VCO/Synthesizer

The entire frequency synthesizer includes crystal oscillator, VCO, divider, phase frequency detector (PFD), charge pump (CP) and loop filter which are all integrated on the MT2503A chip. Upon power-on, VCO is auto-calibrated to its required sub-band. The synthesizer adopts fractional-N sigma-delta PLL topology, which supports 12.6 to 40MHz reference clock frequencies.

#### 4.1.3 LPF

The current-mode LPF supports multiple modes for different GNSS combinations. The LPF also provides 26dB gain-control range, with approximately 2dB per step.

#### 4.1.4 ADC

The differential IF signal is being quantized by a high performance ADC. The sampling clock can be provided from divided clock from LO.

## 4.2 Digital Part

### 4.2.1 ARM7EJ-S

The ARM7EJ-S processor provides flexibility necessary for building Java-enabled, real-time embedded devices requiring small size, low-power and high performance. It builds on the features and benefits of the established ARM7TDMI core and is delivered in synthesizable form. ARM7EJ-S is supported by a wide variety of development tools and can run at speeds up to 158 MHz.

ARM7EJ-S includes a JTAG interface which provides a standard development and debugging interface. The interface can connect to a variety of off-the-shelf emulators. The emulators provide single-step, trap and access to all the internal registers of the digital part of MT2503A.

### 4.2.2 Cache

MT2503A provides cache to speed up program execution and reduce external flash access times. It supports up to 64 Kbits cache buffer and can be used as internal memory when it is not fully used.

### 4.2.3 Boot ROM

The embedded boot ROM provides a function of loading a set of user code through the host interface into SRAM. The host interface (UART/SPI/I2C) is decided by strap control.

### 4.2.4 Real Time Clock (RTC)

MT2503A provides very low leakage battery backed-up memory, which contains all the necessary multi-GNSS information for quick start-up and a small amount of user configuration variables. There is a built-in 1.1 volts LDO for RTC domain and it can be bypassed while an external LDO is applied. The RTC LDO is a voltage regulator having very low quiescent current. The small ceramic capacitor can be used as the output capacitor, and the stable operation region ranges from very light load ( $\approx 0$ ) to about 3 mA.



Figure 49. RTC with internal RTC LDO application circuit 1



**Figure 50. RTC with internal RTC LDO application circuit 2**

#### 4.2.5 SMPS

A built-in switching mode power supply provides 1.8 volts power supply for the digital 1.1 volts CLDO and RF input power. In the active mode, SMPS is operated in the PWM/PFM automatic mode. In the power saving mode, SMPS is operated with reduced switching frequency in the PFM mode. The recommended L/C value is 1 uH / 4.7 uF.

#### 4.2.6 Timer function

The timer function supports a time tick generation of 31.25 ms resolution. With the 24-bit counter, the period of timer is from 31.25 ms to 524,287 s.

#### 4.2.7 GPIO in RTC domain

The “32K\_OUT” pin in RTC domain can output 32.768 KHz clock which can be used to support low clock rate operation mode for some applications or peripherals that need an external clock source. This pin can also be programmed to be an input pin to receive the signal from an external accelerator sensor IC to be the wake-up signal of MT2503A when it is in the low-power mode.

#### 4.2.8 Low power detection

A low power detection circuit is implemented. Whenever the independent power source (AVDD11\_RTC) becomes low voltage, the low power detection circuit will detect this condition and use an indicator signal (output high in normal condition and low in low-power condition) to reflect this condition.

#### 4.2.9 Clock module

The clock module generates all internal clocks required by processor, correlator, internal memory, bus interface and so on. The referenced input clock is generated from the RF block. For system flexibility and maximum power saving, it supports various power management modes.

#### 4.2.10 Reset controller

The built-in reset controller generates reset signals for all digital blocks. It has power-on reset feature and hardware trapping function. The power-on reset level is  $2.7 \pm 0.1$  volts. The software reset function for different circuit blocks are also included for flexible applications.

In Figure 51, the voltage drop time  $T_{drop\_vbat}$  and  $T_{drop\_cl\_do}$  depend on the capacitance connection of their power net. But  $T_{drop\_vbat} > T_{drop\_cl\_do}$  should be guaranteed for the correct operation of reset behavior during power off sequence. It is strongly recommend using external LDOs without output discharged function or make sure  $T_{drop\_vbat} > 100$  ms.



**Figure 51. Power on reset diagram**



**Figure 52. Power on/off reset behavior**

## 4.2.11 Host interface

MT2503A supports 3 different host interfaces, which are UART, SPI, and I2C. The interface used as the host interface is determined by strap pins. Note that SPI and I2C support firmware update only for now.

### 4.2.11.1 UART

UART is the abbreviation of “Universal Asynchronous Receiver/Transmitter”. MT2503A has 3 full duplex serial ports. It is used for serial data communication. A UART converts bytes of data to and from asynchronous start-stop bit streams represented as binary electrical impulses.

There are several functions in MT2503A related to UART communication, such as UART data transmission/receive and NMEA sentences input/output. In general, UART0 is as NMEA output and PMTK command input, UART1 as RTCM input. You can adjust the UART2 port as desired. The receiver (RX) and transmitter (TX) side of every port contains a 16-byte FIFO, but only UART0 has 256 bytes of URAM. The bit rates are selectable and range from 4.8 to 921.6 kbps. UART provides signal or message outputs.

### 4.2.11.2 SPI (by request)

The serial peripheral interface port manages the communication between digital BB and external devices. MT2503A supports both master and slave modes. Only 4 bytes of register in the master mode can be transferred. The slave has 4-byte-register mode or URAM mode. In the URAM mode, the transmitted and received data size is 256 bytes. The clock phase and clock polarity are selectable. MT2503A supports manual or automatic indicator for data transfer in the slave mode.

### 4.2.11.3 I2C (by request)

The I2C interface is mainly connected to external devices. MT2503A supports multi-master and slave modes. Both modes have 256-byte URAM mode and 8-byte FIFO mode for transmitting and receiving data. The multi-master mode supports 7-bit and 10-bit address modes up to 400 Kb/s fast mode and 3.4 Mb/s high-speed mode. In addition, MT2503A supports manual or automatic indicator for data transfer in the slave mode. Device addresses in the slave mode are programmable and support fast mode and high-speed mode data transmission and reception.

## 4.2.12 Interrupt control unit

The interrupt control unit manages all internal and external sources of interrupts, which include timer, watch-dog, all interfaces such as UART, I2C and SPI and external user interrupt pins. These interrupt sources can be wake-up events in the power saving mode.

## 4.2.13 Flash

An external SPI serial flash up to 128 Mb is supported. Specific MTK Flash Tool is also supported for downloading firmware into the internal flash.

#### 4.2.14 GPIO unit

GPIO is the abbreviation of “General-Purpose Input/Output”. MT2503A supports a variety of peripherals through maximum 16 GPIO programmable ports. The unit manages all GPIO lines and supports a simple control interface. GPIO provides signal or message outputs.

#### 4.2.15 PPS

The PPS (Pulse Per Second) signal is provided through designated output pin for many external applications. The pulse is not only limited to being active every second but also allowed to set up the required duration, frequency and active high/low by programming user-defined settings.

#### 4.2.16 ECLK

ECLK is a clock input pin for introducing an external clock signal to MT2503A and obtaining the relation between the external clock and GPS local clock. With precise external clock input, the clock drift of the GPS local clock can be correctly estimated. Therefore, the doppler search range is narrowed down accordingly. The technology is beneficial to speeding up the satellite acquisition process. Particularly in the cold start case, due to limited priori information about the satellite's location and local clock uncertainty, a receiver will execute a search in full frequency range. Consequently, a longer acquisition time is expected. However, the ECLK technology is able to reduce the frequency uncertainty so that the search process will be completed in a short time. Efficient acquisition and lower power consumption are attained by the ECLK technology.

#### 4.2.17 SYNC

SYNC is a time stamp signal input pin for introducing an external timing to the GPS receiver and obtaining the relation between the external timing and the GPS receiver local timing. With precise external timing input and the established relation, the GPS time of week (TOW) can be correctly estimated in the GPS receiver. The technology is beneficial for time to first fix (TTFF), particularly in weak signal environments. In hot starts, with priori information about the GPS receiver's location and satellite ephemeris data, the GPS receiver uses the correct GPS TOW to accurately predict the signal code chip/phase. Therefore, the code search range can be narrowed down accordingly. Hence, fast TTFF is achieved by the SYNC technology.



Figure 53. Flow diagram of SYNC function

#### 4.2.18 Power scheme

Internal SMPS is used as the source power of the internal RF/BB LDO. It is also used as 1.8 volts I/O power, external TCXO/LNA voltage source via built-in TCXO switch. The internal SMPS can switch to the LDO mode to supply power to each of the about block.

The minimum/maximum input voltage of AVDD43\_VBAT and AVDD43\_DCV is 2.8/4.3 volts.

The power-on reset voltage threshold of AVDD43\_VBAT is  $2.7 \pm 0.1$  volts. The maximum TLDO drop out voltage at half load (25 mA) is 0.2 volts. If one external LDO is used to provide power to MT2503A, the 3.3 volts external LDO will be recommended after taking TLDO drop-out into consideration.

The power efficiency in SMPS mode will be better than that in the internal LDO mode.

I/O supports 1.8 and 2.8 volts. The power comes from SMPS output for 1.8 volts application or TLDO output (AVDD28\_TLDO) for 2.8 volts application.

The power for internal flash comes from AVDD28\_TLDO.

TCXO power is from AVDD\_TCXO\_SW that can select either from AVDD28\_TLDO (2.8V) or from AVDD28\_CLDO (1.8V) by setting up power-on strap.

RTC LDO input power comes from backup battery or uses coin battery.

Here are 3 power schemes: low power (Figure 54), low cost (Figure 55) and external PMU (Figure 56).



Figure 54. Power supply connection (low power)



Figure 55. Power supply connection (low cost)



Figure 56. Power supply connection (external LDO)



Figure 57. Power on/off sequence for external LDO mode

## 4.3 Electrical Characteristics

### 4.3.1 DC characteristics

#### 4.3.1.1 Absolute maximum ratings

| Symbol      | Parameter                     | Rating     | Unit |
|-------------|-------------------------------|------------|------|
| AVDD43_DCV  | SMPs power supply             | -0.3 ~ 4.3 | V    |
| AVDD43_VBAT | 2.8 volts TLDO power supply   | -0.3 ~ 4.3 | V    |
| AVDD28_CLDO | 1.1 volts CLDO power supply   | -0.3 ~ 3.6 | V    |
| DVDD28_SF   | Embedded flash power supply   | -0.3 ~ 3.6 | V    |
| DVDD28_IO1  | IO 2.8/1.8 volts power supply | -0.3 ~ 3.6 | V    |

|                              |                                       |             |    |
|------------------------------|---------------------------------------|-------------|----|
| DVDD28_IO2                   |                                       |             |    |
| DVDD11_CORE1<br>DVDD11_CORE2 | Baseband 1.1 volts power supply       | -0.3 ~ 1.21 | V  |
| AVDD43_RTC                   | RTC 1.1 volts LDO power supply        | -0.3 ~ 4.3  | V  |
| AVDD18_RXFE                  | 1.8 volts supply for RF core circuits | -0.3 ~ 3.6  | V  |
| AVDD18_CM                    |                                       | -0.3 ~ 3.6  | V  |
| T <sub>STG</sub>             | Storage temperature                   | -50 ~ +125  | °C |
| T <sub>A</sub>               | Operating temperature                 | -45 ~ +85   | °C |

#### 4.3.1.2 Recommended operating conditions

| Symbol                           | Parameter                                             | Min. | Typ. | Max. | Unit |
|----------------------------------|-------------------------------------------------------|------|------|------|------|
| AVDD43_DCV                       | SMPS power supply                                     | 2.8  | 3.3  | 4.3  | V    |
| AVDD43_VBAT                      | 2.8 volts TLDO power supply                           | 2.8  | 3.3  | 4.3  | V    |
| DVDD11_CORE1<br>DVDD11_CORE2     | 1.1 volts baseband core power                         | 0.99 | 1.1  | 1.21 | V    |
| DVDD28_IO1                       | 2.8 volts digital I/O power                           | 2.52 | 2.8  | 3.08 | V    |
| DVDD28_IO2                       | 1.8 volts digital I/O power                           | 1.62 | 1.8  | 1.98 | V    |
| DVDD28_SF                        | Embedded flash power supply                           | 2.7  | 2.8  | 3.6  | V    |
| AVDD18_RXFE                      | 1.35 volts supply for RF core circuits in bypass mode | 1.3  | 1.35 | 1.98 | V    |
|                                  | 1.8 volts supply for RF core circuits in LDO mode     | 1.62 | 1.8  | 3.08 | V    |
| AVDD18_CM                        | 1.35 volts supply for common RF block in bypass mode  | 1.3  | 1.35 | 1.98 | V    |
|                                  | 1.8V volts supply for common RF block in LDO mode     | 1.62 | 1.8  | 3.08 | V    |
| T <sub>A</sub><br>T <sub>j</sub> | Operating temperature                                 | -40  | 25   | 85   | °C   |
|                                  | Commercial junction operating temperature             | 0    | 25   | 115  | °C   |
|                                  | Industry junction operating temperature               | -40  | 25   | 125  | °C   |

#### 4.3.1.3 General DC characteristics

| Symbol          | Parameter                 | Condition          | Min. | Max. | Unit |
|-----------------|---------------------------|--------------------|------|------|------|
| I <sub>IL</sub> | Input low current         | No pull-up or down | -1   | 1    | uA   |
| I <sub>IH</sub> | Input high current        | No pull-up or down | -1   | 1    | uA   |
| I <sub>OZ</sub> | Tri-state leakage current |                    | -10  | 10   | uA   |

**4.3.1.4 DC electrical characteristics for 2.8 volts operation**

| Symbol          | Parameter                    | Condition                              | Min.       | Typ. | Max.       | Unit |
|-----------------|------------------------------|----------------------------------------|------------|------|------------|------|
| VDD             | Supply voltage of core power |                                        | 0.99       | 1.1  | 1.21       | V    |
| VDDIO           | Supply voltage of IO power   |                                        | 2.52       | 2.8  | 3.08       | V    |
| V <sub>IL</sub> | Input lower voltage          | LVTTL                                  | -0.3       | -    | 0.25*VDDIO | V    |
| V <sub>IH</sub> | Input high voltage           |                                        | 0.75*VDDIO | -    | VDDIO+0.3  | V    |
| V <sub>OL</sub> | Output low voltage           | VDDIO = min<br>I <sub>OL</sub> = -2 mA | -          | -    | 0.15*VDDIO | V    |
| V <sub>OH</sub> | Output high voltage          | VDDIO = min<br>I <sub>OH</sub> = -2 mA | 0.85*VDDIO | -    | -          | V    |
| R <sub>PU</sub> | Input pull-up resistance     | VDDIO = typ<br>Vinput = 0 V            | 40         | 85   | 190        | KΩ   |
| R <sub>PD</sub> | Input pull-down resistance   | VDDIO = typ<br>Vinput = 2.8 V          | 40         | 85   | 190        | KΩ   |

**4.3.1.5 DC electrical characteristics for 1.8 volts operation**

| Symbol          | Parameter                    | Condition                              | Min.       | Typ. | Max.       | Unit |
|-----------------|------------------------------|----------------------------------------|------------|------|------------|------|
| VDD             | Supply voltage of core power |                                        | 0.99       | 1.1  | 1.21       | V    |
| VDDIO           | Supply voltage of IO power   |                                        | 1.62       | 1.8  | 1.98       | V    |
| V <sub>IL</sub> | Input lower voltage          | LVTTL                                  | -0.3       | -    | 0.25*VDDIO | V    |
| V <sub>IH</sub> | Input high voltage           |                                        | 0.75*VDDIO | -    | VDDIO+0.3  | V    |
| V <sub>OL</sub> | Output low voltage           | VDDIO = min<br>I <sub>OL</sub> = -2 mA | -          | -    | 0.15*VDDIO | V    |
| V <sub>OH</sub> | Output high voltage          | VDDIO = min<br>I <sub>OH</sub> = -2 mA | 0.85*VDDIO | -    | -          | V    |
| R <sub>PU</sub> | Input pull-up resistance     | VDDIO = typ<br>Vinput = 0 V            | 70         | 150  | 320        | KΩ   |
| R <sub>PD</sub> | Input pull-down resistance   | VDDIO = typ<br>Vinput = 1.8 V          | 70         | 150  | 320        | KΩ   |

**4.3.1.6 DC electrical characteristics for 1.1 volts operation (for FORCE\_ON and 32K\_OUT)**

| Symbol | Parameter | Condition | Min. | Typ. | Max. | Unit |
|--------|-----------|-----------|------|------|------|------|
|        |           |           |      |      |      |      |

| Symbol          | Parameter                    | Condition                              | Min.       | Typ. | Max.       | Unit |
|-----------------|------------------------------|----------------------------------------|------------|------|------------|------|
| VDD             | Supply voltage of core power |                                        | 0.99       | 1.1  | 1.21       | V    |
| VDDIO           | Supply voltage of IO power   |                                        | 0.99       | 1.1  | 1.21       | V    |
| V <sub>IL</sub> | Input lower voltage          | LV TTL                                 | -0.3       | -    | 0.25*VDDIO | V    |
| V <sub>IH</sub> | Input high voltage           |                                        | 0.75*VDDIO | -    | VDDIO+0.3  | V    |
| V <sub>OL</sub> | Output low voltage           | VDDIO = min<br>I <sub>OL</sub> = -2 mA | -          | -    | 0.15*VDDIO | V    |
| V <sub>OH</sub> | Output high voltage          | VDDIO = min<br>I <sub>OH</sub> = -2 mA | 0.85*VDDIO | -    | -          | V    |
| R <sub>PU</sub> | Input pull-up resistance     | VDDIO = typ<br>Vinput = 0 V            | 130        |      | 560        | KΩ   |
| R <sub>PD</sub> | Input pull-down resistance   | VDDIO = typ<br>Vinput = 1.1 V          | 130        |      | 560        | KΩ   |

### 4.3.2 Analog related characteristics

#### 4.3.2.1 SMPS DC characteristics

| Symbol          | Parameter                 | Min. | Typ. | Max. | Unit | Note                |
|-----------------|---------------------------|------|------|------|------|---------------------|
| AVDD43_DCV      | SMPS input supply voltage | 2.8  | 3.3  | 4.3  | V    |                     |
| DCV             | SMPS output               | 1.74 | 1.84 | 1.94 | V    |                     |
| I <sub>cc</sub> | SMPS output current       | -    | -    | 100  | mA   |                     |
| ΔV_PWM          | Ripple of PWM mode        | -    | -    | 40   | mV   | With L=1uH, C=4.7uF |
| ΔV_PFM          | Ripple of PFM mode        | -    | -    | 90   | mV   | With L=1uH, C=4.7uF |

#### 4.3.2.2 TCXO LDO DC characteristics

| Symbol          | Parameter                     | Min. | Typ. | Max. | Unit | Note                                                         |
|-----------------|-------------------------------|------|------|------|------|--------------------------------------------------------------|
| AVDD43_VBAT     | TCXO LDO input supply voltage | 2.8  | 3.3  | 4.3  | V    | Will change to bypass mode under 3.1 volts                   |
| AVDD28_TLDO     | TCXO LDO output               | 2.71 | 2.8  | 2.89 | V    |                                                              |
| I <sub>cc</sub> | LDO output current            | -    | -    | 50   | mA   | Not include external devices                                 |
|                 | PSRR-30 KHz                   | 35   | -    | -    | dB   | C <sub>0</sub> = 1 uF, ESR = 0.05, I <sub>load</sub> = 25 mA |
|                 | Load regulation               | -84  | 10   | 84   | mV   |                                                              |

#### 4.3.2.3 TCXO SWITCH DC characteristics

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Note |
|--------|-----------|------|------|------|------|------|
|        |           |      |      |      |      |      |

| Symbol           | Parameter                                                    | Min. | Typ. | Max. | Unit | Note |
|------------------|--------------------------------------------------------------|------|------|------|------|------|
| AVDD_TCXO_SW     | TCXO switch output voltage @ TCXO switch input = AVDD28_TLDO | 2.66 | -    | -    | V    |      |
| AVDD_TCXO_SW     | TCXO switch output voltage @ TCXO switch input = AVDD28_CLDO | 1.71 | -    | -    | V    |      |
| I <sub>max</sub> | TCXO SWITCH current limit                                    | -    | -    | 30   | mA   |      |

#### 4.3.2.4 1.1 volts core LDO DC characteristics

| Symbol          | Parameter                          | Min. | Typ. | Max. | Unit | Note |
|-----------------|------------------------------------|------|------|------|------|------|
| AVDD28_CLDO     | 1.2 volts LDO input supply voltage | 1.62 | 1.8  | 3.08 | V    |      |
| AVDD11_CLDO     | 1.1 volts LDO output               | 1.05 | 1.12 | 1.2  | V    |      |
| I <sub>cc</sub> | LDO output current                 | -    | -    | 50   | mA   |      |
|                 | Load regulation                    | -    | -    | -    | mV   |      |

#### 4.3.2.5 1.1 volts RTC LDO DC characteristics

| Symbol            | Parameter                    | Min. | Typ. | Max. | Unit | Note                                 |
|-------------------|------------------------------|------|------|------|------|--------------------------------------|
| AVDD43_RTC        | RTC LDO input supply voltage | 2    | 4    | 4.3  | V    |                                      |
| AVDD11_RTC        | RTC LDO output               | 0.99 | 1.1  | 1.21 | V    |                                      |
| I <sub>cc</sub>   | LDO output current           | -    | -    | 3    | mA   |                                      |
| I <sub>leak</sub> | Leakage current              | 2.2  | 10   | -    | uA   | Including LDO and RTC domain circuit |

#### 4.3.2.6 32 KHz crystal oscillator (XOSC32)

| Symbol     | Parameter           | Min. | Typ. | Max. | Unit | Note |
|------------|---------------------|------|------|------|------|------|
| AVDD11_RTC | Analog power supply | 0.99 | -    | 1.21 | V    |      |
| Dcyc       | Duty cycle          | -    | 50   | -    | %    |      |

### 4.3.3 RF related characteristics

#### 4.3.3.1 DC electrical characteristics for RF part

| Symbol                        | Parameter             | Min. | Typ. | Max. | Unit |
|-------------------------------|-----------------------|------|------|------|------|
| I <sub>cc</sub> (GPS+GLONASS) | Total supply current: | -    | 8.9  | -    | mA   |

## 4.3.3.2 RX chain (GPS+GLONASS mode)

| Parameter                                     | Condition                                                                                              | Min. | Typ.   | Max. | Unit |
|-----------------------------------------------|--------------------------------------------------------------------------------------------------------|------|--------|------|------|
| RF input frequency                            |                                                                                                        | -    | 1575.4 | -    | MHz  |
| LO frequency                                  |                                                                                                        | -    | 1588.6 | --   | MHz  |
| LO leakage                                    | Measured at balun matching network input at LNA high gain                                              | -    | -70    | -    | dBM  |
| Input return loss                             | Differential input and external matched to $50\Omega$ source using balun matching network for all gain | -10  | -      | -    | dB   |
| Gain (Av)<br>(integrated average over Fc+-4M) | High current mode with max PGA gain                                                                    | 80   | 76     | 70   | dB   |
|                                               | Low current mode with max PGA gain                                                                     | -    | 64     | -    | dB   |
| PGA Gain range                                |                                                                                                        | -    | 24     | -    | dB   |
| PGA Gain step                                 |                                                                                                        | -    | 2      | -    | dB   |
| NF (integrated average over Fc+-4M)           | High current mode with max PGA gain                                                                    | -    | 2.2    | -    | dB   |

## 4.3.3.3 Crystal oscillator (XO)

| Symbol    | Parameter                  | Min. | Typ.   | Max. | Unit |
|-----------|----------------------------|------|--------|------|------|
| $F_{txo}$ | TCXO oscillation frequency | 12.6 | 16.368 | 40   | MHz  |
| $V_{txo}$ | TCXO output swing          | 0.8  | 1.2    | -    | Vpp  |

## 4.4 Interface Characteristics

## 4.4.1 JTAG interface timing

| Description                    | Symbol | Min.  | Max. | Unit | Note |
|--------------------------------|--------|-------|------|------|------|
| TDI input setup to rising TCK  | T1     | 0.35T | -    | ns   | 1    |
| TDI input hold from rising TCK | T2     | 0.15T | -    | ns   | 1    |
| TMS input setup to rising TCK  | T1     | 0.35T | -    | ns   | 1    |
| TMS input hold from rising TCK | T2     | 0.15T | -    | ns   | 1    |
| Rising TCK to TDO valid        | T3     | -     | 0.5T | ns   | 1    |
| TDO hold from rising TCK       | T4     | 0     | -    | ns   | 1    |

Note: The maximal condition of JTAG clock cycle (TCK) is 50 MHz.



Figure 58. Timing diagram of JTAG interface

#### 4.4.2 RS-232 interface timing

| Baudrate required (bps) | Programmed baudrate (bps) | Baudrate error (%) | Baudrate error (%) <sup>3</sup> |
|-------------------------|---------------------------|--------------------|---------------------------------|
| 4,800                   | 4,800.000                 | 0.0000             | 0.002                           |
| 9,600                   | 9,600.000                 | 0.0000             | 0.002                           |
| 14,400                  | 14,408.451                | 0.0587             | 0.0567                          |
| 19,200                  | 19,164.319                | 0.0587             | 0.0567                          |
| 38,400                  | 38,422.535                | 0.0587             | 0.0567                          |
| 57,600                  | 57,633.803                | 0.0587             | 0.0567                          |
| 115,200                 | 115,267.606               | 0.0587             | 0.0567                          |
| 230,400                 | 230,535.211               | 0.0587             | 0.0567                          |
| 460,800                 | 454,666.667               | -1.3310            | -1.3330                         |
| 921,600                 | 909,333.333               | -1.3310            | -1.3330                         |

Notes:

1. UART baud-rate settings with UART\_CLK frequency = 16.368 MHz (UART\_CLK uses the reference clock of the system).
2. The baudrate error is optimized. Each baudrate needs to adjust counter to obtain the optimized error.



Figure 59. Timing diagram of RS-232 interface

#### 4.4.3 SPI interface timing

| Description     | Symbol | Min.      | Max.      | Unit | Note |
|-----------------|--------|-----------|-----------|------|------|
| SCS# setup time | T1     | 0.5T      | -         | ns   | 1    |
| SCS# hold time  | T2     | 0.5T      | -         | ns   | 1    |
| SO setup time   | T3     | 0.5T - 3t | 0.5T - 2t | ns   | 1, 2 |
| SO hold time    | T4     | 0.5T + 2t | 0.5T + 3t | ns   | 1, 2 |
| SIN setup time  | T5     | 3t        | -         | ns   | 1, 2 |
| SIN hold time   | T6     | 10        | -         | ns   | 1    |

Notes:

1. The condition of SPI clock cycle (T) is (SPI\_IPLL/12) MHz ~ (rf\_clk/1,020) MHz.
2. t indicates the period of SPI controller clock, which is SPI\_IPLL clock or rf\_clk.



Figure 60. Timing diagram of SPI interface

#### 4.4.4 I2C interface timing

| Symbol | Period                        |
|--------|-------------------------------|
| T1     | (MM_CNT_PHASE_VAL0+1)TCXO_CLK |
| T2     | (MM_CNT_PHASE_VAL1+1)TCXO_CLK |
| T3     | (MM_CNT_PHASE_VAL2+1)TCXO_CLK |
| T4     | (MM_CNT_PHASE_VAL3+1)TCXO_CLK |

Note: The condition of I2C clock cycle (I2C\_CLK) is (TCXO\_CLK/4) MHz ~ (TCXO\_CLK/(MM\_CNT+4)) MHz. The MM\_CNT is sum of MM\_CNT\_PHASE\_VAL0, MM\_CNT\_PHASE\_VAL1, MM\_CNT\_PHASE\_VAL2 and MM\_CNT\_PHASE\_VAL3 in full speed mode.



Figure 61.Timing diagram of HOST I2C interface

MEDIATEK  
FOR lf.ji@coretek.cn USE ONLY