# SC6820 Device Specification

Version 1.0 HW-SC6820--DS-0001 Dec 12, 2011 D1



Spreadtrum Communications, Inc., Confidential and Proprietary



# **IMPORTANT NOTICE**

#### **COPYRIGHT NOTICE**

Copyright © 2010, Spreadtrum Communications, Inc. All rights reserved.

#### **TRADEMARKS**

Spreadtrum Communications, Inc. and Spreadtrum Communications, Inc.'s products are exclusively owned by Spreadtrum Communications, Inc. References to other companies and their products use trademarks owned by the respective companies and are for reference purpose only.

#### WARRANTY DISCLAIMER

Spreadtrum Communications, Inc. makes no representations or warranties, either express or implied, by or with respect to anything in this document, and shall not be liable for any implied warranties of merchantability or fitness for a particular purpose or for any indirect, special or consequential damages.

#### **CONFIDENTIALITY**

The information contained herein (including any attachments) is confidential. The recipient hereby acknowledges the confidentiality of this document, and except for the specific purpose, this document shall not be disclosed to any third party.



# **Revision History**

| Version | Data       | Owner      | Note                    |
|---------|------------|------------|-------------------------|
| 0.8     | 10/26/2011 | Joey Jiang | First draft;            |
| 1.0     | 12/12/2011 | Joey Jiang | Update chapter 3,4,9,10 |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |
|         |            |            |                         |



| REV | ISION | HISTORY.             |                                             | 3  |
|-----|-------|----------------------|---------------------------------------------|----|
| 1   | SYS   | TEM OVER             | RVIEW                                       | 11 |
|     | 1.1   | General              | Description                                 | 11 |
|     | 1.2   | SC6820               | Features                                    | 12 |
|     |       | 1.2.1                | General Features                            | 12 |
|     |       | 1.2.2                | Platform Features                           | 13 |
|     |       | 1.2.3                | Modem Features                              | 14 |
|     |       | 1.2.4                | Power Management Features                   | 15 |
|     |       | 1.2.5                | Multi-media Features                        | 15 |
|     | 1.3   | Application          | ons                                         | 16 |
|     | 1.4   | Chip Arc             | hitecture                                   | 18 |
| 2   | PAC   | KAGE INF             | FORMATION                                   | 19 |
|     | 2.1   | Top Mark             | king Definition                             | 19 |
|     | 2.2   | LFBGA F              | Pinout                                      | 20 |
|     | 2.3   | Package              | e Outline                                   | 21 |
|     | 2.4   | Reflow P             | Profile                                     | 23 |
| 3   | PIN   | INFORMA <sup>-</sup> | TION                                        | 24 |
|     |       | 3.1.1                | Pin symbol descriptions                     | 24 |
|     |       | 3.1.2                | Pin List                                    |    |
|     |       | 3.1.3                | Pin Multiplexed Function List               | 42 |
|     |       | 3.1.4                | Control Registers                           | 51 |
| 4   | ELE   | CTRICAL S            | SPECIFICATIONS                              | 62 |
|     | 4.1   |                      | cifications                                 |    |
|     |       | 4.1.1                | Absolute Maximum Ratings                    |    |
|     |       | 4.1.2                | Recommended Operating Conditions            |    |
|     |       | 4.1.3                | Thermal Characteristics                     |    |
|     |       | 4.1.4                | ESD Characteristics                         | 63 |
|     |       | 4.1.5                | DC Characteristics                          | 63 |
|     | 4.2   | AC Char              | acteristics                                 | 65 |
|     | 4.3   | Performa             | ance Specifications                         | 66 |
|     |       | 4.3.1                | GSM Baseband                                | 67 |
|     |       | 4.3.2                | Voice Band                                  | 68 |
|     |       | 4.3.3                | Phase-Locked Loop (PLL)                     | 75 |
|     |       | 4.3.4                | RTC Oscillator                              | 76 |
|     |       | 4.3.5                | USB 2.0 PHY                                 | 77 |
|     |       | 4.3.6                | GSM APC DAC                                 |    |
|     |       | 4.3.7                | Auxiliary Analog-to-Digital Converter (ADC) |    |
|     |       | 4.3.8                | Low Dropout Regulators                      | 78 |
|     |       | 4.3.9                | Charger                                     |    |
|     |       | 4.3.10               | DC-DC                                       | 92 |
|     |       | 4.3.11               | Audio PA                                    |    |
|     |       | 4.3.12               | LCD Backlight LED Driver                    |    |
|     |       | 4.3.13               | Keypad Backlight LED Driver                 |    |
|     |       | 4.3.14               | Vibarator                                   | 99 |



| 5 | MICF | RO-CONTROI      | LLER UNIT SUBSYSTEM          | . 100                                                                                                                                                                                                                                                                                                                            |  |  |
|---|------|-----------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|   | 5.1  | Processor       |                              | . 100                                                                                                                                                                                                                                                                                                                            |  |  |
|   | 5.2  | External Me     | emory Controller             | . 105                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.2.1           | Overview                     | . 105                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.2.2           | Features                     | . 105                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.2.3           | Signal Description           | . 107                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.2.4           | Function Description         | . 109                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.2.5           | Control Registers            | . 159                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.2.6           | Application Notes            | . 190                                                                                                                                                                                                                                                                                                                            |  |  |
|   | 5.3  | NFC             |                              | . 211                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.3.1           | Overview                     | . 211                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.3.2           | Features                     | ~                                                                                                                                                                                                                                                                                                                                |  |  |
|   |      | 5.3.3           | Signal Description           |                                                                                                                                                                                                                                                                                                                                  |  |  |
|   |      | 5.3.4           | Function Description         |                                                                                                                                                                                                                                                                                                                                  |  |  |
|   |      | 5.3.5           | Micro-Instruction            | . 217                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.3.6           | Control Registers            | . 221                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.3.7           | ECC                          |                                                                                                                                                                                                                                                                                                                                  |  |  |
|   |      | 5.3.8           | Application Notes            | . 241                                                                                                                                                                                                                                                                                                                            |  |  |
|   | 5.4  | DMA Contro      | oller                        | . 249                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.4.1           | Overview                     | . 249                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.4.2           | Features                     | . 249                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.4.3           | Function Description         | . 250                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.4.4           | DMA Logic Request Channels   | . 251                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.4.5           | Control Registers            | . 252                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.4.6           | Application Notes            | . 285                                                                                                                                                                                                                                                                                                                            |  |  |
|   | 5.5  | MCU Interru     | upt Controller               | . 285                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.5.1           | Overview                     | . 285                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.5.2           | Features                     | . 285                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.5.3           | Function Description         | . 285                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.5.4           | Interrupt Channel Assignment | . 287                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.5.5           | Control Registers            | . 105<br>. 105<br>. 107<br>. 109<br>. 159<br>. 190<br>. 211<br>. 211<br>. 212<br>. 217<br>. 221<br>. 240<br>. 241<br>. 249<br>. 249<br>. 250<br>. 251<br>. 285<br>. 285<br>. 285<br>. 285<br>. 285<br>. 285<br>. 287<br>. 297<br>. 297<br>. 297<br>. 298<br>. 298<br>. 306<br>. 306<br>. 306<br>. 307<br>. 313<br>. 313<br>. 313 |  |  |
|   |      | 5.5.6           | Application Notes            | . 297                                                                                                                                                                                                                                                                                                                            |  |  |
|   | 5.6  | AXI Bus Mo      | nitor                        | . 297                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.6.1           | Overview                     | . 297                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.6.2           | Features                     | . 297                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.6.3           | Signal Description           | . 298                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.6.4           | Function Description         | . 298                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.6.5           | Control Registers            | . 298                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.6.6           | Application Note             | . 306                                                                                                                                                                                                                                                                                                                            |  |  |
|   | 5.7  | AHB Bus Monitor |                              |                                                                                                                                                                                                                                                                                                                                  |  |  |
|   |      | 5.7.1           | Overview                     | . 306                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.7.2           | Features                     | . 306                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.7.3           | Bus Monitor Assignment       | . 307                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.7.4           | Control Registers            |                                                                                                                                                                                                                                                                                                                                  |  |  |
| 5 | 5.8  | RTC Timer.      |                              |                                                                                                                                                                                                                                                                                                                                  |  |  |
|   |      | 5.8.1           | Overview                     |                                                                                                                                                                                                                                                                                                                                  |  |  |
|   |      | 5.8.2           | Features                     | . 313                                                                                                                                                                                                                                                                                                                            |  |  |
|   |      | 5.8.3           | Signal Description           |                                                                                                                                                                                                                                                                                                                                  |  |  |
|   |      |                 |                              |                                                                                                                                                                                                                                                                                                                                  |  |  |



|   |      | 5.8.4       | Function Description | . 314 |
|---|------|-------------|----------------------|-------|
|   |      | 5.8.5       | Control Registers    | . 314 |
|   |      | 5.8.6       | Application Notes    | . 329 |
|   | 5.9  | General Pur | pose Timer           | . 330 |
|   |      | 5.9.1       | Overview             | . 330 |
|   |      | 5.9.2       | Features             | . 330 |
|   |      | 5.9.3       | Signal Description   | . 330 |
|   |      | 5.9.4       | Function Description | .330  |
|   |      | 5.9.5       | Control Registers    | . 331 |
|   |      | 5.9.6       | Application Notes    | . 340 |
|   | 5.10 | Watch       | hdog Timer           | . 341 |
|   |      | 5.10.1      | Overview             | .341  |
|   |      | 5.10.2      | Features             | . 342 |
|   |      | 5.10.3      | Signal Description   |       |
|   |      | 5.10.4      | Function Description | . 342 |
|   |      | 5.10.5      | Control Registers    | . 342 |
|   |      | 5.10.6      | Application Notes    | . 349 |
|   | 5.11 | Syste       | m Timer              | . 350 |
|   |      | 5.11.1      | Overview             | . 350 |
|   |      | 5.11.2      | Features             | . 350 |
|   |      | 5.11.3      | Signal Description   | . 350 |
|   |      | 5.11.4      | Function Description | . 350 |
|   |      | 5.11.5      | Control Registers    | . 351 |
|   |      | 5.11.6      | Application Notes    | . 353 |
|   | 5.12 | MCU         | JTAG Interface       | . 353 |
|   |      | 5.12.1      | JTAG Timing          | . 354 |
| 6 | MICR | O-CONTROL   | LER UNIT PERIPHERALS | . 355 |
|   | 6.1  | USB Device  | Interface            | . 355 |
|   |      | 6.1.1       | Overview             | . 355 |
|   |      | 6.1.2       | Features             | . 355 |
|   |      | 6.1.3       | Signal Description   | . 356 |
|   |      | 6.1.4       | Function Description |       |
|   |      | 6.1.5       | Control Registers    | . 358 |
|   |      | 6.1.6       | Application Notes    | . 411 |
|   | 6.2  | UART and I  | rDA interface        | . 413 |
|   |      | 6.2.1       | Overview             | . 413 |
|   |      | 6.2.2       | Features             | . 413 |
|   |      | 6.2.3       | Signal Description   | .414  |
|   |      | 6.2.4       | Function Description |       |
|   |      | 6.2.5       | Control Registers    |       |
|   |      | 6.2.6       | Application Notes    |       |
|   | 6.3  |             | e                    |       |
|   |      | 6.3.1       | Overview             |       |
|   |      | 6.3.2       | Features             |       |
|   |      | 6.3.3       | Signal Description   |       |
|   |      | 6.3.4       | Function Description |       |
|   |      | 6.3.5       | Control Registers    |       |
|   |      | 6.3.6       | Application Notes    |       |
|   |      |             | • •                  |       |



| 6.4  | IIS and PCM   | 1 Interface          | 452   |
|------|---------------|----------------------|-------|
|      | 6.4.1         | Overview             | 452   |
|      | 6.4.2         | Features             | 452   |
|      | 6.4.3         | Signal Description   | 452   |
|      | 6.4.4         | Function Description | 453   |
|      | 6.4.5         | Control Registers    | 458   |
|      | 6.4.6         | Application Notes    | 471   |
| 6.5  | I2C Interface | 9                    | 472   |
|      | 6.5.1         | Overview             | 472   |
|      | 6.5.2         | Features             | 472   |
|      | 6.5.3         | Signal Description   | . 473 |
|      | 6.5.4         | Function Description | 473   |
|      | 6.5.5         | Control Registers    | 475   |
|      | 6.5.6         | Application Notes    |       |
| 6.6  | Keypad Inter  | rface                | 480   |
|      | 6.6.1         | Overview             | 480   |
|      | 6.6.2         | Features             | 481   |
|      | 6.6.3         | Signal Description   | 481   |
|      | 6.6.4         | Function Description |       |
|      | 6.6.5         | Control Registers    | 483   |
|      | 6.6.6         | Application Notes    | 498   |
|      | 6.6.7         | Clock enable         | 498   |
|      | 6.6.8         | KPD configuration    | 498   |
| 6.7  | Pulse Width   | Modulation(PWM)      |       |
|      | 6.7.1         | Overview             | 498   |
|      | 6.7.2         | Features             | 498   |
|      | 6.7.3         | Signal Description   | 498   |
|      | 6.7.4         | Function Description |       |
|      | 6.7.5         | Control Registers    | 500   |
|      | 6.7.6         | Application Notes    | 503   |
| 6.8  | GPIO          |                      | 504   |
|      | 6.8.1         | Overview             | 504   |
|      | 6.8.2         | Features             | 504   |
|      | 6.8.3         | Function Description | 505   |
|      | 6.8.4         | Control Registers    | 505   |
|      | 6.8.5         | Application Notes    | 512   |
| 6.9  | EIC           |                      |       |
|      | 6.9.1         | Overview             | 512   |
|      | 6.9.2         | Features             | 513   |
|      | 6.9.3         | Function Description | 513   |
|      | 6.9.4         | Control Registers    |       |
|      | 6.9.5         | Application Notes    | 532   |
| 6.10 | Auxilia       | ary ADC              | 532   |
|      | 6.10.1        | Overview             |       |
|      | 6.10.2        | Features             | 533   |
|      | 6.10.3        | Signal Description   | 533   |
|      | 6.10.4        | Function Description |       |
|      | 6.10.5        | Control Registers    |       |
|      |               |                      |       |



|       | 6.10.6      | Application Notes         | . 540 |
|-------|-------------|---------------------------|-------|
| 6.11  | Touch       | n Pannel Controller (TPC) | . 541 |
|       | 6.11.1      | Overview                  | . 541 |
|       | 6.11.2      | Features                  | . 541 |
|       | 6.11.3      | Signal Description        | . 542 |
|       | 6.11.4      | Function Description      | . 542 |
|       | 6.11.5      | Control Registers         | . 545 |
|       | 6.11.6      | Application Notes         | . 555 |
| 6.12  | SIM (       | Card Interface            | 556   |
|       | 6.12.1      | Overview                  | . 556 |
|       | 6.12.2      | Features                  | 556   |
|       | 6.12.3      | Signal Description        | .557  |
|       | 6.12.4      | Function Description      | . 558 |
|       | 6.12.5      | Control Registers         |       |
|       | 6.12.6      | Application Notes         | . 575 |
| 6.13  | SDIO        | Host Controller           | . 576 |
|       | 6.13.1      | Overview                  |       |
|       | 6.13.2      | Features                  | . 576 |
|       | 6.13.3      | Signal Description        | . 576 |
|       | 6.13.4      | Function Description      |       |
|       | 6.13.5      | Control Registers         | . 578 |
| 6.14  | SDIO        | slave Controller          | 606   |
|       | 6.14.1      | Overview                  | 606   |
|       | 6.14.2      | Features                  | 606   |
|       | 6.14.3      | Signal Description        | . 607 |
|       | 6.14.4      | Function Description      | . 607 |
|       | 6.14.5      | Control Registers         | 614   |
|       | 6.14.6      | Application Notes         | 642   |
| 6.15  | Efuse       |                           | 644   |
|       | 6.15.1      | Overview                  | . 644 |
|       | 6.15.2      | Features                  |       |
|       | 6.15.3      | Signal Description        | . 645 |
|       | 6.15.4      | Function Description      | 645   |
|       | 6.15.5      | Control Registers         | 646   |
|       | 6.15.6      | Application Notes         | 657   |
| MUL,1 | ΓΙ-MEDIA SU | BSYSTEM                   | . 663 |
| 7.1   | Dcam        |                           | 663   |
|       | 7.1.1       | Overview                  | 663   |
|       | 7.1.2       | Features                  | 663   |
|       | 7.1.3       | Signal Description        | . 664 |
|       | 7.1.4       | Function Description      | 669   |
|       | 7.1.5       | Control Registers         | 674   |
|       | 7.1.6       | Application Notes         | .719  |
| 7.2   | Rotation    |                           | . 726 |
|       | 7.2.1       | Overview                  | .726  |
|       | 7.2.2       | Features                  | . 726 |
|       | 7.2.3       | Signal Description        | . 726 |
|       | 7.2.4       | Function Description      | . 727 |



|   |       | 7.2.5    | Control Registers                 | 730 |
|---|-------|----------|-----------------------------------|-----|
|   |       | 7.2.6    | Application Notes                 | 743 |
|   | 7.3   | LCDC     |                                   | 743 |
|   |       | 7.3.1    | Overview                          | 743 |
|   |       | 7.3.2    | Features                          | 743 |
|   |       | 7.3.3    | Signal Description                | 746 |
|   |       | 7.3.4    | Function Description              |     |
|   |       | 7.3.5    | Control Registers                 | 756 |
|   |       | 7.3.6    | Application Notes                 |     |
|   | 7.4   | Graphics |                                   |     |
|   |       | 7.4.1    | Overview                          |     |
|   |       | 7.4.2    | Pixel processor features          | 801 |
|   |       | 7.4.3    | Geometry processor features       |     |
|   |       | 7.4.4    | Level 2 cache controller features |     |
|   |       | 7.4.5    | MMU                               |     |
|   |       | 7.4.6    | PMU                               |     |
|   | ALIDI |          | EM                                |     |
| 8 | 8.1   |          | EW                                |     |
|   | 8.2   |          |                                   |     |
|   | _     |          | c Path Details                    |     |
|   | 8.3   | 8.3.1    | ADC Path                          |     |
|   |       |          |                                   |     |
|   |       | 8.3.2    | DAC Path                          |     |
|   |       | 8.3.3    | Analog Line-in Path               |     |
|   |       | 8.3.4    | Mixer Path                        |     |
|   | 0.4   | 8.3.5    | Output Branch Description         |     |
|   | 8.4   |          | nterface                          |     |
|   |       | 8.4.1    | General Features                  |     |
|   |       | 8.4.2    | DSP Mode Timing                   |     |
|   | 0.5   | 8.4.3    | I2S Mode Timing                   |     |
|   | 8.5   |          | ce                                |     |
|   |       | 8.5.1    | Overview                          |     |
|   |       | 8.5.2    | Features                          |     |
|   |       | 8.5.3    | Signal Description                |     |
|   |       | 8.5.4    | Function Description              |     |
|   |       | 8.5.5    | Control Registers                 |     |
|   | 8.6   |          | c Control Registers               |     |
|   |       | 8.6.1    | VB_AICR                           |     |
|   |       | 8.6.2    | VB_CR1                            |     |
|   |       | 8.6.3    | VB_CR2                            |     |
|   |       | 8.6.4    | VB_CCR1                           |     |
|   |       | 8.6.5    | VB_CCR2                           |     |
|   |       | 8.6.6    | VB_PMR1                           |     |
|   |       | 8.6.7    | VB_PMR2                           |     |
| • |       | 8.6.8    | VB_CRR                            |     |
|   |       | 8.6.9    | VB_ICR                            |     |
|   |       | 8.6.10   | VB_IFR                            |     |
|   |       | 8.6.11   | VB_CGR1                           |     |
|   |       | 8.6.12   | VB_CGR2                           | 904 |



|     |       | 8.6.13       | VB_CGR3                          | 905  |
|-----|-------|--------------|----------------------------------|------|
|     |       | 8.6.14       | VB_CGR8                          | 906  |
|     |       | 8.6.15       | VB_CGR9                          | 907  |
|     |       | 8.6.16       | VB_CGR10                         | 908  |
|     |       | 8.6.17       | VB_TR1                           | 909  |
|     |       | 8.6.18       | VB_TR2                           | 911  |
|     | 8.7   | Application  | Note                             | 912  |
|     |       | 8.7.1        | ARM Control Mode                 | 912  |
|     |       | 8.7.2        | DSP Control Mode                 | 913  |
|     |       | 8.7.3        | DMA Controlling Mode             | 914  |
| 9   | POW   | ER MANAGI    | EMENT                            | 917  |
|     | 9.1   | Overview     |                                  | 917  |
|     | 9.2   | LDO and D    | C-DC                             | 919  |
|     | 9.3   | Charger      |                                  | 938  |
|     |       | 9.3.1        | Charging Process                 | 939  |
|     |       | 9.3.2        | Programming Charge Current       | 940  |
|     |       | 9.3.3        | Charge Standby                   |      |
|     |       | 9.3.4        | Recharge Control                 | 940  |
|     |       | 9.3.5        | Software Over Current Protection | 940  |
|     | 9.4   | LCD Backli   | ght LED Driver                   | 940  |
|     | 9.5   | Keypad Bad   | cklight LED Driver               | 942  |
|     | 9.6   | Vibrator Dri | ver                              | 943  |
|     | 9.7   | UVLO         |                                  | 945  |
|     | 9.8   | OTP          |                                  | 947  |
|     | 9.9   | Band-Gap     |                                  | 947  |
|     | 9.10  | Powe         | er Control                       | 947  |
|     |       | 9.10.1       | Power on Procedure               | 947  |
|     |       | 9.10.2       | Power on Sequence                | 950  |
|     |       | 9.10.3       | Reset sequence                   | 951  |
|     |       | 9.10.4       | Clock stable sequence            | 952  |
| 10  | ANAL  | OG CONTR     | OL REGISTERS                     | 953  |
|     | 10.1  | Globa        | al Register                      | 953  |
|     |       | 10.1.1 ARM   | l Side                           | 953  |
| APP | ENDIX |              |                                  | 1007 |
|     |       |              | breviations                      |      |
|     |       |              |                                  |      |



# 1 System Overview

SC6820 is a GSM/GPRS/EDGE baseband (BB) chip for mobile devices, and it also integrated a lot of multimedia accelerators and 3D graphic engine to develop rich multimedia applications. This document specifies the functions and features of SC6820.

# 1.1 General Description

SC6820 is a highly integrated mixed signal baseband processor for GSM/GPRS/EDGE applications. It consists with support of specially optimized architecture and many dedicate accelerators. SC6820 can achieve high performance and low power for a lot of applications. Proprietary architectures and algorithms were developed for low power ASIC design and power management. Unique techniques are used for noise/offset calibration and cancellation. Overall, SC6820 presents a revolutionary platform for mobile devices.

#### **Platform**

SC6820 is capable of running the ARM<sup>®</sup> Cortex A5<sup>TM</sup> 32-bit RISC processor at up to 1GHz, thus providing fast data processing capabilities. The high clock frequency, separate code and data caches are included to improve the overall system efficiency.

For large amount of data transfer, high performance DMA (Direct Memory Access) with hardware flow control is implemented, which greatly enhance the data movement efficiency with reducing MCU and DSP processing load.

Targeted as a high performance platform for mobile applications, Unique ID (UID) and secure boot are also provided to prevent unauthorized porting of the software load and fulfill other applications.

#### **External Memory**

SC6820 supports mobile DDR/SDR-SDRAM, Nand flash. The external memory interface is designed for 1.8V I/O voltage. The driving strength is configurable for signal integrity adjustment.

#### Multi-media

SC6820 integrated digital still camera processor, H.264 decoder and MPEG4/H.263/JPEG codec engines. The multi-media subsystem provides a connection to up to 2 CMOS image sensors. With its high performance application platform.

SC6820 utilizes high resolution DAC, digital audio, and audio synthesis technology to provide superior audio features for all future multi-media needs.

Furthermore, a dedicated LCDC controller enables MCU interface to 8/9/16/18/24 bit LCM panels, which provides much better configurability for multi-media products.

#### Peripherals and connectivity interface

SC6820 incorporates myriads of advanced peripherals for different applications. It supports 3 UART, 2 IIS/PCM, 2 SPI, Keypad controller, 2 SIM controller, 4 PWM, 4 I<sup>2</sup>C, USB2.0, 2 SDIO, Touch Panel controller, and General Purpose Programmable I/Os(GPIO). These interfaces provide SC6820 users with the highest degree of flexibility in implementing solutions suitable for the targeted application.



#### **Radio**

SC6820 integrates a mixed-signal baseband front-end in order to provide a well-organized radio interface with flexibility for efficient customization. The front-end contains gain and offset calibration mechanisms, and filters with programmable coefficients for comprehensive compatibility control on RF modules.

The RF interface also consists of the following parts:

- An RF power amplifier control, which controls the timing of an RF power amplifier ON/OFF as well as its output power.
- An RF serial port, which is used to program control registers inside the RF module.
- RF parallel controls, which form a group of control signals to control the ON/OFF of the RF active components and passive couplers/switches.

#### <u>Audio</u>

SC6820 audio interface integrates D/A and A/D converters for Voice band, it also provides stereo input and analog MUX.

#### **Power Management**

With 2 DCDC and 22 LDO on chip ,SC6820 offers various low-power features to help reduce system power consumption. These features include deep sleep(standby mode), ARM system sleep, DSP system sleep, ARM processor sleep mode, DSP processor sleep mode, power down mode for individual peripheral etc. The advanced low leakage CMOS process which SC6820 adopted provide and overall low leakage solution.

#### **Package**

SC6820 is offered in a 13 mm x 13 mm x 1.4 mm 454 ball, 0.5 mm ball pitch LFBGA package

#### 1.2 SC6820 Features

SC6820 is Spreadtrum's 3rd-generation GSM/GPRS/EDGE ASIC solution chip. It inherits most of the features from SC6820 series with performance improvement and feature enhancement.

## 1.2.1 General Features

- With ARM® Cortex<sup>™</sup> A5 @ 1GHz, 32 bits DDR @ 400MHz, embedded Graphics and multimedia accelerators. The overall system performance of processor, graphics engine, DDR interface have been well organized, so SC6820 completes the AP requirements of prevalent Android phone
- mixed signal baseband processor for GSM/GPRS/EDGE applications
- Low power and high-performance device of mixed signal CMOS technology
- External supply voltages: battery 3.6V(typical),optional backup battery 3.0V(typical)
- Internal supply voltages: analog 3.0V or 3.3V, digital I/O 2.85V or 1.8V(typical), digital core 1.1V(typical) and RTC power supply 1.8V(typical)
- Integrated power management, voice band, audio band, and base band analog front ends



#### 1.2.2 Platform Features

#### **MCU** subsystem

- ARM® Cortex<sup>TM</sup> A5 32-bit RISC processor, up to 1G Hz
- 32 KB L1 I-cache and 32 KB L1 D-cache
- 256KB L2 Cache
- 32 KB dedicate on-chip SRAM
- 10 KB on-chip SRAM shared with DCAM (Digital Camera module)
- High performance multi-layer AHB-Lite bus system and low power APB system
- 24KB on-chip ROM for laboratory or factory programming and system boot
- Support boot from NAND, USB or UART
- Support memory re-mapping mechanism
- Dedicate DMA with 32 logical request channels
- Two general purpose RTC timers for task schedule and system timing recording
- One system timer with 1 ms counting scale
- Watchdog timer for system crash recovery
- 4 bus monitors for MCU system debug or performance analysis
- JTAG port for in-circuit emulation
- Support UID and secure boot

#### Note:

 ARM® Cortex<sup>™</sup> A5is a registered trademark of Advanced RISC Machines Limited.

#### **Graphics subsystem**

Integrate Mali-300 GPU, a hardware accelerator for 2D and 3D graphics systems, consisits of

- A Pixel Processor (PP)
- a Geometry Processor(GP)
- a Level 2 Cache Controller(L2)
- a Memory Management Unit (MMU) for each GP and PP included in the GPU

#### **External memory interface**

- Support NAND flash, mobile DDR/SDR-SDRAM
- Two external memory controllers: NAND controller and External Memory Controller (EMC), supporting the following memory combinations:
  - ; NAND + DDR/SDR-SDRAM
- NAND flash is supported by NAND controller, with the following features:
  - ; Support 8 bit and 16 bit devices
  - ; Support 1.8 V and 3.0 V devices
  - ; Support hardware ECC generation up to 24 bits
  - i Support small page (512 bytes) and large page (up to 8K bytes)
  - For small page device, support 4 consecutive memory read/write, and for large page, only support single page operation



- SDR/DDR SDRAM are supported by External Memory Controller, with the features list below:
  - Support only 1.8 V devices
  - ; Support up to 2G bits with single CS
  - ; SDRAM support 16 bit and 32 bit devices
  - Support up to 2 chip select channels (2 CS)
  - Support up to 512M byte devices
  - Memory clock is optional to clk\_emc/2 or clk\_emc/4 (clk\_emc is the EMC controller clock, up to 400 MHz)

#### Peripheral and connectivity interfaces

- Support 4 SIM cards and both 1.8 V or 3.0 V devices
- Support SDIO 2.0
- Support USB 2.0 High speed
- Three UARTs
- Two SPI, support both master and slave, support 3-wire SPI, 4-wire SPI and synchronous SPI
- Two IIS and PCM, for audio codec connection
- Support 8-column x 8-row keypad with internal pull-up resistors
- Four I2C interface
- More than 100 GPIO pins
- Four PWM outputs
- Four 10-bit ADC input
- ETM port

#### 1.2.3 Modem Features

#### Implementation

- Signal processing for modem functions is mainly implemented in CEVA DSP sub-system
- System timing
  - For GSM/GPRS/EDGE, recommend use a low swing 26 MHz master clock input.
  - Time tracking in power saving mode
- 16 general RFCTL wires for RF chip or antenna control
- 1 dedicate SPI ports for BB-RF chip communication
- 10-bit D/A converter with programmable gain

#### Note:

• CEVAX® is a registered trademark of CEVA, Inc.

#### **GSM/GPRS/EDGE** baseband

- Compatible with GSM/GPRS/EDGE Release 1999, GSM850,GSM900, DCS1800, and PCS1900 recommendations
- Complete in-phase and quadrature (I/Q) component interface between the Digital Signal Processor (DSP) and RF module
- EGPRS class12, typeB (MCS1-9 in downlink and MCS1-9 in uplink)



Cryptographic Algorithms: (A5/1, A5/2 and A5/3, GEA 1, GEA 2 and GEA3 algorithms)

#### Voice and modem codec

- Audio signal conversion between microphone/earphone and DSP
- · Second set converters for auxiliary microphone/speaker
- Stereo audio output
- Integrated microphone bias
- Integrated Class A/B or Class D
- Quad vocoders for adaptive multi-rate (AMR), enhanced full rate (EFR), half rate(HR), and full rate (FR)
- Dial tone generation
- Voice memo
- Noise reduction
- Echo suppression/echo cancellation
- Digital sidetone generator with programmable gain
- Voice power amplifier with programmable gain

## 1.2.4 Power Management Features

- Integrated two DC-DC and 25 low dropout regulators (LDOs), supplying power for internal chip or external devices. All such DC-DC and LDOs can be powered down and up with software management.
- Support standby mode with small deep-sleep current
- Integrated Li-ion battery charger, support charging from USB or external adaptor. The charger voltage can be measured with auxiliary ADC.

## 1.2.5 Multi-media Features

#### **LCD** display

- Integrated LCD controller (LCDC), support 2 chip select: LCD\_CS0 and LCD\_CS1
- Support MCU interface
- Support dual display panels: use LCD\_CS1 to connect sub-panel, and LCD\_CS0 to connect main display panel
- Support 8/9/16/18/24 bit LCM interfaces
- Support LCM format RGB565 and RGB666 and RGB888
- Typical image sizes: QCIF, QVGA,WQVGA, CIF, VGA,WVGA, FWVGA
- Support hardware display rotation

#### Image signal processor

- Support image sensor sizes up to 5M pixels
- Support image sensor data YUV422 format and JPEG format
- Support scaling down/up function, scaling factor from 1/4 to 2
- Support hardware rotation
- Support JPEG decoder baseline profile, as defined in ISO/IEC 10918-1, with sizes up to 8M pixels, and color format YUV444, YUV422/YUV422R, YUV420, YUV411 /YUV411R or gray scale.



- Support JPEG encoder baseline profile, as defined in ISO/IEC 10918-1, with sizes up to 8M pixels, and color format YUV422 or YUV420
- Support PNG,GIF decoder

#### Video codec

- Support H264 decoder compliant with ITU-T H.264 baseline profile, D1 30 fps
- Support H263 decoder, compliant with ITU H.263 profile 0. D1 30fps.
- Support H263 encoder compliant with ITU H.263 baseline profile CIF 30fps
- Support MPEG4 decoder compliant with ISO/IEC 14496-2 (MPEG4 Part 2 2001) @ simple profile, D1 30 fps
- Support MPEG4 encoder compliant with ISO/IEC 14496-2 (MPEG4 Part 2 2001) @ simple profile, D1 15fps

#### **Audio codec**

- Wavetable synthesis up to 64 tones
- Support AAC/AAC+ decoding,
- PCM record and playback
- Digital audio playback
- MPEG1 audio layer3, MPEG2 low sampling rate extension layer3, MPEG 2.5 layer3
- MIDI
- AMR-NB
- DRA
- WMA

# 1.3 Applications

SC6820 provides a single-chip baseband solution for GSM/GPRS/EDGE dual-mode wireless telephone handsets and data modems conforming to the GSM/GPRS (Release 1999, GSM850, GSM900, DCS1800 and PCS1900, quad-band).





Figure 1-1 A typical application diagram of SC6820



# 1.4 Chip Architecture

Figure 1-2 shows the chip-level functional block diagram of SC6820. This chip architecture is based on two processor subsystems, an MCU and a DSP, and other functional blocks are connected to one or both of the buses and provide various hardware accelerations and interfaces to other components in the system.



Figure 1-2 SC6820 chip-level functional block diagram



# 2 Package Information

Plastic-encapsulated surface mount packages are sensitive to damage induced by absorbed moisture and temperature. ALL the SC6820 chips are MSL 3, which had been marked on the label for every package.

# 2.1 Top Marking Definition



Figure 2-1 Top marking definition



## 2.2 LFBGA Pinout



Figure 2-2 454-ball LFBGA pinout



# 2.3 Package Outline



Figure 2-3 Package outline



|                             | SYMBOL | COMN | MON DIMENS | SIONS |
|-----------------------------|--------|------|------------|-------|
|                             |        | MIN. | NOR.       | MAX.  |
| TOTAL THICKNESS             | Α      |      |            | 1.3   |
| STAND OFF                   | A1     | 0.16 |            | 0.26  |
| SUBSTRATE THICKNESS         | A2     |      | 0.26       | REF   |
| MOLD THICKNESS              | А3     |      | 0.7        | REF   |
| BODY SIZE                   | D      |      | 13         | BSC   |
| BODT SIZE                   | E      |      | 13         | BSC   |
| BALL DIAMETER               |        |      | 0.3        |       |
| BALL OPENING                |        |      | 0.275      |       |
| BALL WIDTH                  | Ь      | 0.27 |            | 0.37  |
| BALL PITCH                  | е      |      | 0.5        | BSC   |
| BALL COUNT                  | n      |      | 454        |       |
| EDGE BALL CENTER TO CENTER  | D1     |      | 12         | BSC   |
| EDGE BALL CENTER TO CENTER  | E1     |      | 12         | BSC   |
| BODY CENTER TO CONTACT BALL | SD     |      |            | BSC   |
| BODT CENTER TO CONTACT BALL | SE     |      |            | BSC   |
| PACKAGE EDGE TOLERANCE      | aaa    |      | 0.1        |       |
| MOLD FLATNESS               | bbb    |      | 0.2        |       |
| COPLANARITY                 | ddd    |      | 0.08       |       |
| BALL OFFSET (PACKAGE)       | eee    |      | 0.15       |       |
| BALL OFFSET (BALL)          | fff    |      | 0.08       |       |
|                             |        |      |            |       |
| <b>^</b>                    |        |      |            |       |
|                             |        |      |            |       |
|                             |        |      |            |       |
|                             |        |      |            |       |
|                             |        |      |            |       |

Figure 2-4 Package parameters



## 2.4 Reflow Profile



Figure 2-5 Reflow profile

#### Note:

- 1. Recommended reflow profile for lead-free solder paste
  - ; Ramp at 1-2°C per second to 245+/-5°C
  - ; Dwell at 235°C for 10 seconds
  - ; Dwell at 217°C for 30~60s
  - : Total reflow time is about 220~270 s
  - : Cold down ramp < 4°C/s
- 2. Recommended solder paste type
  - ; SnAgCu solder paste
  - Metal contents should be about 88.5%
- 3. Recommended parameter for stencil making
  - Metal mask thickness: 5 mils
  - Opening area ratio: 100%



# **3 Pin Information**

# 3.1.1 Pin symbol descriptions

The following table explains the symbols used in the pin lists.

Table 3-1 Definition of pin symbols

| Field        | Symbol                    | Type Description                                                                                         |  |  |  |  |
|--------------|---------------------------|----------------------------------------------------------------------------------------------------------|--|--|--|--|
|              | I                         | Digital input                                                                                            |  |  |  |  |
|              | 0                         | Digital output                                                                                           |  |  |  |  |
|              | O/T                       | Digital output with tri-state option                                                                     |  |  |  |  |
|              | I/O                       | Digital bi-directional pin                                                                               |  |  |  |  |
|              | I/O/T                     | Digital bi-directional pin with tri-state option                                                         |  |  |  |  |
| Pin          | PI                        | Power pin, input from external power supply                                                              |  |  |  |  |
| Туре         | PIO                       | Power pin, input from external or floating to use internal LDO power supply                              |  |  |  |  |
|              | PO                        | Power pin, output for external devices                                                                   |  |  |  |  |
|              | G                         | Ground pin                                                                                               |  |  |  |  |
|              | Al                        | Analog input pin                                                                                         |  |  |  |  |
|              | AO                        | Analog output pin                                                                                        |  |  |  |  |
|              | AIO                       | Analog bi-directional pin                                                                                |  |  |  |  |
|              | IPU                       | Input with pull-up                                                                                       |  |  |  |  |
|              | IPD                       | Input with pull-down                                                                                     |  |  |  |  |
| Pin<br>Value | ОН                        | Output "1"                                                                                               |  |  |  |  |
|              | OL                        | Output "O"                                                                                               |  |  |  |  |
|              | Z                         | Tri-state                                                                                                |  |  |  |  |
|              | VBAT                      | Battery power supply input                                                                               |  |  |  |  |
|              | VDD_D<br>/VDD1P2          | Power supply for core and ARM, the internal power source are DCDC for CORE and DCDC for ARM              |  |  |  |  |
|              | VIO<br>/VIO_1<br>/VIO_2   | Power supply for I/O, the internal power source is VDD18 or VDD28                                        |  |  |  |  |
| Power        | VMEM                      | Power supply for SRAM/SDRAM memories, the internal power source is VDDMEM                                |  |  |  |  |
|              | VCAM                      | Power supply for Digital Camera, the internal power source is VDDCARM0 or VDDCARM1 or VDDCARMA           |  |  |  |  |
|              | VNF                       | Power supply for NAND flash and LCM, the internal power source is VDD28 or VDD18                         |  |  |  |  |
|              | VSIM0<br>/VSIM1<br>/VSIM2 | Power supply for SIM card 0 1 2 3, the internal power source are LDO_SIM0 LDO_SIM1 LDO_SIM2 and LDO_SIM3 |  |  |  |  |



| Field | Symbol              | Type Description                                                         |
|-------|---------------------|--------------------------------------------------------------------------|
|       | /VSIM3              |                                                                          |
|       | VDDRF0<br>/VDDRF1   | Power supply for RF , the internal power source are VDDRF0/VDDRF1        |
|       | VDDRTC              | Power supply for RTC                                                     |
|       | VDDUSB              | Power supply for USB                                                     |
|       | VDD25               | Power supply for PLL and Efuse                                           |
|       | VSD                 | Power supply for SD card , the internal power source is VDDSD0 or VDDSD1 |
|       | AVDDBB              | Analog base-band RX/TX power supply, the internal power source is AVDDBB |
|       | AVDDVB              | Analog voice-band power supply , the internal power source is AVDDVB     |
|       | VDDWIF0<br>/VDDWIF1 | Power supply for external Wif or other application                       |
|       | VDD_A               | Supply for 26MHz buffer and pLL                                          |

## **3.1.2 Pin List**

## Table 3-2 Pin List

| Ball   | Pin Type                         | Pin Name  | Default<br>Direction | Power | At Reset         | After Reset   | Descrption                    |  |  |
|--------|----------------------------------|-----------|----------------------|-------|------------------|---------------|-------------------------------|--|--|
| Clock  | Clock & Reset Interface (3 Pins) |           |                      |       |                  |               |                               |  |  |
| C9     | SPBC2_24X                        | XTL_EN    | 0                    | VIO_2 | le=0,<br>oe=1, 1 | ie=0, oe=1, 1 | External<br>Crystal<br>Enable |  |  |
| P8     | SPBC2_24X_S                      | CHIP_RSTN | I                    | VIO   | le=1,<br>oe=0    | le=1, oe=0    |                               |  |  |
| M6     | SPSOS2_24X_H                     | PBINT     | I                    | VIO   | le=1,<br>oe=0    | le=1, oe=0    |                               |  |  |
| Produ  | ction Test Interface (1 I        | Pins)     |                      |       |                  |               |                               |  |  |
| J9     | SPPAD3_S                         | PRODT     |                      | VIO   |                  |               |                               |  |  |
| GPIO I | Interface (10 Pins)              |           | <u>'</u>             |       | <u>'</u>         |               |                               |  |  |
| U13    | SPBC2_24X                        | GPIO135   | I/O                  | VIO_1 | le=0,<br>oe=1, 0 | ie=1, oe=0    |                               |  |  |
| V14    | SPBC2_24X                        | GPIO136   | I/O                  | VIO_1 | ie=0,<br>oe=1, 0 | ie=1, oe=0    |                               |  |  |
| U14    | SPBC2_24X                        | GPIO137   | I/O                  | VIO_1 | ie=0,<br>oe=1, 0 | ie=1, oe=0    |                               |  |  |
| U12    | SPBC2_24X                        | GPIO138   | I/O                  | VIO_1 | ie=0,<br>oe=1, 0 | ie=1, oe=0    |                               |  |  |
| V13    | SPBC2_24X                        | GPIO139   | I/O                  | VIO_1 | ie=0,<br>oe=1, 0 | ie=1, oe=0    |                               |  |  |
| U8     | SPBC2_24X                        | GPIO140   | I/O                  | VIO_1 | ie=0,            | ie=1, oe=0    |                               |  |  |



| Ball | Pin Type           | Pin Name | Default<br>Direction | Power | At Reset              | After Reset     | Descrption |
|------|--------------------|----------|----------------------|-------|-----------------------|-----------------|------------|
|      |                    |          |                      |       | oe=1, 0               |                 |            |
| A19  | SPBC2_24X          | GPIO141  | I/O                  | VIO_2 | ie=0,<br>oe=1, 0      | ie=1, oe=0      |            |
| B19  | SPBC2_24X          | GPIO142  | I/O                  | VIO_2 | ie=0,<br>oe=1, 0      | ie=1, oe=0      | • (        |
| F11  | SPBC2_24X          | GPIO143  | I/O                  | VIO_2 | ie=0,<br>oe=1, 0      | ie=1, oe=0      | X          |
| E11  | SPBC2_24X          | GPIO144  | I/O                  | VIO_2 | ie=0,<br>oe=1, 0      | ie=1, oe=0      |            |
| SIM0 | Interface (3 Pins) |          |                      | •     |                       |                 |            |
| AD4  | SPCBC2_24X         | SIMCLK0  | 0                    | VSIM0 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| AD3  | SPSBC2_24X         | SIMDA0   | I/O/T                | VSIM0 | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| AC4  | SPCBC2_24X         | SIMRST0  | 0                    | VSIM0 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| SIM1 | Interface (3 Pins) |          |                      |       |                       |                 |            |
| AD5  | SPCBC2_24X         | SIMCLK1  | 0                    | VSIM1 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| AD6  | SPSBC2_24X         | SIMDA1   | I/O/T                | VSIM1 | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| AC5  | SPCBC2_24X         | SIMRST1  | 0                    | VSIM1 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| SIM2 | Interface (3 Pins) |          |                      |       |                       |                 |            |
| AA3  | SPCBC2_24X         | SIMCLK2  | 0                    | VSIM2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| W3   | SPSBC2_24X         | SIMDA2   | I/O/T                | VSIM2 | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| Y3   | SPCBC2_24X         | SIMRST2  | 0                    | VSIM2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| SIM3 | Interface (3 Pins) |          |                      |       |                       |                 |            |
| W5   | SPCBC2_24X         | SIMCLK3  | 0                    | VSIM3 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| AA5  | SPSBC2_24X         | SIMDA3   | I/O/T                | VSIM3 | ie=1,<br>oe=0,        | ie=1, oe=0, wpu |            |
| Y5   | SPCBC2_24X         | SIMRST3  | 0                    | VSIM3 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| SDIO | Interface (7 Pins) |          |                      |       | 1 3321, 0             |                 |            |
| AC15 | SPCBC2_24X         | SD0_CLK  | I/O/T                | VSD   | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| AD15 | SPCBC2_24X         | SD_CMD   | I/O/T                | VSD   | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| Y15  | SPCBC2_24X         | SD_D[0]  | I/O/T                | VSD   | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
|      |                    | l        | L                    | l     |                       | <u> </u>        | 1          |



| Ball  | Pin Type              | Pin Name  | Default<br>Direction | Power | At Reset              | After Reset     | Descrption |
|-------|-----------------------|-----------|----------------------|-------|-----------------------|-----------------|------------|
| AC16  | SPCBC2_24X            | SD_D[1]   | I/O/T                | VSD   | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| AA15  | SPCBC2_24X            | SD_D[2]   | I/O/T                | VSD   | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| AA16  | SPCBC2_24X            | SD_D[3]   | I/O/T                | VSD   | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| AC17  | SPCBC2_24X            | SD1_CLK   | I/O/T                | VSD   | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| SDIO2 | Interface (6 Pins)    |           |                      |       |                       |                 |            |
| Y16   | SPCBC2_24X            | SD2_CLK   | I/O/T                | VSD2  | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| AD18  | SPCBC2_24X            | SD2_CMD   | I/O/T                | VSD2  | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| AC18  | SPCBC2_24X            | SD2_D[0]  | I/O/T                | VSD2  | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| Y17   | SPCBC2_24X            | SD2_D[1]  | I/O/T                | VSD2  | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| AD17  | SPCBC2_24X            | SD2_D[2]  | I/O/T                | VSD2  | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| AA18  | SPCBC2_24X            | SD2_D[3]  | I/O/T                | VSD2  | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| Keypa | d Interface (16 Pins) |           |                      |       |                       |                 |            |
| Y8    | SPCBC2_24X            | KEYOUT[0] | O/T                  | VIO_1 | ie= oe=0              | ie= oe=0        |            |
| AA6   | SPCBC2_24X            | KEYOUT[1] | O/T                  | VIO_1 | ie= oe=0              | ie= oe=0        |            |
| W6    | SPCBC2_24X            | KEYOUT[2] | O/T                  | VIO_1 | ie= oe=0              | ie= oe=0        |            |
| V9    | SPCBC2_24X            | KEYOUT[3] | O/T                  | VIO_1 | ie= oe=0              | ie= oe=0        |            |
| V8    | SPCBC2_24X            | KEYOUT[4] | O/T                  | VIO_1 | ie= oe=0              | ie= oe=0        |            |
| U11   | SPCBC2_24X            | KEYOUT[5] | O/T                  | VIO_1 | ie= oe=0              | ie= oe=0        |            |
| V10   | SPCBC2_24X            | KEYOUT[6] | O/T                  | VIO_1 | ie= oe=0              | ie= oe=0        |            |
| AA7   | SPCBC2_24X            | KEYOUT[7] | O/T                  | VIO_1 | ie= oe=0              | ie= oe=0        |            |
| V12   | SPCBC2_24X            | KEYIN[0]  | I                    | VIO_1 | ie= oe=0              | ie=1, oe=0, wpu |            |
| Y6    | SPCBC2_24X            | KEYIN[1]  | I                    | VIO_1 | ie=1,<br>oe=0,<br>wpd | ie=1, oe=0, wpu |            |
| U9    | SPCBC2_24X            | KEYIN[2]  | I                    | VIO_1 | ie= oe=0              | ie=1, oe=0, wpu |            |
| T9    | SPCBC2_24X            | KEYIN[3]  | I                    | VIO_1 | ie= oe=0              | ie=1, oe=0, wpu |            |
| V11   | SPCBC2_24X            | KEYIN[4]  | I                    | VIO_1 | ie= oe=0              | ie=1, oe=0, wpu |            |
| AC6   | SPCBC2_24X            | KEYIN[5]  | I                    | VIO_1 | ie= oe=0              | ie=1, oe=0, wpu |            |
| AC7   | SPCBC2_24X            | KEYIN[6]  | I                    | VIO_1 | ie= oe=0              | ie=1, oe=0, wpu |            |
| Y7    | SPCBC2_24X            | KEYIN[7]  | I                    | VIO_1 | ie= oe=0              | ie=1, oe=0, wpu |            |
|       | erface (5 Pins)       |           |                      |       |                       |                 |            |
| AA9   | SPBC2_24X             | SPI_DI    | I                    | VIO_1 | ie=1,<br>oe=0,wpu     | ie=1, oe=0,wpu  |            |
| AA8   | SPBC2_24X             | SPI_CLK   | I/O                  | VIO_1 | ie=0,                 | ie=0, oe=1, 0   |            |



| Ball  | Pin Type             | Pin Name | Default<br>Direction | Power    | At Reset              | After Reset     | Descrption |
|-------|----------------------|----------|----------------------|----------|-----------------------|-----------------|------------|
|       |                      |          |                      |          | oe=1, 0               |                 |            |
| Y10   | SPBC2_24X            | SPI_DO   | I/O                  | VIO_1    | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| Y9    | SPBC2_24X            | SPI_CSN0 | О/Т                  | VIO_1    | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1   | <b>*</b>   |
| AA10  | SPBC2_24X            | SPI_CSN1 | O/T                  | VIO_1    | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1   | X          |
| JTAG  | Interface (5 Pins)   |          |                      |          |                       |                 |            |
| F19   | SPCBC2_24X           | MTDO     | О/Т                  | VIO_2    | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| J18   | SPCBC2_24X           | MTDI     | I                    | VIO_2    | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| F18   | SPCBC2_24X           | MTCK     | I                    | VIO_2    | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| E19   | SPCBC2_24X           | MTMS     | I                    | VIO_2    | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| H18   | SPCBC2_24X           | MTRST_N  |                      | VIO_2    | ie=1,<br>oe=0,<br>wpd | ie=1, oe=0, wpd |            |
| UART  | 0 Interface (4 Pins) |          |                      |          |                       |                 |            |
| F16   | SPCBC2_24X           | U0TXD    | 0                    | VIO_2    | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1   |            |
| A15   | SPCBC2_24X           | U0RXD    |                      | VIO_2    | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| C16   | SPCBC2_24X           | U0CTS    | I                    | VIO_2    | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| E16   | SPCBC2_24X           | UORTS    | 0                    | VIO_2    | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1   |            |
| UART  | 1 Interface (2 Pins) |          |                      |          |                       |                 |            |
| C15   | SPCBC2_24X           | U1TXD    | 0                    | VIO_2    | ie=1,<br>oe=0,<br>wpu | ie=0, oe=1, 1   |            |
| H16   | SPCBC2_24X           | U1RXD    | I                    | VIO_2    | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| UART  | 2 Interface (2 Pins) |          |                      | l        |                       |                 |            |
| H15   | SPCBC2_24X           | U2TXD    | 0                    | VIO_2    | ie=1,<br>oe=0,<br>wpu | ie=0, oe=1, 1   |            |
| F15   | SPCBC2_24X           | U2RXD    | I                    | VIO_2    | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| LCD I | nterface (31 Pins)   |          |                      | <u> </u> | '                     |                 |            |
| AD7   | SPCBC2_24X           | LCD_CSN1 | 0                    | VLCD     | ie=0,                 | ie=0, oe=1, 1   |            |
|       |                      |          | ĺ                    | l        | 10-0,                 | 0, 00 1, 1      |            |



| Ball | Pin Type    | Pin Name  | Default<br>Direction | Power | At Reset         | After Reset   | Descrption |
|------|-------------|-----------|----------------------|-------|------------------|---------------|------------|
|      |             |           |                      |       | oe=1, 1          |               |            |
| AE7  | SPCBC2_24X  | LCD_RSTN  | 0                    | VLCD  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 1 |            |
| AC8  | SPCBC2_24X  | LCD_CD    | 0                    | VLCD  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 | <b>*</b> ( |
| AC9  | SPCBC2_24 X | LCD_D[0]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    | X          |
| AD8  | SPCBC2_24X  | LCD_D[1]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AE8  | SPCBC2_24X  | LCD_D[2]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AD9  | SPCBC2_24X  | LCD_D[3]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AE9  | SPCBC2_24X  | LCD_D[4]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AC10 | SPCBC2_24X  | LCD_D[5]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AD10 | SPCBC2_24X  | LCD_D[6]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AE10 | SPCBC2_24X  | LCD_D[7]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AC11 | SPCBC2_24X  | LCD_D[8]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AD11 | SPCBC2_24X  | LCD_WRN   | 0                    | VLCD  | ie=0,<br>oe=1,1  | ie=0, oe=1,1  |            |
| AA11 | SPCBC2_24X  | LCD_RDN   | 0                    | VLCD  | ie=0,<br>oe=1,1  | ie=0, oe=1,1  |            |
| AE11 | SPCBC2_24X  | LCD_CSN0  | 0                    | VLCD  | ie=0,<br>oe=1,1  | ie=0, oe=1,1  |            |
| Y11  | SPCBC2_24X  | LCD_D[9]  | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AC12 | SPCBC2_24X  | LCD_D[10] | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AD12 | SPCBC2_24X  | LCD_D[11] | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AE12 | SPCBC2_24X  | LCD_D[12] | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AA12 | SPCBC2_24X  | LCD_D[13] | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| Y12  | SPCBC2_24X  | LCD_D[14] | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AD13 | SPCBC2_24X  | LCD_D[15] | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AC13 | SPCBC2_24X  | LCD_D[16] | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| AE13 | SPCBC2_24X  | LCD_D[17] | I/O                  | VLCD  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| Y13  | SPCBC2_24X  | LCD_D[18] | I/O                  | VLCD  | ie=1,            | ie=1, oe=0    |            |



| Ball   | Pin Type            | Pin Name  | Default<br>Direction | Power | At Reset              | After Reset     | Descrption |
|--------|---------------------|-----------|----------------------|-------|-----------------------|-----------------|------------|
|        |                     |           |                      |       | oe=0                  |                 |            |
| AA13   | SPCBC2_24X          | LCD_D[19] | I/O                  | VLCD  | ie=1,<br>oe=0         | ie=1, oe=0      |            |
| Y14    | SPCBC2_24X          | LCD_D[20] | I/O                  | VLCD  | ie=1,<br>oe=0         | ie=1, oe=0      | <b>*</b> ( |
| AA14   | SPCBC2_24X          | LCD_D[21] | I/O                  | VLCD  | ie=1,<br>oe=0         | ie=1, oe=0      | XI         |
| AD14   | SPCBC2_24X          | LCD_D[22] | I/O                  | VLCD  | ie=1,<br>oe=0         | ie=1, oe=0      |            |
| AC14   | SPCBC2_24X          | LCD_D[23] | I/O                  | VLCD  | ie=1,<br>oe=0         | ie=1, oe=0      |            |
| AE14   | SPCBC2_24X          | LCD_FMARK | I                    | VLCD  | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| Nand I | Interface (24 Pins) |           |                      |       |                       |                 |            |
| AC19   | SPBC2_24X           | NFWPN     | 0                    | VNF   | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| AE19   | SPCBC2_24X          | NFRB      | I                    | VNF   | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu |            |
| AA19   | SPBC2_24X           | NFCLE     | 0                    | VNF   | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| Y18    | SPBC2_24X           | NFALE     | 0                    | VNF   | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0   |            |
| AD19   | SPBC2_24X           | NFCEN0    | 0                    | VNF   | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1   |            |
| AE20   | SPBC2_24X           | NFCEN1    | 0                    | VNF   | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1   |            |
| AD20   | SPBC2_24X           | NFREN     | 0                    | VNF   | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1   |            |
| AC20   | SPBC2_24X           | NFWEN     | 0                    | VNF   | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1   |            |
| AA20   | SPBC2_24X           | NFD[0]    | I/O                  | VNF   | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0      |            |
| Y19    | SPBC2_24X           | NFD[1]    | I/O                  | VNF   | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0      |            |
| W20    | SPBC2_24X           | NFD[2]    | I/O                  | VNF   | ie=1,<br>oe=0,wpu     | ie=1, oe=0      |            |
| AC21   | SPBC2_24X           | NFD[3]    | I/O                  | VNF   | ie=1,<br>oe=0,wpu     | ie=1, oe=0      |            |
| AA21   | SPBC2_24X           | NFD[4]    | I/O                  | VNF   | ie=1,<br>oe=0,wpu     | ie=1, oe=0      |            |
| AE22   | SPBC2_24X           | NFD[5]    | I/O                  | VNF   | ie=1,<br>oe=0         | ie=1, oe=0      |            |
| AD21   | SPBC2_24X           | NFD[6]    | I/O                  | VNF   | ie=1,<br>oe=0         | ie=1, oe=0      |            |
| Y20    | SPBC2_24X           | NFD[7]    | I/O                  | VNF   | ie=1,                 | ie=1, oe=0      |            |



| Ball  | Pin Type           | Pin Name | Default<br>Direction | Power | At Reset         | After Reset   | Descrption   |
|-------|--------------------|----------|----------------------|-------|------------------|---------------|--------------|
|       |                    |          |                      |       | oe=0             |               |              |
| AD22  | SPBC2_24X          | NFD[8]   | I/O                  | VNF   | ie=1,<br>oe=0    | ie=1, oe=0    |              |
| AE23  | SPBC2_24X          | NFD[9]   | I/O                  | VNF   | ie=1,<br>oe=0    | ie=1, oe=0    | <b>*</b> . ( |
| AD23  | SPBC2_24X          | NFD[10]  | I/O                  | VNF   | ie=1,<br>oe=0    | ie=1, oe=0    | X            |
| AC22  | SPBC2_24X          | NFD[11]  | I/O                  | VNF   | ie=1,<br>oe=0    | ie=1, oe=0    |              |
| AD24  | SPBC2_24X          | NFD[12]  | I/O                  | VNF   | ie=1,<br>oe=0    | ie=1, oe=0    |              |
| AC25  | SPBC2_24X          | NFD[13]  | I/O                  | VNF   | ie=1,<br>oe=0    | ie=1, oe=0    |              |
| AC24  | SPBC2_24X          | NFD]14]  | I/O                  | VNF   | ie=1,<br>oe=0    | ie=1, oe=0    |              |
| Y21   | SPBC2_24X          | NFD[15]  | I/O                  | VNF   | ie=1,<br>oe=0    | ie=1, oe=0    |              |
| EMC I | nterface (66 Pins) |          |                      |       |                  |               |              |
| W21   | SPBC2_24X_18       | EMRST_N  | 0                    | VMEM  | ie=0,<br>oe=1, 0 | oe=1, ie=0, 1 |              |
| AA23  | SPBC2_24X_18       | EMA[0]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| AB23  | SPBC2_24X_18       | EMA[1]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| Y24   | SPBC2_24X_18       | EMA[2]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| AA24  | SPBC2_24X_18       | EMA[3]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| W24   | SPBC2_24X_18       | EMA[4]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| W25   | SPBC2_24X_18       | EMA[5]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| AB24  | SPBC2_24X_18       | EMA[6]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| AB25  | SPBC2_24X_18       | EMA[7]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| W23   | SPBC2_24X_18       | EMA[8]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| V24   | SPBC2_24X_18       | EMA[9]   | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| AA25  | SPBC2_24X_18       | EMA[10]  | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| Y25   | SPBC2_24X_18       | EMA[11]  | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| Y23   | SPBC2_24X_18       | EMA[12]  | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |
| V25   | SPBC2_24X_18       | EMA[13]  | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |              |



| Ball | Pin Type     | Pin Name | Default<br>Direction | Power | At Reset         | After Reset   | Descrption |
|------|--------------|----------|----------------------|-------|------------------|---------------|------------|
| U23  | SPBC2_24X_18 | EMD[0]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| U24  | SPBC2_24X_18 | EMD[1]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       | •          |
| U25  | SPBC2_24X_18 | EMD[2]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| V21  | SPBC2_24X_18 | EMD[3]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       | <b>*</b>   |
| U21  | SPBC2_24X_18 | EMD[4]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| T24  | SPBC2_24X_18 | EMD[5]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| R25  | SPBC2_24X_18 | EMD[6]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| T23  | SPBC2_24X_18 | EMD[7]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| R24  | SPBC2_24X_18 | EMDQM[0] | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| T25  | SPBC2_24X_18 | EMDQS[0] | I/O                  | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| R23  | SPBC2_24X_18 | EMD[8]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| R21  | SPBC2_24X_18 | EMD[9]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| P25  | SPBC2_24X_18 | EMD[10]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| P21  | SPBC2_24X_18 | EMD[11]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| M25  | SPBC2_24X_18 | EMD[12]  | 1/0                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| N25  | SPBC2_24X_18 | EMD[13]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| P24  | SPBC2_24X_18 | EMD[14]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| N24  | SPBC2_24X_18 | EMD[15]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| N23  | SPBC2_24X_18 | EMDQM[1] | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| P23  | SPBC2_24X_18 | EMDQS[1] | 1/0                  | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| M24  | SPBC2_24X_18 | EMD[16]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| M23  | SPBC2_24X_18 | EMD[17]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| N20  | SPBC2_24X_18 | EMCKE[1] | I/O                  | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| M21  | SPBC2_24X_18 | EMD[18]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| L24  | SPBC2_24X_18 | EMD[19]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| L25  | SPBC2_24X_18 | EMD[20]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| L21  | SPBC2_24X_18 | EMD[21]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| K25  | SPBC2_24X_18 | EMD[22]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| K24  | SPBC2_24X_18 | EMD[23]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| K23  | SPBC2_24X_18 | EMDQM[2] | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| L23  | SPBC2_24X_18 | EMDQS[2] | I/O                  | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| G24  | SPBC2_24X_18 | EMD[24]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| J21  | SPBC2_24X_18 | EMD[25]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| J25  | SPBC2_24X_18 | EMD[26]  | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |



| Ball | Pin Type            | Pin Name  | Default<br>Direction | Power | At Reset         | After Reset   | Descrption |
|------|---------------------|-----------|----------------------|-------|------------------|---------------|------------|
| J24  | SPBC2_24X_18        | EMD[27]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| H25  | SPBC2_24X_18        | EMD[28]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| G25  | SPBC2_24X_18        | EMD[29]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| H24  | SPBC2_24X_18        | EMD[30]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       | <b>*</b>   |
| H21  | SPBC2_24X_18        | EMD[31]   | I/O                  | VMEM  | ie=oe=0          | ie=oe=0       |            |
| H23  | SPBC2_24X_18        | EMDQM[3]  | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| J23  | SPBC2_24X_18        | EMDQS[3]  | I/O                  | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| F25  | SPBC2_24X_18        | CLKDPMEM  | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |            |
| E25  | SPBC2_24X_18        | CLKDMMEM  | 0                    | VMEM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |            |
| F23  | SPBC2_24X_18        | EMRAS_N   | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| F24  | SPBC2_24X_18        | EMCAS_N   | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| M20  | SPBC2_24X_18        | EMWE_N    | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| K20  | SPBC2_24X_18        | EMCS_N[0] | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| L20  | SPBC2_24X_18        | EMCS_N[1] | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| E23  | SPBC2_24X_18        | EMBA[0]   | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| E24  | SPBC2_24X_18        | EMBA[1]   | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| P20  | SPBC2_24X_18        | EMCKE[0]  | 0                    | VMEM  | ie=0,<br>oe=1, 1 | ie=0, oe=1, 1 |            |
| DCAM | Interface (15 Pins) |           |                      |       |                  |               |            |
| C25  | SPCBC2_24X          | CCIRMCLK  | 0                    | VCAM  | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |            |
| D25  | SPCBC2_24X          | CCIRCK    | I                    | VCAM  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| F20  | SPCBC2_24X          | CCIRHS    | I                    | VCAM  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| E20  | SPCBC2_24X          | CCIRVS    | I                    | VCAM  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| J20  | SPCBC2_24X          | CCIRD[0]  | I                    | VCAM  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| G21  | SPCBC2_24X          | CCIRD[1]  | I                    | VCAM  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| F21  | SPCBC2_24X          | CCIRD[2]  | I                    | VCAM  | ie=1,<br>oe=0    | ie=1, oe=0    |            |
| H20  | SPCBC2_24X          | CCIRD[3]  | 1                    | VCAM  | ie=1,<br>oe=0    | ie=1, oe=0    |            |



| Ball    | Pin Type                | Pin Name | Default<br>Direction | Power | At Reset              | After Reset                  | Descrption |
|---------|-------------------------|----------|----------------------|-------|-----------------------|------------------------------|------------|
| D24     | SPCBC2_24X              | CCIRD[4] | I                    | VCAM  | ie=1,<br>oe=0         | ie=1, oe=0                   |            |
| C24     | SPCBC2_24X              | CCIRD[5] | I                    | VCAM  | ie=1,<br>oe=0         | ie=1, oe=0                   |            |
| D23     | SPCBC2_24X              | CCIRD[6] | I                    | VCAM  | ie=1,<br>oe=0         | ie=1, oe=0                   |            |
| G20     | SPCBC2_24X              | CCIRD[7] | I                    | VCAM  | ie=1,<br>oe=0         | ie=1, oe=0                   |            |
| E21     | SPCBC2_24X              | CCIRRST  | 0                    | VCAM  | ie=0,<br>oe=1, 0      | ie=0, oe=1, 1                |            |
| L18     | SPCBC2_24X              | CCIRPD1  | 0                    | VCAM  | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1                |            |
| K18     | SPCBC2_24X              | CCIRPD0  | 0                    | VCAM  | ie=0,<br>oe=1, 1      | ie=0, oe=1, 1                |            |
| I2C In  | terface (8 Pins)        |          |                      |       |                       |                              |            |
| A22     | SPCBC2_24X              | SCL0     | I/O/T                | VIO_2 | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu              |            |
| A23     | SPCBC2_24X              | SDA0     | I/O/T                | VIO_2 | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu              |            |
| B24     | SPCBC2_24X              | SCL1     | I/O/T                | VCAM  | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu              |            |
| B23     | SPCBC2_24X              | SDA1     | I/O/T                | VCAM  | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu              |            |
| B22     | SPCBC2_24X              | SCL2     | I/O/T                | VIO_2 | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu              |            |
| C22     | SPCBC2_24X              | SDA2     | I/O/T                | VIO_2 | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu              |            |
| A21     | SPCBC2_24X              | SCL3     | I/O/T                | VIO_2 | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu              |            |
| B21     | SPCBC2_24X              | SDA3     | I/O/T                | VIO_2 | ie=1,<br>oe=0,<br>wpu | ie=1, oe=0, wpu              |            |
| Aux     | Clock Interface (1 Pin) |          |                      |       |                       |                              |            |
| J15     | SPBC2_24X               | CLK_AUX0 | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| IIS Int | erface (5 Pins)         |          |                      |       |                       |                              |            |
| C21     | SPBC2_24X               | IISDI    | O/T                  | VIO_2 | ie=1,<br>oe=0,wpd     | ie=1,<br>oe=0,wpd,fun_sel=1  |            |
| B20     | SPBC2_24X               | IISDO    | I                    | VIO_2 | ie=0,<br>oe=0,        | ie=0,<br>oe=0,fun_sel=1      |            |
| C19     | SPBC2_24X               | IISCLK   | I                    | VIO_2 | ie=1,<br>oe=0,<br>wpd | ie=1, oe=0,<br>wpd,fun_sel=1 |            |



| Ball   | Pin Type         | Pin Name    | Default<br>Direction | Power | At Reset              | After Reset                  | Descrption |
|--------|------------------|-------------|----------------------|-------|-----------------------|------------------------------|------------|
| A20    | SPBC2_24X        | IISLRCK     | I                    | VIO_2 | ie=1,<br>oe=0,<br>wpd | ie=1, oe=0,<br>wpd,fun_sel=1 |            |
| C20    | SPBC2_24X        | IISMCK      | 0                    | VIO_2 | ie=1,<br>oe=0,<br>wpd | ie=1, oe=0,<br>wpd,fun_sel=1 |            |
| TRAC   | E port (10 Pins) |             |                      |       |                       |                              |            |
| A18    | SPBC2_24X        | TRACECLK    | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| C18    | SPBC2_24X        | TRACECTRL   | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| B18    | SPBC2_24X        | TRACEDAT[0] | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| A17    | SPBC2_24X        | TRACEDAT[1] | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| C17    | SPBC2_24X        | TRACEDAT[2] | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| E18    | SPBC2_24X        | TRACEDAT[3] | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| A16    | SPBC2_24X        | TRACEDAT[4] | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| B17    | SPBC2_24X        | TRACEDAT[5] | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| B16    | SPBC2_24X        | TRACEDAT[6] | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| E17    | SPBC2_24X        | TRACEDAT[7] | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| RF Int | erface (19 Pins) |             |                      |       |                       |                              |            |
| E15    | SPBC2_24X        | RFSDA0      | I/O/T                | VIO_2 | ie=oe=0,<br>wpd       | ie=oe=0, wpd                 |            |
| A14    | SPBC2_24X        | RFSCK0      | O/T                  | VIO_2 | ie=oe=0,<br>wpd       | ie=oe=0, wpd                 |            |
| B15    | SPBC2_24X        | RFSEN0      | О/Т                  | VIO_2 | ie=oe=0,<br>wpu       | ie=oe=0, wpu                 |            |
| C14    | SPBC2_24X        | RFCTL[0]    | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| E14    | SPBC2_24X        | RFCTL[1]    | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| A13    | SPBC2_24X        | RFCTL[2]    | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| B14    | SPBC2_24X        | RFCTL[3]    | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| H14    | SPBC2_24X        | RFCTL[4]    | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| C13    | SPBC2_24X        | RFCTL[5]    | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |
| B12    | SPBC2_24X        | RFCTL[6]    | 0                    | VIO_2 | ie=0,<br>oe=1, 0      | ie=0, oe=1, 0                |            |



| Ball   | Pin Type                | Pin Name  | Default<br>Direction | Power | At Reset         | After Reset   | Descrption               |
|--------|-------------------------|-----------|----------------------|-------|------------------|---------------|--------------------------|
| E13    | SPBC2_24X               | RFCTL[7]  | 0                    | VIO_2 | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |                          |
| F13    | SPBC2_24X               | RFCTL[8]  | 0                    | VIO_2 | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |                          |
| B13    | SPBC2_24X               | RFCTL[9]  | 0                    | VIO_2 | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |                          |
| H13    | SPBC2_24X               | RFCTL[10] | 0                    | VIO_2 | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |                          |
| C12    | SPBC2_24X               | RFCTL[11] | 0                    | VIO_2 | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |                          |
| F12    | SPBC2_24X               | RFCTL[12] | 0                    | VIO_0 | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |                          |
| H12    | SPBC2_24X               | RFCTL[13] | 0                    | VIO_0 | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |                          |
| E12    | SPBC2_24X               | RFCTL[14] | 0                    | VIO_0 | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |                          |
| B11    | SPBC2_24X               | RFCTL[15] | 0                    | VIO_0 | ie=0,<br>oe=1, 0 | ie=0, oe=1, 0 |                          |
| Touch  | Panel Interface (4 Pins | 5)        |                      |       |                  |               |                          |
| M8     | SPCBC2_24X_GP_S         | TP_XL     | I/O/T                | VIO   | le=1,<br>oe=0    | le=1, oe=0    |                          |
| L8     | SPCBC2_24X_GP_S         | TP_XR     | I/O/T                | VIO   | le=1,<br>oe=0    | le=1, oe=0    |                          |
| K8     | SPCBC2_24X_GP_S         | TP_YU     | I/O/T                | VIO   | le=1,<br>oe=0    | le=1, oe=0    |                          |
| N8     | SPCBC2_24X_GP_S         | TP_YD     | I/O/T                | VIO   | le=1,<br>oe=0    | le=1, oe=0    |                          |
| Supply | y Input                 |           | ·                    |       |                  |               |                          |
| AE3    | SPVDD2                  | VSIM0     |                      |       |                  |               | VSIM0<br>supply<br>input |
| AE4    | SPVDD2                  | VSIM1     |                      |       |                  |               | VSIM1<br>supply<br>input |
| AE5    | SPVDD2                  | VSIM2     |                      |       |                  |               | VSIM2<br>supply<br>input |
| AE6    | SPVDD2                  | VSIM3     |                      |       |                  |               | VSIM3<br>supply<br>input |
| G5     | SPAVDD3                 | VDDSIM2   |                      |       |                  |               |                          |
| H5     | SPAVDD3                 | VDDSIM3   |                      |       |                  |               |                          |
| F17    | SPVSS2                  | VSSIO     |                      |       |                  |               | 3V IO ring<br>Ground     |
| H17    | SPVSS2                  | VSSIO     |                      |       |                  |               | 3V IO ring<br>Ground     |
| J13    | SPVSS2                  | VSSIO     |                      |       |                  |               | 3V IO ring<br>Ground     |



| Ball | Pin Type  | Pin Name | Default<br>Direction | Power | At Reset | After Reset | Descrption                  |
|------|-----------|----------|----------------------|-------|----------|-------------|-----------------------------|
| J14  | SPVSS2    | VSSIO    |                      |       |          |             | 3V IO ring<br>Ground        |
| M9   | SPVSS2    | VSSIO    |                      |       |          |             | 3V IO ring<br>Ground        |
| N9   | SPVSS2    | VSSIO    |                      |       |          |             | 3V IO ring<br>Ground        |
| P9   | SPVSS2    | VSSIO    |                      |       |          |             | 3V IO ring<br>Ground        |
| M17  | SPVSS2    | VSSIO    |                      |       |          |             | 3V IO ring<br>Ground        |
| M18  | SPVSS2    | VSSIO    |                      |       |          | 70          | 3V IO ring<br>Ground        |
| N18  | SPVSS2    | VSSIO    |                      |       |          |             | 3V IO ring<br>Ground        |
| U17  | SPVDD1    | VDD_D    |                      |       | X        |             | VDD core<br>supply<br>input |
| U18  | SPVDD1    | VDD_D    |                      |       |          |             | VDD core<br>supply<br>input |
| V17  | SPVDD1    | VDD_D    |                      |       |          |             | VDD core<br>supply<br>input |
| V18  | SPVDD1    | VDD_D    |                      |       |          |             | VDD core<br>supply<br>input |
| P18  | SPVDD1ANA | VDD1P2   |                      |       |          |             | VDD ARM<br>SUPPLY           |
| R18  | SPVDD1ANA | VDD1P2   |                      |       |          |             | VDD ARM<br>SUPPLY           |
| T18  | SPVDD1ANA | VDD1P2   |                      |       |          |             | VDD ARM<br>SUPPLY           |
| C4   | SPVSS1    | VSS      |                      |       |          |             | 1.1V Core<br>Ground         |
| C11  | SPVSS1    | VSS      |                      |       |          |             | 1.1V Core<br>Ground         |
| E9   | SPVSS1    | VSS      |                      |       |          |             | 1.1V Core<br>Ground         |
| F14  | SPVSS1    | VSS      |                      |       |          |             | 1.1V Core<br>Ground         |
| G23  | SPVSS1    | VSS      |                      |       |          |             | 1.1V Core<br>Ground         |
| H6   | SPVSS1    | VSS      |                      |       |          |             | 1.1V Core<br>Ground         |
| K21  | SPVSS1    | VSS      |                      |       |          |             | 1.1V Core<br>Ground         |
| M12  | SPVSS1    | VSS      |                      |       |          |             | 1.1V Core<br>Ground         |
| M13  | SPVSS1    | VSS      |                      |       |          |             | 1.1V Core                   |



| Ball | Pin Type | Pin Name | Default<br>Direction | Power | At Reset | After Reset | Descrption               |
|------|----------|----------|----------------------|-------|----------|-------------|--------------------------|
|      |          |          |                      |       |          |             | Ground                   |
| M14  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| N12  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| N13  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| N14  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| P12  | SPVSS1   | VSS      |                      |       |          | 101         | 1.1V Core<br>Ground      |
| P13  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| P14  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| T21  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| U10  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| V23  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| N21  | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| P5   | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| R9   | SPVSS1   | VSS      |                      |       |          |             | 1.1V Core<br>Ground      |
| J10  | SPVDD2   | VIO0     |                      |       |          |             | VIO0<br>supply<br>input  |
| J11  | SPVDD2   | VIO0     |                      |       |          |             | VIO<br>0supply<br>input  |
| J12  | SPVDD2   | VIO0     |                      |       |          |             | VIO0<br>supply<br>input  |
| R17  | SPVDD2   | VIO1     |                      |       |          |             | VIO1<br>supply<br>input  |
| T17  | SPVDD2   | VIO1     |                      |       |          |             | VIO1<br>supply<br>input  |
| N17  | SPVDD2   | VIO2     |                      |       |          |             | VIO2<br>supply<br>input  |
| P17  | SPVDD2   | VIO2     |                      |       |          |             | VIO 2<br>supply<br>input |
| V15  | SPVDD2   | VLCD     |                      |       |          |             | VLCD<br>supply           |



| Ball | Pin Type       | Pin Name | Default<br>Direction | Power | At Reset | After Reset | Descrption              |
|------|----------------|----------|----------------------|-------|----------|-------------|-------------------------|
|      |                |          |                      |       |          |             | input                   |
| AE21 | SPVDD2         | VNF      |                      |       |          |             | VLCD<br>supply<br>input |
| R20  | SPVDD2         | VMEM     |                      |       |          |             | VMEM<br>supply<br>input |
| T20  | SPVDD2         | VMEM     |                      |       |          |             | VMEM<br>supply<br>input |
| U20  | SPVDD2POC      | VMEM     |                      |       |          | 70          | VMEM<br>supply<br>input |
| V20  | SPVDD2POC      | VMEM     |                      |       | C        |             | VMEM<br>supply<br>input |
| J17  | SPVDD2         | VCAM     |                      |       |          |             | VCAM<br>supply<br>input |
| AA17 |                | VDDUSB   |                      |       |          |             | VUSB<br>supply<br>input |
| V16  |                | AVSSUSB  |                      |       |          |             |                         |
| J1   |                | AVDDBB   |                      |       |          |             |                         |
| B5   |                | AGNDBB   |                      |       |          |             |                         |
| F7   |                | AGNDBB   |                      |       |          |             |                         |
| E1   | SPAVDD3        | AVDDVBO  |                      |       |          |             |                         |
| L1   | SPAPAD3        | VCOM     |                      |       |          |             |                         |
| МЗ   | SPAVDD3        | AGNDVB   |                      |       |          |             |                         |
| L3   | SPAVSS3        | VSSAO    |                      |       |          |             |                         |
| J2   | SPAVDD3        | VDDAO    |                      |       |          |             |                         |
| N1   | SPAVDD2_RTC    | VDDRTC   |                      |       |          |             |                         |
| J8   | SPAVDD3        | VDD_A    |                      |       |          |             |                         |
| R3   |                | VSSPA    |                      |       |          |             |                         |
| R2   |                | VSSPA    |                      |       |          |             |                         |
| U1   | SPAVDD3(diode) | AVDDPA   |                      |       |          |             |                         |
| T5   |                | VSSBUCK  |                      |       |          |             |                         |
| T6   |                | VSSBUCK  |                      |       |          |             |                         |
| U5   |                | VSSBUCK  |                      |       |          |             |                         |
| U6   |                | VSSBUCK  |                      |       |          |             |                         |
| T8   |                | VSSBUCK  |                      |       |          |             |                         |
| A9   | SPAVDD3        | VDD18    |                      |       |          |             |                         |
| H9   | SPAVDD3        | VDDSD0   |                      |       |          |             |                         |
| H10  | SPAVDD3        | VDDSD1   |                      |       |          |             |                         |



| Ball       | Pin Type               | Pin Name    | Default<br>Direction | Power | At Reset | After Reset | Descrption |
|------------|------------------------|-------------|----------------------|-------|----------|-------------|------------|
| P1         | SPAVDD3                | VDDWIF0     |                      |       |          |             |            |
| A11        | SPAVDD3                | VDDWIF1     |                      |       |          |             |            |
| T3         | SPVDD2ANA              | VDD_EFUSE   |                      |       |          |             |            |
| A8         | SPAVDD3                | VDD28       |                      |       |          |             | <b>*</b>   |
| A12        | SPAVDD3                | VDDMEM      |                      |       |          |             |            |
| A7         | SPAVDD3                | VDDCAMD1    |                      |       |          |             |            |
| F6         | SPAVSS3_H              | AGNDAFC     |                      |       |          |             |            |
| A4         | SPAVDD3_H              | AVDDBB      |                      |       |          |             |            |
| B2         | SPAVDD3                | VDDRF1      |                      |       |          | 1 (/)       |            |
| A3         | SPAVDD3                | VDDRF0      |                      |       |          | AU          |            |
| F1         | SPAVDD3_Double         | VDDCAMD0    |                      |       |          |             |            |
| D1         | SPAVDD3                | VDDCAMA     |                      |       |          |             |            |
| USB in     | nterface(2 pads)       |             |                      |       |          |             |            |
| U15        |                        | ANATEST     |                      |       | 4        |             |            |
| AE17       |                        | VRES        |                      |       |          |             |            |
| AD16       |                        | PADM        |                      |       |          |             |            |
| AE16       |                        | PADP        |                      |       |          |             |            |
| USB ir     | nterface(2 pads)       |             |                      |       |          |             |            |
| R6         | SPAPAD2                | OPTION0A    |                      |       |          |             |            |
| P6         | SPAPAD2                | OPTION1A    |                      |       |          |             |            |
| R8         | SPAPAD2                | OPTION2A    |                      |       |          |             |            |
| White      | LED interface(7 pins)  |             |                      |       |          |             |            |
| F5         | SPAPAD3                | WHTLED_IB5  |                      |       |          |             |            |
| F2         | SPAPAD3                | WHTLED_IB4  |                      |       |          |             |            |
| E3         | SPAPAD3                | WHTLED_IB3  |                      |       |          |             |            |
| E2         | SPAPAD3                | WHTLED_IB2  |                      |       |          |             |            |
| F3         | SPAPAD3                | WHTLED_IB1  |                      |       |          |             |            |
| G3         | SPAPAD3                | WHTLED_IB0  |                      |       |          |             |            |
| G2         | SPAPAD3                | WHTLED_RSET |                      |       |          |             |            |
| Voice      | band interface(5 pins) |             |                      |       |          |             | 1          |
| G1         | SPAPAD3                | HEADMIC_IN  |                      |       |          |             |            |
| <b>J</b> 5 | SPAPAD3                | AUXMICP     |                      |       |          |             |            |
| J6         | SPAPAD3                | AUXMICN     |                      |       |          |             |            |
| K6         | SPAPAD3                | MICP        |                      |       |          |             |            |
| K5         | SPAPAD3                | MICN        |                      |       |          |             |            |
| H1         | SPAPAD3                | MICBIAS     |                      |       |          |             |            |
| H2         | SPAPAD3                | AIL1        |                      |       |          |             |            |
| Н3         | SPAPAD3                | AIR1        |                      |       |          |             |            |



| Ball   | Pin Type              | Pin Name   | Default<br>Direction | Power | At Reset | After Reset | Descrption |
|--------|-----------------------|------------|----------------------|-------|----------|-------------|------------|
| L6     | SPAPAD3               | HEAD_P_L   |                      |       |          |             |            |
| L2     | SPAPAD3               | AOM        |                      |       |          |             |            |
| L5     | SPAPAD3               | HEAD_P_R   |                      |       |          |             |            |
| J3     | SPAPAD3               | AUXSPP     |                      |       |          |             | <b>*</b>   |
| K3     | SPAPAD3               | AUXSPN     |                      |       |          |             | 4          |
| K2     | SPAPAD3               | EARN       |                      |       |          |             |            |
| K1     | SPAPAD3               | EARP       |                      |       |          |             |            |
| VBAT   | input(pins)           |            |                      |       |          |             |            |
| D2     | SPAVBAT               | AVDD36_1   |                      |       |          |             |            |
| D3     | SPAVBAT               | AVDD36_1   |                      |       |          |             |            |
| N6     | SPAVBAT               | VBAT_SENSE |                      |       |          |             |            |
| N2     | SPAVBAT               | VBATBK     |                      |       |          |             |            |
| T2     |                       | VBATPA1    |                      |       |          |             |            |
| U2     |                       | VBATPA1    |                      |       | 4        |             |            |
| U3     |                       | VBATPA1    |                      |       |          |             |            |
| V1     |                       | VBATBUCK   |                      |       |          |             |            |
| V2     |                       | VBATBUCK   |                      |       |          |             |            |
| V3     |                       | VBATBUCK   |                      |       |          |             |            |
| W1     |                       | VBATBUCK   |                      |       |          |             |            |
| W2     |                       | VBATBUCK   |                      |       |          |             |            |
| A10    | SPAVBAT               | VBATD      |                      |       |          |             |            |
| B10    | SPAVBAT               | VBATD      |                      |       |          |             |            |
| C10    | SPAVBAT               | VBATD      |                      |       |          |             |            |
| C2     | SPAVBAT               | AVDD36RF   |                      |       |          |             |            |
| C1     | SPAVBAT               | AVDD36RF   |                      |       |          |             |            |
| R1     | SPAVDD3               | VDD25      |                      |       |          |             |            |
| R5     | SPAVSS3               | KPLED_VSS  |                      |       |          |             |            |
| Charg  | er Interface (3 pins) |            |                      |       |          |             |            |
| N5     | SPAVBAT               | ISENSE     |                      |       |          |             |            |
| M5     | SPVCHG_HVT            | VCHG       |                      |       |          |             |            |
| N3     | SPVDRV_HVT            | VDRV       |                      |       |          |             |            |
| RTC In | nterface (2 pins)     |            |                      |       |          |             |            |
| M2     | SPAPAD3               | RTC32KO    |                      |       |          |             |            |
| M1     | SPAPAD3               | RTC32KI    |                      |       |          |             |            |
| Vibera | tor Driver (1 pins)   |            |                      |       |          |             |            |
| V5     | SPAPAD3_DRV           | VIBR       |                      |       |          |             |            |
| Keypa  | d LED Driver (1 pins) |            |                      |       |          |             |            |
| V6     | SPAPAD3_DRV           | KPLED      |                      |       |          |             |            |
| ClassI | O output(2 pins)      |            |                      |       |          |             |            |



| Ball   | Pin Type               | Pin Name    | Default<br>Direction | Power | At Reset | After Reset | Descrption |
|--------|------------------------|-------------|----------------------|-------|----------|-------------|------------|
| Y1     |                        | OUTPPA      |                      |       |          |             |            |
| Y2     |                        | OUTPPA      |                      |       |          |             |            |
| AA1    |                        | OUTNPA      |                      |       |          |             |            |
| AA2    |                        | OUTNPA      |                      |       |          |             | <b>*</b>   |
| DCDC   | interface(4 pins)      |             |                      |       |          |             |            |
| P3     | SPAPAD3                | EDCDCEN     |                      |       |          |             |            |
| T1     | SPAPAD3                | VCMPA       |                      |       |          |             |            |
| AB3    | SPAPAD3                | VFB         |                      |       |          |             |            |
| AB1    |                        | LX          |                      |       |          |             |            |
| AB2    |                        | LX          |                      |       |          | A           |            |
| P2     |                        | EDCDCARM_EN |                      |       |          |             |            |
| AD2    | SPAPAD3                | VFB_ARM     |                      |       | <b>X</b> |             |            |
| AC1    |                        | LX_ARM      |                      |       |          |             |            |
| AC2    |                        | LX_ARM      |                      |       | 4        |             |            |
| Clock  | input(2 pins)          |             |                      |       |          |             |            |
| G6     | SPAPAD3_H              | REF26M      |                      | ,     |          |             |            |
| A5     | SPAPAD3_H              | MCLKI       |                      |       |          |             |            |
| Analo  | g Baseband Interface ( | 5 pins)     |                      |       |          |             |            |
| E6     | SPAPAD3_H              | TRXQN       |                      |       |          |             |            |
| C6     | SPAPAD3_H              | TRXQP       |                      |       |          |             |            |
| A6     | SPAPAD3_H              | TXREF       |                      |       |          |             |            |
| E5     | SPAPAD3_H              | TRXIN       |                      |       |          |             |            |
| C5     | SPAPAD3_H              | TRXIP       |                      |       |          |             |            |
| APC o  | output (1 pin)         |             |                      |       |          |             |            |
| B4     | SPAPAD3_H              | APCOUT      |                      |       |          |             |            |
| Extern | nal reset input(1 pin) |             |                      |       |          |             |            |
| H11    | SPAPAD3_ADCI           | EXTRSTN     |                      |       |          |             |            |
| Aux A  | DC Interface (4 Pins)  |             |                      |       |          |             |            |
| F10    | SPAPAD3_ADCI           | ADCI0       |                      |       |          |             |            |
| В9     | SPAPAD3_ADCI           | ADCI1       |                      |       |          |             |            |
| F9     | SPAPAD3_ADCI           | ADCI2       |                      |       |          |             |            |
| E10    | SPAPAD3_ADCI           | ADCI3       |                      |       |          |             |            |

# 3.1.3 Pin Multiplexed Function List

SC6820 adopts programmable pin multiplexing to reduce pin number as well as providing enough flexibililty. Multiple signals are connected to a multiplexer that connects to the same I/O pin.



Table 3-3 Pin Multiplexed Functions

| Pin Name               | Mode0        | Mode1                 | Mode2                    | Mode3   |
|------------------------|--------------|-----------------------|--------------------------|---------|
|                        | Clock and Re | eset Interface (3 Pir | ns)                      |         |
| XTL_EN                 | XTL_EN       |                       |                          | GPIO106 |
| TESTRSTN               | TESTRSTN     | DOPHIN_12M_<br>EXT    | PLL_DIV32OU<br>T_padtest | GPIO201 |
| PBINT                  | PBINT        |                       |                          |         |
|                        | GPIO In      | terface (10 Pins)     |                          |         |
| GPIO135                | GPIO135      |                       |                          |         |
| GPIO136                | GPIO136      |                       |                          | PWMC    |
| GPIO137                | GPIO137      |                       |                          | PWMD    |
| GPIO138                | GPIO138      |                       |                          |         |
| GPIO139                | GPIO139      |                       |                          |         |
| GPIO140                | GPIO140      |                       |                          |         |
| GPIO141                | GPIO141      |                       |                          |         |
| GPIO142                | GPIO142      |                       |                          |         |
| GPIO143                | GPIO143      |                       |                          | PWMA    |
| GPIO144                | GPIO144      |                       |                          | PWMB    |
|                        | SIM0 Ir      | nterface (3 Pins)     |                          |         |
| SIMCLK0                | SIMCLK0      |                       |                          |         |
| SIMDA0                 | SIMDA0       |                       |                          |         |
| SIMRST0                | SIMRST0      |                       |                          |         |
|                        | SIM1 Ir      | nterface (3 Pins)     |                          |         |
| SIMCLK1                | SIMCLK1      |                       |                          | GPIO16  |
| SIMDA1                 | SIMDA1       |                       |                          |         |
| SIMRST1                | SIMRST1      |                       |                          | GPIO17  |
|                        | SIM2 Ir      | nterface (3 Pins)     |                          |         |
| SIMCLK2                | SIMCLK2      | SCL2                  |                          | GPIO18  |
| SIMDA2                 | SIMDA2       | SDA2                  |                          |         |
| SIMRST2                | SIMRST2      | CLK_RTC               |                          |         |
|                        | SIM3 Ir      | nterface (3 Pins)     |                          |         |
| SIMCLK3                | SIMCLK3      |                       | U1RXD                    | GPIO59  |
| SIMDA3                 | SIMDA3       |                       |                          |         |
| SIMRST3                | SIMRST3      |                       | U1TXD                    | GPIO60  |
| SDIO Interface (7 Pins | s)           |                       |                          |         |
| SD0_CLK                | SD0_CLK      |                       |                          |         |
| SD_CMD                 | SD_CMD       |                       |                          |         |



| Pin Name              | Mode0                   | Mode1              | Mode2 | Mode3  |  |  |  |
|-----------------------|-------------------------|--------------------|-------|--------|--|--|--|
| SD_D[0]               | SD_D0                   |                    |       |        |  |  |  |
| SD_D]1]               | SD_D1                   |                    |       |        |  |  |  |
| SD_D[2]               | SD_D2                   |                    |       |        |  |  |  |
| SD_D[3]               | SD_D3                   |                    |       |        |  |  |  |
| SD1_CLK               | SD1_CLK                 |                    |       | GPIO39 |  |  |  |
| SDIO2 Interface (7 Pi | ns)                     |                    |       |        |  |  |  |
| SD2_CLK               | SD2_CLK                 | SPI1_CLK           |       | GPIO19 |  |  |  |
| SD2_CMD               | SD2_CMD                 | SPI1_DI            |       | GPIO20 |  |  |  |
| SD2_D[0]              | SD2_D0                  | SPI1_DO            |       | GPIO21 |  |  |  |
| SD2_D]1]              | SD2_D1                  | SPI1_CSN0          |       | GPIO22 |  |  |  |
| SD2_D[2]              | SD2_D2                  | SPI1_CSN1          | CAL   | GPIO23 |  |  |  |
| SD2_D[3]              | SD2_D3                  |                    |       | GPIO24 |  |  |  |
|                       | Keypad I                | nterface (16 Pins) |       | T      |  |  |  |
| KEYOUT[0]             | KEYOUT0                 |                    |       |        |  |  |  |
| KEYOUT[1]             | KEYOUT1                 |                    |       |        |  |  |  |
| KEYOUT[2]             | KEYOUT2                 |                    |       |        |  |  |  |
| KEYOUT[3]             | KEYOUT3                 |                    |       |        |  |  |  |
| KEYOUT[4]             | KEYOUT4                 |                    |       |        |  |  |  |
| KEYOUT[5]             | KEYOUT5                 |                    |       | GPIO25 |  |  |  |
| KEYOUT[6]             | KEYOUT6                 |                    |       | GPIO26 |  |  |  |
| KEYOUT[7]             | KEYOUT7                 | CLK_AUX1           |       | GPIO27 |  |  |  |
| KEYIN[0]              | KEYIN0                  |                    |       |        |  |  |  |
| KEYIN[1]              | KEYIN1                  |                    |       |        |  |  |  |
| KEYIN[2]              | KEYIN2                  | MRTCK              |       |        |  |  |  |
| KEYIN[3]              | KEYIN3                  |                    |       |        |  |  |  |
| KEYIN[4]              | KEYIN4                  |                    |       |        |  |  |  |
| KEYIN[5]              | KEYIN5                  |                    |       | GPIO28 |  |  |  |
| KEYIN[6]              | KEYIN6                  |                    |       | EIC0   |  |  |  |
| KEYIN[7]              | KEYIN7                  |                    |       | EIC1   |  |  |  |
|                       | SPI In                  | terface (5 Pins)   |       |        |  |  |  |
| SPI_DI                | SPI_DI                  | IISDI_VBDA         |       | GPIO29 |  |  |  |
| SPI_CLK               | SPI_CLK                 | IISCLK_VBDA        |       | GPIO30 |  |  |  |
| SPI_DO                | SPI_DO                  | IISLRCK_VBDA       |       | GPIO31 |  |  |  |
| SPI_CSN[0]            | SPI_CSN0                |                    |       | GPIO32 |  |  |  |
| SPI_CSN[1]            | SPI_CSN1                |                    |       | GPIO33 |  |  |  |
|                       | JTAG Interface (5 Pins) |                    |       |        |  |  |  |



| Pin Name              | Mode0     | Mode1              | Mode2     | Mode3  |
|-----------------------|-----------|--------------------|-----------|--------|
| MTDO                  | MTDO      |                    | DTDO      | GPIO34 |
| MTDI                  | MTDI      |                    | DTDI      | GPIO35 |
| MTCK                  | MTCK      |                    | DTCK      | GPIO36 |
| MTMS                  | MTMS      |                    | DTMS      | GPIO37 |
| MTRST_N               | MTRST_N   |                    | DRTCK     | GPIO38 |
|                       | TRAC      | E PORT(10pin)      |           |        |
| TRACECLK              | TRACECLK  |                    | SPI1_DI   | GPIO41 |
| TRACECTRL             | TRACECTRL |                    | SPI1_CLK  | GPIO42 |
| TRACEDAT0             | TRACEDAT0 |                    | SPI1_DO   | GPIO43 |
| TRACEDAT1             | TRACEDAT1 |                    | SPI1_CSN0 | GPIO44 |
| TRACEDAT2             | TRACEDAT2 |                    | SPI1_CSN1 | GPIO65 |
| TRACEDAT3             | TRACEDAT3 | IIS1DI             |           | GPIO66 |
| TRACEDAT4             | TRACEDAT4 | IIS1DO             |           | GPIO67 |
| TRACEDAT5             | TRACEDAT5 | IIS1CLK            |           | GPIO68 |
| TRACEDAT6             | TRACEDAT6 | IIS1LRCK           |           | GPIO69 |
| TRACEDAT7             | TRACEDAT7 | IIS1MCK            |           | GPIO70 |
|                       | UART0     | Interface (4 Pins) |           |        |
| U0TXD                 | U0TXD     |                    | SPI_DO    |        |
| U0RXD                 | U0RXD     |                    | SPI_DI    |        |
| U0CTS                 | U0CTS     | U2CTS              | SPI_CSN0  |        |
| U0RTS                 | U0RTS     | U2RTS              | SPI_CLK   |        |
| UART1 Interface (2 Pi | ns)       |                    |           |        |
| U2TXD                 | U2TXD     |                    |           |        |
| U2RXD                 | U2RXD     |                    |           |        |
| UART2 Interface (2 Pi | ns)       |                    |           |        |
| U1TXD                 | U1TXD     |                    |           |        |
| U1RXD                 | U1RXD     |                    |           |        |
|                       | LCD Int   | terface (25 Pins)  |           |        |
| LCD_CSN1              | LCD_CSN1  | CLK_RTC            |           | GPIO62 |
| LCD_RSTN              | LCD_RSTN  |                    |           |        |
| LCD_CD                | LCD_CD    |                    |           |        |
| LCD_D[0]              | LCD_D0    |                    |           |        |
| LCD_D[1]              | LCD_D1    |                    |           |        |
| LCD_D[2]              | LCD_D2    |                    |           |        |
| LCD_D[3]              | LCD_D3    |                    |           |        |
| LCD_D[4]              | LCD_D4    |                    |           |        |



| Pin Name  | Mode0     | Mode1              | Mode2 | Mode3  |
|-----------|-----------|--------------------|-------|--------|
| LCD_D[5]  | LCD_D5    |                    |       |        |
| LCD_D[6]  | LCD_D6    |                    |       |        |
| LCD_D[7]  | LCD_D7    | utmifs_speed       |       |        |
| LCD_D[8]  | LCD_D8    | utmifs_suspend     |       |        |
| LCD_WRN   | LCD_WRN   |                    |       |        |
| LCD_RDN   | LCD_RDN   |                    |       |        |
| LCD_CSN0  | LCD_CSN0  |                    |       |        |
| LCD_D[9]  | LCD_D9    | utmifs_tx_enable   |       |        |
| LCD_D[10] | LCD_D10   | utmifs_tx_dat      |       |        |
| LCD_D[11] | LCD_D11   | utmifs_tx_se0      |       |        |
| LCD_D[12] | LCD_D12   | utmifs_int         |       |        |
| LCD_D[13] | LCD_D13   | utmifs_rx_dp       |       |        |
| LCD_D[14] | LCD_D14   | utmifs_rx_dm       |       |        |
| LCD_D[15] | LCD_D15   | utmifs_rx_rcv      |       |        |
| LCD_D[16] | LCD_D16   |                    |       | GPIO63 |
| LCD_D[17] | LCD_D17   |                    |       | GPIO64 |
| LCD_D[18] | LCD_D18   |                    |       | GPIO75 |
| LCD_D[19] | LCD_D19   |                    |       | GPIO76 |
| LCD_D[20] | LCD_D20   |                    |       | GPIO77 |
| LCD_D[21] | LCD_D21   |                    |       | GPIO78 |
| LCD_D[22] | LCD_D22   |                    |       | GPIO79 |
| LCD_D[23] | LCD_D23   |                    |       | GPIO80 |
| LCD_FMARK | LCD_FMARK |                    |       | GPIO81 |
|           | Nand Ir   | nterface (23 Pins) |       |        |
| NFWPN     | NFWPN     |                    |       |        |
| NFRB      | NFRB      |                    |       |        |
| NFCLE     | NFCLE     |                    |       |        |
| NFALE     | NFALE     |                    |       |        |
| NFCEN0    | NFCEN0    |                    |       |        |
| NFCEN1    | NFCEN1    |                    |       | GPIO71 |
| NFWEN     | NFWEN     |                    |       |        |
| NFREN     | NFREN     |                    |       |        |
| NFD[0]    | NFD0      |                    |       |        |
| NFD[1]    | NFD1      |                    |       |        |
| NFD[2]    | NFD2      |                    |       |        |
| NFD[3]    | NFD3      |                    |       |        |



| Pin Name            | Mode0   | Mode1    | Mode2 | Mode3  |
|---------------------|---------|----------|-------|--------|
| NFD[4]              | NFD4    |          |       |        |
| NFD[5]              | NFD5    |          |       |        |
| NFD[6]              | NFD6    |          |       |        |
| NFD[7]              | NFD7    |          |       |        |
| NFD[8]              | NFD8    | CLK_AUX1 |       | GPIO45 |
| NFD[9]              | NFD9    |          |       | GPIO46 |
| NFD[10]             | NFD10   |          |       | GPIO47 |
| NFD[11]             | NFD11   |          |       | GPIO48 |
| NFD[12]             | NFD12   |          |       | GPIO49 |
| NFD[13]             | NFD13   |          |       | GPIO50 |
| NFD[14]             | NFD14   |          |       | GPIO51 |
| NFD[15]             | NFD15   |          |       | GPIO52 |
| EMC Interface (68 P | ins)    |          |       |        |
| EMRST_N             | EMRST_N |          |       | GPIO40 |
| EMA[0]              | EMA0    |          |       |        |
| EMA[1]              | EMA1    |          |       |        |
| EMA[2]              | EMA2    |          |       |        |
| EMA[3]              | EMA3    |          |       |        |
| EMA[4]              | EMA4    |          |       |        |
| EMA[5]              | EMA5    |          |       |        |
| EMA[6]              | EMA6    | >        |       |        |
| EMA[7]              | EMA7    |          |       |        |
| EMA[8]              | EMA8    |          |       |        |
| EMA[9]              | EMA9    |          |       |        |
| EMA[10]             | EMA10   |          |       |        |
| EMA[11]             | EMA11   |          |       |        |
| EMA[12]             | EMA12   |          |       |        |
| EMA[13]             | EMA13   |          |       |        |
| EMD[0]              | EMD0    |          |       |        |
| EMD[1]              | EMD1    |          |       |        |
| EMD[2]              | EMD2    |          |       |        |
| EMD[3]              | EMD3    |          |       |        |
| EMD[4]              | EMD4    |          |       |        |
| EMD[5]              | EMD5    |          |       |        |
| EMD[6]              | EMD6    |          |       |        |
| EMD[7]              | EMD7    |          |       |        |



| Pin Name | Mode0    | Mode1   | Mode2   | Mode3  |
|----------|----------|---------|---------|--------|
| EMDQM[0] | EMDQM0   |         |         |        |
| EMDQS[0] | EMDQS0   |         |         | GPIO54 |
| EMD[8]   | EMD8     |         |         |        |
| EMD[9]   | EMD9     |         |         |        |
| EMD[10]  | EMD10    |         |         |        |
| EMD[11]  | EMD11    |         |         |        |
| EMD[12]  | EMD12    |         |         |        |
| EMD[13]  | EMD13    |         |         |        |
| EMD[14]  | EMD14    |         |         |        |
| EMD[15]  | EMD15    |         |         |        |
| EMDQM[1] | EMDQM1   |         |         |        |
| EMDQS[1] | EMDQS1   |         |         | GPIO55 |
| EMD[16]  | EMD16    |         |         |        |
| EMD[17]  | EMD17    |         |         |        |
| EMCKE[1] | EMCKE1   |         |         | GPIO53 |
| EMD[18]  | EMD18    |         |         |        |
| EMD[19]  | EMD19    |         |         |        |
| EMD[20]  | EMD20    |         |         |        |
| EMD[21]  | EMD21    |         |         |        |
| EMD[22]  | EMD22    |         |         |        |
| EMD[23]  | EMD23    |         |         |        |
| EMDQM[2] | EMDQM2   |         |         |        |
| EMDQS[2] | EMDQS2   |         |         | GPIO56 |
| EMD[24]  | EMD24    |         |         |        |
| EMD[25]  | EMD25    |         |         |        |
| EMD[26]  | EMD26    |         |         |        |
| EMD[27]  | EMD27    |         |         |        |
| EMD[28]  | EMD28    |         |         |        |
| EMD[29]  | EMD29    |         |         |        |
| EMD[30]  | EMD30    |         |         |        |
| EMD[31]  | EMD31    |         |         |        |
| EMDQM[3] | EMDQM3   |         |         |        |
| EMDQS[3] | EMDQS3   |         |         | GPIO57 |
| CLKDPMEM | CLKDPMEM | CLK_DSP |         |        |
| CLKDMMEM | CLKDMMEM | CLK_RTC | CLK_AHB | GPIO58 |
| EMRAS_N  | EMRAS_N  |         |         |        |



| Pin Name                | Mode0     | Mode1               | Mode2        | Mode3  |
|-------------------------|-----------|---------------------|--------------|--------|
| EMCAS_N                 | EMCAS_N   |                     |              |        |
| EMWE_N                  | EMWE_N    |                     |              |        |
| EMCS_N[0]               | EMCS_N0   |                     |              |        |
| EMCS_N[1]               | EMCS_N1   |                     |              |        |
| EMBA[0]                 | EMBA0     |                     |              | ı      |
| EMBA[1]                 | EMBA1     |                     |              |        |
| EMCKE[0]                | EMCKE0    |                     |              | GPIO61 |
|                         | DCAM Ir   | nterface (15 Pins)  |              |        |
| CCIRMCLK                | CCIRMCLK  |                     | CLK_DSP      |        |
| CCIR_CK                 | CCIR_CK   | RFT_GPO8            |              |        |
| CCIR_HS                 | CCIR_HS   | RFT_GPO9            |              |        |
| CCIR_VS                 | CCIR_VS   | RFT_GPO10           |              |        |
| CCIR_D[0]               | CCIR_D0   |                     | IISLRCK_VBDA |        |
| CCIR_D[1]               | CCIR_D1   |                     | IISDI_VBDA   |        |
| CCIR_D[2]               | CCIR_D2   | RFT_GPO0            | IISCLK_VBDA  |        |
| CCIR_D[3]               | CCIR_D3   | RFT_GPO1            |              |        |
| CCIR_D[4]               | CCIR_D4   | RFT_GPO2            |              |        |
| CCIR_D[5]               | CCIR_D5   | RFT_GPO3            |              |        |
| CCIR_D[6]               | CCIR_D6   | RFT_GPO4            |              |        |
| CCIR_D[7]               | CCIR_D7   | RFT_GPO5            |              |        |
| CCIRRST                 | CCIRRST   | RFT_GPO6            |              | GPIO72 |
| CCIRPD1                 | CCIRPD1   | RFT_GPO7            |              | GPIO73 |
| CCIRPD0                 | CCIRPD0   |                     |              | GPIO74 |
| I2C0 Interface (2 Pins) |           |                     |              |        |
| SCL0                    | SCL0      |                     |              |        |
| SDA0                    | SDA0      |                     |              |        |
|                         |           |                     |              |        |
| SCL1                    | SCL1      |                     |              |        |
| SDA1                    | SDA1      |                     |              |        |
|                         |           |                     |              |        |
| SCL2                    | SCL2      |                     |              |        |
| SDA2                    | SDA2 SDA2 |                     |              |        |
|                         |           |                     |              |        |
| SCL3                    | SCL3      |                     |              |        |
| SDA3                    | SDA3      |                     |              |        |
|                         | Aux Cloc  | k Interface (1 Pin) |              |        |



| Pin Name               | Mode0     | Mode1                 | Mode2   | Mode3   |
|------------------------|-----------|-----------------------|---------|---------|
| CLK_AUX0               | CLK_AUX0  |                       |         | GPIO82  |
| IIS Interface (5 Pins) |           |                       |         |         |
| IISDI                  | IISDI     | DTDO                  |         | GPIO83  |
| IISDO                  | IISDO     | DTDI                  |         | GPIO84  |
| IISCLK                 | IISCLK    | DTCK                  | ttout0p | GPIO85  |
| IISLRCK                | IISLRCK   | DTMS                  |         | GPIO86  |
| IISMCK                 | IISMCK    | DRTCK                 | BTXLEN  | EIC2    |
|                        | RF Inte   | erface (19 Pins)      |         |         |
| RFSDA0                 | RFSDA0    |                       |         | GPIO87  |
| RFSCK0                 | RFSCK0    |                       |         | GPIO88  |
| RFSEN0                 | RFSEN0    |                       | CAL     | GPIO89  |
| RFCTL[0]               | RFCTL0    |                       |         | GPIO90  |
| RFCTL[1]               | RFCTL1    |                       |         | GPIO91  |
| RFCTL[2]               | RFCTL2    |                       |         | GPIO92  |
| RFCTL[3]               | RFCTL3    | PWMA                  |         | GPIO93  |
| RFCTL[4]               | RFCTL4    | PWMB                  |         | GPIO94  |
| RFCTL[5]               | RFCTL5    |                       |         | GPIO95  |
| RFCTL[6]               | RFCTL6    | PWMC                  |         | GPIO96  |
| RFCTL[7]               | RFCTL7    |                       |         | GPIO97  |
| RFCTL[8]               | RFCTL8    |                       |         | GPIO98  |
| RFCTL[9]               | RFCTL9    | PWMD                  |         | GPIO99  |
| RFCTL[10]              | RFCTL10   | ttout1p               |         | GPIO100 |
| RFCTL[11]              | RFCTL11   |                       |         | GPIO101 |
| RFCTL[12]              | RFCTL12   |                       |         | GPIO102 |
| RFCTL[13]              | RFCTL13   |                       |         | GPIO103 |
| RFCTL[14]              | RFCTL14   |                       |         | GPIO104 |
| RFCTL[15]              | RFCTL15   |                       |         | GPIO105 |
|                        | Touch Pan | el Interface (4 Pins) |         |         |
| TP_XL                  | TP_XL     |                       |         | GPIO202 |
| TP_XR                  | TP_XR     |                       |         | GPIO203 |
| TP_YU                  | TP_YU     |                       |         | GPIO204 |
| TP_YD                  | TP_YD     |                       |         | GPIO205 |



# 3.1.4 Control Registers

### 3.1.4.1 Memory map

ARM base address: 0x8C00\_0000

| Offset Address | Pin Name     | Default Value after<br>Reset |
|----------------|--------------|------------------------------|
| 0x0004         | ANA_INT      | 10'h100                      |
| 0x0008         | EXT_RST_B    | 10'h100                      |
| 0x000C         | CHIP_SLEEP   | 10'h100                      |
| 0x0010         | XTL_BUF_EN   | 10'h100                      |
| 0x0014         | VBDA_D       | 10'h101                      |
| 0x0018         | VBDA_LR      | 10'h100                      |
| 0x001C         | VBDA_SCLK    | 10'h100                      |
| 0x0020         | VBAD_D       | 10'h100                      |
| 0x0024         | VBAD_LR      | 10'h100                      |
| 0x0028         | VBAD_SCLK    | 10'h100                      |
| 0x0034         | GSM_TXPD     | 10'h100                      |
| 0x0038         | GSM_RXPD     | 10'h100                      |
| 0x0040         | CLK_32K      | 10'h100                      |
| 0x0044         | CLK_26M      | 10'h100                      |
| 0x0048         | ADI_D        | 10'h100                      |
| 0x004C         | ADI_SYNC     | 10'h101                      |
| 0x0050         | ADI_SCLK     | 10'h101                      |
| 0x0054         | IF_SPR       | 10'h100                      |
| 0x0058         | COM_TX_APCD  | 10'h100                      |
| 0x005C         | COM_TX_DQ[1] | 10'h100                      |
| 0x0060         | COM_TX_DQ[0] | 10'h100                      |
| 0x0064         | COM_TX_DI[1] | 10'h100                      |
| 0x0068         | COM_TX_DI[0] | 10'h100                      |
| 0x006C         | COM_TX_SYNC  | 10'h100                      |
| 0×0070         | COM_TX_SCLK  | 10'h100                      |
| 0x0074         | COM_RX_DQ[1] | 10'h100                      |
| 0x0078         | COM_RX_DQ[0] | 10'h100                      |
| 0x007C         | COM_RX_DI[1] | 10'h100                      |
| 0x0080         | COM_RX_DI[0] | 10'h100                      |
| 0x0084         | COM_RX_SYNC  | 10'h100                      |
| 0x0088         | COM_RX_SCLK  | 10'h100                      |
| 0x008C         | SIMCLK0      | 10'h100                      |
| 0x0090         | SIMDA0       | 10'h180                      |



| 0x0094 | SIMRST0   | 10'h100 |
|--------|-----------|---------|
| 0x0098 | SIMCLK1   | 10'h100 |
| 0x009C | SIMDA1    | 10'h180 |
| 0x00A0 | SIMRST1   | 10'h100 |
| 0x00A4 | SD0_CLK   | 10'h100 |
| 0x00A8 | SD_CMD    | 10'h180 |
| 0x00AC | SD_D[0]   | 10'h180 |
| 0x00B0 | SD_D[1]   | 10'h180 |
| 0x00B4 | SD_D[2]   | 10'h180 |
| 0x00B8 | SD_D[3]   | 10'h180 |
| 0x00BC | SD1_CLK   | 10'h100 |
| 0x00C0 | KEYOUT[0] | 10'h100 |
| 0x00C4 | KEYOUT[1] | 10'h100 |
| 0x00C8 | KEYOUT[2] | 10'h100 |
| 0x00CC | KEYOUT[3] | 10'h100 |
| 0x00D0 | KEYOUT[4] | 10'h100 |
| 0x00D4 | KEYOUT[5] | 10'h100 |
| 0x00D8 | KEYOUT[6] | 10'h100 |
| 0x00DC | KEYOUT[7] | 10'h100 |
| 0x00E0 | KEYIN[0]  | 10'h180 |
| 0x00E4 | KEYIN[1]  | 10'h180 |
| 0x00E8 | KEYIN[2]  | 10'h180 |
| 0x00EC | KEYIN[3]  | 10'h180 |
| 0x00F0 | KEYIN[4]  | 10'h180 |
| 0x00F4 | KEYIN[5]  | 10'h180 |
| 0x00F8 | KEYIN[6]  | 10'h180 |
| 0x00FC | KEYIN[7]  | 10'h180 |
| 0x0100 | SPI_DI    | 10'h18A |
| 0x0104 | SPI_CLK   | 10'h106 |
| 0x0108 | SPI_DO    | 10'h10A |
| 0x010C | SPI_CSN0  | 10'h10A |
| 0x0110 | SPI_CSN1  | 10'h106 |
| 0x0114 | MTDO      | 10'h101 |
| 0x0118 | MTDI      | 10'h18A |
| 0x011C | MTCK      | 10'h146 |
| 0x0120 | MTMS      | 10'h18A |
| 0x0124 | MTRST_N   | 10'h18A |
| 0x0128 | U0TXD     | 10'h100 |
|        | •         | •       |



| 0x012C | U0RXD   | 10'h180 |
|--------|---------|---------|
| 0x0130 | U0CTS   | 10'h180 |
| 0x0134 | U0RTS   | 10'h100 |
| 0x0138 | U1TXD   | 10'h100 |
| 0x013C | U1RXD   | 10'h180 |
| 0x0140 | NFWPN   | 10'h100 |
| 0x0144 | NFRB    | 10'h180 |
| 0x0148 | NFCLE   | 10'h100 |
| 0x014C | NFALE   | 10'h100 |
| 0x0150 | NFCEN0  | 10'h100 |
| 0x0154 | NFWEN   | 10'h100 |
| 0x0158 | NFREN   | 10'h100 |
| 0x015C | NFD[0]  | 10'h100 |
| 0x0160 | NFD[1]  | 10'h100 |
| 0x0164 | NFD[2]  | 10'h100 |
| 0x0168 | NFD[3]  | 10'h100 |
| 0x016C | NFD[4]  | 10'h100 |
| 0x0170 | NFD[5]  | 10'h100 |
| 0x0174 | NFD[6]  | 10'h100 |
| 0x0178 | NFD[7]  | 10'h100 |
| 0x017C | NFD[8]  | 10'h100 |
| 0x0180 | NFD[9]  | 10'h100 |
| 0x0184 | NFD[10] | 10'h100 |
| 0x0188 | NFD[11] | 10'h100 |
| 0x018C | NFD[12] | 10'h100 |
| 0x0190 | NFD[13] | 10'h100 |
| 0x0194 | NFD[14] | 10'h100 |
| 0x0198 | NFD[15] | 10'h100 |
| 0x019C | EMRST_N | 10'h100 |
| 0x01A0 | EMA[0]  | 10'h100 |
| 0x01A4 | EMA[1]  | 10'h100 |
| 0x01A8 | EMA[2]  | 10'h100 |
| 0x01AC | EMA[3]  | 10'h100 |
| 0x01B0 | EMA[4]  | 10'h100 |
| 0x01B4 | EMA[5]  | 10'h100 |
| 0x01B8 | EMA[6]  | 10'h100 |
| 0x01BC | EMA[7]  | 10'h100 |
| 0x01C0 | EMA[8]  | 10'h100 |
|        |         |         |



| 0x01C4 | EMA[9]   | 10'h100 |
|--------|----------|---------|
| 0x01C8 | EMA[10]  | 10'h100 |
| 0x01CC | EMA[11]  | 10'h100 |
| 0x01D0 | EMA[12]  | 10'h100 |
| 0x01D4 | EMA[13]  | 10'h100 |
| 0x01D8 | EMCKE[1] | 10'h100 |
| 0x01DC | EMD[0]   | 10'h100 |
| 0x01E0 | EMD[1]   | 10'h100 |
| 0x01E4 | EMD[2]   | 10'h100 |
| 0x01E8 | EMD[3]   | 10'h100 |
| 0x01EC | EMD[4]   | 10'h100 |
| 0x01F0 | EMD[5]   | 10'h100 |
| 0x01F4 | EMD[6]   | 10'h100 |
| 0x01F8 | EMD[7]   | 10'h100 |
| 0x01FC | EMDQM[0] | 10'h100 |
| 0x0200 | EMDQS[0] | 10'h100 |
| 0x0204 | EMD[8]   | 10'h100 |
| 0x0208 | EMD[9]   | 10'h100 |
| 0x020C | EMD[10]  | 10'h100 |
| 0x0210 | EMD[11]  | 10'h100 |
| 0x0214 | EMD[12]  | 10'h100 |
| 0x0218 | EMD[13]  | 10'h100 |
| 0x021C | EMD[14]  | 10'h100 |
| 0x0220 | EMD[15]  | 10'h100 |
| 0x0224 | EMDQM[1] | 10'h100 |
| 0x0228 | EMDQS[1] | 10'h100 |
| 0x022C | EMD[16]  | 10'h100 |
| 0x0230 | EMD[17]  | 10'h100 |
| 0x0234 | EMD[18]  | 10'h100 |
| 0x0238 | EMD[19]  | 10'h100 |
| 0x023C | EMD[20]  | 10'h100 |
| 0x0240 | EMD[21]  | 10'h100 |
| 0x0244 | EMD[22]  | 10'h100 |
| 0x0248 | EMD[23]  | 10'h100 |
| 0x024C | EMDQM[2] | 10'h100 |
| 0x0250 | EMDQS[2] | 10'h100 |
| 0x0254 | EMD[24]  | 10'h100 |
| 0x0258 | EMD[25]  | 10'h100 |
|        | 1        | 1       |



| 0x025C | EMD[26]     | 10'h100 |
|--------|-------------|---------|
| 0x0260 | EMD[27]     | 10'h100 |
| 0x0264 | EMD[28]     | 10'h100 |
| 0x0268 | EMD[29]     | 10'h100 |
| 0x026C | EMD[30]     | 10'h100 |
| 0x0270 | EMD[31]     | 10'h100 |
| 0x0274 | EMDQM[3]    | 10'h100 |
| 0x0278 | EMDQS[3]    | 10'h100 |
| 0x027C | CLKDPMEM    | 10'h100 |
| 0x0280 | CLKDMMEM    | 10'h100 |
| 0x0284 | EMRAS_N     | 10'h100 |
| 0x0288 | EMCAS_N     | 10'h100 |
| 0x028C | EMWE_N      | 10'h100 |
| 0x0290 | EMCS_N[0]   | 10'h100 |
| 0x0294 | EMCS_N[1]   | 10'h100 |
| 0x0298 | EMGPRE_LOOP | 10'h100 |
| 0x029C | EMGPST_LOOP | 10'h100 |
| 0x02A0 | EMBA[0]     | 10'h100 |
| 0x02A4 | EMBA[1]     | 10'h100 |
| 0x02A8 | EMCKE[0]    | 10'h100 |
| 0x02AC | LCD_CSN1    | 10'h100 |
| 0x02B0 | LCD_RSTN    | 10'h100 |
| 0x02B4 | LCD_CD      | 10'h100 |
| 0x02B8 | LCD_D[0]    | 10'h100 |
| 0x02BC | LCD_D[1]    | 10'h100 |
| 0x02C0 | LCD_D[2]    | 10'h100 |
| 0x02C4 | LCD_D[3]    | 10'h100 |
| 0x02C8 | LCD_D[4]    | 10'h100 |
| 0x02CC | LCD_D[5]    | 10'h100 |
| 0x02D0 | LCD_D[6]    | 10'h100 |
| 0x02D4 | LCD_D[7]    | 10'h100 |
| 0x02D8 | LCD_D[8]    | 10'h100 |
| 0x02DC | LCD_WRN     | 10'h100 |
| 0x02E0 | LCD_RDN     | 10'h100 |
| 0x02E4 | LCD_CSN0    | 10'h100 |
| 0x02E8 | LCD_D[9]    | 10'h100 |
| 0x02EC | LCD_D[10]   | 10'h100 |
| 0x02F0 | LCD_D[11]   | 10'h100 |
|        |             |         |



| 0x02F4         LCD_D[12]         10h100           0x02F8         LCD_D[13]         10h100           0x02FC         LCD_D[14]         10h100           0x0300         LCD_D[15]         10h100           0x0304         LCD_D[16]         10h100           0x0308         LCD_D[17]         10h100           0x030C         LCD_FMARK         10h180           0x0310         CCIRMCLK         10h100           0x0314         CCIRCK         10h100           0x0318         CCIRHS         10h100           0x0310         CCIRD(S         10h100           0x0320         CCIRD(D)         10h100           0x0324         CCIRD(D)         10h100           0x0328         CCIRD(E)         10h100           0x0329         CCIRD(E)         10h100           0x0320         CCIRD(E)         10h100           0x0321         CCIRD(E)         10h100           0x0322         CCIRD(E)         10h100           0x0334         CCIRD(E)         10h100           0x0334         CCIRD(E)         10h100           0x0334         CCIRD(E)         10h100           0x0344         CCIRPD(E)         10h100     <                                            |        | T         |         |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|---------|--|--|--|--|
| 0x02FC         LCD_D[14]         10h100           0x0300         LCD_D[15]         10h100           0x0304         LCD_D[16]         10h100           0x0308         LCD_D[17]         10h100           0x030C         LCD_FMARK         10h100           0x0310         CCIRMCLK         10h100           0x0314         CCIRCK         10h100           0x0318         CCIRHS         10h100           0x031C         CCIRVS         10h100           0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x0320         CCIRD[3]         10h100           0x0321         CCIRD[4]         10h100           0x0322         CCIRD[5]         10h100           0x0334         CCIRD[6]         10h100           0x0334         CCIRD[6]         10h100           0x0338         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0348         CCIRPD0         10h100           0x0350         SDA1         10h180 <t< td=""><td></td><td></td><td></td></t<>                  |        |           |         |  |  |  |  |
| 0x0300         LCD_D[15]         10h100           0x0304         LCD_D[16]         10h100           0x0308         LCD_D[17]         10h100           0x030C         LCD_FMARK         10h180           0x0310         CCIRMCLK         10h100           0x0314         CCIRCK         10h100           0x0318         CCIRHS         10h100           0x031C         CCIRVS         10h100           0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x0320         CCIRD[3]         10h100           0x0322         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x0320         CCIRD[1]         10h100           0x0321         10h100         0x032           0x0322         CCIRD[3]         10h100           0x0332         CCIRD[4]         10h100           0x0334         CCIRD[5]         10h100           0x0334         CCIRD[5]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100      <                                                     |        |           |         |  |  |  |  |
| 0x0304         LCD_D[16]         10h100           0x0308         LCD_D[17]         10h100           0x030C         LCD_FMARK         10h180           0x0310         CCIRMCLK         10h100           0x0314         CCIRCK         10h100           0x0318         CCIRHS         10h100           0x031C         CCIRVS         10h100           0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x0320         CCIRD[3]         10h100           0x0332         CCIRD[4]         10h100           0x0332         CCIRD[3]         10h100           0x0334         CCIRD[4]         10h100           0x0334         CCIRD[5]         10h100           0x0338         CCIRD[6]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0344         CCIRPD0         10h100           0x0346         SCL1         10h180           0x0350         SDA1         10h180           0x0354         CLK_AUXO         10h106                                                                   |        |           |         |  |  |  |  |
| 0x0308         LCD_D[17]         10h100           0x030C         LCD_FMARK         10h180           0x0310         CCIRMCLK         10h100           0x0314         CCIRCK         10h100           0x0318         CCIRHS         10h100           0x031C         CCIRVS         10h100           0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x0329         CCIRD[3]         10h100           0x0320         CCIRD[1]         10h100           0x0322         CCIRD[2]         10h100           0x0322         CCIRD[2]         10h100           0x0332         CCIRD[3]         10h100           0x0334         CCIRD[5]         10h100           0x0334         CCIRD[6]         10h100           0x0338         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0341         CCIRRST         10h100           0x0342         CCIRPD0         10h100           0x0343         CCIRPD0         10h100           0x0340         SCL1         10h180                                                                 | 0x0300 | LCD_D[15] | 10'h100 |  |  |  |  |
| 0x030C         LCD_FMARK         10h180           0x0310         CCIRMCLK         10h100           0x0314         CCIRCK         10h100           0x0318         CCIRHS         10h100           0x031C         CCIRVS         10h100           0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x0332C         CCIRD[3]         10h100           0x0333         CCIRD[4]         10h100           0x0334         CCIRD[5]         10h100           0x0338         CCIRD[6]         10h100           0x033C         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0344         CCIRPD0         10h100           0x0340         SCL1         10h180           0x0340         SCL1         10h180           0x0340         SCL1         10h100           0x0344         CCIRPD0         10h100           0x0345         SLL         10h140           0x0350         SDA1         10h106           0x035<                                                                 | 0x0304 | LCD_D[16] | 10'h100 |  |  |  |  |
| 0x0310         CCIRMCLK         10h100           0x0314         CCIRCK         10h100           0x0318         CCIRHS         10h100           0x031C         CCIRVS         10h100           0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x0320         CCIRD[3]         10h100           0x0321         10h100         0           0x0322         CCIRD[4]         10h100           0x0334         CCIRD[5]         10h100           0x0334         CCIRD[6]         10h100           0x0338         CCIRD[6]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0344         CCIRPD0         10h100           0x0348         CCIRPD0         10h100           0x0340         SCL1         10h180           0x0350         SDA1         10h180           0x0350         SDA1         10h106           0x0350         SDA1         10h106           0x0358         IISD0         10h146           0x0360                                                                        | 0x0308 | LCD_D[17] | 10'h100 |  |  |  |  |
| 0x0314         CCIRCK         10h100           0x0318         CCIRHS         10h100           0x031C         CCIRVS         10h100           0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x0320         CCIRD[3]         10h100           0x0330         CCIRD[4]         10h100           0x0334         CCIRD[6]         10h100           0x0338         CCIRD[6]         10h100           0x0336         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0348         CCIRPD0         10h100           0x0340         SCL1         10h180           0x0340         SCL1         10h100           0x0344         CCIRPD0         10h100           0x0348         CCIRPD0         10h100           0x0350         SDA1         10h180           0x0354         CLK_AUXO         10h106           0x0358         IISD0         10h146           0x0360         IISCLK         10h14A           0x036                                                                 | 0x030C | LCD_FMARK | 10'h180 |  |  |  |  |
| 0x031B         CCIRHS         10h100           0x031C         CCIRVS         10h100           0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x032C         CCIRD[3]         10h100           0x0330         CCIRD[4]         10h100           0x0334         CCIRD[5]         10h100           0x0338         CCIRD[6]         10h100           0x033C         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0348         CCIRPD0         10h100           0x0340         SCL1         10h180           0x0341         CCIRPD0         10h100           0x0342         SCL1         10h180           0x0350         SDA1         10h180           0x0354         CLK_AUXO         10h106           0x0358         IISDI         10h146           0x0360         IISCLK         10h14A           0x0364         IISLRCK         10h14A           0x0365         ISMCK         10h140           0x0370                                                                 | 0x0310 | CCIRMCLK  | 10'h100 |  |  |  |  |
| 0x031C         CCIRVS         10h100           0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x032C         CCIRD[3]         10h100           0x0330         CCIRD[4]         10h100           0x0334         CCIRD[5]         10h100           0x0338         CCIRD[6]         10h100           0x033C         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0348         CCIRPD0         10h100           0x0340         SCL1         10h180           0x0341         CCIRPD0         10h100           0x0342         SCL1         10h180           0x0350         SDA1         10h180           0x0354         CLK_AUX0         10h106           0x0358         IISDI         10h146           0x0360         IISCLK         10h14A           0x0364         IISLRCK         10h14A           0x0368         IISMCK         10h140           0x0370         RFSCK0         10h140           0x037                                                                 | 0x0314 | CCIRCK    | 10'h100 |  |  |  |  |
| 0x0320         CCIRD[0]         10h100           0x0324         CCIRD[1]         10h100           0x0328         CCIRD[2]         10h100           0x032C         CCIRD[3]         10h100           0x0330         CCIRD[4]         10h100           0x0334         CCIRD[5]         10h100           0x0338         CCIRD[6]         10h100           0x033C         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0348         CCIRPD0         10h100           0x0340         SCL1         10h180           0x0350         SDA1         10h180           0x0350         SDA1         10h180           0x0354         CLK_AUXO         10h106           0x0358         IISDI         10h106           0x0350         IISDO         10h10A           0x0360         IISCLK         10h14A           0x0361         IISCLK         10h14A           0x0362         RFSDA0         10h140           0x0370         RFSCKO         10h140           0x0374         RFSENO         10h100           0x0378 </td <td>0x0318</td> <td>CCIRHS</td> <td>10'h100</td>             | 0x0318 | CCIRHS    | 10'h100 |  |  |  |  |
| 0x0324         CCIRD[1]         10'h100           0x0328         CCIRD[2]         10'h100           0x032C         CCIRD[3]         10'h100           0x0330         CCIRD[4]         10'h100           0x0334         CCIRD[5]         10'h100           0x0338         CCIRD[6]         10'h100           0x033C         CCIRD[7]         10'h100           0x0340         CCIRRST         10'h100           0x0344         CCIRPD1         10'h100           0x0348         CCIRPD0         10'h100           0x0340         SCL1         10'h180           0x0350         SDA1         10'h180           0x0354         CLK_AUX0         10'h106           0x0358         IISDI         10'h146           0x035C         IISDO         10'h14A           0x0360         IISCLK         10'h14A           0x0368         IISMCK         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100  <                                                     | 0x031C | CCIRVS    | 10'h100 |  |  |  |  |
| 0x0328         CCIRD[2]         10'h100           0x032C         CCIRD[3]         10'h100           0x0330         CCIRD[4]         10'h100           0x0334         CCIRD[5]         10'h100           0x0338         CCIRD[6]         10'h100           0x033C         CCIRD[7]         10'h100           0x0340         CCIRRST         10'h100           0x0344         CCIRPD1         10'h100           0x0348         CCIRPD0         10'h100           0x034C         SCL1         10'h180           0x0350         SDA1         10'h180           0x0354         CLK_AUX0         10'h106           0x0358         IISDI         10'h146           0x035C         IISDO         10'h14A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h146           0x0365         IISMCK         10'h140           0x0370         RFSDA0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100 </td <td>0x0320</td> <td>CCIRD[0]</td> <td>10'h100</td> | 0x0320 | CCIRD[0]  | 10'h100 |  |  |  |  |
| 0x032C         CCIRD[3]         10h100           0x0330         CCIRD[4]         10h100           0x0334         CCIRD[5]         10h100           0x0338         CCIRD[6]         10h100           0x033C         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0348         CCIRPD0         10h100           0x034C         SCL1         10h180           0x0350         SDA1         10h180           0x0354         CLK_AUX0         10h106           0x0358         IISDI         10h146           0x035C         IISDO         10h10A           0x0360         IISCLK         10h14A           0x0364         IISLRCK         10h14A           0x0368         IISMCK         10h140           0x0370         RFSCK0         10h140           0x0374         RFSEN0         10h100           0x0378         RFCTL[0]         10h100           0x0380         RFCTL[2]         10h100           0x0384         RFCTL[3]         10h100                                                                                                                                | 0x0324 | CCIRD[1]  | 10'h100 |  |  |  |  |
| 0x0330         CCIRD[4]         10h100           0x0334         CCIRD[5]         10h100           0x0338         CCIRD[6]         10h100           0x033C         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0348         CCIRPD0         10h100           0x034C         SCL1         10h180           0x0350         SDA1         10h180           0x0354         CLK_AUX0         10h106           0x0358         IISDI         10h146           0x035C         IISDO         10h10A           0x0360         IISCLK         10h14A           0x0364         IISLRCK         10h14A           0x0365         IISMCK         10h14A           0x0366         RFSDA0         10h140           0x0370         RFSCK0         10h140           0x0374         RFSEN0         10h180           0x0378         RFCTL[0]         10h100           0x0380         RFCTL[2]         10h100           0x0384         RFCTL[3]         10h100                                                                                                                                  | 0x0328 | CCIRD[2]  | 10'h100 |  |  |  |  |
| 0x0334         CCIRD[5]         10'h100           0x0338         CCIRD[6]         10'h100           0x033C         CCIRD[7]         10'h100           0x0340         CCIRRST         10'h100           0x0344         CCIRPD1         10'h100           0x0348         CCIRPD0         10'h100           0x034C         SCL1         10'h180           0x0350         SDA1         10'h180           0x0354         CLK_AUX0         10'h106           0x0358         IISDI         10'h146           0x035C         IISDO         10'h10A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h14A           0x0368         IISMCK         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x0370         RFCTL[1]         10'h100           0x0370         RFCTL[2]         10'h100           0x0372         RFCTL[2]         10'h100           0x0380         RFCTL[2]         10'h100                                                                                                           | 0x032C | CCIRD[3]  | 10'h100 |  |  |  |  |
| 0x0338         CCIRD[6]         10'h100           0x033C         CCIRD[7]         10'h100           0x0340         CCIRRST         10'h100           0x0344         CCIRPD1         10'h100           0x0348         CCIRPD0         10'h100           0x034C         SCL1         10'h180           0x0350         SDA1         10'h180           0x0354         CLK_AUX0         10'h106           0x0358         IISDI         10'h146           0x035C         IISDO         10'h10A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h14A           0x0368         IISMCK         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x0370         RFCTL[1]         10'h100           0x0370         RFCTL[2]         10'h100           0x0372         RFCTL[2]         10'h100           0x0373         RFCTL[2]         10'h100                                                                                                                                                             | 0x0330 | CCIRD[4]  | 10'h100 |  |  |  |  |
| 0x033C         CCIRD[7]         10h100           0x0340         CCIRRST         10h100           0x0344         CCIRPD1         10h100           0x0348         CCIRPD0         10h100           0x034C         SCL1         10h180           0x0350         SDA1         10h180           0x0354         CLK_AUX0         10h106           0x0358         IISDI         10h146           0x035C         IISDO         10h10A           0x0360         IISCLK         10h14A           0x0364         IISLRCK         10h14A           0x0368         IISMCK         10h140           0x0370         RFSCK0         10h140           0x0374         RFSEN0         10h180           0x0378         RFCTL[0]         10h100           0x0380         RFCTL[1]         10h100           0x0384         RFCTL[3]         10h100                                                                                                                                                                                                                                                                                                                                    | 0x0334 | CCIRD[5]  |         |  |  |  |  |
| 0x0340         CCIRRST         10'h100           0x0344         CCIRPD1         10'h100           0x0348         CCIRPD0         10'h100           0x034C         SCL1         10'h180           0x0350         SDA1         10'h180           0x0354         CLK_AUX0         10'h106           0x0358         IISDI         10'h146           0x035C         IISDO         10'h10A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h14A           0x0368         IISMCK         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100                                                                                                                                                                                                                                                                                                                                                                     | 0x0338 | CCIRD[6]  |         |  |  |  |  |
| 0x0344         CCIRPD0         10'h100           0x0348         CCIRPD0         10'h100           0x034C         SCL1         10'h180           0x0350         SDA1         10'h180           0x0354         CLK_AUX0         10'h106           0x0358         IISDI         10'h146           0x035C         IISDO         10'h10A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h14A           0x0368         IISMCK         10'h146           0x036C         RFSDA0         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x037C         RFCTL[0]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                      | 0x033C | CCIRD[7]  | 10'h100 |  |  |  |  |
| 0x0348         CCIRPD0         10'h100           0x034C         SCL1         10'h180           0x0350         SDA1         10'h180           0x0354         CLK_AUX0         10'h106           0x0358         IISDI         10'h146           0x035C         IISDO         10'h10A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h14A           0x0368         IISMCK         10'h146           0x036C         RFSDA0         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                     | 0x0340 | CCIRRST   | 10'h100 |  |  |  |  |
| 0x034C         SCL1         10'h180           0x0350         SDA1         10'h180           0x0354         CLK_AUX0         10'h106           0x0358         IISDI         10'h146           0x035C         IISDO         10'h10A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h14A           0x0368         IISMCK         10'h146           0x036C         RFSDA0         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0344 | CCIRPD1   | 10'h100 |  |  |  |  |
| 0x0350         SDA1         10h180           0x0354         CLK_AUX0         10h106           0x0358         IISDI         10h146           0x035C         IISDO         10h10A           0x0360         IISCLK         10h14A           0x0364         IISLRCK         10h14A           0x0368         IISMCK         10h146           0x036C         RFSDA0         10h140           0x0370         RFSCK0         10h140           0x0374         RFSEN0         10h180           0x0378         RFCTL[0]         10h100           0x037C         RFCTL[1]         10h100           0x0380         RFCTL[2]         10h100           0x0384         RFCTL[3]         10h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0348 | CCIRPD0   | 10'h100 |  |  |  |  |
| 0x0354         CLK_AUX0         10'h106           0x0358         IISDI         10'h146           0x035C         IISDO         10'h10A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h14A           0x0368         IISMCK         10'h146           0x036C         RFSDA0         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x034C | SCL1      | 10'h180 |  |  |  |  |
| 0x0358         IISDI         10'h146           0x035C         IISDO         10'h10A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h14A           0x0368         IISMCK         10'h146           0x036C         RFSDA0         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0350 | SDA1      | 10'h180 |  |  |  |  |
| 0x035C         IISDO         10'h10A           0x0360         IISCLK         10'h14A           0x0364         IISLRCK         10'h14A           0x0368         IISMCK         10'h146           0x036C         RFSDA0         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0354 | CLK_AUX0  | 10'h106 |  |  |  |  |
| 0x0360       IISCLK       10'h14A         0x0364       IISLRCK       10'h14A         0x0368       IISMCK       10'h146         0x036C       RFSDA0       10'h140         0x0370       RFSCK0       10'h140         0x0374       RFSEN0       10'h180         0x0378       RFCTL[0]       10'h100         0x037C       RFCTL[1]       10'h100         0x0380       RFCTL[2]       10'h100         0x0384       RFCTL[3]       10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x0358 | IISDI     | 10'h146 |  |  |  |  |
| 0x0364       IISLRCK       10'h14A         0x0368       IISMCK       10'h146         0x036C       RFSDA0       10'h140         0x0370       RFSCK0       10'h140         0x0374       RFSEN0       10'h180         0x0378       RFCTL[0]       10'h100         0x037C       RFCTL[1]       10'h100         0x0380       RFCTL[2]       10'h100         0x0384       RFCTL[3]       10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x035C | IISDO     | 10'h10A |  |  |  |  |
| 0x0368         IISMCK         10'h146           0x036C         RFSDA0         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0360 | IISCLK    | 10'h14A |  |  |  |  |
| 0x036C         RFSDA0         10'h140           0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0364 | IISLRCK   | 10'h14A |  |  |  |  |
| 0x0370         RFSCK0         10'h140           0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0368 | IISMCK    | 10'h146 |  |  |  |  |
| 0x0374         RFSEN0         10'h180           0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x036C | RFSDA0    | 10'h140 |  |  |  |  |
| 0x0378         RFCTL[0]         10'h100           0x037C         RFCTL[1]         10'h100           0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0370 | RFSCK0    | 10'h140 |  |  |  |  |
| 0x037C       RFCTL[1]       10'h100         0x0380       RFCTL[2]       10'h100         0x0384       RFCTL[3]       10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0374 | RFSEN0    | 10'h180 |  |  |  |  |
| 0x0380         RFCTL[2]         10'h100           0x0384         RFCTL[3]         10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0378 | RFCTL[0]  | 10'h100 |  |  |  |  |
| 0x0384 RFCTL[3] 10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x037C | RFCTL[1]  | 10'h100 |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0380 | RFCTL[2]  | 10'h100 |  |  |  |  |
| 0x0388 RFCTL[4] 10'h100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0384 | RFCTL[3]  | 10'h100 |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0388 | RFCTL[4]  | 10'h100 |  |  |  |  |



| 0x038C | RFCTL[5]  | 10'h100 |
|--------|-----------|---------|
| 0x0390 | RFCTL[6]  | 10'h100 |
| 0x0394 | RFCTL[7]  | 10'h100 |
| 0x0398 | RFCTL[8]  | 10'h100 |
| 0x039C | RFCTL[9]  | 10'h100 |
| 0x03A0 | RFCTL[10] | 10'h100 |
| 0x03A4 | RFCTL[11] | 10'h100 |
| 0x03A8 | RFCTL[12] | 10'h100 |
| 0x03AC | RFCTL[13] | 10'h100 |
| 0x03B0 | RFCTL[14] | 10'h100 |
| 0x03B4 | RFCTL[15] | 10'h100 |
| 0x03B8 | XTL_EN    | 10'h101 |
| 0x03BC | PTEST     | 10'h101 |
| 0x03C0 | GPIO135   | 10'h100 |
| 0x03C4 | GPIO136   | 10'h100 |
| 0x03C8 | GPIO137   | 10'h100 |
| 0x03CC | GPIO138   | 10'h100 |
| 0x03D0 | GPIO139   | 10'h100 |
| 0x03D4 | GPIO140   | 10'h100 |
| 0x03D8 | GPIO141   | 10'h100 |
| 0x03DC | GPIO142   | 10'h100 |
| 0x03E0 | GPIO143   | 10'h100 |
| 0x03E4 | GPIO144   | 10'h100 |
| 0x03E8 | SD2_CLK   | 10'h100 |
| 0x03EC | SD2_CMD   | 10'h180 |
| 0x03F0 | SD2_D[0]  | 10'h180 |
| 0x03F4 | SD2_D[1]  | 10'h180 |
| 0x03F8 | SD2_D[2]  | 10'h180 |
| 0x03FC | SD2_D[3]  | 10'h180 |
| 0x0400 | U2TXD     | 10'h100 |
| 0x0404 | U2RXD     | 10'h180 |
| 0x0408 | NFCEN1    | 10'h100 |
| 0x040C | SCL0      | 10'h180 |
| 0x0410 | SDA0      | 10'h180 |
| 0x0414 | SCL2      | 10'h180 |
| 0x0418 | SDA2      | 10'h180 |
| 0x041C | SCL3      | 10'h180 |
| 0x0420 | SDA3      | 10'h180 |
|        |           |         |



| 0x0424 | LCD_D[18]   | 10'h100 |
|--------|-------------|---------|
| 0x0428 | LCD_D[19]   | 10'h100 |
| 0x042C | LCD_D[20]   | 10'h100 |
| 0x0430 | LCD_D[21]   | 10'h100 |
| 0x0434 | LCD_D[22]   | 10'h100 |
| 0x0438 | LCD_D[23]   | 10'h100 |
| 0x043C | TRACECLK    | 10'h10A |
| 0x0440 | TRACECTRL   | 10'h106 |
| 0x0444 | TRACEDAT[0] | 10'h10A |
| 0x0448 | TRACEDAT[1] | 10'h100 |
| 0x044C | TRACEDAT[2] | 10'h100 |
| 0x0450 | TRACEDAT[3] | 10'h106 |
| 0x0454 | TRACEDAT[4] | 10'h100 |
| 0x0458 | TRACEDAT[5] | 10'h106 |
| 0x045C | TRACEDAT[6] | 10'h106 |
| 0x0460 | TRACEDAT[7] | 10'h106 |
| 0x0464 | SIMCLK2     | 10'h100 |
| 0x0468 | SIMDA2      | 10'h180 |
| 0x046C | SIMRST2     | 10'h100 |
| 0x0470 | SIMCLK3     | 10'h100 |
| 0x0474 | SIMDA3      | 10'h180 |
| 0x0478 | SIMRST3     | 10'h100 |

ARM base address: 0x8200\_0180

| Offset Address | Pin Name | Default Value after Reset |
|----------------|----------|---------------------------|
| 0x008C         | TESTRSTN | 10'h102                   |
| 0x0094         | PBINT    | 10'h100                   |
| 0x0098         | TP_XL    | 10'h100                   |
| 0x009C         | TP_XR    | 10'h100                   |
| 0x00A0         | TP_YU    | 10'h100                   |
| 0x00A4         | TP_YD    | 10'h100                   |
|                |          |                           |

# 3.1.4.2 Register Description

### 3.1.4.2.1 PIN\_CTRL\_REG

Description: Pin control register



| 0x0000 |                       |                     | Pin c                  | Pin control register (reset 0x0) |                         |                         |                   |                   |                   |                   |                    | PIN_CTRL_REG        |                     |                          |                                |                    |
|--------|-----------------------|---------------------|------------------------|----------------------------------|-------------------------|-------------------------|-------------------|-------------------|-------------------|-------------------|--------------------|---------------------|---------------------|--------------------------|--------------------------------|--------------------|
| Bit    | 31                    | 30                  | 29                     | 28                               | 27                      | 26                      | 25                | 24                | 23                | 22                | 21                 | 20                  | 19                  | 18                       | 17                             | 16                 |
| Name   | Sim<br>3_cl<br>k_pl   | Sim<br>2_cl<br>k_pl | wpd<br>_sim<br>3pd     | wpd<br>_sim<br>2pd               | wpd<br>_sd2<br>pd       | SDA<br>3_w<br>pus       | SCL<br>3_w<br>pus | SDA<br>2_w<br>pus | SCL<br>2_w<br>pus | SDA<br>0_w<br>pus | SCL<br>0_w<br>pus  | Sim<br>1_cl<br>k_pl | Sim<br>0_cl<br>k_pl | SIM<br>CLK<br>2_w<br>pus | SIM<br>DA2<br>(3)_<br>wpu<br>s | MTR<br>ST_<br>N    |
| Туре   | R/W                   | R/W                 | R/W                    | R/W                              | R/W                     | 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                  | 0                   | 0                   | 0                        | 0                              | 0                  |
| Bit    | 15                    | 14                  | 13                     | 12                               | 11                      | 10                      | 9                 | 8                 | 7                 | 6                 | 5                  | 4                   | 3                   | 2                        | 1                              | 0                  |
| Name   | MT<br>MS_<br>wpu<br>s | MTD<br>I_wp<br>us   | KEY<br>IN_<br>wpu<br>s | NFR<br>B_w<br>pus                | SIM<br>DA1<br>_wp<br>us | SIM<br>DA0<br>_wp<br>us | SDA<br>1_w<br>pus | SCL<br>1_w<br>pus | wpd<br>_ca<br>mpd | wpd<br>_iop<br>d  | wpd<br>_sim<br>1pd | wpd<br>_sdp<br>d    | wpd<br>_nfp<br>d    | wpd<br>_sim<br>0pd       | wpd<br>_me<br>mpd              | wpd<br>_lcd<br>_pd |
| Туре   | R/W                   | R/W                 | R/W                    | R/W                              | R/W                     | 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                  | 0                   | 0                   | 0                        | 0                              | 0                  |

#### Note:

PIN\_CTL\_REG[7:0], [29:27] are used to avoid current leakage when LDO Pad is shut down, each bit corresponding to pads in the same Voltage Domain, These bits should be set before LDO shut down.

PIN\_CTL\_REG[18:8], [26:21] are used to select pull up resistor from 72K and 4.7K,1'b1 is 4.7K,1'b0 is 72K.

| Field-Name   | Bit  | Туре | Reset<br>Value | Description                                                          |
|--------------|------|------|----------------|----------------------------------------------------------------------|
| Sim3_clk_pl  | [31] | R/W  | 1'h0           | Clock polarity sel of SIM_CLK3,when sim3 haven't been selected.      |
| Sim2_clk_pl  | [30] | R/W  | 1'h0           | Clock polarity sel of SIM_CLK2,when sim3 haven't been selected.      |
| Wpd_sim3pd   | [29] | R/W  | 1'h0           | Weakly pull down pads in VSIM3 domain before the domain is shut down |
| Wpd_sim2pd   | [28] | R/W  | 1'h0           | Weakly pull down pads in VSIM2 domain before the domain is shut down |
| Wpd_sd2pd    | [27] | R/W  | 1'h0           | Weakly pull down pads in VSD2 domain before the domain is shut down  |
| SDA3_wpus    | [26] | R/W  | 1'h0           | Wake up pull up resistor select for SDA3                             |
| SCL3_wpus    | [25] | R/W  | 1'h0           | Wake up pull up resistor select for SCL3                             |
| SDA2_wpus    | [24] | R/W  | 1'h0           | Wake up pull up resistor select for SDA2                             |
| SCL2_wpus    | [23] | R/W  | 1'h0           | Wake up pull up resistor select for SCL2                             |
| SDA0_wpus    | [22] | R/W  | 1'h0           | Wake up pull up resistor select for SDA0                             |
| SCL0_wpus    | [21] | R/W  | 1'h0           | Wake up pull up resistor select for SCL0                             |
| Sim1_clk_pl  | [20] | R/W  | 1'h0           | Clock polarity sel of SIM_CLK1,when sim3 haven't been selected.      |
| Sim0_clk_pl  | [19] | R/W  | 1'h0           | Clock polarity sel of SIM_CLK0,when sim3 haven't been selected.      |
| SIMCLK2_wpus | [18] | R/W  | 1'h0           | Wake up pull up resistor select for SIMCLK2                          |



| [17] | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for SIMDA2 and SIMDA3                                                                                                                                                                               |
|------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16] | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for MTRST_N                                                                                                                                                                                         |
| [15] | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for MTMS                                                                                                                                                                                            |
| [14] | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for MTDI                                                                                                                                                                                            |
| [13] | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for KEYIN                                                                                                                                                                                           |
| [12] | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for NFRB                                                                                                                                                                                            |
| [11] | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for SIMDA[1]                                                                                                                                                                                        |
| [10] | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for SIMDA[0]                                                                                                                                                                                        |
| [9]  | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for SDA1                                                                                                                                                                                            |
| [8]  | R/W                                                                    | 1'h0                                                                                                                   | Wake up pull up resistor select for SCL1                                                                                                                                                                                            |
| [7]  | R/W                                                                    | 1'h0                                                                                                                   | Weakly pull down pads in VCAM domain before the domain is shut down                                                                                                                                                                 |
| [6]  | R/W                                                                    | 1'h0                                                                                                                   | Weakly pull down pads in VIO/VIO_0/VIO_1/VIO_2 domain before the domain is shut down                                                                                                                                                |
| [5]  | R/W                                                                    | 1'h0                                                                                                                   | Weakly pull down pads in VSIM1 domain before the domain is shut down                                                                                                                                                                |
| [4]  | R/W                                                                    | 1'h0                                                                                                                   | Weakly pull down pads in VSD domain before the domain is shut down                                                                                                                                                                  |
| [3]  | R/W                                                                    | 1'h0                                                                                                                   | Weakly pull down pads in VNF domain before the domain is shut down                                                                                                                                                                  |
| [2]  | R/W                                                                    | 1'h0                                                                                                                   | Weakly pull down pads in VSIM0 domain before the domain is shut down                                                                                                                                                                |
| [1]  | R/W                                                                    | 1'h0                                                                                                                   | Weakly pull down pads in VMEM domain before the domain is shut down                                                                                                                                                                 |
| [0]  | R/W                                                                    | 1'h0                                                                                                                   | Weakly pull down pads in VLCD domain beforen the domain is shut down                                                                                                                                                                |
|      | [16] [15] [14] [13] [12] [11] [10] [9] [8] [7] [6] [5] [4] [3] [2] [1] | [16] R/W [15] R/W [14] R/W [13] R/W [12] R/W [11] R/W [10] R/W [9] R/W [8] R/W [7] R/W [6] R/W [5] R/W [4] R/W [2] R/W | [16] R/W 1'h0 [15] R/W 1'h0 [14] R/W 1'h0 [13] R/W 1'h0 [12] R/W 1'h0 [11] R/W 1'h0 [10] R/W 1'h0 [9] R/W 1'h0 [8] R/W 1'h0 [7] R/W 1'h0 [6] R/W 1'h0 [5] R/W 1'h0 [5] R/W 1'h0 [1] R/W 1'h0 [1] R/W 1'h0 [2] R/W 1'h0 [3] R/W 1'h0 |

### 3.1.4.2.2 Other Pin Control Register

Description: Other Pin control register share the same bit format shown as below:



| Offset A | Addres | is       | Othe | r Pin c | ontrol | regist | er (res | et val      | ue dep                            | ends)                             |    |             |                          | PIN_N                    | IAME_               | REG                     |
|----------|--------|----------|------|---------|--------|--------|---------|-------------|-----------------------------------|-----------------------------------|----|-------------|--------------------------|--------------------------|---------------------|-------------------------|
| Bit      | 31     | 30       | 29   | 28      | 27     | 26     | 25      | 24          | 23                                | 22                                | 21 | 20          | 19                       | 18                       | 17                  | 16                      |
| Name     |        | Reserved |      |         |        |        |         |             |                                   |                                   |    |             |                          |                          |                     |                         |
| Туре     |        |          |      |         |        |        |         | R           | .0                                |                                   |    |             |                          |                          |                     |                         |
| 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     |        |          | Rese | erved   |        |        |         | IAME_<br>rv | PIN_<br>NAM<br>E_fu<br>nc_<br>wpu | PIN_<br>NAM<br>E_fu<br>nc_<br>wpd |    | IAME_<br>el | PIN_<br>NAM<br>E_w<br>pu | PIN_<br>NAM<br>E_w<br>pd | PIN_<br>NAM<br>E_ie | PIN_<br>NAM<br>E_o<br>e |
| Туре     |        |          | R    | 0       |        |        | 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  | 0           | 0                        | 0                        | 0                   | 0                       |

#### Note:

"PIN\_NAME" represents each pin. Function 0, 1, 2, 3 of each pin is detailed in Pin Multiplexed Function List, the default value of each control bit is detailed in Memory Map.

| Field Name        | Bit     | Туре | Reset<br>Value | Description                                                                      |
|-------------------|---------|------|----------------|----------------------------------------------------------------------------------|
|                   | [31:10] | RO   | 22'h0          | Reserved                                                                         |
| PIN_NAME_drv      | [9:8]   | R/W  |                | Driver Strength select                                                           |
| PIN_NAME_func_wpu | [7]     | R/W  |                | Weakly pull up for function mode                                                 |
| PIN_NAME_func_wpd | [6]     | R/W  |                | Weakly pull down for function mode                                               |
| PIN_NAME_sel      | [5:4]   | R/W  |                | Function select:<br>2'b00: Mode0<br>2'b01: Mode1<br>2'b10: Mode2<br>2'b11: Mode3 |
| PIN_NAME_wpu      | [3]     | R/W  |                | Weak pull up for chip deep sleep mode                                            |
| PIN_NAME_wpd      | [2]     | R/W  |                | Weak pull down for chip deep sleep mode                                          |
| PIN_NAME_ie       | [1]     | R/W  |                | Input enable for chip deep sleep mode                                            |
| PIN_NAME_oe       | [0]     | R/W  |                | Output enable for chip deep sleep mode                                           |



# **4 Electrical Specifications**

# 4.1 DC Specifications

### 4.1.1 Absolute Maximum Ratings

The functionality of SC6820 is subject to the absolute maximum/minimum values listed in Table 4-1. Do not exceed these parameters or the part may be damaged permanently. Operation at absolute maximum ratings is not guaranteed.

Table 4-1 Absolute maximum ratings of SC6820

| Symbol               | Parameter                                                                                                                                                                     | Min  | Max      | Unit    |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|---------|
| VCHG                 | Charger input voltage from adaptor or USB                                                                                                                                     | -0.3 | 18       | V       |
| VBAT                 | Supply voltage from a battery                                                                                                                                                 | -0.3 | 5.2      | V       |
| $V_{DI}$             | Input voltage on any digital input                                                                                                                                            | -0.3 | 3.6      | V       |
| V <sub>AI</sub>      | Input voltage on any analog input                                                                                                                                             | -0.3 | 3.6      | V       |
| I <sub>Al2</sub>     | DC drive current for EARP, EARN, AUXSPP and AUXSPN                                                                                                                            |      | 60       | mA      |
| $V_{max,ESD}$        | Maximum ESD stress voltage, Human Body Model, any pin to any supply pin, either polarity or any pin to all non-supply pins together, either polarity. Three stresses maximum. |      | 2,000    | V       |
| I <sub>max, DC</sub> | Maximum DC Input current for any non-supply pin                                                                                                                               |      | 5        | mA      |
| Ta                   | Ambient temperature                                                                                                                                                           | -45  | +95      | °C      |
| T <sub>storage</sub> | Storage temperature                                                                                                                                                           | -65  | +125     | °C      |
| Vpulse,<br>Twidth    | Voltage surge on vbat                                                                                                                                                         |      | 14<br>10 | V<br>μs |

Note: Vpulse and Twidth is described below:



Figure 4-1 Voltage surge on VBAT



### 4.1.2 Recommended Operating Conditions

SC6820 is recommended to operate under the conditions list in Table 4-2.

Table 4-2 Recommended operating conditions

| Symbol                | Parameter                     | Min | Typical | Max  | Unit |
|-----------------------|-------------------------------|-----|---------|------|------|
| VCHG                  | Charger input voltage         | 4.5 | 5.0     | 5.5  | V    |
| VBAT                  | Supply voltage from a battery | 3.2 | 3.6     | 4.2  | V    |
| VDD                   | Core supply voltage           | 1.0 | 1.1     | 1.2  | V    |
|                       | Arm supply voltage            | 1.1 | 1.2     | 1.3  | V    |
| T <sub>junction</sub> | Junction temperature          | -20 |         | +125 | °C   |
| T <sub>ambient</sub>  | Ambient operating temperature | -40 |         | +85  | °C   |

Note1: Hardware stops charging if VCHG is higher than 9V and the maximum value of VCHG can be set by software. The higher maximum value of VCHG, the stricter Vds requirement of external MOSFET.

Note2: The value set by software should be 10% higher than maximum value of VCHG listed in table to guarantee all chips can stop charging over the maximum value of VCHG.

#### 4.1.3 Thermal Characteristics

The thermal characteristics are as shown in Table 4-3.

Table 4-3 Thermal characteristics

| Symbol   | Parameter                              | Condition         | Value | Unit    |
|----------|----------------------------------------|-------------------|-------|---------|
| Theta JA | Junction-to-Ambient thermal resistance | Air flow: 0 m/sec | 40    | °C/watt |

### 4.1.4 ESD Characteristics

The ESD characteristics are shown in Table 4-4.

Table 4-4 ESD characteristics

| Symbol | Parameter            | Condition                   | Value | Unit |
|--------|----------------------|-----------------------------|-------|------|
| НВМ    | Human body model     | MIL STD 883G, method 3015.7 | ±2K   | V    |
| CDM    | Charged-device model | JESD22-C101-C               | ±800  | V    |
| MM     | Machine model        | JESD22-A115-A               | ±200  | V    |

### 4.1.5 DC Characteristics

SC6820 typical core voltage (VDD) is 1.1 V and the I/O supply (VDDIO) is typically at 2.8 V. The analog circuits are typically powered at 3.0 V. The core and analog power supplies are provided by the on-chip LDOs. The external battery can be connected directly to pins VBATD, VBATPA, VBATBUCK, AVDD36\_1, AVDD36RF. If not specified, VBAT means all and VBATA includes VBATPA, AVDD36-1, AVDD36RF. The power pins should be connected with a decoupling capacitor to ground (VSS, VSSIO).



For the following table,  $T_{amb}$  = -40 to +85 °C, VSS = 0 V (ground), VBAT = 3.6 V, and all voltages are measured with respect to VSS, unless otherwise specified.

Table 4-5 DC characteristics

| Istandby (tot) | Total standby current                  | The whole chip is in                              |          |     |          | _  |
|----------------|----------------------------------------|---------------------------------------------------|----------|-----|----------|----|
|                |                                        | deep sleep mode                                   | _        | 0.8 | _        | mA |
|                | Deep power-down current                | The whole chip is powered down by software        |          | 50  |          | uA |
| Digital supp   | oly voltage: pins VDI                  | DIO                                               |          |     |          |    |
|                | Digital supply voltage                 |                                                   | 1.5      | _   | 3.1      | V  |
| Digital supp   | oly voltage: pins VLC                  | D                                                 |          | (,) |          |    |
|                | Digital supply voltage                 |                                                   | 1.5      |     | 3.1      | V  |
| Digital supp   | oly voltage: pins VC                   | AM                                                |          |     |          |    |
|                | Digital supply voltage                 |                                                   | 1.5      | -   | 3.1      | V  |
| Digital supp   | oly voltage: pins VMI                  | EM                                                |          |     |          |    |
|                | Digital supply voltage                 |                                                   | 1.6      | I   | 2.0      | V  |
| Digital supp   | oly voltage: pins VNF                  |                                                   |          |     |          |    |
|                | Digital supply voltage                 |                                                   | 1.5      | I   | 3.1      | ٧  |
| Digital supp   | oly voltage: internal                  | VDD                                               |          |     |          |    |
|                | Digital core supply voltage            | 5                                                 | 1.0      | 1.1 | 1.2      | ٧  |
|                | Sleep mode digital core supply voltage |                                                   | 0.8      | 0.9 | 1.0      | ٧  |
|                | Arm Core supply voltage                |                                                   | 1.1      | 1.2 | 1.3      | V  |
| Digital input  | t                                      |                                                   |          |     |          |    |
|                | Input voltage<br>LOW-level             |                                                   | 0        | I   | 0.3 Vpad | ٧  |
|                | Input voltage<br>HIGH-level            |                                                   | 0.7 Vpad | _   | Vpad     | V  |
|                | Input leakage current                  |                                                   | _        | ±2  | _        | μΑ |
| Digital outp   | ut                                     |                                                   |          |     |          |    |
|                | Output voltage<br>LOW-level            | At I <sub>sink</sub> = 2,4,6,10 mA (programmable) | 0        | _   | 0.1 Vpad | V  |



| Symbol              | Parameter                    | Conditions                                                                              | Min      | Typical | Max  | Unit |
|---------------------|------------------------------|-----------------------------------------------------------------------------------------|----------|---------|------|------|
| V <sub>OH</sub>     | Output voltage<br>HIGH-level | At I <sub>source</sub> = 2,4,6,10 mA (programmable)                                     | 0.9 Vpad | -       | Vpad | V    |
| Analog su           | pply voltage: pins VB        | ATA                                                                                     |          |         |      |      |
| VBATA               | Analog supply voltage        |                                                                                         | 3.3      | 3.6     | 4.2  | V    |
| I <sub>VBATA</sub>  | Analog supply current        | AVDD = 2.8 V All analog blocks are active, but no load at EARP, EARN, AUXSPP and AUXSPN | -        | 5       | -0   | mA   |
| Analog su           | pply voltage: internal       | AVDD                                                                                    |          |         |      |      |
| AVDD                | Analog core supply voltage   |                                                                                         | 2.7      | 3.0     | 3.3  | V    |
| RTC suppl           | y: pin RTCVDD                |                                                                                         |          |         |      |      |
| RTCVDD              | Supply voltage               |                                                                                         | 1.6      | 1.8     | 2    | V    |
| I <sub>RTCVDD</sub> | Supply current               |                                                                                         |          | 10      |      | μΑ   |
| Iquiescent          | LDORTC quiescent current     |                                                                                         |          | 9       |      | μΑ   |

Note1: Vpad means the power supply voltage at the corresponding pad.

Note2: Supply voltage of RTCVDD can be set as 1.8V, 1.7V, 1.6V and 1.5V, please refer to 4.3.10 about details. When VBAT is on,  $I_{\text{RTCVDD}}$  can be reduce to 2uA through setting  $V_{\text{RTCVDD}}$  as 1.5V in power down mode. When VBAT is off,  $I_{\text{RTCVDD}}$  can be reduce to 5uA through reducing the amplitude of XTL32K.

### 4.2 AC Characteristics

A pin's AC characteristics include input and output capacitance, which determine loading for external drivers or other load analysis. The AC characteristics also include a de-rating factor, which indicates how much faster or slower the AC timings get with different loads.

Table 4-6 Standard input, output and I/O pin AC characteristics

| Symbol          | Parameters                                                                         | Min | Typical | Max | Units |
|-----------------|------------------------------------------------------------------------------------|-----|---------|-----|-------|
| C <sub>in</sub> | Input capacitance, all standard input and IO pins                                  |     |         | 3.5 | pF    |
| $C_{load}$      | Output capacitance, all standard output and IO pins                                |     |         | 30  | pF    |
| $T_{dr}$        | Output de-rating falling edge on all standard output and I/O pins, from 30 pF load |     | 0.166   |     | ns/pF |

#### Note:

1. The AC specifications are tested with a 30 pF load as indicated in Figure 4-2





Figure 4-2 Test circuit of an I/O pin

2. The output capacitance and de-rating falling edge are measured under the condition of maximum driving strength: 24 mA @ 3 V.

For the following tables,  $T_{amb}$  = -40 to +85 °C, VSS = 0 V (ground), VBAT = 3.6 V, and all voltages are measured with respect to VSS, unless otherwise specified.

Table 4-7 AC characteristics

| Symbol                          | Parameter                    | Conditions          | Min      | Typical | Max | Unit |
|---------------------------------|------------------------------|---------------------|----------|---------|-----|------|
| f <sub>mclk</sub>               | Master clock frequency       |                     | -        | 26      | _   | MHz  |
| f <sub>rtcclk</sub>             | Real-time clock frequency    |                     | <b>-</b> | 32.768  | _   | kHz  |
| Digital in                      | put                          |                     |          |         |     |      |
| Cı                              | Input capacitance            |                     |          | 3       | _   | pF   |
| Digital ou                      | itput                        |                     |          |         |     | •    |
| T <sub>R</sub>                  | Output rise time             | Output load = 20 pF | 2        | _       | 5   | ns   |
| T <sub>F</sub>                  | Output fall time             | Output load = 20 pF | 2        | _       | 5   | ns   |
| Master cl                       | ock input                    |                     |          |         |     | •    |
| $\triangle$ f/f <sub>mclk</sub> | Frequency compensation range | <b>O</b> *          | -27      |         | 27  | ppm  |
| V <sub>mclk</sub>               | Master clock amplitude       | AC coupling         | 0.65     | _       | 2.4 | V    |
| $\delta_{\text{mclk}}$          | Master clock duty cycle      |                     | 40       | _       | 60  | %    |
| Real-time                       | clock input                  |                     |          | •       | •   | •    |
| △f/f <sub>rtclk</sub>           | Frequency tolerance          | Standard deviation  | -80      |         | 80  | ppm  |
| $\delta_{	ext{rtclk}}$          | Clock duty cycle             |                     | 35       | -       | 65  | %    |

# 4.3 Performance Specifications

This section specifies the performance of some major SC6820 modules.



### 4.3.1 GSM Baseband

#### 4.3.1.1 Baseband Transmit Path

The outputs of GMSK modulator are converted to analog levels by 10-bit D/A Converters (DAC), and then passed to an analog Butterworth low pass filter. Each analog part has special offset cancellation.

Table 4-8 Performance of GSM baseband transmit path

| Parameter                           | Conditions/Comments     | Min | Typical              | Max | Unit |
|-------------------------------------|-------------------------|-----|----------------------|-----|------|
| Transmission buffer length          |                         |     | 160                  |     | bits |
| GMSK modulator                      |                         |     |                      |     |      |
| Input data word rate                |                         |     | 270.833              |     | kHz  |
| I/Q interpolation output size       |                         |     | 10                   |     | bits |
| DAC                                 |                         |     |                      |     |      |
| Number of Channels                  |                         |     | 2                    |     |      |
| Resolution                          |                         | 7   | 10                   |     | bits |
| Signal to noise ratio               |                         | 54  |                      |     | dB   |
| Dynamic Range                       |                         | 54  |                      |     | dB   |
| Total harmonic distortion           |                         |     |                      | -54 | dBFs |
| GMSK phase trajectory error         |                         |     |                      |     |      |
| RMS error                           | Including analog filter |     |                      | 1.5 | 0    |
| Peak error                          | Including analog filter |     |                      | 7   | 0    |
| LP analog filter                    |                         |     |                      | •   |      |
| Cutoff frequency (3 dB)             |                         |     | 250 (±<br>20%)       |     | kHz  |
| Group delay                         |                         |     |                      | 9   | μsec |
| I/Q mismatch                        |                         |     |                      | •   |      |
| I/Q amplitude mismatch              |                         |     |                      | 0.2 | dB   |
| I/Q phase mismatch                  |                         |     |                      | 0.1 | 0    |
|                                     | TX_B [1:0] = 00         |     | ±0.6                 |     |      |
|                                     | TX_B [1:0] = 10         |     | ±0.9                 |     | V    |
| Maximum differential output voltage | TX_B [1:0] = 01         |     | ±1.2                 |     |      |
|                                     | TX_B [1:0] = 11         |     | ±1.5                 |     |      |
| Output common mode voltage          |                         |     | 1.15<br>1.25<br>1.05 |     | V    |
| <b>*</b>                            |                         |     | 1.35                 |     |      |
| DC offset                           |                         |     |                      | 10  | mV   |
| Minimum load resistance             |                         | ı   | T.                   | _   |      |
| Single-ended                        |                         | 100 |                      |     | kΩ   |



| Parameter                | Conditions/Comments             | Min | Typical  | Max | Unit |  |  |
|--------------------------|---------------------------------|-----|----------|-----|------|--|--|
| Differential             |                                 | 50  |          |     | kΩ   |  |  |
| Maximum load Capacitance | Maximum load Capacitance        |     |          |     |      |  |  |
| Single-ended             |                                 |     |          | 50  | pF   |  |  |
| Differential             |                                 |     |          | 50  | pF   |  |  |
|                          | Complies with GSM spectral mask |     |          |     |      |  |  |
|                          | 0 – 100 kHz                     | -3  |          | 0   |      |  |  |
|                          | 200 kHz                         |     |          | -32 |      |  |  |
| Relative output power    | 250 kHz                         |     |          | -35 |      |  |  |
|                          | 400 kHz                         |     |          | -63 | dB   |  |  |
|                          | 600 kHz                         |     | <b>*</b> | -71 |      |  |  |
|                          | 1200 kHz                        |     |          | -71 |      |  |  |
|                          | > 1800 kHz                      |     |          | -71 |      |  |  |

#### 4.3.1.2 Baseband Receive Path

The differential I/Q signal from the RF module is modulated to two-bit words by  $\Sigma$ - $\Delta$  modulator at a frequency much higher than the Nyquist rate. Then the signal passes through a digital filter. Each analog part has special offset cancellation.

Table 4-9 Performance of the baseband receive path

| Parameter                             | Conditions/Comments | Min   | Typical | Max  | Unit |
|---------------------------------------|---------------------|-------|---------|------|------|
| Input common mode signal range        |                     | 1.26  | 1.4     | 1.54 | V    |
| Input differential full scale voltage | **                  | -     | 6       | -    | V    |
| Input sampling frequency              |                     | -     | 26      | -    | MHz  |
| Output data                           |                     |       |         |      |      |
| Analog input signal bandwidth         |                     |       | 262.5   |      | kHz  |
| Dynamic range                         |                     | 78    |         |      | dB   |
| Signal to (noise + distortion) ratio  |                     |       | 78      |      | dB   |
| Input DC offset                       |                     |       | 2       |      | mV   |
| In-band gain flatness                 |                     | -0.25 |         | 0.25 | dB   |

# 4.3.2 Voice Band

#### 4.3.2.1 Micbias

Table 4-10 Electrical specification of micbias

| Symbol | Parameter description | Condition   | Min | Тур | Max | Unit |
|--------|-----------------------|-------------|-----|-----|-----|------|
| Vi     | Input supply voltage  | From AVDDVB | 2.9 | 3.3 | 3.6 | V    |



| Symbol          | Parameter description        | Condition           | Min | Тур  | Max | Unit |
|-----------------|------------------------------|---------------------|-----|------|-----|------|
|                 | Regulated output voltage     | Vi=3.3              |     | 2.8  |     |      |
| Vo              |                              | Vi=3.4              |     | 2.85 |     | V    |
| VO              |                              | Vi=3.2              |     | 2.7  |     | V    |
|                 |                              | Vi=2.9              |     | 2.45 |     |      |
| lout            | Output current               |                     | 2   |      | 4   | mA   |
| Output<br>Noise | A-Weighted, RMS output level |                     |     | 20   | 40  | μV   |
| Cext            | External cap                 | ESR typical <0.5ohm |     | 2.2  |     | μF   |

### 4.3.2.2 Voice Band Uplink PGA

Table 4-11 Electrical specification of Voice band uplink PGA

| Symbol           | Parameter description                                  | Condition | Min  | Тур | Max  | Unit |  |
|------------------|--------------------------------------------------------|-----------|------|-----|------|------|--|
| Gain range       | Gain range                                             |           | 0    |     | 22.5 | dB   |  |
| Gain step        | Gain step size                                         |           | 1.1  | 1.5 | 1.7  | dB   |  |
| Gain<br>accuracy |                                                        | GI@1kHz   | -0.2 |     | 0.2  | dB   |  |
| Gain boost       | Boost gain GM activated                                |           |      | 20  |      | dB   |  |
| Notes: GI is for | Notes: GI is for PGATM gain and GIM is for boost gain. |           |      |     |      |      |  |

### 4.3.2.3 Voice Band Uplink Sigma-Delta ADC

### Table 4-12 Electrical specification of Voice band uplink sigma-delta ADC

| Symbol                       | Parameter description     | Condition                                                                    | Min          | Тур         | Max         | Unit |
|------------------------------|---------------------------|------------------------------------------------------------------------------|--------------|-------------|-------------|------|
| AVDD                         | Power supply              |                                                                              | 2.9          | 3.3         | 3.6         | V    |
| Input Level                  | Input full scale voltage  | GIM=0dB GI=0dB<br>GIM=20dB GI=0dB                                            | 2.49<br>0.24 | 2.8<br>0.28 | 3.5<br>0.35 | V    |
| Input<br>Resistance          |                           | GI=0 or 22.5dB,<br>GIM=20dB                                                  | 14           | 20          | 26          | KOhm |
| Input<br>bypass<br>capacitor | Cbymic                    |                                                                              |              | 1           |             | μF   |
| SNR                          | Signal to noise ratio     | A-weighted, 1kHz<br>sine wave @ Full<br>Scale GI = 0dB,<br>GIM = 20dB or 0dB | 80           | 85          |             | dB   |
| THD                          | Total harmonic distortion | 1kHz sine wave @<br>Full Scale GI = 0dB,<br>GIM = 20dB or 0dB                |              | -70         | -65         | dB   |
| Dynamic<br>range             | Dynamic range             | A-weighted, 1kHz<br>sine wave @ Full<br>Scale -60dB                          |              | 80          |             | dB   |



| Symbol | Parameter description | Condition                                                                                  | Min | Тур | Max | Unit |
|--------|-----------------------|--------------------------------------------------------------------------------------------|-----|-----|-----|------|
|        |                       | GIM = 20dB                                                                                 |     |     |     |      |
| PSRR   | Power rejection ratio | 100mVpp 1kHz sine<br>wave is applied to<br>AVDD, input data is<br>0, GI=0dB, GIM =<br>20dB | 50  | 63  |     | dB   |

### 4.3.2.4 Voice Band Downlink DAC to Headphone Output

Table 4-13 Electrical specification of voice band downlink DAC to headphone output

| Symbol                  | Parameter description | Condition                                                                                                    | Min | Тур  | Max | Unit |
|-------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------|-----|------|-----|------|
| AVDD                    | Power supply          |                                                                                                              | 2.9 | 3.3  | 3.6 | V    |
| Output level            | Output range          | Full Scale, Gain<br>GOL,GOR=-1.5dB,<br>GODL, GODR = 0dB                                                      | X   | 2.35 |     | V    |
| Maximum<br>output level |                       | Full Scale, Gain<br>GOL,GOR=1dB,<br>GODL, GODR =<br>0dB,32ohm loading                                        |     | 3.05 |     | V    |
| Maximum                 |                       | R=16 Ohms                                                                                                    |     | 30   |     |      |
| output<br>power         |                       | R=32 Ohms                                                                                                    |     | 20   |     | mW   |
| SNR                     |                       | A-weighted, 1kHz<br>sine wave @ Full<br>Scale<br>GOL,GOR=-1.5dB,<br>GODL, GODR = 0dB,<br>32 Ohm load         | 85  | 90   |     | dB   |
| DR                      |                       | A-weighted, 1kHz<br>sine wave @ Full<br>Scale –60dB<br>GOL/R=-1.5dB,<br>GODL/R=0dB                           | 85  | 90   |     | dB   |
| THD                     | 2                     | 1kHz sine wave @<br>Full Scale –1dB /-6dB<br>GOL/R=-1.5dB,<br>GODL/R=0dB                                     |     |      | -70 | dB   |
| Output<br>noise         |                       | A-weighted, RMS<br>Noise level @ 0vpp<br>output                                                              |     | 16   |     | μV   |
| PSRR                    |                       | 100/450mVpp<br>217/434/651Hz sine<br>wave is applied to<br>AVDD, input is 0<br>GOL/R=-1.5dB ,GOD<br>L/R =0dB | 50  | 68   |     | dB   |
| Channel separation      |                       | Full scale at one output, detection the signal at the other                                                  | 70  |      |     | dB   |



| Symbol                              | Parameter description | Condition                                                                         | Min   | Тур | Max  | Unit |
|-------------------------------------|-----------------------|-----------------------------------------------------------------------------------|-------|-----|------|------|
|                                     |                       | side                                                                              |       |     |      |      |
| DAC<br>channel<br>mismatch          |                       | L and R channel output level mismatch                                             |       |     | 0.15 | dB   |
| Gain<br>range(GOL/<br>GOR)          |                       | GOL, GOR 5-bit<br>programmable range,<br>mixed analog/digital<br>control, @1kHz   | -33.5 |     | +4.5 | dB   |
|                                     |                       | GOL/R: +4.5dB ~<br>+0.5dB                                                         |       | 0.5 |      |      |
| Gain<br>step(GOL/G<br>OR)           |                       | GOL/R: +0.5dB ~<br>-11.5dB                                                        |       | 1   |      | dB   |
|                                     |                       | GOL/R: -11.5dB ~<br>-33.5dB                                                       |       | 2   |      |      |
| Gain<br>accuracy(G<br>OL/GOR)       |                       | GOL/GOR @1kHz                                                                     | -0.2  |     | 0.2  | dB   |
| Gain<br>range(GOD<br>L/GODR)        |                       | GODL, GODR 4-bit<br>programmable range,<br>mixed analog/digital<br>control, @1kHz | -22.5 |     | 0    | dB   |
| Gain<br>step(GODL/<br>GODR)         |                       | GODL/GODR                                                                         |       | 1.5 |      | dB   |
| Gain<br>accuracy(G<br>ODL/GODR<br>) |                       | GODL/GODR @1kHz                                                                   | -0.5  |     | 0.5  | dB   |
| Output<br>Resistance                |                       |                                                                                   | 16    |     |      | ohm  |
| Output<br>Capacitanc<br>e           |                       |                                                                                   |       |     | 100  | pF   |

### 4.3.2.5 Voice Band Downlink Line Input to Headphone Output

# Table 4-14 Electrical specification of Voice band downlink Line input to Headphone output

|   | Symbol       | Parameter description | Condition                                              | Min | Тур  | Max | Unit |
|---|--------------|-----------------------|--------------------------------------------------------|-----|------|-----|------|
|   | AVDD         | Power supply          |                                                        | 2.9 | 3.3  | 3.6 | V    |
| Ì | Input level  |                       |                                                        |     | 2.8  |     | V    |
|   | Output level | Output range          | Full Scale, Gain<br>GOL,GOR=-1.5dB,<br>GOBL/GOBR = 0dB |     | 2.09 |     | V    |



| Symbol                       | Parameter description | Condition                                                                                           | Min   | Тур | Max | Unit |
|------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------|-------|-----|-----|------|
| Input<br>Resistance          |                       |                                                                                                     |       | 40  |     | kohm |
| Input<br>bypass<br>capacitor | Cbyline               |                                                                                                     |       | 1   |     | μF   |
| SNR                          |                       | A-weighted, 1kHz<br>sine wave @ Full<br>Scale<br>GOL,GOR=-1.5dB,<br>GOBL/GOBR = 0dB,<br>32 Ohm load |       | 87  |     | dB   |
| THD                          |                       | A-weighted, 1kHz<br>sine wave @ Full<br>Scale –1dB /-6dB<br>GOL/R=-1.5dB,<br>GOBL/GOBR =0dB         | Ç.    | -78 | >   | dB   |
| Mute<br>attenuation          |                       |                                                                                                     | 80    | 98  |     | dB   |
| Gain range                   |                       | GOBL, GOBR 5-bit<br>programmable range,<br>mixed analog/digital<br>control, @1kHz                   | -22.5 |     | +6  | dB   |
| Gain step                    |                       | GOBL/GOBR                                                                                           |       | 1.5 |     | dB   |
| Gain<br>accuracy             |                       | GOBL/GOBR @1kHz                                                                                     | -0.5  |     | 0.5 | dB   |

### 4.3.2.6 Voice Band Downlink DAC to BTL

Table 4-15 Electrical specification of Voice band downlink DAC to BTL

| Symbol                     | Parameter description | Condition                                        | Min | Тур | Max | Unit |
|----------------------------|-----------------------|--------------------------------------------------|-----|-----|-----|------|
| AVDD                       | Power supply          |                                                  | 2.9 | 3.3 | 3.6 | V    |
| Output level               | Output range          | Full Scale, 32 Ohms load, Gain GODL, GODR = 0dB, |     | 5.1 |     | V    |
|                            |                       | Full Scale, 16 Ohms load, Gain GODL, GODR = 0dB, |     | 4.9 |     | V    |
|                            |                       | Full Scale, 8 Ohms load, Gain GODL, GODR = 0dB,  |     | 4.2 |     | V    |
| Maximum<br>output<br>power |                       | R=32 Ohms                                        |     | 110 |     | mW   |
|                            |                       | R=16 Ohms                                        |     | 190 |     | mW   |
|                            |                       | R=8 Ohms                                         |     | 240 |     | mW   |
| SNR                        |                       | A-weighted, 1kHz<br>sine wave @ Full             | 85  | 90  |     | dB   |



| Symbol                    | Parameter description | Condition                                                                                  | Min | Тур | Max | Unit |
|---------------------------|-----------------------|--------------------------------------------------------------------------------------------|-----|-----|-----|------|
|                           |                       | Scale-1dB<br>GODL, GODR = 0dB                                                              |     |     |     |      |
| DR                        |                       | A-weighted, 1kHz<br>sine wave @ Full<br>Scale –60dB<br>GODL/R=0dB                          | 90  |     |     | dB   |
| THD                       |                       | 1kHz sine wave @<br>Full Scale -1dB /-6dB<br>GOL/R=-1.5dB,<br>GODL/R=0dB R=8<br>Ohms       |     |     | -70 | dB   |
| Output<br>noise           |                       | A-weighted, RMS<br>Noise level @ 0vpp<br>output                                            |     | 30  | 35  | μV   |
| PSRR                      |                       | 100/450mVpp<br>217/434/651Hz sine<br>wave is applied to<br>AVDD, input is 0<br>GODL/R =0dB |     | 75  |     | dB   |
| Output<br>Resistance      |                       |                                                                                            | 8   |     |     | ohm  |
| Output<br>Capacitanc<br>e |                       |                                                                                            |     |     | 100 | pF   |

# 4.3.2.7 Voice Band Downlink DAC to Line out

# Table 4-16 Electrical specification of Voice band downlink DAC to Line out

| Symbol       | Parameter description | Condition                                                                                   | Min | Тур  | Max | Unit |
|--------------|-----------------------|---------------------------------------------------------------------------------------------|-----|------|-----|------|
| AVDD         | Power supply          |                                                                                             | 2.9 | 3.3  | 3.6 | V    |
| Output level | Output range          | Full Scale, 10k Ohms load, Gain GODL, GODR = 0dB,                                           |     | 4.98 |     | V    |
| SNR          | 2                     | A-weighted, 1kHz<br>sine wave @ Full<br>Scale-1dB<br>GODL, GODR =<br>0dB,10kohm loading     | 90  |      |     | dB   |
| DR           |                       | A-weighted, 1kHz<br>sine wave @ Full<br>Scale –60dB<br>GODL/R=0dB,10koh<br>m loading        | 90  |      |     | dB   |
| THD          |                       | 1kHz sine wave @<br>Full Scale -1dB /-6dB<br>GOL/R=-1.5dB,<br>GODL/R=0dB,<br>10kOhm loading |     |      | -75 | dB   |



| Symbol             | Parameter description | Condition                                                                                  | Min | Тур | Max | Unit |
|--------------------|-----------------------|--------------------------------------------------------------------------------------------|-----|-----|-----|------|
| Output<br>noise    |                       | A-weighted, RMS<br>Noise level @ 0vpp<br>output                                            |     | 36  |     | μV   |
| PSRR               |                       | 100/450mVpp<br>217/434/651Hz sine<br>wave is applied to<br>AVDD, input is 0<br>GODL/R =0dB |     | 84  |     | dB   |
| Output resistance  |                       |                                                                                            | 10  |     |     | Kohm |
| Output capacitance |                       |                                                                                            |     |     | 100 | pF   |

### 4.3.2.8 Linein Record

Table 4-17 Electrical specification of Linein record

| Symbol | Parameter Description                | Condition                               | Min.  | Тур. | Max. | Unit |
|--------|--------------------------------------|-----------------------------------------|-------|------|------|------|
| AVDD   | Analog power supply                  |                                         | 3     | 3.3  | 3.6  | V    |
| DVDD   | Digital power supply                 |                                         | 1.6   | 1.8  | 2    | V    |
| Idd    | Current consumption                  |                                         |       |      | 1    | uA   |
| lpd    | Power down leakage                   |                                         |       |      | 10   | nA   |
| VFS    | Input level                          | VI Analog full-scale 0 dB input voltage |       | 5    | 6.6  | Vpp  |
| SNR    | Signal-to-noise ratio,<br>A-weighted | Gain=0dB                                | 80    | 85   |      | dB   |
| THD    | Total harmonic distortion            | Gain=0dB                                |       | -70  | -60  | dB   |
| DR     | Dynamic range,<br>A-weighted         | Gain=0dB                                | 85    | 90   |      | dB   |
|        | Gain range                           | 3-bit programmable range,<br>@1kHz      | -10.5 |      | 0    | dB   |
| Gp     | Gain step                            |                                         | 1     | 1.5  | 2    | dB   |
| 38     |                                      | Gain=0dB, Dolphin boost gain=0dB        | 48    | 60   | 72   | kOhm |
| Ri     | Input resistance                     | Gain=-10.5dB, Dolphin<br>boost gain=0dB | 165   | 205  | 250  | kOhm |

Note: Input sine wave with a frequency of 1kHz, measurement bandwidth 20Hz – 20kHz.



### 4.3.2.9 Head detect

Table 4-18 Electrical specification of head detect

| Condition: VDDIO=  | 1.8V, Temp=27C | ;              |             |                              |         |
|--------------------|----------------|----------------|-------------|------------------------------|---------|
| HEADDETECT_PD      | HEADMIC_IN     | HEADMIC_DETECT | HEAD_BUTTON | Function Descriptions        | Current |
| (V)                | (V)            | (V)            | (V)         |                              | (uA)    |
| 0                  | 1.8            | 1.8            | 0           | Without headset              | 0.1     |
| 0                  | 0.6-1.4        | 0              | 0           | Headset insert               | 0.1     |
| 0                  | 0              | 0              | 1.8         | Headset's mic button pressed | 0.5     |
| 1.8                | Х              | 1.8            | 0           | Power down                   | <1e-3   |
| Condition: VDDIO=2 | 2.8V, Temp=27C |                |             |                              |         |
| HEADDETECT_PD      | HEADMIC_IN     | HEADMIC_DETECT | HEAD_BUTTON | Function Descriptions        | Current |
| (V)                | (V)            | (V)            | (V)         | 1                            | (uA)    |
| 0                  | 2.8            | 2.8            | 0           | Without headset              | 1.3     |
| 0                  | 0.9-2.2        | 0              | 0           | Headset insert               | 1.6     |
| 0                  | 0              | 0              | 2.8         | Headset's mic button pressed | 2.9     |
| 2.8                | х              | 2.8            | 0           | Power down<br>(VDDIO=2.8V)   | <1e-3   |

# 4.3.3 Phase-Locked Loop (PLL)

Table 4-19 Performance of the phase-locked loop

| Parameter                      | Conditions/Comments         | Min | Тур            | Max | Unit     |
|--------------------------------|-----------------------------|-----|----------------|-----|----------|
| Power supply                   | Digital power Analog power  |     | 1.1<br>3.0/2.5 |     | V        |
| Input clock coupling capacitor | External coupling capacitor |     | 1000           |     | pF       |
| Input reference                |                             |     | 26             |     | MHz      |
|                                | MPLL                        |     | 1000           |     | MHz      |
| Fraguency Pango                | APLL                        |     | 384            |     | MHz      |
| Frequency Range                | DPLL                        |     | 400            |     | MHz      |
|                                | TDPLL                       |     | 768            |     | MHz      |
| cycle to cycle jitter (RMS)    | All other circuits on       |     | 20             |     | ps       |
| Cycle to cycle jitter (p-p)    | All other circuits on       |     | 200            |     | ps/cycle |



| Parameter     | Conditions/Comments | Min | Тур | Max | Unit |
|---------------|---------------------|-----|-----|-----|------|
| Settling time |                     | 100 | 400 |     | μs   |
| Sleep mode    | Yes                 |     |     |     |      |
| ldd           | 3.0V                |     | 1   |     | mA   |
| luu           | 2.5V                |     | 1.5 |     | mA 🔷 |
|               | 1.1V                |     | 1.5 |     | mA   |

#### Note:

- For MPLL, fin is always at 26 MHz, while for the other three PLLs, fin frequency is the same as the external oscillator.
- TDPLL frequency should always be multiple of 5.12 MHz, for TD-SCDMA Rx/Tx timing.

### 4.3.4 RTC Oscillator

SC6820 contains an RTC oscillator, for a specific crystal frequency at 32.768 kHz. The 32.768 kHz crystal is connected at RTC32KI and RTC32KO.

Table 4-20 Performance of the 32.768-kHz oscillator

| Description                                         | Symbol            | Min      | Typical | Max      | Units |
|-----------------------------------------------------|-------------------|----------|---------|----------|-------|
| Power supply                                        |                   |          | 1.8     |          | V     |
| Crystal Frequency                                   |                   |          | 32.768  |          | KHz   |
| Frequency tolerance                                 | △f/f              | -80      |         | 80       | ppm   |
| clock duty cycle                                    | $\delta_{clk32K}$ | 35       |         | 65       | %     |
| Equivalent series resistance                        |                   | 6        |         | 65       | KOhm  |
| Drive Level                                         |                   |          |         | 1        | uW    |
| Internal power supply                               | VRTC              |          | 1.8     |          | V     |
| Input High Voltage RTC32XI                          |                   | 0.8 VRTC |         |          | V     |
| Input Low Voltage RTC32XI                           |                   |          |         | 0.2 VRTC | V     |
| Input Leakage, RTC32XI                              |                   |          |         | 1        | uA    |
| Input Capacitance<br>RTC32XI/RTC32XO                |                   |          | 18      |          | pF    |
| Amplifier Stabilization Time                        |                   | 2        |         | 10       | s     |
| Parasitic Resistance<br>RTC32XI/RTC32XO to any node |                   | 20       |         |          | MOhm  |
| Parasitic Capacitance,<br>RTC32XI/RTC32XO           |                   |          | 5       |          | pF    |

Note1: The recommended frequency tolerance of crystal is  $\pm 20$ ppm.

Note2: SC6820 also supports digital 32.768KHz clock input. The digital clock should be connected through a 10-51K  $\Omega$  series resistor to RTC32KI, while RTC32KO can be left floating. The logic low of this digital clock should be between 0-0.4V while the logic high should be between 1.4-1.8V. The drive strength of this digital clock must be larger than 1mA.



### 4.3.5 USB 2.0 PHY

The USB 2.0 PHY in SC6820 is fully compliant with USB 1.1 specifications. Please refer to Universal Serial Bus Specification revision 1.1 at <a href="http://www.usb.org/developers/docs">http://www.usb.org/developers/docs</a>.

### 4.3.6 GSM APC DAC

Two general DACs are used to control power ramping and gain in SC6820, which name as GSM APC. It is a all 10 bits D/A converters with a programmable-gain output driver. Special offset cancellation is applied in those DACs.

Physically they copy from the same design (but with different control method), so they almost have the same performance, list as follow,

Table 4-21 Performance of the AGC/APC DACs

| Parameter                  | Conditions/Comments | Min | Typical | Max | Units |
|----------------------------|---------------------|-----|---------|-----|-------|
| Power supply               |                     | 2.7 | 3       | 3.3 | V     |
| Resolution                 |                     | 3   | 10      |     | bits  |
| Integral non-linearity     |                     | -2  |         | +2  | LSB   |
| Differential non-linearity |                     | -1  |         | +1  | LSB   |
| Settling time              |                     |     | 4       |     | μs    |
| Gain range                 |                     | 1.9 |         | 2.4 | х     |
| Minimum output voltage     |                     |     | 0       |     | V     |
| Maximum output voltage     | Gain = 2.4          |     | 2.9     |     | V     |
| Minimum load resistance    |                     |     | 50      |     | kΩ    |
| Maximum load capacitance   |                     |     | 50      |     | PF    |

# 4.3.7 Auxiliary Analog-to-Digital Converter (ADC)

The auxiliary ADC is a 10-bit successive approximation A/D converter. The ADC has 11 input channels, three are from internal analog circuit used to monitor battery voltage, charging current and voltage and the others are for external usage. Two are specially used for touch panel. Special offset cancellation is applied in the ADC.





Figure 4-3 AUXADC circuit

Table 4-22 Performance of the Auxiliary ADC

| Parameter                  | Conditions/Comments | Min | Typical | Max | Unit |
|----------------------------|---------------------|-----|---------|-----|------|
| Power supply               |                     | 2.7 | 3       | 3.3 | V    |
| Resolution                 |                     |     | 10      |     | bits |
| Integral non-linearity     |                     | -2  |         | +2  | LSB  |
| Differential non-linearity |                     | -1  |         | +1  | LSB  |
| Number of input channels   | For external users  |     | 4       |     |      |
| Analog input rongo         | Small range         |     | 1.2     |     | V    |
| Analog input range         | Large range         |     | 3       |     | V    |
| Conversion time            | )                   |     |         | 15  | μs   |

# 4.3.8 Low Dropout Regulators

Table 4-23 Performance of the integrated LDO regulators

| Parameter                  | Comments                        | Min | Typical | Max | Unit |  |
|----------------------------|---------------------------------|-----|---------|-----|------|--|
| External Memory Volta      | External Memory Voltage(VDDMEM) |     |         |     |      |  |
| Status after reset         | on                              |     |         |     |      |  |
| Application                | SDRAM                           |     |         |     |      |  |
| Output Voltage             | 0(default)                      | 1.7 | 1.8     | 1.9 | ٧    |  |
| Output Current             |                                 |     |         | 300 | mA   |  |
| Line regulation            | Vi=3.6V-4.2V;Io=100mA;          | 5   | 10      | 20  | mV   |  |
| Line Transient<br>Response | Vi=3.6V-4.2V;Io=100mA;Tr=10us   | 25  | 50      | 75  | mV   |  |
| Load regulation            | Vi=3.8V; Io=0-200mA;            | 25  | 50      | 75  | mV   |  |



| Parameter                    | Comments                                 | Min  | Typical | Max  | Unit |
|------------------------------|------------------------------------------|------|---------|------|------|
| Load Transient<br>Response   | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 30   | 60      | 90   | mV   |
| PSRR                         | F=217Hz,Io=100mA,                        | 36   | 40      | 50   | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs       | 50   | 85      | 120  | us   |
| Tpd                          | Vo=0.1V (lout=Imax/2)                    | 50   | 80      | 120  | us   |
| Isleep                       | Io=0mA                                   | 8    | 10      | 20   | uA   |
| Cext                         | External cap                             | 2.2  | 2.2     | 4.7  | uF   |
| Digital 2.8V IO Volta        | ge(VDD28)                                |      |         |      |      |
| Status after reset           | on                                       |      |         |      |      |
| Application                  | IO/ NAND Flash/LCM                       |      |         |      |      |
| Output Voltage               | 00(default)                              | 2.7  | 2.8     | 2.9  | V    |
|                              | 01                                       | 2.9  | 3.0     | 3.1  | V    |
|                              | 10                                       | 2.55 | 2.65    | 2.75 | V    |
|                              | 11                                       | 1.75 | 1.8     | 1.85 | V    |
| Output Current               |                                          |      |         | 200  | mA   |
| Line regulation              | Vi=3.6V-4.2V;lo=100mA;                   | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 15   | 25      | 50   | mV   |
| Load Regulation              | Vi=3.8V; Io=0-200mA;                     | 30   | 50      | 75   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 30   | 50      | 75   | mV   |
| Short current limit          |                                          | 75   | 90      | 120  | mA   |
| Current limit                | Vi=3.8V                                  | 410  | 480     | 640  | mA   |
| PSRR                         | F=217Hz,lo=100mA,                        | 36   | 40      | 50   | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs       | 80   | 100     | 120  | us   |
| Tpd                          | Vo=0.1V (lout=Imax/2)                    | 200  | 300     | 400  | us   |
| Isleep                       | Io=0mA                                   | 12   | 15      | 25   | uA   |
| Cext                         | External cap                             | 2.2  | 2.2     | 4.7  | uF   |
| Digital 1.8V IO Volta        | ge(VDD18)                                |      |         |      | •    |
| Status after reset           | on                                       |      |         |      |      |
| Application                  | IO/ NAND Flash/LCM                       |      |         |      |      |
| Output Voltage               | 00(default)                              | 1.75 | 1.8     | 1.85 | V    |
|                              | 01                                       | 2.7  | 2.8     | 2.9  | V    |
|                              | 10                                       | 1.45 | 1.5     | 1.55 | V    |
| -                            | 11                                       | 1.15 | 1.2     | 1.25 | V    |
| Output Current               |                                          |      |         | 200  | mA   |
| Line Regulation              | Vi=3.6V-4.2V;Io=100mA;                   | 6    | 12      | 24   | mV   |



| Parameter                    | Comments                                 | Min  | Typical | Max  | Unit |
|------------------------------|------------------------------------------|------|---------|------|------|
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 10   | 20      | 30   | mV   |
| Load regulation              | Vi=3.8V; Io=0-200mA;                     | 30   | 60      | 90   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 30   | 60      | 90   | mV   |
| Short current limit          |                                          | 75   | 90      | 120  | mA   |
| Current limit                | Vi=3.8V                                  | 410  | 480     | 640  | mA   |
| PSRR                         | F=217Hz,lo=100mA,                        | 36   | 40      | 50   | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs       | 90   | 150     | 225  | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                    | 90   | 150     | 225  | us   |
| Isleep                       | Io=0mA                                   | 10   | 15      | 25   | uA   |
| Cext                         |                                          | 2.2  | 2.2     | 4.7  | uF   |
| LDO for RF0(VDDRI            | F0)                                      |      |         |      | •    |
| Status after reset           | on                                       |      |         |      |      |
| Application                  | RF/TCXO                                  |      |         |      |      |
| Output Voltage               | 00(default)                              | 2.75 | 2.85    | 2.95 | V    |
|                              | 01                                       | 2.85 | 2.95    | 3.05 | V    |
|                              | 10                                       | 2.65 | 2.75    | 2.85 | V    |
|                              | 11                                       | 1.75 | 1.8     | 1.85 | V    |
| Output Current               |                                          |      |         | 200  | mA   |
| Line regulation              | Vi=3.6V-4.2V;lo=100mA;                   | 3    | 5       | 10   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 5    | 10      | 20   | mV   |
| Load regulation              | Vi=3.8V; lo=0-200mA;                     | 25   | 50      | 75   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 25   | 50      | 75   | mV   |
| PSRR                         | F=217Hz,Io=100mA,                        | 48   | 60      | 72   | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs       | 30   | 50      | 75   | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                    | 110  | 160     | 240  | us   |
| Isleep                       | Io=0mA                                   | 30   | 40      | 55   | uA   |
| Cext                         |                                          | 2.2  | 2.2     | 4.7  | uF   |
| LDO for RF1 (VDDR            | F1)                                      |      | •       | •    |      |
| Status after reset           | off                                      |      |         |      |      |
| Application                  | Supply for external terminal             |      |         |      |      |
| Output Voltage               | 00(default)                              | 2.75 | 2.85    | 2.95 | V    |
|                              | 01                                       | 2.85 | 2.95    | 3.05 | ٧    |
|                              | 10                                       | 2.4  | 2.5     | 2.6  | V    |
|                              | 11                                       | 1.75 | 1.8     | 1.85 | V    |



| Parameter                    | Comments                                 | Min | Typical | Max | Unit |
|------------------------------|------------------------------------------|-----|---------|-----|------|
| Output Current               |                                          |     |         | 200 | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=100mA;                   | 3   | 5       | 10  | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 5   | 10      | 20  | mV   |
| Load regulation              | Vi=3.8V; Io=0-100mA;                     | 25  | 50      | 75  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-100mA;Co=2.2uF;<br>Tr=10us | 25  | 50      | 75  | mV   |
| PSRR                         | F=217Hz,Io=100mA,                        | 48  | 60      | 72  | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs       | 30  | 50      | 75  | us   |
| Tpd                          | Vo=0.1V (lout=Imax/2)                    | 96  | 160     | 240 | us   |
| Isleep                       | Io=0mA                                   | 32  | 40      | 55  | uA   |
| Cext                         |                                          | 2.2 | 2.2     | 4.7 | uF   |
| Digital SDIO0 Voltag         | e (VDDSD0)                               |     |         |     | •    |
| Status after reset           | off                                      |     |         |     |      |
| Application                  | SD Card                                  |     |         |     |      |
| Output Voltage               | 00(default)                              | 2.7 | 2.8     | 2.9 | V    |
|                              | 01                                       | 2.9 | 3.0     | 3.1 | V    |
|                              | 10                                       | 2.4 | 2.5     | 2.6 | V    |
|                              | 11                                       | 1.7 | 1.8     | 1.9 | V    |
| Output Current               |                                          |     |         | 150 | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                    | 5   | 10      | 20  | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us             | 15  | 30      | 45  | mV   |
| Load regulation              | Vi=3.8V; lo=0-50mA;                      | 15  | 30      | 45  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-50mA;Co=1uF;<br>Tr=10us    | 25  | 50      | 75  | mV   |
| Short current limit          |                                          | 75  | 90      | 120 | mA   |
| Current limit                | Vi=3.8V                                  | 410 | 480     | 640 | mA   |
| PSRR                         | F=217Hz,Io=50mA,                         | 36  | 40      | 50  | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs       | 20  | 35      | 50  | us   |
| Tpd                          | Vo=0.1V (lout=Imax/2)                    | 110 | 180     | 270 | us   |
| Isleep                       | Io=0mA                                   | 16  | 20      | 30  | uA   |
| Cext                         |                                          | 1   | 2.2     | 4.7 | uF   |
| Digital SDIO1 Voltag         | e (VDDSD1)                               | •   | •       | •   | •    |
| Status after reset           | off                                      |     |         |     |      |
| Application                  | SD Card                                  |     |         |     |      |
| Output Voltage               | 00(default)                              | 2.7 | 2.8     | 2.9 | V    |
|                              | 01                                       | 2.9 | 3.0     | 3.1 | V    |



| Parameter                    | Comments                              | Min  | Typical | Max  | Unit |
|------------------------------|---------------------------------------|------|---------|------|------|
|                              | 10                                    | 2.4  | 2.5     | 2.6  | V    |
|                              | 11                                    | 1.7  | 1.8     | 1.9  | V    |
| Output Current               |                                       |      |         | 150  | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                 | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us          | 15   | 30      | 45   | mV   |
| Load regulation              | Vi=3.8V; Io=0-50mA; 15 30             |      | 45      | mV   |      |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-50mA;Co=1uF;<br>Tr=10us | 25   | 50      | 75   | mV   |
| Short current limit          |                                       | 75   | 90      | 120  | mA   |
| Current limit                | Vi=3.8V                               | 410  | 480     | 640  | mA   |
| PSRR                         | F=217Hz,Io=50mA,                      | 36   | 40      | 50   | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10μs    | 20   | 35      | 50   | us   |
| Tpd                          | Vo=0.1V (lout=Imax/2)                 | 110  | 180     | 270  | us   |
| Isleep                       | Io=0mA                                | 16   | 20      | 30   | uA   |
| Cext                         |                                       | 1    | 2.2     | 4.7  | uF   |
| General LDO(VDDC             | AMD0)                                 |      |         |      |      |
| Status after reset           | off                                   |      |         |      |      |
| Application                  | Supply for external sensor            |      |         |      |      |
| Output Voltage               | 00(default)                           | 1.75 | 1.8     | 1.85 | V    |
|                              | 01                                    | 2.7  | 2.8     | 2.9  | V    |
|                              | 10                                    | 1.45 | 1.5     | 1.55 | V    |
|                              | 11                                    | 1.25 | 1.3     | 1.35 | V    |
| Output Current               |                                       |      |         | 100  | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                 | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;lo=50mA;Tr=10us          | 10   | 20      | 30   | mV   |
| Load regulation              | Vi=3.8V; Io=0-50mA;                   | 15   | 30      | 45   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-50mA;Co=1uF;<br>Tr=10us | 15   | 30      | 45   | mV   |
| PSRR                         | F=217Hz,Io=50mA,                      | 36   | 40      | 50   | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10μs    | 12   | 20      | 30   | us   |
| Tpd                          | Vo=0.1V (lout=Imax/2)                 | 110  | 180     | 270  | us   |
| Isleep                       | Io=0mA                                | 16   | 20      | 30   | uA   |
| Cext                         |                                       | 1    | 1       | 2.2  | uF   |
| General LDO (VDDC            | AMDA)                                 |      |         |      |      |
| Status after reset           | off                                   |      |         |      |      |
| Application                  | Supply for external sensor            |      |         |      |      |
|                              |                                       |      |         |      |      |



| Parameter                    | Comments                              | Min  | Typical | Max  | Unit |
|------------------------------|---------------------------------------|------|---------|------|------|
| Output Voltage               | 00(default)                           | 2.7  | 2.8     | 2.9  | V    |
|                              | 01                                    | 2.9  | 3.0     | 3.1  | V    |
|                              | 10                                    | 2.4  | 2.5     | 2.6  | V    |
|                              | 11                                    | 1.7  | 1.8     | 1.9  | V    |
| Output Current               |                                       |      |         | 150  | mA   |
| Line regulation              | ine regulation Vi=3.6V-4.2V;lo=80mA;  |      | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=80mA;Tr=10us          | 10   | 20      | 30   | mV   |
| Load regulation              | Vi=3.8V; Io=0-80mA;                   | 15   | 30      | 45   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-80mA;Co=1uF;<br>Tr=10us | 15   | 30      | 45   | mV   |
| PSRR                         | F=217Hz,Io=50mA,                      | 36   | 40      | 50   | dB   |
| Cext                         |                                       | 1    | 1       | 2.2  | uF   |
| General LDO (VDDC            | AMD1)                                 |      |         |      |      |
| Status after reset           | off                                   |      |         |      |      |
| Application                  | Supply for external sensor            |      |         |      |      |
| Output Voltage               | 00(default)                           | 2.7  | 2.8     | 2.9  | ٧    |
|                              | 01                                    | 3.2  | 3.3     | 3.4  | V    |
|                              | 10                                    | 1.75 | 1.8     | 1.85 | V    |
|                              | 11                                    | 1.15 | 1.2     | 1.25 | V    |
| Output Current               |                                       |      |         | 100  | mA   |
| Line regulation              | Vi=3.6V-4.2V;lo=50mA;                 | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;lo=50mA;Tr=10us          | 10   | 20      | 30   | mV   |
| Load regulation              | Vi=3.8V; Io=0-50mA;                   | 15   | 30      | 45   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-50mA;Co=1uF;<br>Tr=10us | 15   | 30      | 45   | mV   |
| PSRR                         | F=217Hz,Io=50mA,                      | 36   | 40      | 50   | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs    | 12   | 20      | 30   | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                 | 110  | 180     | 270  | us   |
| Isleep                       | Io=0mA                                | 16   | 20      | 30   | uA   |
| Cext                         |                                       | 1    | 1       | 2.2  | uF   |
| Small battery and R          | eal time clock LDO (VDDBK and VDDR    | TC)  |         |      | •    |
| Status after reset           | On                                    |      |         |      |      |
| Application                  | Supply for small battery and RTC      |      |         |      |      |
| VBATBK Output<br>Voltage     | 00                                    | 2.45 | 2.6     | 2.75 | V    |
|                              | 01 (default)                          | 2.65 | 2.8     | 2.95 | V    |



| Parameter                    | Comments                              | Min  | Typical | Max   | Unit |
|------------------------------|---------------------------------------|------|---------|-------|------|
|                              | 10                                    | 2.85 | 3.0     | 3.15  | V    |
|                              | 11                                    | 3.05 | 3.2     | 3.35  | V    |
| VBATBK output resistor       | 00 (default)                          | 160  | 200     | 240   | Ω    |
|                              | 01                                    | 400  | 500     | 600   | Ω    |
|                              | 10                                    | 1200 | 1500    | 1800  | Ω    |
|                              | 11                                    | 1600 | 2000    | 2400  | Ω    |
| VDDRTC Output<br>Voltage     | 00(default)                           | 1.75 | 1.8     | 1.85  | V    |
|                              | 01                                    | 1.65 | 1.7     | 1.75  | V    |
|                              | 10                                    | 1.55 | 1.6     | 1.65  | V    |
|                              | 11                                    | 1.45 | 1.5     | 1.55  | V    |
| Output Current               |                                       |      |         | 1     | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=0.2mA;                | 8    | 15      | 30    | mV   |
| Load regulation              | pad regulation Vi=3.8V; Io=0-0.2mA    |      | 10      | 20    | mV   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs    |      | 80      | 120   | us   |
| Isleep                       | Vbat                                  | 15   | 18      | 24    | uA   |
|                              | Vbuk                                  | 10   | 11.5    | 17    | uA   |
| Cext                         |                                       | 0.01 | 0.01    | 0.047 | uF   |
| SIMO LDO (VSIM0)             |                                       |      |         |       |      |
| Status after reset           | On                                    |      |         |       |      |
| Application                  | Supply for SIM Card                   |      | _       | •     |      |
| Output Voltage               | 00(default)                           | 1.7  | 1.8     | 1.9   | V    |
|                              | 01                                    | 2.8  | 2.9     | 3.0   | V    |
|                              | 10                                    | 2.9  | 3.0     | 3.1   | V    |
|                              | 11                                    | 3.0  | 3.1     | 3.2   | V    |
| Output Current               | <b>&gt;</b>                           |      |         | 60    | mA   |
| Line regulation              | Vi=3.6V-4.2V;lo=30mA;                 | 5    | 10      | 20    | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=30mA;Tr=10us          | 10   | 20      | 30    | mV   |
| Load regulation              | Vi=3.8V; Io=0-30mA;                   | 15   | 30      | 45    | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=1uF;<br>Tr=10us | 15   | 30      | 45    | mV   |
| Short current limit          |                                       | 25   | 30      | 45    | mA   |
| Current limit                | Vi=3.8V                               | 120  | 150     | 225   | mA   |
| PSRR                         | F=217Hz,lo=30mA,                      | 36   | 40      | 50    | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs    | 60   | 100     | 150   | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                 | 150  | 250     | 375   | us   |



| Parameter                    | Comments                                | Min     | Typical | Max | Unit |
|------------------------------|-----------------------------------------|---------|---------|-----|------|
| Isleep                       | Io=0mA                                  | 12      | 15      | 23  | uA   |
| Cext                         |                                         | 1       | 1       | 2.2 | uF   |
| SIM1 LDO (VSIM1)             |                                         |         |         |     |      |
| Status after reset           | Off                                     |         |         |     |      |
| Application                  | Supply for SIM Card                     |         |         |     |      |
| Output Voltage               | 00(default)                             | 1.7     | 1.8     | 1.9 | V    |
|                              | 01                                      | 2.8     | 2.9     | 3.0 | V    |
|                              | 10                                      | 2.9     | 3.0     | 3.1 | V    |
|                              | 11                                      | 3.0     | 3.1     | 3.2 | V    |
| Output Current               |                                         |         |         | 60  | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=30mA;                   | 5       | 10      | 20  | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=30mA;Tr=10us            | 10      | 20      | 30  | mV   |
| Load regulation              | Vi=3.8V; Io=0-30mA;                     | 15      | 30      | 45  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=1uF;<br>Tr=10us   | 15      | 30      | 45  | mV   |
| Short current limit          |                                         | 25      | 30      | 45  | mA   |
| Current limit                | Vi=3.8V                                 | 120     | 150     | 225 | mA   |
| PSRR                         | F=217Hz,Io=30mA,                        | 36      | 40      | 50  | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10μs      | 60      | 100     | 150 | us   |
| Tpd                          | Vo=0.1V (lout=Imax/2)                   | 150     | 250     | 375 | us   |
| Isleep                       | Io=0mA                                  | 12      | 15      | 23  | uA   |
| Cext                         |                                         | 1       | 1       | 2.2 | uF   |
| Analog BB Voltage(           | AVDDBB)                                 |         |         |     |      |
| Status after reset           | On                                      |         |         |     |      |
| Application                  | Supply for BB circuit, for example AD   | C/DAC/A | PC      |     |      |
| Output Voltage               | 00(default)                             | 2.9     | 3.0     | 3.1 | V    |
|                              | 01                                      | 3.0     | 3.1     | 3.2 | V    |
| 00                           | 10                                      | 2.8     | 2.9     | 3.0 | V    |
|                              | 11                                      | 2.7     | 2.8     | 2.9 | V    |
| Output Current               |                                         |         |         | 60  | mA   |
| Line regulation              | Vi=3.6V-4.2;Io=50mA;                    | 3       | 5       | 10  | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2;Io=50mA;Tr=10us             | 5       | 10      | 20  | mV   |
| Load regulation              | Vi=3.8V; Io=0-100mA;                    | 15      | 30      | 60  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-50mA;Co=2.2uF;<br>Tr=10us | 25      | 50      | 100 | mV   |
| PSRR                         | F=217Hz,Io=50mA,                        | 48      | 60      | 72  | dB   |



| Parameter                                              | Comments                                | Min | Typical | Max | Unit |
|--------------------------------------------------------|-----------------------------------------|-----|---------|-----|------|
| Tpu                                                    | Supply ramp from 0 to 3.6v in 10μs      | 36  | 60      | 90  | us   |
| Tpd                                                    | Vo=0.1V (lout=lmax/2)                   | 90  | 150     | 225 | us   |
| Isleep                                                 | Io=0mA                                  | 32  | 40      | 60  | uA   |
| Cext                                                   |                                         | 2.2 | 2.2     | 4.7 | uF   |
| Analog VB Voltage(                                     | AVDDVB)                                 |     |         |     | -    |
| Status after reset                                     | Off                                     |     |         |     |      |
| Application                                            | VB analog/VB output                     |     |         |     |      |
| Output Voltage                                         | 00(default)                             | 3.2 | 3.3     | 3.4 | V    |
|                                                        | 01                                      | 3.3 | 3.4     | 3.5 | V    |
|                                                        | 10                                      | 3.1 | 3.2     | 3.3 | V    |
|                                                        | 11                                      | 2.8 | 2.9     | 3.0 | V    |
| Output Current                                         |                                         |     |         | 100 | mA   |
| Line regulation                                        | Vi=3.6V-4.2V;Io=50mA;                   | 3   | 5       | 10  | mV   |
| Line Transient Vi=3.6V-4.2V;Io=50mA;Tr=10us Regulation |                                         | 5   | 10      | 20  | mV   |
| Load regulation                                        | Vi=3.8V; Io=0-100mA;                    | 8   | 15      | 30  | mV   |
| Load Transient<br>Regulation                           | · · · · · · · · · · · · · · · · · · ·   |     | 50      | 75  | mV   |
| PSRR                                                   | F=217Hz,lo=50mA,                        | 48  | 60      | 72  | dB   |
| Tpu                                                    | Supply ramp from 0 to 3.6v in 10µs      | 30  | 50      | 75  | us   |
| Tpd                                                    | Vo=0.1V (lout=lmax/2)                   | 210 | 350     | 500 | us   |
| Isleep                                                 | Io=0mA                                  | 32  | 40      | 60  | uA   |
| Cext                                                   |                                         | 2.2 | 2.2     | 4.7 | uF   |
| USB High Voltage(V                                     | DDUSBH)                                 |     |         |     |      |
| Status after reset                                     | Off                                     |     |         |     |      |
| Application                                            | USB IP                                  |     |         |     |      |
| Output Voltage                                         | 00 (default)                            | 3.2 | 3.3     | 3.4 | V    |
|                                                        | 01                                      | 3.3 | 3.4     | 3.5 | V    |
| 0.0                                                    | 10                                      | 3.1 | 3.2     | 3.3 | V    |
|                                                        | 11                                      | 3.0 | 3.1     | 3.2 | V    |
| Output Current                                         |                                         |     |         | 60  | mA   |
| Line regulation                                        | Vi=3.6V-4.2V;Io=50mA;                   | 5   | 10      | 20  | mV   |
| Line Transient<br>Regulation                           | Vi=3.6V-4.2V;Io=50mA;Tr=10us            | 10  | 20      | 40  | mV   |
| Load regulation                                        | Vi=3.8V; Io=0-30mA;                     | 15  | 30      | 60  | mV   |
| Load Transient<br>Regulation                           | Vi=3.8V; Io=0-30mA;Co=2.2uF;<br>Tr=10us | 15  | 30      | 60  | mV   |
| PSRR                                                   | F=217Hz,Io=50mA,                        | 36  | 40      | 50  | dB   |



| Parameter                    | Comments                                | Min           | Typical | Max  | Unit |  |  |
|------------------------------|-----------------------------------------|---------------|---------|------|------|--|--|
| Tpu                          | Supply ramp from 0 to 3.6v in 10μs      | 9             | 15      | 23   | us   |  |  |
| Tpd                          | Vo=0.1V (lout=Imax/2)                   | 240           | 400     | 600  | us   |  |  |
| Isleep                       | Io=0mA                                  | 12            | 15      | 23   | uA   |  |  |
| Cex                          |                                         | 1             | 1       | 2.2  | uF   |  |  |
| VDD25(VDD25)                 |                                         |               |         |      |      |  |  |
| Status after reset           | On                                      |               |         |      |      |  |  |
| Application                  | PLL and EFUSE                           | PLL and EFUSE |         |      |      |  |  |
| Output Voltage               | 00 (default)                            | 2.4           | 2.5     | 2.6  | V    |  |  |
|                              | 01                                      | 2.65          | 2.75    | 2.85 | V    |  |  |
|                              | 10                                      | 2.9           | 3.0     | 3.1  | V    |  |  |
|                              | 11                                      | 2.8           | 2.9     | 3.0  | V    |  |  |
| Output Current               |                                         |               |         | 60   | mA   |  |  |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                   | 5             | 10      | 20   | mV   |  |  |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us            | 10            | 20      | 40   | mV   |  |  |
| Load regulation              | Vi=3.8V; Io=0-30mA;                     | 20            | 40      | 80   | mV   |  |  |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=2.2uF;<br>Tr=10us | 20            | 40      | 80   | mV   |  |  |
| Tpu                          | Supply ramp from 0 to 3.6v in 10µs      | 60            | 100     | 200  | us   |  |  |
| PSRR                         | F=217Hz,Io=30mA,                        | 48            | 60      | 72   | dB   |  |  |
| Cex                          |                                         | 2.2           | 2.2     | 4.7  | uF   |  |  |
| DVDD18(VDD_A)                |                                         |               |         |      |      |  |  |
| Status after reset           | On                                      |               |         |      |      |  |  |
| Application                  | Analog 1.8V power                       |               |         |      |      |  |  |
| Output Voltage               |                                         | 1.7           | 1.8     | 1.9  | V    |  |  |
| Output Current               |                                         |               |         | 80   | mA   |  |  |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                   | 5             | 10      | 20   | mV   |  |  |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us            | 10            | 20      | 40   | mV   |  |  |
| Load regulation              | Vi=3.8V; Io=0-30mA;                     | 20            | 40      | 80   | mV   |  |  |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=2.2uF;<br>Tr=10us | 20            | 40      | 80   | mV   |  |  |
| PSRR                         | F=217Hz,Io=50mA,                        | 36            | 40      | 50   | dB   |  |  |
| Сех                          |                                         | 1             | 1       | 2.2  | uF   |  |  |
| WIF0 LDO Voltage (\          | /DDWIF0)                                | •             |         |      | •    |  |  |
| Status after reset           | Off                                     |               |         |      |      |  |  |
| Application                  | Supply for external Wif terminal        |               |         |      |      |  |  |
| Output Voltage               | 00                                      | 2.7           | 2.8     | 2.9  | V    |  |  |



| Parameter                    | Comments                                 | Min  | Typical | Max  | Unit |
|------------------------------|------------------------------------------|------|---------|------|------|
|                              | 01(default)                              | 3.15 | 3.3     | 3.45 | V    |
|                              | 10                                       | 1.7  | 1.8     | 1.9  | V    |
|                              | 11                                       | 1.1  | 1.2     | 1.3  | V    |
| Output Current               |                                          |      |         | 200  | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=100mA;                   | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;lo=100mA;Tr=10us            | 12   | 25      | 50   | mV   |
| Load Regulation              | Vi=3.8V; Io=0-200mA;                     | 25   | 50      | 100  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 25   | 50      | 100  | mV   |
| Short current limit          |                                          | 75   | 90      | 120  | mA   |
| Current limit                | Vi=3.8V                                  | 410  | 480     | 640  | mA   |
| PSRR                         | F=217Hz,Io=100mA,                        | 36   | 40      | 50   | dB   |
| Три                          | Supply ramp from 0 to 3.6v in 10µs       | 60   | 100     | 150  | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2) 180 300            |      | 300     | 450  | us   |
| Isleep                       | Io=0mA                                   | 12   | 15      | 23   | uA   |
| Cext                         | External cap                             | 2.2  | 2.2     | 4.7  | uF   |
| WIF1 LDO Voltage (V          | DDWIF1)                                  |      | •       | •    |      |
| Status after reset           | Off                                      |      |         |      |      |
| Application                  | Supply for external Wif terminal         |      |         |      |      |
| Output Voltage               | 00                                       | 2.7  | 2.8     | 2.9  | V    |
|                              | 01(default)                              | 3.15 | 3.3     | 3.45 | V    |
|                              | 10                                       | 1.7  | 1.8     | 1.9  | V    |
| -                            | 11                                       | 1.1  | 1.2     | 1.3  | V    |
| Output Current               |                                          |      |         | 200  | mA   |
| Line regulation              | Vi=3.6V-4.2V;lo=100mA;                   | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;lo=100mA;Tr=10us            | 12   | 25      | 50   | mV   |
| Load Regulation              | Vi=3.8V; Io=0-200mA;                     | 25   | 50      | 100  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 25   | 50      | 100  | mV   |
| Short current limit          |                                          | 75   | 90      | 120  | mA   |
| Current limit                | Vi=3.8V                                  | 410  | 480     | 640  | mA   |
| PSRR                         | F=217Hz,Io=100mA,                        | 36   | 40      | 50   | dB   |
| Tpu                          | Supply ramp from 0 to 3.6v in 10μs       | 60   | 100     | 150  | us   |
| Tpd                          | Vo=0.1V<br>(lout=lmax/2)                 | 180  | 300     | 450  | us   |
|                              | Io=0mA                                   | 12   | 15      | 23   | uA   |



| Parameter                    | Comments                              | Min                           | Typical | Max | Unit |  |  |  |
|------------------------------|---------------------------------------|-------------------------------|---------|-----|------|--|--|--|
| Cext                         | External cap                          | 2.2                           | 2.2     | 4.7 | uF   |  |  |  |
| SIM2 LDO (VSIM2)             |                                       |                               |         |     |      |  |  |  |
| Status after reset           | Off                                   |                               |         |     |      |  |  |  |
| Application                  | Supply for SIM Card or CMMB RF        | upply for SIM Card or CMMB RF |         |     |      |  |  |  |
| Output Voltage               | 00                                    | 2.7                           | 2.8     | 2.9 | V    |  |  |  |
|                              | 01                                    | 2.9                           | 3       | 3.1 | ٧    |  |  |  |
|                              | 10(default)                           | 1.7                           | 1.8     | 1.9 | V    |  |  |  |
|                              | 11                                    | 1.3                           | 1.2     | 1.1 | V    |  |  |  |
| Output Current               |                                       |                               |         | 200 | mA   |  |  |  |
| Line regulation              | Vi=3.6V-4.2V;Io=30mA;                 | 5                             | 10      | 20  | mV   |  |  |  |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=30mA;Tr=10us          | 10                            | 20      | 40  | mV   |  |  |  |
| Load regulation              | Vi=3.8V; Io=0-30mA;                   | 15                            | 30      | 60  | mV   |  |  |  |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=1uF;<br>Tr=10us | 15                            | 30      | 60  | mV   |  |  |  |
| Short current limit          |                                       | 130                           | 150     | 200 | mA   |  |  |  |
| Current limit                | Vi=3.8V                               | 410                           | 480     | 640 | mA   |  |  |  |
| PSRR                         | F=217Hz,Io=30mA,                      | 48                            | 60      | 72  | dB   |  |  |  |
| Tpu                          | Supply ramp from 0 to 3.63v in 10μs   | 72                            | 120     | 180 | us   |  |  |  |
| Tpd                          | Vo=0.1V (lout=lmax/2)                 | 150                           | 250     | 333 | us   |  |  |  |
| Isleep                       | Io=0mA                                | 12                            | 15      | 23  | uA   |  |  |  |
| Cext                         |                                       | 2.2                           | 2.2     | 4.7 | uF   |  |  |  |
| SIM3 LDO (VSIM3)             |                                       |                               |         |     |      |  |  |  |
| Status after reset           | Off                                   |                               |         |     |      |  |  |  |
| Application                  | Supply for SIM Card or CMMB RF        |                               |         |     |      |  |  |  |
| Output Voltage               | 00                                    | 2.7                           | 2.8     | 2.9 | V    |  |  |  |
|                              | 01                                    | 2.9                           | 3       | 3.1 | V    |  |  |  |
|                              | 10(default)                           | 1.7                           | 1.8     | 1.9 | V    |  |  |  |
|                              | 11                                    | 1.3                           | 1.2     | 1.1 | V    |  |  |  |
| Output Current               |                                       |                               |         | 200 | mA   |  |  |  |
| Line regulation              | Vi=3.6V-4.2V;Io=30mA;                 | 5                             | 10      | 20  | mV   |  |  |  |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=30mA;Tr=10us          | 10                            | 20      | 40  | mV   |  |  |  |
| Load regulation              | Vi=3.8V; Io=0-30mA;                   | 15                            | 30      | 60  | mV   |  |  |  |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=1uF;<br>Tr=10us | 15                            | 30      | 60  | mV   |  |  |  |
| Short current limit          |                                       | 130                           | 150     | 200 | mA   |  |  |  |
| Current limit                | Vi=3.8V                               | 410                           | 480     | 640 | mA   |  |  |  |



| Parameter                 | Comments                                     | Min | Typical | Max | Unit |
|---------------------------|----------------------------------------------|-----|---------|-----|------|
| PSRR                      | F=217Hz,Io=30mA,                             | 48  | 60      | 72  | dB   |
| Tpu                       | Supply ramp from 0 to 3.6v in 10µs           | 72  | 120     | 180 | us   |
| Tpd                       | Vo=0.1V (lout=Imax/2)                        | 150 | 250     | 333 | us   |
| Isleep                    | Io=0mA                                       | 12  | 15      | 23  | uA   |
| Cext                      |                                              | 2.2 | 2.2     | 4.7 | uF   |
| LDO_PA                    |                                              |     |         |     |      |
| Status after reset        | off                                          |     |         |     | 7    |
| Application               | Audio PA                                     |     |         |     |      |
| Output voltage            | 000                                          | 2.7 | 2.9     | 3.1 | V    |
|                           | 001                                          | 2.8 | 3.0     | 3.2 | V    |
|                           | 010                                          | 2.9 | 3.1     | 3.3 | V    |
|                           | 011                                          | 3.0 | 3.2     | 3.4 | V    |
|                           | 100(default)                                 | 3.1 | 3.3     | 3.5 | V    |
|                           | 101                                          | 3.2 | 3.4     | 3.6 | V    |
|                           | 110                                          | 3.3 | 3.5     | 3.6 | V    |
|                           | 111                                          | 3.4 | 3.6     | -   | V    |
| Output current            |                                              |     |         | 400 | mA   |
| Line regulation           | Vsupply=3.6->4.2V, lout=200mA                | 5   | 10      | 20  | mV   |
| Line transient regulation | Vsupply=3.6->4.2V, lout=200mA,<br>Trise=10us | 10  | 20      | 40  | mV   |
| Load regulation           | Vsupply=3.8V, lout=0->400mA                  | 40  | 80      | 160 | mV   |
| Load transient regulation | Vsupply=3.8V, lout=0->400mA,<br>Trise=10us   | 50  | 100     | 200 | mV   |
| PSRR                      | Freq=217Hz, lout=400mA                       | 36  | 40      | 50  | dB   |
| Time to power up          | Vsupply=0->3.8V, Trise=10us                  | 60  | 100     | 150 | us   |
| Time to power down        | Vout=0.1V, lout=400mA                        | 180 | 300     | 450 | us   |
| Isleep                    | lout=0mA                                     | 12  | 15      | 23  | uA   |
| Output capacitor          | Required for stability and ripple rejection  | 4.7 | 4.7     | 10  | μF   |

Note1. There are two structures for these intergrated LDOs.

Note2. The PSRR listed means the worst value for all loading statuses and cover all frequency range.

# 4.3.9 Charger

Table 4-24 Performance of charger circuit

| Symbol     | Description      | Condition          | Min | Typical | Max | Unit |
|------------|------------------|--------------------|-----|---------|-----|------|
| VCHG       | Power supply pin | Charging condition | 4.5 | 5.0     | 5.5 | V    |
| Vtolerance | Maxim tolerance  |                    |     |         | 18  | V    |



| Symbol   | Description                         | Condition                                     | Min                                                  | Typical                                               | Max                                                   | Unit |
|----------|-------------------------------------|-----------------------------------------------|------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------|------|
|          | voltage at VCHG                     |                                               |                                                      |                                                       |                                                       |      |
| Vuvh     | Supply under voltage high threshold | AVDD low to high                              | 4.3                                                  | 4.5                                                   | 4.7                                                   | V    |
| Vuvl     | Supply under voltage low threshold  | AVDD high to low                              | 4.05                                                 | 4.25                                                  | 4.45                                                  | V    |
| Vuvhys   | Supply under voltage hysteresis     |                                               | 160                                                  | 200                                                   | 240                                                   | mV   |
| Vtrickle | Trickle threshold voltage           |                                               | 2.5                                                  | 2.7                                                   | 2.9                                                   | V    |
| Itrickle | Trickle charge current              | VBAT < Vtrickle                               | 40                                                   | 50                                                    | 60                                                    | mA   |
| Vrego    | Regulated output voltage            | Floating or when charging finished            | 4.1                                                  | 4.2                                                   | 4.3                                                   | V    |
| Imbat    | Charging current                    | Adapter mode 00 01 10 11 USB mode 00 01 10 11 | 360<br>540<br>720<br>900<br>270<br>360<br>450<br>450 | 400<br>600<br>800<br>1000<br>300<br>400<br>500<br>500 | 440<br>660<br>880<br>1100<br>330<br>440<br>550<br>550 | mA   |
| Istop    | Charging stop current threshold     |                                               |                                                      | Imbat/10                                              |                                                       | mA   |
| ldd      | Current consumption                 |                                               |                                                      | 0.5                                                   | 1                                                     | mA   |
| Istdby   | Standby current                     | When charging finished                        |                                                      | 1                                                     |                                                       | μΑ   |
| lpd      | Power down leakage                  |                                               |                                                      |                                                       | 1                                                     | μА   |
| Irev     | Reverse leakage current             | VCHG=0; Vrego=4.2V                            |                                                      |                                                       | 1                                                     | μА   |

Note1: Hardware stops charging if VCHG is higher than 9V and the maximum value of VCHG can be set by software. The higher maximum value of VCHG, the stricter Vds requirement of external MOSFET.

Note2: The value set by software should be 10% higher than maximum value of VCHG listed in table to guarantee all chips can stop charging over the maximum value of VCHG.

Note3: Istop can be set according to specific requirement.



# 4.3.10 DC-DC

### Table 4-25 Performance of DC-DC circuit

Table 4-26 Performance of DC-DC circuit

| Parameter                 | Comments/Conditions                          | Min  | Typical | Max  | Unit |
|---------------------------|----------------------------------------------|------|---------|------|------|
| DCDC for ARM              |                                              |      |         | •    |      |
| Status after reset        | on                                           |      |         |      |      |
| Application               | Digital core power                           |      |         |      |      |
|                           | 000                                          | 0.55 | 0.65    | 0.75 | V    |
|                           | 001                                          | 0.6  | 0.7     | 0.8  | V    |
|                           | 010                                          | 0.7  | 0.8     | 0.9  | V    |
| Output valtage            | 011                                          | 0.8  | 0.9     | 1    | V    |
| Output voltage            | 100                                          | 0.9  | 1.0     | 1.1  | V    |
|                           | 101                                          | 1    | 1.1     | 1.2  | V    |
|                           | 110(default)                                 | 1.1  | 1.2     | 1.3  | ٧    |
|                           | 111                                          | 1.2  | 1.3     | 1.4  | V    |
| Trim voltage              | Trim votage step (32 step)                   | 2    | 3       | 4    | mv   |
| Output current            |                                              |      |         | 500  | mA   |
| Line regulation           | Vsupply=3.6->4.2V, lout=200mA                | 5    | 10      | 20   | mV   |
| Line transient regulation | Vsupply=3.6->4.2V, lout=200mA,<br>Trise=10us | 15   | 30      | 60   | mV   |
| Load regulation           | Vsupply=3.8V, lout=0->400mA                  | 40   | 80      | 160  | mV   |
| Load transient regulation | Vsupply=3.8V, lout=0->400mA,<br>Trise=10us   | 50   | 100     | 200  | mV   |
| Time to power up          | Vsupply=0->4.3V, Trise=10us                  | 60   | 100     | 150  | us   |
| Switching frequency       |                                              | 1    | 1.5     | 2.25 | MHz  |
| Isleep                    | lout=0mA                                     | 72   | 90      | 100  | uA   |
| Effiency                  | 100mA loading                                | 80   | 85      | 90   | %    |
| Parameter                 | Comments/Conditions                          | Min  | Typical | Max  | Unit |
| DCDC for other Core       |                                              |      |         |      |      |
| Status after reset        | on                                           |      |         |      |      |
| Application               | Digital core power                           |      |         |      |      |
|                           | 000                                          | 0.55 | 0.65    | 0.75 | V    |
|                           | 001                                          | 0.6  | 0.7     | 0.8  | ٧    |
|                           | 010                                          | 0.7  | 0.8     | 0.9  | V    |
| Output voltage            | 011                                          | 0.8  | 0.9     | 1    | V    |
|                           | 100                                          | 0.9  | 1.0     | 1.1  | V    |
|                           | 101(default)                                 | 1    | 1.1     | 1.2  | V    |
|                           | 110                                          | 1.1  | 1.2     | 1.3  | V    |



| Parameter                 | Comments/Conditions                          | Min | Typical | Max  | Unit |
|---------------------------|----------------------------------------------|-----|---------|------|------|
|                           | 111                                          | 1.2 | 1.3     | 1.4  | V    |
| Trim voltage              | Trim votage step (32 step)                   | 2   | 3       | 4    | mv   |
| Output current            |                                              |     |         | 500  | mA   |
| Line regulation           | Vsupply=3.6->4.2V, Iout=200mA                | 5   | 10      | 20   | mV 🔷 |
| Line transient regulation | Vsupply=3.6->4.2V, lout=200mA,<br>Trise=10us | 15  | 30      | 60   | mV   |
| Load regulation           | Vsupply=3.8V, lout=0->400mA                  | 40  | 80      | 160  | mV   |
| Load transient regulation | Vsupply=3.8V, lout=0->400mA,<br>Trise=10us   | 50  | 100     | 200  | mV   |
| Time to power up          | Vsupply=0->4.3V, Trise=10us                  | 60  | 100     | 150  | us   |
| Switching frequency       |                                              | 1   | 1.5     | 2.25 | MHz  |
| Isleep                    | lout=0mA                                     | 72  | 90      | 100  | uA   |
| Effiency                  | 100mA loading                                | 80  | 85      | 90   | %    |



Figure 4-4 DCDC application diagram





Figure 4-5 DCDC efficiency vs loading

# 4.3.11 Audio PA

The block is an audio amplifier, which is Class-AB mode and Class-D mode optional. It can deliver 800mW of continuous average power into a mono  $8\Omega$  bridged-tied load (BTL) with 1% THD+N in Class-D mode or 500mW with 0.1% THD+N in Class-AB mode, using a 3.8V power supply.





Figure 4-6 Audio PA structure

Table 4-27 Absolute maximum ratings

| Parameter | Description                    | Condition | MIN | TYP | MAX | UNIT |
|-----------|--------------------------------|-----------|-----|-----|-----|------|
| VBAT      | Driver power supply            |           | 3.6 | 3.8 | 5.2 | ٧    |
| AVDD      | Analog power supply            |           | 3.0 | 3.3 | 3.6 | ٧    |
| TA        | Operating free-air temperature |           | 0   |     | 80  | С    |

Table 4-28 Performance of PA circuit

Test condition: VBAT=3.8V, AVDDVB=3.3V, AVDDPA=3.6V, T=27°C, Rload=8Ω. Input sine wave with a frequency of 1kHz, measurement bandwidth 20-20kHz, unless otherwise specified.

| Parameter | Description                  | Condition |          | MIN | TYP | MAX | UNIT |
|-----------|------------------------------|-----------|----------|-----|-----|-----|------|
| Psleep    | Sleep mode power consumption |           |          |     | 10  |     | uA   |
| Idd       | Current                      |           | Class-AB |     | 15  |     | mA   |
| C         | consumption                  |           | Class-D  |     | 10  |     | mA   |
| Pomax     | Maximum output               | Class-AB  | THD>=1%  |     | 500 |     | mW   |



|             | power                                              |          | VBAT=3.3V,<br>AVDDVB=AVDDPA<br>=2.9V, THD>=1% |      | 350  |     | mW  |
|-------------|----------------------------------------------------|----------|-----------------------------------------------|------|------|-----|-----|
|             |                                                    | Class-D  | THD>=1%                                       | 700* | 800  |     | mW  |
|             |                                                    |          | VBAT=3.3V,<br>AVDDVB=AVDDPA<br>=2.9V, THD>=1% |      | 500  |     | mW  |
|             |                                                    |          | Rload=4Ω,<br>THD>=1%                          |      | 1.2  |     | W   |
| PSRR(Note1) | Power supply                                       | Class-AB |                                               |      | -75  | -55 | dB  |
|             | rejection ratio                                    | Class-D  |                                               |      | -70  | -45 | dB  |
| THD         | Total harmonic                                     | Class-AB | Po=0.5W                                       |      | 0.2% |     |     |
|             | distortion plus<br>noise                           |          | Po=0.3W                                       |      | 0.1% |     |     |
|             |                                                    | Class-D  | Po=0.7W                                       |      | 1%   |     |     |
|             |                                                    |          | Po=0.3W                                       |      | 0.5% |     |     |
| SNR         | Signal-to-noise                                    | Class-AB | Po=0.5W                                       |      | 90   |     | dB  |
|             | ratio                                              | Class-D  | Po=0.7W                                       |      | 70   |     | dB  |
|             |                                                    |          | Po=0.3W                                       |      | 80   |     | dB  |
| Vn(Note2)   | Output voltage                                     | Class-AB |                                               |      | 15   | 50  | uV  |
|             | noise                                              | Class-D  |                                               |      | 100  | 150 | uV  |
| Efficiency  | Power efficiency                                   | Class-AB | Po=0.5W                                       |      | 50%  |     |     |
|             |                                                    |          | Po=0.3W                                       |      | 30%  |     |     |
|             |                                                    | Class-D  | Po=0.7W                                       |      | 85%  |     |     |
|             |                                                    |          | Po=0.3W                                       |      | 80%  |     |     |
| Gain        |                                                    | Class-AB |                                               |      | 6    |     | dB  |
|             |                                                    | Class-D  |                                               |      | 9    |     | dB  |
| fsw         | Switching frequency                                | Class-D  |                                               | 0.5  | 0.6  | 0.7 | MHz |
| tsw         | Power switch slow start-up time                    |          |                                               |      | 1    | 2   | ms  |
| tcom        | PA Class-AB mode common voltage fast start-up time |          |                                               |      | 30   | 50  | ms  |
| Area        | Layout area                                        | _        |                                               |      | 0.84 |     | mm2 |

Note \*: When set Dolphin's control register GODL=GODR=-6dB, set digital gain=Full scale-1dB, the maximum output power on the speaker (with bead and 1nF capacitor low pass filter) with THD>=1% is 700mW.

Note 1: Ripple voltage on VBAT is 0.3Vpp at 217Hz and 1kHz.

Note 2: When PA's input comes from Dolphin, the output voltage noise will be 50uV in Class-AB mode, 150uV in Class-D mode.



#### 4.3.12 LCD Backlight LED Driver

The LCD Backlight module provides six matched current sources, sinks up to 24.75 mA of load current to accommodate each of the six White LEDs. The module uses current mirror to construct LCD backlight driver. The reference current source ISET is set with an external resistor R. Each of the matched current regulators has a 100:1 current ratio between the VLEDx outputs (one channel) and the ISET currents. It requires no charge pump. Brightness can be controlled by software. The module is in shut down mode when the whtled pd is active.



Figure 4-7 LCD backlight LED driver application

Note1: D1 in the diagram must be connected to a LED when in use, otherwise the LED driver current control bits will not be effective.

**Parameter** Conditions/Comments Min **Typical** Max Unit Status after reset 00000(min current) (default) 1.5 00001 2.25

**Table 4-29** Peformance of LCD backlight LED driver

| Output current | ŀ |
|----------------|---|
|                | Ļ |

| 00010 |   | 3.0   |   |      |
|-------|---|-------|---|------|
| 00011 |   | 3.75  |   |      |
| 00100 |   | 4.5   |   |      |
| 00101 |   | 5.25  |   |      |
| 00110 |   | 6.0   |   |      |
| 00111 |   | 6.75  |   | mA   |
| 01000 |   | 7.5   |   | IIIA |
| 01001 |   | 8.25  |   |      |
| 01010 |   | 9     |   |      |
| 01011 |   | 9.75  |   |      |
| 01100 |   | 10.5  |   |      |
| 01101 |   | 11.25 |   |      |
| 01110 | · | 12.0  | · |      |
| 01111 | · | 12.75 | · |      |



|                | 10000              | 13.5  |    |
|----------------|--------------------|-------|----|
|                | 10001              | 14.25 |    |
|                | 10010              | 15.0  |    |
|                | 10011              | 15.75 |    |
|                | 10100              | 16.5  |    |
|                | 10101              | 17.25 |    |
|                | 10110              | 18.0  |    |
|                | 10111              | 18.75 |    |
| Output current | 11000              | 19.5  | mA |
|                | 11001              | 20.25 |    |
|                | 11010              | 21.0  |    |
|                | 11011              | 21.75 |    |
|                | 11100              | 22.5  |    |
|                | 11101              | 23.25 |    |
|                | 11110              | 24.0  |    |
|                | 11111(max current) | 24.75 |    |

# 4.3.13 Keypad Backlight LED Driver

The keypad backlight driver is constructed with current mirror.



Figure 4-8 Keypad backlight LED driver application

Table 4-30 Performance of Keypad backlight LED driver

| Parameter          | Conditions/Comments        | Min | Typical | Max | Unit |
|--------------------|----------------------------|-----|---------|-----|------|
| Status after reset | off                        |     |         |     |      |
|                    | 000(min current) (default) |     | 5       |     |      |
| Output ourront     | 001                        |     | 10      |     | m Λ  |
| Output current     | 010                        |     | 15      |     | mA   |
|                    | 011                        |     | 20      |     |      |



| 100 | 25 |  |
|-----|----|--|
| 101 | 30 |  |
| 110 | 35 |  |
| 111 | 40 |  |

# 4.3.14 Vibarator

The vibrator driver is constructed with current mirror.



Figure 4-9 Vibrator driver application

Table 4-31 Performance of Vibrator driver

| Parameter          | Conditions/Comments | Min | Typical | Max | Unit             |
|--------------------|---------------------|-----|---------|-----|------------------|
| Status after reset | off                 | •   |         |     | •                |
|                    | 0000 (default)      |     | 20      |     |                  |
|                    | 0001                |     | 30      |     |                  |
|                    | 0010                |     | 40      |     |                  |
|                    | 0011                |     | 50      |     | ] <sub>m</sub> , |
|                    | 0100                |     | 60      |     | - mA             |
|                    | 0101                |     | 70      |     | ]                |
|                    | 0110                |     | 80      |     | 1                |
| Output ourront     | 0111                |     | 90      |     |                  |
| Output current     | 1000                |     | 100     |     |                  |
|                    | 1001                |     | 110     |     | 1                |
|                    | 1010                |     | 120     |     |                  |
|                    | 1011                |     | 130     |     | ]<br>^           |
|                    | 1100                |     | 140     |     | - mA             |
|                    | 1101                |     | 150     |     |                  |
|                    | 1110                |     | 160     |     |                  |
|                    | 1111                |     | 170     |     |                  |



# 5 Micro-Controller Unit Subsystem

SC6820 has two embedded processor cores: CortexA5 and Ceva-X1622. In general, the MCU and DSP control the operation of various ASIC hardware modules. The MCU or DSP prepares the data that needs the ASIC to process and sets up some control registers that tells the ASIC how to process the data. Therefore, the software control interface consists of data memories and control registers. The software interface sections define the organization of the data memories and the meanings of control register bits.

# 5.1 Processor

SC6820 contains one 32-bit RSIC core, CortexA5, with 32kB L1 cache for data and program and also with 128KB L2 cache.

**ARM Memory Map** 

On the ARM side, the address bus is 32-bit wide and the address map is presented in this section. In order to support multiple boot modes, the ARM memory space can be remapped after reset.

Table 5-1 SC6820 ARM memory address map after reset

| Address Range                | Memory Sector                       | Sub-Sector | Note       |
|------------------------------|-------------------------------------|------------|------------|
| 0x0000_0000 -<br>0x0FFF_FFF  | External Memory Space               |            | 256M bytes |
| 0x1000_0000 -<br>0x1FFF_FFFF | reserved                            |            |            |
| 0x2000_0000 -<br>0x200F_FFFF | External Memory Control<br>Register |            |            |
| 0x2010_0000 –<br>0x201F_FFFF | DMA Control Register                |            |            |
| 0x2020_0000 -<br>0x202F_FFFF | DCAM Control Register               |            |            |
| 0x2030_0000 -<br>0x203F_FFFF | USB 2.0                             |            |            |
| 0x2040_0000 -<br>0x2040_0FFF | Bus Monitor 0                       |            |            |
| 0x2040_1000 -<br>0x2040_1FFF | Bus Monitor 1                       |            |            |
| 0x2050_0000 -<br>0x205F_FFFF | SDIO0 Control Register              |            |            |
| 0x2060_0000 -<br>0x206F_FFFF | SDIO1 Control Register              |            |            |
| 0x2070_0000 -<br>0x207F_FFFF | LCD Control Register                |            |            |
| 0x2080_0000 -<br>0x208F_FFFF | Rotation Control Register           |            |            |



| Address Range                | Memory Sector               | Sub-Sector                                                          | Note                                                                     |
|------------------------------|-----------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------|
| 0x2090_0000 -<br>0x209F_FFFF | AHB Global Control Register |                                                                     |                                                                          |
| 0x20A0_0000 -<br>0x20AF_FFFF | AXI Bus Monitor             |                                                                     | Monitor the AXI bus between ARM and EMC                                  |
| 0x20B0_0000 -<br>0x20BF_FFFF | DRM Control Register        |                                                                     | ×                                                                        |
| 0x20C0_0000 -<br>0x20CF_FFFF | VSP Control Register        |                                                                     |                                                                          |
|                              |                             | 0X20C0_0000                                                         | Global<br>Registers                                                      |
|                              |                             | 0X20C0_0400                                                         | BSM                                                                      |
|                              |                             | 0X20C0_0800                                                         | VLD                                                                      |
|                              |                             | 0X20C0_0C00                                                         | VLC                                                                      |
|                              |                             | 0X20C0_1000                                                         | DCT                                                                      |
|                              |                             | 0X20C0_1400                                                         | MCA                                                                      |
|                              |                             | 0X20C0_1800                                                         | MBC                                                                      |
|                              |                             | 0X20C0_1C00                                                         | DBK                                                                      |
|                              |                             | 0X20C0_2000                                                         | MEA                                                                      |
| 0x20D0_0000 -<br>0x20DF_FFFF | GPU_ACC Control Register    |                                                                     |                                                                          |
| 0x20E0_0000 -<br>0x20EF_FFFF | Reserved                    |                                                                     |                                                                          |
| 0x3000_0000 -<br>0x3FFF_FFF  | Reserved                    |                                                                     |                                                                          |
|                              |                             | There are three RAMs used as Internal RAM. IRAM0 0x4000_0000 -      | W. 22222                                                                 |
|                              | Internal On Chip RAM space/ | 0x4000_3FFF<br>Dedicate for ARM (16 KB)                             | If remap = 0:<br>Internal On<br>Chip RAM<br>Space                        |
| 0x4000_0000 –<br>0x4FFF_FFFF | Internal On Chip ROM space  | IRAM1<br>0x4000_4000 –<br>0x4000_7FFF<br>Dedicate for ARM (16 KB)   | 0x4000_0000 -<br>0x4000_7FFF<br>is used.<br>If remap = 1:<br>Internal On |
|                              |                             | IRAM2                                                               | Chip ROM<br>Space                                                        |
|                              |                             | 0x4000_8000 –<br>0x4000_AFFF                                        |                                                                          |
|                              |                             | Share with DCAM (12 KB)                                             |                                                                          |
| 0x5000_0000 –<br>0x5FFF_FFF  | Share Memory with DSP       | 0x5000_0000 –<br>0x5000_0FFF Dual Port<br>Memory Shared with DSP (4 |                                                                          |



| Address Range                | Memory Sector            | Sub-Sector                                               | Note           |  |
|------------------------------|--------------------------|----------------------------------------------------------|----------------|--|
|                              |                          | KB)                                                      |                |  |
| 0x6000_0000 -<br>0x6FFF_FFF  | NAND Controller Space    |                                                          |                |  |
| 0x7000_0000 –<br>0x7FFF_FFFF | DSP-Side Space           | Map to 0x0000_0000 –<br>0x0FFF_FFFF space on<br>DSP-side |                |  |
| 0x8000_0000 -<br>0x8FFF_FFFF | Peripheral Address Space |                                                          |                |  |
|                              | 0x8000_0000              | Reserved                                                 |                |  |
|                              | 0x8000_3000              | INTC                                                     |                |  |
|                              | 0x8100_0000              | General RTC Timers                                       | 7              |  |
|                              | 0x8200_0000              | ADI master                                               |                |  |
|                              | 0x8200_0040              | Watch dog                                                | Analog control |  |
|                              | 0x8200_0080              | Real Time Clock                                          | Analog control |  |
|                              | 0x8200_0100              | Dophin MC                                                | Analog control |  |
|                              | 0x8200_0180              | Pin reg                                                  | Analog control |  |
|                              | 0x8200_0280              | Touch panel                                              | Analog control |  |
|                              | 0x8200_0300              | Aux ADC                                                  | Analog control |  |
|                              | 0x8200_0380              | INTC                                                     | Analog control |  |
|                              | 0x8200_03c0              | Charger WDG                                              | Analog control |  |
|                              | 0x8200_0400              | COM slave                                                | Analog control |  |
|                              | 0x8200_0480              | GPIO                                                     | Analog control |  |
|                              | 0x8200_0600              | Ana_reg                                                  | Analog control |  |
| 4                            | 0x8200_0700              | EIC                                                      | Analog control |  |
|                              | 0x8200_3000              | Voice Band                                               |                |  |
|                              | 0x8300_0000              | UART0                                                    |                |  |
|                              | 0x8400_0000              | UART1                                                    |                |  |
| 00                           | 0x8500_0000              | SIM Card0                                                |                |  |
| ~ (/)                        | 0x8500_3000              | SIM Card1                                                |                |  |
|                              | 0x8600_0000              | I2C0                                                     |                |  |
|                              | 0x8600_1000              | I2C1                                                     |                |  |
|                              | 0x8600_2000              | I2C2                                                     |                |  |
|                              | 0x8600_3000              | I2C3                                                     |                |  |
|                              | 0x8700_0000              | Keypad                                                   |                |  |
|                              | 0x8700_3000              | System Counter0                                          |                |  |
|                              | 0x8800_0000              | PWM                                                      |                |  |



| Address Range               | Memory Sector               | Sub-Sector                | Note |
|-----------------------------|-----------------------------|---------------------------|------|
|                             | 0x8900_0000                 | Efuse                     |      |
|                             | 0x8A00_0000                 | GPIO                      |      |
|                             | 0x8A00_1000                 | EIC                       |      |
|                             | 0x8B00_0000                 | Global registers          |      |
|                             | 0x8C00_0000                 | Chip pin registers        |      |
|                             | 0x8D00_0000                 | EPT                       |      |
|                             | 0x8E00_0000                 | UART 2                    |      |
|                             | 0x8E00_1000                 | IIS0                      |      |
|                             | 0x8E00_2000                 | SPI0                      |      |
|                             | 0x8E00_3000                 | SPI1                      |      |
|                             | 0x8E00_4000                 | IIS1                      |      |
|                             | 0x8F00_0000                 | Reserved                  |      |
| 0x9000_0000 -<br>0x9FFF_FFF | Reserved                    |                           |      |
| 0xA000_0000-<br>0xA000_FFFF | Coresight components        | 70                        |      |
|                             | 0xA000_0000-<br>0xA000_0FFF | Coresight debug rom table |      |
|                             | 0xA000_1000-<br>0xA000_1FFF | Coresight ETB             |      |
|                             | 0xA000_2000-<br>0xA000_2FFF | Coresight CTI             |      |
|                             | 0xA000_3000-<br>0xA000_3FFF | Coresight TPIU            |      |
|                             | 0xA000_4000-<br>0xA000_4FFF | Coresight Funnel          |      |
|                             | 0xA000_7000-<br>0xA000_7FFF | A5 integration rom table  |      |
| 100                         | 0xA000_8000-<br>0xA000_8FFF | A5 debug unit             |      |
|                             | 0xA000_9000-<br>0xA000_9FFF | A5 PMU                    |      |
|                             | 0xA000_A000-<br>0xA000_AFFF | A5 integration CTI        |      |
|                             | 0xA000_B000-<br>0xA000_BFFF | ETM                       |      |



| Address Range                | Memory Sector                                                                  | Sub-Sector                                                                                                                          | Note      |  |
|------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------|--|
|                              | 0xA000_C000-<br>0xA000_FFFF                                                    | Reserved                                                                                                                            |           |  |
| 0xA001_0000-<br>0xA001_FFFF  | MALI                                                                           |                                                                                                                                     | <u> </u>  |  |
| 0xA002_0000-<br>0xA00F_FFFF  | Reserved                                                                       |                                                                                                                                     |           |  |
| 0xA010_0000-<br>0xA01F_FFFF  | CPU NIC301                                                                     |                                                                                                                                     |           |  |
| 0xA020_0000-<br>0xA1FF_FFFF  | Reserved                                                                       |                                                                                                                                     | <b>)</b>  |  |
| 0xA200_2000-<br>0xA200_2FFF  | L2 cache controller                                                            |                                                                                                                                     |           |  |
| 0xA200_3000 -<br>0xBFFF_FFFF | Reserved                                                                       | ~ (),                                                                                                                               |           |  |
| 0xC000_0000 -<br>0xCFFF_FFFF | External Memory Space                                                          |                                                                                                                                     |           |  |
| 0xD000_0000 -<br>0xDFFF_FFFF | Reserved                                                                       |                                                                                                                                     |           |  |
| 0xE000_0000 -<br>0xEFFF_FFFF | External Memory Space (in case using 4Gb DDR, this area should be second half) |                                                                                                                                     |           |  |
| 0xF000_0000 -<br>0xFFFE_FFFF | Reserved                                                                       |                                                                                                                                     |           |  |
| 0xFFFF_0000                  | Internal On Chip ROM Space / Internal On-chip RAM space                        | If remap = 0: Internal On Chip<br>ROM Space<br>0xFFFF_0000 -<br>0xFFFF_7FFF is used.<br>If remap = 1: Internal On Chip<br>RAM Space | 32K bytes |  |
|                              |                                                                                |                                                                                                                                     |           |  |

### It should be noted that:

 The re-map (address space swapping) among the on chip RAM and internal ROM is controlled only by write value to remap control bit when system was powered up.



# **5.2 External Memory Controller**

### 5.2.1 Overview

The EMC is a multiple AHB channels and one AXI channel external memory controller, and it supports only DRAM.

- 16-bit SDR-SDRAM and DDR-SDRAM
- I 32-bit SDR-SDRAM and DDR-SDRAM

#### 5.2.2 Features

#### 5.2.2.1 AHB Related Features

#### **General features:**

- I Support multiple AHB channel.
- I Support 32-bit AHB and 64-bit AHB
- I Support AHB big-endian or AHB little-endian
- I Support multiple options for data endian converting
- I Support asynchronous mode and synchronous mode between AHB clock and EMC clock (configurable)
- I Support all AHB-compatible transaction.
- Support a FIFO for read in each channel
- Support a single-buffer or double-buffer (configurable) for write in each channel
- I Support automatically channel closing or forcedly channel closing (configurable) for power saving

### 5.2.2.2 AXI Related Features

### **General features:**

- I Support one AXI channel.
- I Support 64-bit AXI
- Support AXI big-endian or AXI little-endian
- Support multiple options for data endian converting
- Support asynchronous mode and synchronous mode between AXI clock and EMC clock (configurable)
- Support all AXI-compatible transaction.
- Support a FIFO for command (write address and read address) in the channel
- I Support a FIFO for read in the channel
- I Support a FIFO for write in the channel
- I Support automatically channel closing or forcedly channel closing (configurable) for power saving

#### 5.2.2.3 Channel Multiplex Features



- I 4-level configurable priority.
- For the same priority, robin-round algorithm is used.
- I For the same priority, read bursts and write bursts are taken with the same priority.

### 5.2.2.4 External Memory Related Features

#### Device type:

- I All kinds of 16-bit SDR-SDRAM
- All kinds of 16-bit DDR-SDRAM
- I All kinds of 32-bit SDR-SDRAM
- I All kinds of 32-bit DDR-SDRAM

#### **DRAM Operation mode features:**

- Support SDR-SDRAM and DDR-SDRAM.
- I Support from 16Mbit to 8Gbit SDRAM. (Still no data sheet for single-die 1G/2G/4G/8G bit SDRAM).
- Support up to 2 CS. And all SDRAM must have the same type.
- Support 4-bank.
- I Support 11/12/13/14-bit row width.
- I Support 8/9/10/11/12-bit column width.
- Support 16/32-bit data width.
- I For 16-bit SDR, support 2/4/8/16/32-burst

For 32-bit SDR, support 1/2/4/8/16-burst

For 16-bit DDR, support 2/4/8/16/32-burst

For 32-bit DDR, support 2/4/8/16-burst

- Support 1/1.5/2/2.5/3/3.5 CAS latency.
- Support 0/0.5/1/1.5 WRITE latency.
- Only support sequential type, not support interleave type.
- I Support configurable auto-precharge bit location.
- I Support configurable mode register and extended mode registers.

### **DRAM Timing features:**

- All timing parameters of SDR-SDRAM and DDR-SDRAM can be met by controlling FMC.
- Support configurable auto refresh interval time tREF.
- Support configurable Minimum PRECHARGE(m) to ACTIVE(m) delay tRP.
- Support configurable Minimum ACTIVE(m) to READ/WRITE(m) delay tRCD.
- Support configurable Minimum ACTIVE(m) to ACTIVE(n) delay tRRD.
- I Support configurable Minimum ACTIVE(m) to ACTIVE(m) delay tRC. But tRC and tRAS make use of the same configuration register to control timing. That is, the configuration register of tRAS also MUST guarantee tRC.
  - Support configurable Minimum ACTIVE(m) to PRECHARGE(m) delay tRAS.
- Support configurable Minimum WRITE(m) to PRECHARGE(m) delay tWR.
- I Support configurable AUTO REFRESH command period tRFC/tRC/tARFC.
- Support configurable exit SELF REFRESH to ACTIVE command time tXSR/tSREX/tSRFX.
- Support configurable LOAD MODE REGISTER command to ACTIVE or REFRESH command delay tMRD.
- I Support configurable Minimum read to write turn around delay tRTW.
- I Support configurable Minimum write to read turn around delay tWTR.
- I Support configurable Minimum different-CS read to read turn around delay tRTR.



# 5.2.3 Signal Description

Table 5.2-1 EMC signal description

| PAD name  | 16-bit<br>SDR | DIR | 16-bit<br>DDR | DIR | 32-bit<br>SDR | DIR | 32-bit<br>DDR | DIR |
|-----------|---------------|-----|---------------|-----|---------------|-----|---------------|-----|
| ENRSTN_M  |               |     |               |     |               |     |               |     |
| ENCLKDP_M | CLK           | 0   | CLK           | 0   | CLK           | 0   | CLK           | 0   |
| EMCLKDM_M |               |     | CLK#          | 0   |               |     | CLK#          | 0   |
| EMCKE_M   | CKE           | 0   | CKE           | 0   | CKE           | 0   | CKE           | 0   |
| EMCSNO_M  | CS#[0]        | 0   | CS#[0]        | 0   | CS#[0]        | 0   | CS#[0]        | 0   |
| EMCSN1_M  | CS#[1]        | 0   | CS#[1]        | 0   | CS#[1]        | 0   | CS#[1]        | 0   |
| EMCSN2_M  | CS#[2]        | 0   | CS#[2]        | 0   | CS#[2]        | 0   | CS#[2]        | 0   |
| EMCSN3_M  | CS#[3]        | 0   | CS#[3]        | 0   | CS#[3]        | 0   | CS#[3]        | 0   |
| ENRASN_M  | RAS#          | 0   | RAS#          | 0   | RAS#          | 0   | RAS#          | 0   |
| ENCASN_M  | CAS#          | 0   | CAS#          | 0   | CAS#          | 0   | CAS#          | 0   |
| EMMEN_M   | WE#           | 0   | WE#           | 0   | WE#           | 0   | WE#           | 0   |
| ENDQNO_M  | DQM#[0]       | 0   | DQM#[0]       | 0   | DQN#[0]       | 0   | DQM#[0]       | 0   |
| EMDQM1_M  | DQM#[1]       | 0   | DQM#[1]       | 0   | DQN#[1]       | 0   | DQN#[1]       | 0   |
| ENDQN2_M  |               |     |               |     | DQN#[2]       | 0   | DQN#[2]       | 0   |
| ENDQN3_M  |               |     |               |     | DQN#[3]       | 0   | DQN#[3]       | 0   |
| EMDQSO_M  |               |     | DQS[0]        | 1/0 |               |     | DQS[0]        | 1/0 |
| ENDQS1_M  |               |     | DQS[1]        | 1/0 |               |     | DQS[1]        | 1/0 |
| ENDQS2_M  | X             |     |               |     |               |     | DQS[2]        | 1/0 |
| ENDQS3_M  |               |     |               |     |               |     | DQS[3]        | 1/0 |
| ENBA1_M   | BA[1]         | 0   | BA[1]         | 0   | BA[1]         | 0   | BA[1]         | 0   |
| EMAO_M    | A[0]          | 0   | A[0]          | 0   | A[0]          | 0   | A[0]          | 0   |
| ENA1_M    | A[1]          | 0   | A[1]          | 0   | A[1]          | 0   | A[1]          | 0   |
| EMA2_M    | A[2]          | 0   | A[2]          | 0   | A[2]          | 0   | A[2]          | 0   |
| EIMA3_M   | A[3]          | 0   | A[3]          | 0   | A[3]          | 0   | A[3]          | 0   |
| EMA4_M    | A[4]          | 0   | A[4]          | 0   | A[4]          | 0   | A[4]          | 0   |
| EWA5_M    | A[5]          | 0   | A[5]          | 0   | A[5]          | 0   | A[5]          | 0   |
| EMA6_M    | A[6]          | 0   | A[6]          | 0   | A[6]          | 0   | A[6]          | 0   |
| EMA7_M    | A[7]          | 0   | A[7]          | 0   | A[7]          | 0   | A[7]          | 0   |
| EMA8_M    | A[8]A         | 0   | A[8]          | 0   | A[8]          | 0   | A[8]          | 0   |
| EMA9_M    | A[9]          | 0   | A[9]          | 0   | A[9]          | 0   | A[9]          | 0   |



| EMA10_M           | A[10] | 0   | A[10] | 0   | A[10] | 0   | A[10] | 0   |
|-------------------|-------|-----|-------|-----|-------|-----|-------|-----|
| EMA11_M           | A[11] | 0   | A[11] | 0   | A[11] | 0   | A[11] | 0   |
| EMA12_M           | A[12] | 0   | A[12] | 0   | A[12] | 0   | A[12] | 0   |
| EMA13_M           | A[13] | 0   | A[13] | 0   | A[13] | 0   | A[13] | 0   |
| EMA14_M / EMBAO_M | BA[0] | 0   | BA[0] | 0   | BA[0] | 0   | BA[0] | 0   |
| EMA15_M / EMD16_M |       |     |       |     | D[16] | 1/0 | D[16] | 1/0 |
| EMA16_M / EMD17_M |       |     |       |     | D[17] | 1/0 | D[17] | 1/0 |
| EMA17_M / EMD18_M |       |     |       |     | D[18] | 1/0 | D[18] | 1/0 |
| EWA18_M / EMD19_M |       |     |       |     | D[19] | 1/0 | D[19] | 1/0 |
| EMA19_M / EMD20_M |       |     |       |     | D[20] | 1/0 | D[20] | 1/0 |
| EMA20_M / EMD21_M |       |     |       |     | D[21] | 1/0 | D[21] | 1/0 |
| EWA21_M / EWD22_M |       |     |       |     | D[22] | 1/0 | D[22] | 1/0 |
| EWA22_M / EWD23_M |       |     |       |     | D[23] | 1/0 | D[23] | 1/0 |
| EWA23_M / EWD24_M |       |     |       |     | D[24] | 1/0 | D[24] | 1/0 |
| EMA24_M / EMD25_M |       |     |       |     | D[25] | 1/0 | D[25] | 1/0 |
| EMA25_M / EMD26_M |       |     |       |     | D[26] | 1/0 | D[26] | 1/0 |
| EMA26_M / EMD27_M |       |     |       |     | D[27] | 1/0 | D[27] | 1/0 |
| EWA27_M / EMD28_M |       |     |       |     | D[28] | 1/0 | D[28] | 1/0 |
| EMA28_M / EMD29_M |       |     |       |     | D[29] | 1/0 | D[29] | 1/0 |
| / EMD30_M         |       |     |       |     | D[30] | 1/0 | D[30] | 1/0 |
| / EMD31_M         |       |     |       |     | D[31] | 1/0 | D[31] | 1/0 |
| ENDO_M            | D[0]  | 1/0 | D[0]  | 1/0 | D[0]  | 1/0 | D[0]  | 1/0 |
| END1_M            | D[1]  | 1/0 | D[1]  | 1/0 | D[1]  | 1/0 | D[1]  | 1/0 |
| END2_M            | D[2]  | 1/0 | D[2]  | 1/0 | D[2]  | 1/0 | D[2]  | 1/0 |
| END3_M            | D[3]  | 1/0 | D[3]  | 1/0 | D[3]  | 1/0 | D[3]  | 1/0 |
| END4_M            | D[4]  | 1/0 | D[4]  | 1/0 | D[4]  | 1/0 | D[4]  | 1/0 |
| END5_M            | D[5]  | 1/0 | D[5]  | 1/0 | D[5]  | 1/0 | D[5]  | 1/0 |
| END6_M            | D[6]  | 1/0 | D[6]  | 1/0 | D[6]  | 1/0 | D[6]  | 1/0 |
| END7_M            | D[7]  | 1/0 | D[7]  | 1/0 | D[7]  | 1/0 | D[7]  | 1/0 |
| END8_M            | D[8]  | 1/0 | D[8]  | 1/0 | D[8]  | 1/0 | D[8]  | 1/0 |
| EMD9_M            | D[9]  | 1/0 | D[9]  | 1/0 | D[9]  | 1/0 | D[9]  | 1/0 |
| EMD10_M           | D[10] | 1/0 | D[10] | 1/0 | D[10] | 1/0 | D[10] | 1/0 |
| EMD11_M           | D[11] | 1/0 | D[11] | 1/0 | D[11] | 1/0 | D[11] | 1/0 |
| END12_M           | D[12] | 1/0 | D[12] | 1/0 | D[12] | 1/0 | D[12] | 1/0 |
| END13_M           | D[13] | 1/0 | D[13] | 1/0 | D[13] | 1/0 | D[13] | 1/0 |
| END14_M           | D[14] | 1/0 | D[14] | 1/0 | D[14] | 1/0 | D[14] | 1/0 |
| EMD15_M           | D[15] | 1/0 | D[15] | 1/0 | D[15] | 1/0 | D[15] | 1/0 |
|                   |       | •   | -     | •   | -     | •   | -     |     |



|  |  |  |  | 1 |
|--|--|--|--|---|
|  |  |  |  | i |
|  |  |  |  | i |
|  |  |  |  | ı |

# 5.2.4 Function Description

## 5.2.4.1 Block Diagram



Figure 5.2-1 EMC block diagram

EMC mainly have six parts:

- I emc\_ahb32 and emc\_ahb64 are used to interface with AHB, and emc\_axi64 is used to interface with AXI.
- I emc\_sel, emc\_arb and emc\_addr are used to multiplex multiple channels and divide channel bursts to device bursts
- I emc\_dmem and emc\_if are used to generate external memory bus sequence.
- I emc\_phy is used to interface with external memory and handle timing.
- I emc\_rf is configuration registers.



I emc\_pmu is used to gate clock automatically or forcedly.

### 5.2.4.2 Configuration AHB Interface Descriptions

This port is a very simple asynchronous AHB slave only used for EMC configuring.

- 32-bit AHB slave
- I No endian issue
- I READ, WRITE
- I Only support WORD accessing
- I Support All AHB burst types (EMC takes all types as SINGLE transactions)
- I No requirement for the frequency of configuration AHB slave clock and clk\_emc. Or, support any combination between the two clocks.
- Wait state: 0 wait state.
- I Always response OK.

## 5.2.4.3 Accessing AHB Interface Descriptions

EMC supports multiple accessing AHB channels, 32-bit or 64-bit, big-endian or little-endian, asynchronous or synchronous.

## 5.2.4.3.1 Block Diagram



Figure 5.2-2 Accessing AHB interface block diagram

## 5.2.4.3.2 AHB Compatibility



- I 32-bit AHB channel
- I 64-bit AHB channel
- I AHB big-endian or AHB little-endian
- Asynchronous or synchronous between AHB clock and EMC clock
- I READ, WRITE
- BYTE, HALF, WORD for 32-bit AHB channels and DWORD for 64-bit AHB channels
- I All burst types: SINGLE, INCR, WRAP4, INCR4, WRAP8, INCR8, WRAP16, INCR16
- For INCR, support HLENGTH from 1 to 15
- I Support BUSY-inserted
- I Cannot response ERROR to AHB
- I Cannot issue SPLIT transactions
- I Don't care about HPROT

#### 5.2.4.3.3 AHB Bursts Mapping to Channel Bursts

EMC maps AHB bursts to channel bursts in emc\_ahb32 or emc\_ahb64 because of too long AHB burst length or undefined burst length.

Burst mapping includes three steps - pre-mapping, burst mapping, post-adjusting.

Pre-mapping divides the too long bursts, and follows these rules:

#### To WRAP16 Bursts:

- If a burst starts from WRAP16 boundary, the burst is mapped to one INCR burst.
- I If a burst doesn't start from WRAP16 boundary, the burst is divided to two INCR burst. The first one is from start to WRAP16 boundary, and the other is from boundary to end.

### To INCR16 Bursts:

A INCR16 burst is divided to two INCR8 bursts, each of which includes 8 data.

### To INCR Bursts:

- I If HLENGTH is 0, do nothing.
- I If HLENGTH is not more than 8, do nothing.
- I If HLENGTH is more than 8, the burst is divided to two bursts, the first 8 data constitutes the first burst with HLENGTH of 8, and the left data constitutes the next burst with HLENGTH of original HLENGTH minus 8.

### Burst-mapping follows these rules:

- If related rf\_hburst\_ren\_csx for reading or rf\_hburst\_ren\_csx for writing is cleared, this burst is taken as multiple single transactions, and burst length is 1 BYTE for BYTE transaction, or 1 HALF for HALF transaction, or 1 WORD for WORD transaction, or 1 DWORD for DWORD transaction. It's IMPORTANT that this rule is only used by SMEM.
- If HBURST is SINGLE, burst mode is INCR, and burst length is 1 data (BYTE, HALF, WORD or DWORD).
- I If HBURST is WRAP4, burst mode is WRAP, and burst length is 4 data (BYTE, HALF, WORD or DWORD).
- If HBURST is INCR4, burst mode is INCR, and burst length is 4 data (BYTE, HALF, WORD or DWORD).
- I If HBURST is WRAP8, burst mode is WRAP, and burst length is 8 data (BYTE, HALF, WORD or DWORD).



- If HBURST is INCR8, burst mode is INCR, and burst length is 8 data (BYTE, HALF, WORD or DWORD).
- I If HBURST is INCR and HLENGTH is not 0, burst mode is INCR, and burst length is HLENGTH of data (BYTE, HALF, WORD or DWORD).
- If HBURST is INCR and HLENGTH is 0, burst mode is INCR, and burst length is from related rf\_hburst\_rlength\_incr\_chx or rf\_hburst\_wlength\_incr\_chx.
  - rf\_hburst\_xlength\_incr\_chx = 0 : burst length is 2 WORD
  - rf\_hburst\_xlength\_incr\_chx = 1 : burst length is 4 WORD
  - rf\_hburst\_xlength\_incr\_chx = 2 : burst length is 6 WORD
  - rf\_hburst\_xlength\_incr\_chx = 3 : burst length is 8 WORD
  - rf\_hburst\_xlength\_incr\_chx = 4 : burst length is 10 WORD (only for 64-bit AHB interface)
  - rf\_hburst\_xlength\_incr\_chx = 5 : burst length is 12 WORD (only for 64-bit AHB interface)
  - rf\_hburst\_xlength\_incr\_chx = 6 : burst length is 14 WORD (only for 64-bit AHB interface)
  - rf\_hburst\_xlength\_incr\_chx = 7 : burst length is 16 WORD (only for 64-bit AHB interface)

Post-adjusting deals with burst length from above in order to unify the unit

- For 32-bit AHB interface, burst length is unified to WORD.
- I For 64-bit AHB interface, burst length is unified to DWORD.

In AHB interface logic, both WRAP bursts and INCR bursts are taken with the same optimization method.

### 5.2.4.3.4 Read Operation Description

An 8-entry (8-WORD for 32-bit AHB and 8-DWORD for 64-bit AHB) read FIFO is used in each AHB channel to improve accessing performance. All reading operations, single access or burst access, cannot bypass this FIFO.

The read FIFO always contains only one channel burst at the same time.

For read operations, only one channel burst is on process in emc\_ahb at the same time, and there is only one pipeline stage, unlike write operations. All read operations are executed one by one.

#### 5.2.4.3.5 Write Operation Description

There is only one data path for write, and all write transactions should pass write buffer. One AHB bursts should be written into write buffer firstly, and then EMC transfers data to external memory from write buffer.

Write buffer is a 16-entry (16-WORD for 32-bit AHB and 16-DWORD for 64-bit AHB) double buffer.

There are two pipeline stages for write operations. One is AHB writes data to write buffer, and the other is write buffer transfers data to external memory. So there are at most two channel bursts on process in one emc\_ahb.



Because software completes one transfer only after data is written into write buffer, there is a delay time between software transfer completing and external memory transfer completing. The maximum delay time is the time that EMC writes two channel bursts to external memory.

### 5.2.4.3.6 Data Endian Switching

There two types of endian issues in EMC, one is AHB protocol endian, and the other is data endian.

For AHB protocol endian, EMC can handle it automatically by hardware.

For data endian, because EMC cannot understand different requirements from software, it provides different converting options for software.

For each AHB channel, EMC provides one rf\_endian\_swt\_chx to select the converting options.

For 32-bit AHB:

rf\_endian\_swt\_chx = 0 : BYTE switching

0 -> 3

1 -> 2

2 -> 1

3 -> 0

rf\_endian\_swt\_chx = 1 : HALF switching

0 -> 2

2 -> 0

rf\_endian\_swt\_chx = 2 : Not supported

rf\_endian\_swt\_chx = 3 : no-switching

For 32-bit AHB:

rf\_endian\_swt\_chx = 0 : BYTE switching

0 -> 7

1 -> 6

2 -> 5

3 -> 4

4 -> 3

5 -> 2

6 -> 1

7-> 0

rf endian swt chx = 1 : HALF switching

0 -> 6

2 -> 4

4 -> 2

6 -> 0

rf\_endian\_swt\_chx = 2 : WORD switching

0 -> 4

4 -> 0

rf\_endian\_swt\_chx = 3 : no-switching



## 5.2.4.3.7 Channel Sleep Control

EMC provides a method to hold each channel for system sleep control.

If rf\_auto\_sleep\_en\_chx is set, this method is enabled. System can use some hardware signals to hold EMC AHB channels and make these channel sleep.

## 5.2.4.4 Channel Multiplex Descriptions

This logic mainly has four functions: channel bursts arbitrating and multiplexing, multiplexed command queue, channel bursts being divided to device bursts, and device bursts address mapping.

## 5.2.4.4.1 Block Diagram





Figure 5.2-3 Channel multiplex block diagram

## 5.2.4.4.2 Channel Burst Arbitration and Multiplex

- I Arbitration is done based on channel bursts.
- The arbitrator receives channel burst requests from each channel logic, and response acknowledges to them if accepting related requests.
- I The request signals MUST be held until related acknowledge is received. And also, the command information MUST be issued together with requests.
- I Arbiter strategy: 4-level priority robin-round.
  - ü 4-level configurable priority.
  - **ü** For the same priority, robin-round algorithm is used.
  - **ü** For the same priority, read bursts and write bursts are taken with the same priority.



I This part of logic completes another function, which is to multiplex channel command and write data and to de-multiplex read data to each channel.

#### 5.2.4.4.3 Channel Burst Command Queue

- After arbitration and multiplexing, multiplexed commands are stored into a stage-configurable channel burst command queue. Output from channel burst command queue, channel bursts are divided into device bursts (this part is described in next chapter) and AHB address is mapped to external memory address (this part is described in following chapter). Then device bursts are written into 2-stage device burst command queue. At last, both commands (current command and next command) in device burst command queue is transmitted to DMEM controller, and current command is transmitted to SMEM controller.
- I Channel burst command queue is stage-configurable (controlled by rf cmd queue mode), and the configuration is:
  - O-stage (rf\_cmd\_queue\_mode is 0): if the 2<sup>nd</sup> command in device burst command queue is empty, arbitration is issued, and new channel burst command is written to the 1<sup>st</sup> command.
  - 1-stage (rf\_cmd\_queue\_mode is 1): if the 1<sup>st</sup> command in channel burst command queue is empty, arbitration is issued, and new channel burst command is written to the 1<sup>st</sup> command.
  - **ü** 2-stage (rf\_cmd\_queue\_mode is 2): if the 2<sup>nd</sup> command in channel burst command queue is empty, arbitration is issued, and new channel burst command is written to the 1<sup>st</sup> command (if 1<sup>st</sup> is empry) or the 2<sup>nd</sup> command (if 1<sup>st</sup> is not empty).
- I Channel burst sequence in channel burst command queue is fixed and cannot be changed.
- I Channel burst command structure:

Table 5.2-2 Channel burst command structure

| Bit     | Item                                                                                                                | Note |
|---------|---------------------------------------------------------------------------------------------------------------------|------|
| [50]    | Command valid 0: empty in this entry 1: one valid command in this entry                                             |      |
| [49:46] | Channel number 0: this command is for channel 0 1: this command is for channel 1 15: this command is for channel 15 |      |
| [45:44] | Reserved                                                                                                            |      |
| [43]    | External memory chip select 0: CS0 1: CS1                                                                           |      |
| [42]    | Channel burst operating mode 0: read 1: write                                                                       |      |
| [41:40] | Data width 0: 8-bit (only for SMEM single mode)                                                                     |      |



|           | : 16-bit (only for SMEM single mode)     |  |
|-----------|------------------------------------------|--|
| 1 2       | , ,                                      |  |
| -         | 2: 32-bit                                |  |
| 3         | 3: 64-bit (only for SMEM single mode)    |  |
| [39] C    | Channel burst enable                     |  |
| 0         | ): single access                         |  |
| 1         | : burst access                           |  |
| [38] C    | Channel burst mode                       |  |
| 0         | ): wrap mode                             |  |
| 1         | : increase mode                          |  |
| [37:35] C | Channel wrap mode length                 |  |
| 0         | ): wrap of 1 WORD                        |  |
| 1         | : wrap of 2 WORD                         |  |
| 2         | 2: wrap of 4 WORD                        |  |
| 3         | 3: wrap of 8 WORD                        |  |
| 4         | l: wrap of 16 WORD                       |  |
| 5         | 5: reserved                              |  |
| 6         | 6: reserved                              |  |
| 7         | 7: reserved                              |  |
| [34:30] C | Channel burst length                     |  |
| Т         | The unit is WORD                         |  |
|           | The supported range is from 1 to 16 WORD |  |
| [29:0] C  | Channel burst first address              |  |
| Т         | The unit is BYTE                         |  |

## 5.2.4.4.4 Device Burst Command Queue

- Device burst command queue is 2-stage, which is fixed. The two stage commands are:
  - ü Current command: current executing command
  - ü Next command: next executing command
- Same with channel burst command queue, device burst sequence in device burst command queue is fixed and cannot be changed.
- Device burst command structure:

## Table 5.2-3 Device burst command structure

| Bit  | Item                                                                                           | Note |
|------|------------------------------------------------------------------------------------------------|------|
| [46] | Command valid 0: empty in this entry 1: one valid command in this entry                        |      |
| [45] | The last device burst flag in one channel burst 0: not last device bursts 1: last device burst |      |



| [44:41] | Channel number                           |   |
|---------|------------------------------------------|---|
|         | 0: this command is for channel 0         |   |
|         | 1: this command is for channel 1         |   |
|         |                                          |   |
|         | 15: this command is for channel 15       |   |
| [40:39] | Reserved                                 |   |
| [38]    | External memory chip select              |   |
|         | 0: CS0                                   | • |
|         | 1: CS1                                   |   |
| [37]    | Device burst operating mode              |   |
|         | 0: read                                  |   |
|         | 1: write                                 |   |
| [36:35] | Data width                               |   |
|         | 0: 8-bit (only for SMEM single mode)     |   |
|         | 1: 16-bit (only for SMEM single mode)    | X |
|         | 2: 32-bit                                |   |
|         | 3: 64-bit (only for SMEM single mode)    |   |
| [34]    | Device burst enable                      |   |
|         | 0: single access                         |   |
|         | 1: burst access                          |   |
| [33:30] | Device burst length                      |   |
|         | The unit is WORD                         |   |
|         | The supported range is from 1 to 16 WORD |   |

## For DMEM:

| [29:28] | reserved                         |  |
|---------|----------------------------------|--|
| [27:26] | DMEM device burst bank address   |  |
| [25:12] | DMEM device burst row address    |  |
| [11:0]  | DMEM device burst column address |  |

## 5.2.4.4.5 AHB Channel Bursts Dividing to Device Bursts

AHB channel bursts from AHB interface logic are mapped to external device bursts in this part. Device burst information comes from configuration registers

One channel burst is divided into several device bursts according to:

- I Device burst length is met
- I If channel burst is WRAP mode, and WRAP boundary is hit
- I If external memory is in WRAP mode, and WRAP boundary is hit
- I Channel burst end is met

## Notes,

Device burst information from configuration registers MUST be matched with external memory configuration information.



In order to simplify hardware design, all device bursts are INCR mode even if channel bursts are WRAP mode or external memory is in WRAP mode. an WRAP channel burst is divided on WRAP boundary.

### 5.2.4.4.6 AHB Address Mapping

EMC should map AHB address to external memory address. AHB address is used by AHB transactions and this address is the same as software accessing address. BYTE is the unit of AHB address. External memory address is used by external memory accessing, and the unit is external memory data width.

Another work of EMC is to map AHB address (or software address) to which device, because EMC supports multiple external devices.

EMC provides rf\_cs\_position and rf\_cs\_mode to finish this mapping:

Table 5.2-4 AHB address mapping

|                       | rf_cs_position=2'h0                                                                      | rf_cs_position=2'h1                                                                      | rf_cs_position=2'h2                                                                      | rf_cs_position=2'h3                                                                      |
|-----------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| Note                  | The 8 domains of HADDR[29:27] is from 0 to 7 are equivalent and duplicated               | The 4 domains of HADDR[29:28] is from 0 to 3 are equivalent and duplicated               | The 2 domains of HADDR[29] is from 0 to 1 are equivalent and duplicated                  |                                                                                          |
| rf_cs_mode<br>=3'b000 | CS0: HADDR[26:25]=0<br>CS1: HADDR[26:25]=1<br>CS2: HADDR[26:25]=2<br>CS3: HADDR[26:25]=3 | CS0: HADDR[27:26]=0<br>CS1: HADDR[27:26]=1<br>CS2: HADDR[27:26]=2<br>CS3: HADDR[27:26]=3 | CS0: HADDR[28:27]=0<br>CS1: HADDR[28:27]=1<br>CS2: HADDR[28:27]=2<br>CS3: HADDR[28:27]=3 | CS0: HADDR[29:28]=0<br>CS1: HADDR[29:28]=1<br>CS2: HADDR[29:28]=2<br>CS3: HADDR[29:28]=3 |
| rf_cs_mode<br>=3'b001 | CS0: HADDR[26]=0<br>CS1: NA<br>CS2: HADDR[26:25]=2<br>CS3: HADDR[26:25]=3                | CS0: HADDR[27]=0<br>CS1: NA<br>CS2: HADDR[27:26]=2<br>CS3: HADDR[27:26]=3                | CS0: HADDR[28]=0<br>CS1: NA<br>CS2: HADDR[28:27]=2<br>CS3: HADDR[28:27]=3                | CS0: HADDR[29]=0<br>CS1: NA<br>CS2: HADDR[29:28]=2<br>CS3: HADDR[29:28]=3                |
| rf_cs_mode<br>=3'b010 | CS0: HADDR[26:25]=0<br>CS1: HADDR[26:25]=1<br>CS2: HADDR[26]=1<br>CS3: NA                | CS0: HADDR[27:26]=0<br>CS1: HADDR[27:26]=1<br>CS2: HADDR[27]=1<br>CS3: NA                | CS0: HADDR[28:27]=0<br>CS1: HADDR[28:27]=1<br>CS2: HADDR[28]=1<br>CS3: NA                | CS0: HADDR[29:28]=0<br>CS1: HADDR[29:28]=1<br>CS2: HADDR[29]=1<br>CS3: NA                |
| rf_cs_mode<br>=3'b011 | CS0: HADDR[26]=0<br>CS1: NA<br>CS2: HADDR[26]=1<br>CS3: NA                               | CS0: HADDR[27]=0<br>CS1: NA<br>CS2: HADDR[27]=1<br>CS3: NA                               | CS0: HADDR[28]=0<br>CS1: NA<br>CS2: HADDR[28]=1<br>CS3: NA                               | CS0: HADDR[29]=0<br>CS1: NA<br>CS2: HADDR[29]=1<br>CS3: NA                               |
| rf_cs_mode<br>=3'b1xx | CS0: Always Selected<br>CS1: NA<br>CS2: NA<br>CS3: NA                                    |

## 5.2.4.4.7 DMEM Address Mapping



In this part, EMC generates DMEM address according to **drf\_data\_width** and **drf\_column\_mode**.

Table 5.2-5 DMEM address mapping

| drf_data_width | drf_column_mode | row mapping  | bank mapping | column mapping     |  |
|----------------|-----------------|--------------|--------------|--------------------|--|
| 16-bit         | 8-bit           | HADDR[24:11] | HADDR[10:9]  | {HADDR[8:2],1'b0}  |  |
|                | 9-bit           | HADDR[25:12] | HADDR[11:10] | {HADDR[9:2],1'b0}  |  |
|                | 10-bit          | HADDR[26:13] | HADDR[12:11] | {HADDR[10:2],1'b0} |  |
|                | 11-bit          | HADDR[27:14] | HADDR[13:12] | {HADDR[11:2],1'b0} |  |
|                | 12-bit          | HADDR[28:15] | HADDR[14:13] | {HADDR[12:2],1'b0} |  |
| 32-bit         | 8-bit           | HADDR[25:12] | HADDR[11:10] | HADDR[9:2]         |  |
|                | 9-bit           | HADDR[26:13] | HADDR[12:11] | HADDR[10:2]        |  |
|                | 10-bit          | HADDR[27:14] | HADDR[13:12] | HADDR[11:2]        |  |
|                | 11-bit          | HADDR[28:15] | HADDR[14:13] | HADDR[12:2]        |  |
|                | 12-bit          | HADDR[29:16] | HADDR[15:14] | HADDR[13:2]        |  |

### 5.2.4.5 DMEM Operation Descriptions

DMEM controller is made of three paths, command path, write data path and read data path. The architecture is described in the following diagram.

One write burst is executed in two pipelined stage, command stage on command path and data stage on write data path.

One read burst is executed also in two pipelined stage, command stage on command path and data stage on read data path.

The command path mainly have three functions, planning and issuing commands, organizing DMEM bursts from difference device bursts, handling DMEM timing constraints

The write data path mainly have three functions, getting and generating write data and controlling its delay time, getting and generating write DM and controlling its delay time, generating write DQS and controlling its delay time.

The read data path mainly have three functions, sampling and handling read data, generating read DM and control its delay time, controlling input DQS signals.

When a device burst is issued, the command path translates it to DMEM bursts in command stage and issues related DMEM commands, then the command path transmits this DMEM bursts to the data path through delay-configurable shift registers, and also the command path begins to handle next device burst.

When the data path receives a DMEM burst, it handles data, DM and DQS parts, and completes this read or write burst.



This chapter describes the DMEM device features, main command control, other command control, write data path and read data path.

DMEM timing control, sampling control and PHY control are described in following chapters.

## 5.2.4.5.1 Block Diagram



Figure 5.2-4 DMEM controller block diagram

Refer to EMC PHY Specifications for detailed circuits in EMC PHY.

## 5.2.4.5.2 Device Features and Device Control

- I Support up to 1G byte space.
- I Support SDR-SDRAM and DDR-SDRAM.
- I Support from 16Mbits to 8Gbits SDRAM. (Still no data sheet for single-die 1G/2G/4G/8G bit SDRAM).
- I Support up to 2 CS. And all SDRAM must have the same type.



- I Support 4-bank.
- Support 11/12/13/14-bit row width.
- I Support 8/9/10/11/12-bit column width.
- I Support 16/32-bit data width.
- I For 16-bit SDR, support 2/4/8/16/32-burst

For 32-bit SDR, support 1/2/4/8/16-burst

For 16-bit DDR, support 2/4/8/16/32-burst

For 32-bit DDR, support 2/4/8/16-burst

- I Support 1/1.5/2/2.5/3/3.5 CAS latency.
- I Support 0/0.5/1/1.5 WRITE latency.
- Support real wrap mode burst. That is, one wrap burst is implemented by one SDRAM burst stead of divided into two SDRAM bursts.
- I Only support sequential type, not support interleave type.
- I Support configurable auto-precharge bit location.
- I Support configurable mode register and extended mode registers.
- I SDRAM output clock features:
  - ü Clock frequency is fixed to the half of clk\_emc frequency.
  - **ü** Support two phase-inverted options for delay coarse adjustment.
  - ü Support delay fine adjustment by a dedicated delay line.

EMC provides the following registers to configure external memory type.

- I drf\_data\_width:
  - 0: 16-bit
  - 1: 32-bit
- I drf column mode:
  - 0: 8-bit
  - 1: 9-bit
  - 2: 10-bit
  - 3: 11-bit
  - 4: 12-bit
  - 5: reserved
  - 6: reserved
  - 7: reserved
- I drf\_row\_mode:
  - 0: 11-bit
  - 1: 12-bit
  - 2: 13-bit
  - 3: 14-bit
- I drf\_auto\_pre\_position:
  - 0: A[10]
  - 1: A[11]
  - 2: A[12]
  - 3: A[13]

### 5.2.4.5.3 Device Command Descriptions

I Device Command Truth Table:



| Command              | CS# | CKE | RAS# | CAS# | WE# | ВА      | ADDR     |
|----------------------|-----|-----|------|------|-----|---------|----------|
| NOP                  | Н   | Х   | Х    | Х    | Х   | Х       | Х        |
| NOP                  | L   | Н   | Н    | Н    | Н   | Х       | Х        |
| ACTIVE               | L   | Н   | L    | Н    | Н   | bank    | row      |
| READ                 | L   | Н   | Н    | L    | Н   | bank    | column   |
| WRITE                | L   | Н   | Н    | L    | L   | bank    | column   |
| BURST TERMINATE      | L   | Н   | Н    | Н    | L   | Х       | X        |
| PRECHARGE (one bank) | L   | Н   | L    | Н    | L   | bank    | A10 low  |
| PRECHARGE (all bank) | L   | Н   | L    | Н    | L   | Х       | A10 high |
| AUTO REFRESH         | L   | Н   | L    | L    | Н   | Х       | X        |
| SELF REFRESH         | L   | L   | L    | L    | Н   | Х       | Х        |
| LOAD MODE REGISTER   | L   | Н   | L    | L    | L   | Op-Code |          |

## I LOAD MODE REGISTER

The mode register is loaded via EMA, and EMBA is used to select mode register or extended mode register. The detailed description of mode register can be achieved from device specifications. The LOAD MODE REGISTER command can only be issued when all banks are idle, and a subsequent executable command cannot be issued until tMRD is met.



Figure 5.2-5 Load mode register command

### I ACTIVE

The ACTIVE command is used to open a row in a particular bank for a subsequent access. The value on the EMBA select the bank, and the EMA select the row. This row remains active for accesses until a PRECHARGE command is issued to this bank. A PRECHARGE command must be issued before opening a different row in the same bank.





Figure 5.2-6 Active command

## I PRECHARGE (one bank)

The PRECARGE command is used to deactivate the open row in a particular bank or the open row in all banks. The banks will be available for a subsequent row operations a specified time tRP after the PRECHARGE command is issued. EMA[10] indicates whether on or all banks are to be pre-charged. If EMA[10] is 0, EMBA indicates which bank to be pre-charged, otherwise, all banks are pre-charged and EMBA is DON'T CARE. Once a bank has been pre-charge, it's in the idle state and must be activated before next accessing issued to this bank.



Figure 5.2-7 Precharge (one bank) command

## I PRECHARGE (all bank)





Figure 5.2-8 Precharge (all bank) command

### I AUTO REFRESH

AUTO REFRESH is used to retain data in DRAM. This command is non-persistent, so it must be issued each time a refresh is required. All active banks should be pre-charged before an AUTO REFRESH is issued. During AUTO REFRESH, EMA and EMBA is DON'T CARE, and the refresh address is generated by the internal logic. One AUTO REFRESH command starts only one row refresh, and all rows must be refresh one time every specified time (in normal cases, it's 64ms). The total row number can be achieved from device specification, so the maximum interval between two refresh commands can be calculated. To complete one refresh, tRFC should be guaranteed.



Figure 5.2-9 Auto refresh command

### I Enter SELF REFRESH



SELF REFRESH command can be used to retain data in DRAM even if the clock is shut down. SELF REFRESH command is initiated like an AUTO REFRESH command except CKE is low. Once the SELF REFRESH command is issued, all inputs to DRAM are DON'T CARE except CKE, which must remain low. And DRAM generates an internal clock to refresh all rows.



Figure 5.2-10 Enter self refresh command

### I Exit SELF REFRESH

To exit SELF REFRESH needs CKE comes back to high and NOP is issued with clock stable. After exiting SELF REFRESH, tXSR must be guaranteed for the completion of any internal refresh in progress.

Upon exiting the SELF REFRESH, AUTO REFRESH commands must be restarted issued.





Figure 5.2-11 Exit self refresh command

### I READ

The READ command is used to initiate a burst read access to an active row. EMBA selects the bank, and EMA selects the start column address. EMA[10] determines whether or not auto-precharge is used. In current EMC, DRAM controller always issues READ without auto-precharge, and the row remain open for subsequent accesses.



Figure 5.2-12 Read command

#### I WRITE

The WRITE command is used to initiate a burst write access to an active row. EMBA selects the bank, and EMA selects the start column address. EMA[10] determines whether or not auto-precharge is used. In current EMC, DRAM controller always issues WRITE without auto-precharge, and the row remain open for subsequent accesses.





## Figure 5.2-13 Write command

### I SDR-SDRAM Burst Read and Write

## Single Read (CAS Latency = 2)



Figure 5.2-14 SDR-SDRAM read (CAS latency = 2)

## Single Read (CAS Latency = 3)



Figure 5.2-15 SDR-SDRAM read (CAS latency = 3)

Single Write





Figure 5.2-16 SDR-SDRAM write

#### Read to Read



Figure 5.2-17 SDR-SDRAM read to read

#### Read to Write



Figure 5.2-18 SDR-SDRAM read to write

## Write to Write





Figure 5.2-19 SDR-SDRAM write to write

## Write to Read



Figure 5.2-20 SDR-SDRAM write to read

## I DDR-SDRAM Burst Read and Write

## Single Read (CAS Latency = 2)



Figure 5.2-21 DDR-SDRAM read (CAS latency = 2)



## Single Read (CAS Latency = 3)



Figure 5.2-22 DDR-SDRAM read (CAS latency = 3)

## **Single Write**



Figure 5.2-23 DDR-SDRAM write

## Read to Read





Figure 5.2-24 DDR-SDRAM read to read

## Read to Write



Figure 5.2-25 DDR-SDRAM read to write

## Write to Write



Figure 5.2-26 DDR-SDRAM write to write

Write to Read





Figure 5.2-27 DDR-SDRAM write to read

#### 5.2.4.5.4 EMC Main Command Control

DMEM controller is a two-burst SDR and DDR controller. The main control method is described as follows.

#### Introduction:

In order to improve performance, it's better for DMEM controller to see multiple bursts at the same time, because DMEM controller can plan and issue commands in different banks as parallel as possible.

This DMEM controller is designed to handle two bursts at the same time. It is not the best solution, but it's easier to implement.

The next issue is how to plan the two bursts. There are many methods for this issue, our method is to issue commands (PRECHARGE/ACTIVE/READ/WRITE) of two bursts in turn. The following specifies this method.

Firstly, we define one burst as current burst and the other as next burst.

## State machine:

I IDLE: idle state

PRE: precharge current burst bank

I ACT: active current burst row

I PRE\_ALTER: precharge next burst bank

ACT\_ALTER: active next burst row

ACCESS: access (read or write) current burst

## State and command transfer description:

- In IDLE: after current burst is issued, if current row is active, access current burst and enters ACCESS; or if current bank is idle, active current row and enters ACT; or precharge current bank and enters PRE.
- In PRE: If next burst issued and bank is difference and next bank is idle, active next row and enters ACT\_ALTER; or if next burst issued and bank is difference and next row is not active, precharge next bank and enters PRE\_ALTER; or active current row and enters ACT.



- In ACT: If next burst issued and bank is difference and next bank is idle, active next row and enters ACT\_ALTER; or if next burst issued and bank is difference and next row is not active, precharge next bank and enters PRE\_ALTER; or access current burst and enters ACCESS.
- In ACCESS: If not burst done and next burst issued and bank is difference and next bank is idle, active next row and enters ACT\_ALTER; or if not burst done and next burst issued and bank is difference and next row is not active, precharge next bank and enters PRE\_ALTER; or if burst done and next burst is not issued, enters IDLE; or if burst done and next burst is issued and next row is active, accesses next burst and enters ACCESS; or if burst done and next burst is issued and next bank is idle, active next row and enters ACT; or if burst done and next burst is issued and next row is not active, precharge next bank and enters PRE.
- In PRE\_ALTER: If current burst is being executing and burst done and next bank is idle, active next row and enters ACT; or if current burst is being executing and burst done and the timing condition of active next row is not met, enters PRE; or if current burst is being executing and burst not done and next bank is idle, active next row and enters ACT\_ALTER; or if current burst isn't being executing and current row is active, access current burst and enters ACCESS; or if current burst isn't being executing and current bank is idle, active current row and enters ACT; or if current burst isn't being executing and current row is not active, precharge current bank and enters PRE.
- In ACT\_ALTER: If current burst is being executing and burst done and next row is active, access next burst and enters ACCESS; or if current burst is being executing and burst done and the timing condition of access next burst is not met, enters ACT; or if current burst isn't being executing and current row is active, access current burst and enters ACCESS; or if current burst isn't being executing and current bank is idle, active current row and enters ACT; or if current burst isn't being executing and current row is not active, precharge current bank and enters PRE.

State and command transfer diagram:



DMEM controller state tranfer



Figure 5.2-28 DMEM controller state transfer - 1



example 1: two bursts and both need precharging

Figure 5.2-29 DMEM controller state transfer - 2



example 2: two bursts and both need precharging



Figure 5.2-30 DMEM controller state transfer - 3



Figure 5.2-31 DMEM controller state transfer - 4

#### Note:

1, CMD0, CMD1, CMD2, CMD3: burst 0/1/2/3 command

I: Idle

P0, P1, P2, P3: burst 0/1/2/3 precharge

A0, A1, A2, A3: burst 0/1/2/3 active

W0, W1, W2, W3: burst 0/1/2/3 write (or read)

2, Suppose that tRP, tRCD and tRRD are 3-cycle.

Main command path mode control register:

- I drf\_rowhit\_en : Row-hit access enable
- I drf alternative mode0 en : Alternative-bank access mode 0 enable
- I drf\_alternative\_mode1\_en : Alternative-bank access mode 1 enable

Above three bits should always be set to improve efficiency.

#### Notes:

- Not support any burst is terminated/interrupted by any command before it completes. For example, it isn't supported that one burst is terminated by BURST TERMINATE cmmand, or by new READ / WRITE, or by PRECHARGE, etc.
- I Not support CONCURRENT AUTO PRECHARGE.
- I Not support BURST READ / SINGLE WRITE mode.

### 5.2.4.5.5 Refresh Control



#### Auto-refresh functions:

- Support hardware-automatically auto-refresh. This function can be enabled or disabled
- I Support configurable auto-refresh interval.
- I Support two options for auto-refresh, chip by chip refresh mode, and all chips at the same time mode. The option select depends on LDO driving strength.

EMC provides the following registers to control external memory auto-refresh.

drf\_auto\_ref\_en is used to enable automatic hardware AUTO-REFRESH.

Remember: This bit must be set if DMEM is not in self-refresh mode. Otherwise, data in DMEM may be lost.

drf\_auto\_ref\_allcs is enable bit for that all CSs are auto-refreshed at the same time.

For stacked multi-chip SDRAM, we need auto-refresh more than one chip. There are two ways to do it, one is to handle one chip by one chip and the other is to handle all chips at the same time.

For the first solution, drf\_auto\_ref\_allcs should be cleared. And For the second solution,

#### drf auto ref allcs is set.

Obviously, the second solution is more efficient. However, we MUST guarantee our chip can supply so much current when all chips are operated at the same time.

### 5.2.4.5.6 Sleep Control

EMC should guarantee two conditions to make DMEM sleep or wakeup. One is that EMC should issue self-refresh or resume command to make DMEM sleep or wakeup. The other is that EMC should guarantee one burst completed before issuing self-refresh.

### DMEM Sleep and wakeup functions:

- I Support software-issued sleep and wakeup. And each CS can be controlled separately. Software should guarantee burst completed and issue self-refresh and resume manually.
- I Support hardware-automatically sleep and wakeup. EMC guarantee burst completed and issue self-refresh and resume automatically.

## For manually sleep mode:

- Software should guarantee there is no new burst requests for external memory, and check **rfemc\_idle\_sync** to make sure last bursts completed.
- I Software should close auto-refresh before issuing self-refresh and open auto-refresh after issuing resume.

### For automatically sleep mode:

- Support two modes for auto-sleep, mode 0 and mode 1.
- I For mode 0, if received sleep requests, DMEM controller waits for current channel burst completing firstly, then DMEM controller issues precharge all banks and self-refresh automatically. At last, DMEM controller feeds back sleep signal. If received wakeup, DMEM controller resumes device automatically.
- I For mode 1, if received sleep requests, DMEM controller waits for current channel burst completing firstly, then DMEM controller doesn't issue precharge all banks and



self-refresh immediately, but it makes use of one auto-refresh counter to guarantee all rows are refreshed at least one time during this wakeup period, if there are some row left not refreshed, DMEM controller refreshes these rows at first, then DMEM controller issues precharge all banks and self-refresh automatically. At last, DMEM controller feeds back sleep signal. If received wakeup, DMEM controller resumes device automatically and auto refresh counter should be cleared by software.

EMC provides the following registers to control sleep.

I auto-sleep control:

rf\_auto\_sleep\_en is used to enable EMC auto-sleep and auto-resume.

- 1: enable
- 0: disable

drf\_auto\_sleep\_mode is EMC auto-sleep/resume mode.

- 1: EMC guarantees all rows are refreshed before sleep.
- 0: EMC doesn't check whether some rows are still not refreshed

cmd\_chip\_sleep is sleep status for each CS.

I auto-refresh control before sleep:

Auto-refresh can be issued in two mode, normal mode auto-refresh and sleep mode auto-refresh.

Sleep mode auto-refresh is issued before sleep to guarantee all rows are refreshed. In this mode, the only operation of EMC is auto-refresh. The following registers are used in sleep mode auto-refresh, and **drf\_auto\_sleep\_mode** should be set.

drf\_auto\_sleep\_t\_ref is auto-refresh interval time before sleeping, and it can be
configured to a small value to speed up auto-refresh. Relatively, drf\_t\_ref is used in
normal mode, and it is always configured according to device data sheet.

drf\_ref\_cnt\_thr is used to inform hardware how many times auto-refresh should be issued before sleep. In general, this value is configured as row number.

ref\_cnt\_done is a status indicating required refresh number is completed.

drf\_ref\_cnt\_rst is used to reset refresh counter.

I Idle status before sleep:

rfemc\_idle\_sync is a status indicating EMC enters IDLE state and last bursts completed.

#### 5.2.4.5.7 Software Commands

Software direct command functions:



- Support the following software direct command list for SDRAM:
  - ü Pre-charge all banks
  - ü Auto-refresh
  - ü Load mode register and extended mode register
  - ü Self-refresh
  - ü Resume
- I For each command, there is one bit to check done status.
- Support two options for software commands, one command for one chip, and one command for all chips. The option select depends on LDO driving strength.

#### Notes:

- I Not support SDRAM POWER DOWN AND DEEP POWER DOWN mode.
- I Not support CLOCK SUSPEND mode.

EMC provide the following registers to issue software commands.

- I dsoft\_pre\_all: Issue one PRECHARGE all banks command
- dsoft\_auto\_ref: Issue one AUTO-REFRESH command
- dsoft\_ld\_mdreg: Issue one LOAD MODE REGISTER command. Mode register value should be configured in drf\_mode\_reg before issuing this command.
- I dsoft\_self\_ref: Enter SELF-REFRESH
- I dsoft\_resume: Exit SELF-REFRESH

drf\_mode\_reg[15:14] is mapped to BA[1:0].
drf\_mode\_reg[13:0] is mapped to A[13:0].

For stacked SDRAMs, when software commands are issued, two options are provided for chip select. If **dsoft\_cmd\_allcs** is set, the command is active on all CS at the same time. If it is cleared, the **dsoft\_cs** is used to select which CS is active.

### 5.2.4.5.8 Data Path Control

The main function of DMEM data path logic is to handle data, DM and DQS.

Through several stage-configurable shift registers, burst commands and related information are transmitted from command path to data path. Data path should:

- Adjust the timing of data, DM and DQS, which are described in following chapter.
- Request and receive write data from each channel
- Translate write data format and sequence according to SDR/DDR and 16-bit/32-bit.
- I Transmit write data on external memory bus, and the specific circuit is described in EMC PHY Specifications
- Receive and sample read data from external memory bus, and the specific circuit is described in EMC PHY Specifications, and the function is described in following chapter.
- I Translate read data format and sequence according to SDR/DDR and 16-bit/32-bit.
- I Transmit read data to each channel.

The detailed features in each task are as follows.



Data path adjust the timing of data, DM and DQS

I This function is described in following chapter

Data path requests and receives write data from each channel

Channel information is got from the shift registers.

Data path translates write data format and sequence according to SDR/DDR and 16-bit/32-bit

- For 16-bit DMEM, higher 16-bit of 32-bit data is executed firstly and is written into the column address that LSB is 0, and lower 16-bit of 32-bit data is executed secondly and is written into the column address that LSB is 1.
- I For 16-bit SDR, the maximum EMC core data rate is as four times as external memory data rate, so data rate need be matched.
- For 32-bit SDR, the maximum EMC core data rate is as twice as external memory data rate, so data rate need be matched.
- I For 16-bit DDR, the maximum EMC core data rate is as twice as external memory data rate, so data rate need be matched.
- For 32-bit DDR, the maximum EMC core data rate is the same as external memory data rate.

Data path transmits write data on external memory bus.

- I For SDR, write data and DM is latched output trigged by clk\_emc
- For DDR, write data and DM is latched output trigged by clk\_em\_wr, which is generated from clk\_emc through a delay line. Through coarse and fine timing adjustment, write data and DM need delay about 0.75 DMEM clock cycle (generally, coarse adjustment achieves 0.5 and delay line achieve about 0.25).

Data path receives and samples read data from external memory bus

I This function is described in following chapter

Data path translates read data format and sequence according to SDR/DDR and 16-bit/32-bit.

- For 16-bit DMEM, to consecutive two receiving data, the first one is stored in higher 16-bit of 32-bit data, and the second is stored in lower 16-bit of 32-bit data.
- For 16-bit SDR, the maximum EMC core data rate is as four times as external memory data rate, so data rate need be matched.
- For 32-bit SDR, the maximum EMC core data rate is as twice as external memory data rate, so data rate need be matched.
- I For 16-bit DDR, the maximum EMC core data rate is as twice as external memory data rate, so data rate need be matched.
- For 32-bit DDR, the maximum EMC core data rate is the same as external memory data rate

Data path transmits read data to each channel.

I Channel information is got from the shift registers.



## 5.2.4.6 DMEM Timing Descriptions

Timing control registers are divided into two groups, one is used to control cycle-based command timing sequence, and the other is used to adjust data path and sampling timing.

## 5.2.4.6.1 Timing Diagrams

SDRAM is configured that CAS Latency is 3 and Burst Length is 2.

### **SDRAM Initialize**



Figure 5.2-32 SDRAM initialize timing diagram

## **SDRAM Auto-Refresh**



Figure 5.2-33 SDRAM auto-refresh timing diagram



#### **SDRAM Self-Refresh**



Figure 5.2-34 SDRAM self-refresh timing diagram

### **SDR-SDRAM** Read



Figure 5.2-35 SDR-SDRAM read timing diagram

SDR-SDRAM alternative-bank Read





Figure 5.2-36 SDR-SDRAM alternative-bank read timing diagram

## **SDR-SDRAM Write**



Figure 5.2-37 SDR-SDRAM write timing diagram

## SDR-SDRAM alternative-bank Write





SDR-SDRAM Read-Write-Read turn-around

Figure 5.2-38 SDR-SDRAM alternative-bank write timing diagram

#### 250ms 790m 1000ms Read to Write +White-to-Read+ AS Latency = CUK NOP NOF CMD READ WRITE NOP READ ADDR ADDR1 Bank Bank Bank DOM DMO DM1 00 D0 Dt D1

Figure 5.2-39 SDR-SDRAM read-write turn-around timing diagram

## **DDR-SDRAM Read**





**DDR-SDRAM Write** 

Figure 5.2-40 DDR-SDRAM read timing diagram

#### Ons 200ns 300ns 500ns 700ns 800ns 100ns **IRAS** CLK CMD NOP ACT NOP WRITE NOP PRE NOP ACT Row Row Column A10 Low ADDR +DOSS(NOM)--IWPRE-WAYPST DOS DQM DM0 DM1 tD8 DO

## Figure 5.2-41 DDR-SDRAM write timing diagram

#### )ne 250ms 500ns 750ns 1000 na Witte-to-Read or (WTR-C) CUK READ WRITE NOP CMD NOP NOP READ ADDR Column Column Column ADDR1 Bank Bank DOS DOM DM1 DMD (00) (01) 01 DQ. D0

## DDR-SDRAM Read-Write-Read turn-around

Figure 5.2-42 DDR-SDRAM read-write turn-around timing diagram



### DDR-SDRAM alternative-CS Read-Read turn-around



Figure 5.2-43 DDR-SDRAM alternative-CS read-read turn-around timing diagram

## 5.2.4.6.2 Output Clock Timing Control

- I drf\_clkdmem\_out\_en is used to enable DMEM output clock.
  - 1: enable
  - 0: disable
- **I** drf\_clkdmem\_out\_sel is used to adjust DMEM output clock phase. One step is one clk\_emc cycle, or 1/2 DMEM clock cycle.
- I rf\_clkdmem\_out\_dl\_sel and rf\_clkdmem\_out\_dl\_inv is used for related delay line to adjust DMEM output clock timing.

## 5.2.4.6.3 Command Timing Control

All timing parameters of SDR-SDRAM and DDR-SDRAM can be met by controlling DMEM configuration registers.

Note, the real wait cycles is (**drf\_t\_x** register value + 1), for example, if 3 cycles are needed for **Trcd** in data sheet, **drf\_t\_rcd** should be set to 2.

The following is detailed manual to guarantee the DMEM timing parameters.

T is DMEM clock cycle time, or clk\_emc/2 clock cycle.

Tref is clk\_emc\_ref clock cycle.

I Minimum PRECHARGE command period time (or tRP):



We should use  $drf_t_p$  to guarantee it. That is,  $(drf_t_p+1)^*T >= tRP$ .

Minimum ACTIVE to READ or WRITE delay (or minimum RAS to CAS delay, or tRCD):

We should use  $drf_t - rcd$  to guarantee it. That is,  $(drf_t - rcd + 1)^*T > = tRCD$ .

- I Minimum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MIN): We should use **drf\_t\_ras** to guarantee it. That is, (**drf\_t\_ras**+1)\*T >= tRAS-MIN.
- Maximum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MAX):

We should use **drf\_t\_ref** to guarantee it because all banks are pre-charged before auto-refresh. That is, (**drf\_t\_ref+**1)\*Tref <= tRAS-MAX. In general, this condition is met.

- Minimum ACTIVE(m) to ACTIVE(n) (in different bank) time (or tRRD):
  We should use drf\_t\_rrd to guarantee it. That is, (drf\_t\_rrd+1)\*T >= tRRD.
- I Minimum ACTIVE(m) to ACTIVE(m) (in same bank) time (or tRC):
  - a. Because in the same bank there is a PRECHARGE in two ACTIVE in normal Read/Write, so we should also use  $drf_t_ras$  to guarantee tRC. That is,  $(drf_t_ras+drf_t_rp+2)*T>= tRC$ .
  - b. There are only two cases that there isn't PRECHARGE, one is auto-refresh progress is in two ACTIVE. That is,  $(\mathbf{drf}_{t}\mathbf{rp}+\mathbf{drf}_{t}\mathbf{rfc}+3)^{*}T >= tRC$ . In general, this condition is always met.
  - c. The other is software-issued PRECHARGE ALL BANK command is in two ACTIVE. That is, software should guarantee PRECHARGE ALL BANK period is more than tRC. In general, this condition is always met.
- Minimum Write recovery time (or minimum last data-in to PRECHARGE time, or tWR, or tDPL, or tRDL):

We should use drf\_t\_wr to guarantee it.

For SDR,  $(d\mathbf{rf}_t\mathbf{wr}+1)^*T >= tWR$ 

For DDR, (drf t wr -1)\*T >= tWR

(Because EMC is designed for both SDR and DDR, there are fixed 2 cycle difference between them)

I Maximum Refresh period (or tREF):

We should use **drf\_t\_ref** to guarantee it. That is, (**drf\_t\_ref**+1)\*Tref\*(row number) <= tREF

Minimum AUTO-REFRESH period (or tRFC):

We should use **drf\_t\_rfc** to guarantee it. That is, (**drf\_t\_rfc**+2)\*T >= tRFC

- Minimum SELF-REFRESH time (tRAS for Micron, Samsung, etc):
  We should use drf\_t\_xsr to guarantee it. That is, (drf\_t\_xsr+2)\*T >= this minimum time
- I Minimum RESUME time (or exit SELF-REFRESH to ACTIVE or AUTO-REFRESH delay, or tXSR for Micron, or tRC for Samsung, etc):



We should use  $drf_t_xsr$  to quarantee it. That is,  $(drf_t_xsr+2)^*T >= this minimum time$ 

- Minimum LOAD MODE REGISTER to ACTIVE or REFRESH delay (or tMRD): We should use drf\_t\_mrd to guarantee it. That is, (drf\_t\_mrd+2)\*T >= tMRD
- I drf\_t\_rtw is read-to-write turn-around time, used to prevent data bus conflict. It's from the last read in command stage to the next write in command stage.
  For SDR and DDR, normally, it should be configure to 2 (3 cycles) for CAS latency 2 or 3 (4 cycles) for CAS latency 3.
- drf\_t\_wtr is write-to-read turn-around time. It's from the last write in command stage to the next read in command stage. And this register is used to guarantee tWTR for DDR. However, unlike other parameters, this register has the different physical definitions with tWTR.

For SDR, it should always be configured to 0 (1 cycle)

For DDR,  $(drf_t_wtr+1)^T >= tWTR+2$ 

drf\_t\_rtr is read-to-read turn-around time between different CSs, used to prevent two DDR-SDRAM DQS conflict. It's from the last read in command stage on CSn to the next read in command stage on CSm.

For SDR, it should always be configured to 0 (1 cycle).

For DDR, it should be configured to 0 (1 cycle) for only supporting one CS, or 1(2 cycle) for supporting two or above.

### 5.2.4.6.4 Write Data Path Timing Control

- I Support independent and configurable write data latency. For SDR, it's zero. For DDR, it should be adjusted. This adjustment includes coarse adjustment and fine adjustment.
  - **ü** For coarse adjustment, supporting 0, 0.5, 1, 1.5, 2, 2.5, 3, 3.5 DMEM clock cycles delay
  - For fine adjustment, support one delay line to control delay value. This delay line is also used for write DQM delay control.

drf\_wdata\_latency is used to adjust write data latency. One step is one clk\_emc cycle.

rf\_clkwr\_dl\_sel and rf\_clkwr\_dl\_inv is used for related delay line to adjust write
data latency.

- Support independent and configurable data pad OE timing. It's used for SDR and DDR, and only coarse adjustment is on this signal and no delay line for fine adjustment.
  - Ü For coarse adjustment, support configurable delay of 0, 0.5, 1, 1.5, 2, 2.5, 3, 3.5 DMEM clock cycles, and support configurable period of one DMEM burst cycles, one DMEM burst cycles + 0.5 DMEM clock cycles, one DMEM burst cycles + 1 DMEM clock cycles, ..., one DMEM burst cycles + 3.5 DMEM clock cycles.

drf\_data\_oe\_sel is used to adjust data PAD OE timing. One bit is one range, and the delay between two consecutive ranges is one clk\_emc cycle. Then all selected ranges are OR output.



- Support independent and configurable write DQM latency. For SDR, it's zero. For DDR, it should be adjusted. This adjustment includes coarse adjustment and fine adjustment.
  - For coarse adjustment, supporting 0, 0.5, 1, 1.5, 2, 2.5, 3, 3.5 DMEM clock cycles delay
  - **ü** For fine adjustment, support one delay line to control delay value. This delay line is also used for write data delay control.

drf\_wdm\_latency is used to adjust write DM latency. One step is one clk\_emc cycle.
rf\_clkwr\_dl\_sel and rf\_clkwr\_dl\_inv is used for related delay line to adjust write
DQM latency.

- I Support independent and configurable output DQS timing. It's only used for DDR, and this adjustment includes coarse adjustment and fine adjustment.
  - **ü** For coarse adjustment, supporting 0, 0.5, 1, 1.5, 2, 2.5, 3, 3.5 DMEM clock cycles delay
  - **ü** For fine adjustment, support one delay line to control delay value.

drf\_dqs\_out\_sel is used to adjust DQS output latency. One step is one clk\_emc cycle.

**rf\_dqs\_out\_dl\_sel** and **rf\_dqs\_out\_dl\_inv** is used for related delay line to adjust output DQS.

- I Support independent and configurable DQS pad OE timing. It's only used for DDR, and only coarse adjustment is on this signal and no delay line for fine adjustment.
  - Ü For coarse adjustment, support configurable delay of 0, 0.5, 1, 1.5, 2, 2.5, 3, 3.5 DMEM clock cycles, and support configurable period of one DMEM burst cycles, one DMEM burst cycles + 0.5 DMEM clock cycles, one DMEM burst cycles + 1 DMEM clock cycles, ..., one DMEM burst cycles + 3.5 DMEM clock cycles.

drf\_dqs\_oe\_sel is used to adjust DQS PAD OE timing. One bit is one range, and the
delay between two consecutive ranges is one clk\_emc cycle. Then all selected
ranges are OR output.

### 5.2.4.6.5 Read Data Path Timing Control

- Support independent and configurable sampling clock timing. It's only used for SDR, and this adjustment includes coarse adjustment and fine adjustment.
  - For coarse adjustment, supporting 0, 0.5, 1, 1.5, ..., 7, 7.5 DMEM clock cycles delay
  - For fine adjustment, support four delay lines to control delay value, and each delay line controls one byte data sampling clock. These delay lines are shared with DQS input control.

drf\_clkdmem\_in\_sel is used to adjust sample clock phase. One step is one clk\_emc cycle.

- **rf\_dqs\_in\_pos\_dl\_0\_sel** and **rf\_dqs\_in\_pos\_dl\_0\_inv** is used for related delay line to adjust sampling clock positive edge timing.
- **rf\_dqs\_in\_pos\_dl\_1\_sel** and **rf\_dqs\_in\_pos\_dl\_1\_inv** is used for related delay line to adjust sampling clock positive edge timing.
- **rf\_dqs\_in\_pos\_dl\_2\_sel** and **rf\_dqs\_in\_pos\_dl\_2\_inv** is used for related delay line to adjust sampling clock positive edge timing.
- **rf\_dqs\_in\_pos\_dl\_3\_sel** and **rf\_dqs\_in\_pos\_dl\_3\_inv** is used for related delay line to adjust sampling clock positive edge timing.



- **rf\_dqs\_in\_neg\_dl\_0\_sel** and **rf\_dqs\_in\_neg\_dl\_0\_inv** is used for related delay line to adjust sampling clock negative edge timing.
- **rf\_dqs\_in\_neg\_dl\_1\_sel** and **rf\_dqs\_in\_neg\_dl\_1\_inv** is used for related delay line to adjust sampling clock negative edge timing.
- rf\_dqs\_in\_neg\_dl\_2\_sel and rf\_dqs\_in\_neg\_dl\_2\_inv is used for related delay line to adjust sampling clock negative edge timing.
- **rf\_dqs\_in\_neg\_dl\_3\_sel** and **rf\_dqs\_in\_neg\_dl\_3\_inv** is used for related delay line to adjust sampling clock negative edge timing.
- I Support independent and configurable read data latency. It's used for SDR and DDR, and only coarse adjustment is on this signal and no delay line for fine adjustment.
  - **ü** For coarse adjustment, supporting 0, 0.5, 1, 1.5, ..., 7, 7.5 DMEM clock cycles delay
  - drf\_rdata\_latency is used to adjust read data latency. One step is one clk\_emc cycle.
- I Support independent and configurable data pad IE timing. It's used for SDR and DDR, and only coarse adjustment is on this signal and no delay line for fine adjustment.
  - **ü** For coarse adjustment, support configurable delay of 0, 0.5, 1, 1.5, ..., 7, 7.5 DMEM clock cycles, and support configurable period of one DMEM burst cycles, one DMEM burst cycles + 0.5 DMEM clock cycles, one DMEM burst cycles + 1 DMEM clock cycles, ..., one DMEM burst cycles + 7.5 DMEM clock cycles.
  - drf\_data\_ie\_sel is used to adjust data PAD IE timing. One bit is one range, and the
    delay between two consecutive ranges is one clk\_emc cycle. Then all selected
    ranges are OR output.
- I Support independent and configurable read DQM latency. For SDR, it's should be adjusted. For DDR, it's DON'T CARE. This adjustment only includes coarse adjustment.
  - **ü** For coarse adjustment, supporting 0, 0.5, 1, 1.5, 2, 2.5, 3 DMEM clock cycles delay (the last option is disabled)
  - drf rdm latency is used to adjust read DM latency. One step is one clk\_emc cycle.
- I Support independent and configurable DQS input timing. It's only used for DDR, and this adjustment only includes fine adjustment.
  - For fine adjustment, support four delay lines to control delay value, and each delay line controls one byte DQS input. These delay lines are shared with SDR sampling clock control.
- Support independent and configurable input DQS gate timing. It's only used for DDR, and this adjustment includes coarse adjustment and fine adjustment.
  - **ü** For coarse adjustment, support configurable delay of 0, 0.5, 1, 1.5, ..., 7, 7.5 DMEM clock cycles, and support configurable period of one DMEM burst cycles, one DMEM burst cycles + 0.5 DMEM clock cycles, one DMEM burst cycles + 1 DMEM clock cycles, ..., one DMEM burst cycles + 7.5 DMEM clock cycles.
  - **ü** For fine adjustment, support four delay lines to control delay value, and each delay controls one byte data DQS gate.
  - **drf\_dqs\_gate\_pre\_sel** and **drf\_dqs\_gate\_pst\_sel** is used to adjust DQS input mask timing. One bit is one range, and the delay between two consecutive ranges is one clk\_emc cycle. Then all selected ranges are OR output.
  - **rf\_dqs\_gate\_pre\_dl\_0\_sel** and **rf\_dqs\_gate\_pre\_dl\_0\_inv** is used for related delay line to adjust DQS gate timing.



**rf\_dqs\_gate\_pre\_dl\_1\_sel** and **rf\_dqs\_gate\_pre\_dl\_1\_inv** is used for related delay line to adjust DQS gate timing.

**rf\_dqs\_gate\_pre\_dl\_2\_sel** and **rf\_dqs\_gate\_pre\_dl\_2\_inv** is used for related delay line to adjust DQS gate timing.

**rf\_dqs\_gate\_pre\_dl\_3\_sel** and **rf\_dqs\_gate\_pre\_dl\_3\_inv** is used for related delay line to adjust DQS gate timing.

**rf\_dqs\_gate\_pst\_dl\_0\_sel** and **rf\_dqs\_gate\_pst\_dl\_0\_inv** is used for related delay line to adjust DQS gate timing.

rf\_dqs\_gate\_pst\_dl\_1\_sel and rf\_dqs\_gate\_pst\_dl\_1\_inv is used for related delay line to adjust DQS gate timing.

**rf\_dqs\_gate\_pst\_dl\_2\_sel** and **rf\_dqs\_gate\_pst\_dl\_2\_inv** is used for related delay line to adjust DQS gate timing.

**rf\_dqs\_gate\_pst\_dl\_3\_sel** and **rf\_dqs\_gate\_pst\_dl\_3\_inv** is used for related delay line to adjust DQS gate timing.

- Support independent and configurable DQS pad IE timing. It's only used for DDR, and this adjustment includes coarse adjustment and fine adjustment.
  - For coarse adjustment, support configurable delay of 0, 0.5, 1, 1.5, ..., 7, 7.5 DMEM clock cycles, and support configurable period of one DMEM burst cycles, one DMEM burst cycles + 0.5 DMEM clock cycles, one DMEM burst cycles + 1 DMEM clock cycles, ..., one DMEM burst cycles + 7.5 DMEM clock cycles.
  - **ü** For fine adjustment, support one delay lines to control delay value.

drf\_dqs\_ie\_sel is used to adjust DQS PAD IE timing. One bit is one range, and the delay between two consecutive ranges is one clk\_emc cycle. Then all selected ranges are OR output.

**rf\_dqs\_ie\_dl\_sel** and **rf\_dqs\_ie\_dl\_inv** is used for related delay line to adjust DQS pad IE timing.

### 5.2.4.6.6 Sampling Control

Refer to EMC PHY specification for detailed circuit.

The base theory is described here:

Four dedicated sample clocks (each for one byte data) are used to sample data on external memory bus. These sample clocks have the same frequency as DMEM clock, but the phase is different. We guarantee the stability of sampling data by adjusting this phase.

Then the sampled data is written to FIFOs, and the async clock domains are passed through these FIFOs.

At last the output data from FIFOs is transmitted to DMEM controller.

SDR sampling clock features:

- For SDR, sampling clock is generated in DMEM controller. It's only active during burst data active, one cycle for one read data. Then this clock passes four delay lines to adjust sampling timing, and each delay line is related to one byte data. At last, the four clocks output from four delay lines are used for DFFs in sampling FIFO as trigging clocks.
- For SDR, support sample clock out-of-chip loop mode, and this function can be enabled or disabled. After sample clock is generated from DMEM controller, if this function is disabled, sample clock is connected to delay line directly, otherwise, sample clock output out of chip through CS3 pin firstly and then input through DQS pins to delay line.



Note, if this function is used, CS3 pin is used as sample clock output, and related CS function is disabled.

### DDR sampling clock features:

- For DDR, sampling clock is from four DQS signals (one DQS for one byte data), which is generated by DDR device. And also, this clock is only active during burst data active, one cycle for one data. After input from DQS pads, sampling clocks MUST be gated by DQS gate signals to remove unstable state, because DQS lines are high-Z state if no bursts issued. Then sampling clocks passes four delay lines to adjust sampling timing, and these delay lines are shared for SDR. At last, the four clocks output from four delay lines are used for DFFs in pose-edge sampling FIFO as trigging clocks, and at the same time, this four clocks are inverted to used for DFFs in negative-edge sampling FIFO as trigging clocks.
- From above description, the DQS gate signals are very important to guarantee sampling correction. The source of these DQS gate signals is generated in DMEM controller and only active during burst data active. Then it passes two groups of delay lines to adjust timing, and each group has four delay lines and each delay line is related to one DQS. There are two modes for the function of these two groups of delay lines. For mode 0, one group is used to meet fast-case rising edge timing and the other is used to meet slow-case rising edge timing, and the falling edge of DQS gate is generated automatically. For mode 1, one group is used to adjust DQS gate rising edge timing and the other is used to adjust falling edge timing. At last, the four DQS gate signals output from these delay lines are used for gating DQS.
- For DDR, support DQS gate signal out-of-chip loop mode, and this function can be enabled or disabled. DQS gate is generated from internal logic, and if this function is disabled, DQS gate is connected to delay line directly, otherwise, DQS gate output out of chip through CS3 pin firstly and then input through CKE1 pin to delay line.
- Note, if this function is used, CS3 and CKE1 pin are used as DQS gate output and input, and related CS and CKE function is disabled.

### SDR sampling FIFOs features:

- I One FIFO is used for one data and totally there are 32 FIFOs for SDR.
- I All FIFOs have the same structure: 3-entry asynchronous FIFO.
- I The writing clock is sampling clock
- I The reading clock is clk emc
- I The writing pointer is generated in PHY
- I The reading pointer is generated from DMEM controller.
- I Because the frequency of sampling clock is the half of clk\_emc and there is no accumulated error, so full and empty information is not needed, and we can guarantee data is valid in FIFO by adjusting read pointer delay timing (that is, read data latency described above).

## DDR sampling FIFOs features:

- I One pose-edge sampling FIFO and one neg-edge sampling FIFO are used for one data and totally there are 64 FIFOs for DDR. The 32 pose-edge sampling FIFO is shared for SDR.
- Both pose-edge sampling FIFO and neg-edge FIFO have the same structure: 3-entry asynchronous FIFO.
- I The writing clock of pose-edge sampling FIFO is pose-edge sampling clock and the writing clock of neg-edge sampling FIFO is neg-edge sampling clock.
- I The reading clock of both is clk\_emc.
- I The writing pointers of both are generated in PHY. One is trigged by pose-edge sampling clock and the other is trigged by neq-edge sampling clock.
- I The reading pointers of both are the same one, and it is generated from DMEM controller.
- Because the frequency of both sampling clock is the half of clk\_emc and there is no accumulated error, so full and empty information of both is not needed, and we can



guarantee data is valid in both FIFO by adjusting read pointer delay timing (that is, read data latency described above).

### Sample FIFO Reset:

- I drf\_sample\_rst is used to reset DMEM sample FIFO by software.
- I drf\_sample\_auto\_rst\_en is used to enable resetting DMEM sample FIFO automatically during each auto-refresh and resume.

### 5.2.4.7 PHY Descriptions

All constraints described as follows should be checked in FF, TT and SS cases.

## 5.2.4.7.1 SDR Sampling Circuit Timing Budget

Sampling circuit is described as follows.



Figure 5.2-44 SDR sampling circuit

In order to make sampling stable, EMC should guarantee some timing:

- I Data sample setup stable: (t\_clkout + t\_padout + t\_AC + t\_pcb + t\_padin + t\_datain + DFF setup time + clock tree skew) < (t\_clksample + 2 \* clk\_emc cycle time)</p>
- I Data sample hold stable:



(t\_clkout + t\_padout + 2 \* clk\_emc cycle time + t\_OH + t\_pcb + t\_padin + t\_datain + DFF setup time - clock tree skew) > (t\_clksample + 2 \* clk\_emc cycle time)

I Sample FIFO reading stable: (t\_clksample + DFF output delay + t\_samplein + DFF setup time + clock tree skew) < (1 \* clk\_emc cycle time)

### 5.2.4.7.2 DDR Output Data Timing Budget

Output data circuit is described as follows.



Figure 5.2-45 DDR sampling circuit

- I clk emc wr DFF setup:
  - (t\_tree + DFF output delay + DFF setup time) < t\_clkwr
- I output data setup to DQS:
  - (t\_clkwr + DFF output delay + t\_dataout + t\_padout + data skew + t\_DS) < (t\_tree + DFF output delay + t\_dqsout + t\_padout)
- I output data hold to DQS:
  - $(t\_clkwr + DFF \ output \ delay + t\_dataout + t\_padout data \ skew + 1 * clk\_emc \ cycle \\ time t\_DH) > (t\_tree + DFF \ output \ delay + t\_dqsout + t\_padout)$

## 5.2.4.7.3 DDR Sampling Circuit Timing Budget

Sampling circuit is described as follows.





Figure 5.2-46 DDR sampling circuit

- I Data sample setup stable:
  - (t\_padin + t\_datain + DFF setup time + data skew) < (t\_padin + t\_dqsin t\_DQSQ)
- I Data sample hold stable:
  - $(t_padin + t_datain + DFF setup time data skew + data valid window) > (t_padin + t_dqsin t_DQSQ)$
  - Or (t\_padin + t\_datain + DFF setup time data skew) > (t\_padin + t\_dqsin t\_QH)
- I Sample FIFO reading stable:
  - (DFF output delay + t\_clkout + t\_padout + t\_DQSCK\_MAX + t\_pcb + t\_padin + t\_dqsin + DFF output delay + t\_samplein + DFF setup time) <  $(3 * clk_emc cycle time)$

## 5.2.4.7.4 DDR DQS gating Circuit Timing Budget

DQS gating circuit is described as follows.





Figure 5.2-47 DDR gate circuit

DQS gating timing diagram is described as follows.





Figure 5.2-48 DDR gate timing diagram

I Gating signal falling edge delay constraint:

Refer to Fall\_S and Fall\_H in above diagram

t\_gatefalling > 0

t\_gatefalling < 1 \* clk\_emc cycle time

t\_gatefalling < t\_RPST

I DQSCK MAX guarantee from dqs\_gate\_pre:

Refer to PRE S in above diagram

(DFF output delay + t\_clkout + t\_padout + t\_DQSCK\_MAX - t\_RPRE + t\_pcb + t\_padin + t\_dqsin) < (DFF output delay + t\_gate\_pre)

I DQSCK MIN guarantee from dqs\_gate\_pre:

Refer to PRE\_H in above diagram

(DFF output delay + t\_clkout + t\_padout + t\_DQSCK\_MIN + t\_pcb + t\_padin + t\_dqsin) > (DFF output delay + t\_gate\_pre)

I DQSCK MAX guarantee from dqs\_gate\_pst:

Refer to PST\_S in above diagram

(DFF output delay + t\_clkout + t\_padout + t\_DQSCK\_MAX + t\_pcb + t\_padin + t\_dqsin + t\_gatefalling 1 \* clk\_emc cycle time) < (DFF output delay + t\_gate\_pst + 3 \* clk\_emc cycle time)

I DQSCK MIN guarantee from dqs\_gate\_pst:

Refer to PST\_H in above diagram

(DFF output delay + t\_clkout + t\_padout + t\_DQSCK\_MIN + t\_pcb + t\_padin + t\_dqsin + t\_gatefalling 3 \* clk\_emc cycle time) > (DFF output delay + t\_gate\_pst + 3 \* clk\_emc cycle time)



### 5.2.4.8 DLL Descriptions

#### 5.2.4.8.1 DLL Control

Memory controller includes a DLL to compensate delay line.

I rf\_dll\_en, rf\_dll\_clr, rf\_dll\_init and rf\_dll\_auto\_clr\_en are used to control DLL.
If rf\_dll\_clr is set, DLL is reset and kept in idle. After system reset, rf\_dll\_clr is set.
When rf\_dll\_clr is cleared, DLL starts to search LOCK point automatically.
If LOCK point is found, DLL enters LOCKED state and continues to track this point.

rf\_dll\_en is used to enable DLL function.

rf\_dll\_init is used to configure DLL searching start value.

During sleep, if **rf\_dll\_auto\_clr\_en** is set, DLL is reset automatically and memory controller waits for LOCKED automatically. It's recommended to set this bit.

I rfdll\_locked, rfdll\_error are used by software to monitor DLL status.

### rfdll\_locked:

- 1: DLL LOCKED
- 0: DLL UNLOCKED

**rfdll\_error** is set if DLL error happens, and is cleared by software to write 1 to this bit. **rf\_dll\_err\_clr** is used to clear the error bit.

### 5.2.4.8.2 Delay Line Control

There are twenty delay lines used in memory controller to delay clocks or control signals. All delay lines can be controlled independently.

Each delay line can be controlled in two ways.

The first is software-directly configuring.

The second is DLL-automatically compensating.

I All delay lines share a group of DLL-compensating configuration registers, rf\_dl\_cpst\_thr, rf\_dl\_cpst\_group, rf\_dl\_cpst\_en, rd\_dl\_cpst\_start, and rfdl\_cpst\_st\_idle.

**rf\_dl\_cpst\_en** must be set if any delay line is compensated automatically by DLL. If all delay lines are controlled directly by software, this bit is cleared.

rf\_dl\_cpst\_group is DLL-compensating group mode.

0: DMEM is hold during all clkwr\_dl, dqs\_in\_pos\_dl\_x, dqs\_in\_neg\_dl\_x delay lines compensating.



- 1: DMEM is hold during all clkwr\_dl, dqs\_in\_pos\_dl\_x, dqs\_in\_neg\_dl\_x, dqs\_gate\_pre\_dl\_x, dqs\_gate\_pst\_dl\_x delay lines compensating.
- 2: DMEM is hold during all clkwr\_dl, dqs\_in\_pos\_dl\_x, dqs\_in\_neg\_dl\_x, dqs\_gate\_pre\_dl\_x, dqs\_gate\_pst\_dl\_x, dqs\_ie\_dl delay lines compensating.
- 3: DMEM is hold only during all delay lines compensating.

rf\_dl\_cpst\_thr is threshold to start one compensation. That is, only if the DLL change value from last compensation is more than threshold, a new compensation is started. This value is used to prevent delay lines from compensating too frequently.

rf\_dl\_cpst\_start is used to start DLL-compensating.

rfdl cpst st idle is an indicator of compensation state machine idle.

I Each delay line has a separate group of configuration registers, rf\_xxx\_dl\_sel, rf\_xxx\_dl\_inv, rfdl\_xxx\_cnt, and rf\_xxx\_cpst\_en.

rf\_xxx\_cpst\_en is used to select control modes.

- 1: related delay line is compensated by DLL.
- 0: related delay line can be configured only by software.

rf\_xxx\_dl\_sel has different functions in different configuring ways.

If **rf\_xxx\_cpst\_en** is set, this value means delay phase.

Otherwise, it means delay line number.

rf\_xxx\_dl\_inv provides an inverting option for signal through delay line.

rfdl\_xxx\_cnt is a read-back delay line value.

I Configuring flow is described as follows

### For Software-directly control:

Related rf\_xxx\_cpst\_en should be cleared.

rf\_xxx\_sel is configured to new delay line number.

### For DLL-automatically compensating:

rf\_dll\_en is set, rf\_dl\_cpst\_group and rf\_dl\_cpst\_thr are configured firstly.

rf\_xxx\_sel is counted and configured.

Then related rf\_xxx\_cpst\_en is set.

At last, rf\_dl\_cpst\_en is set.

## 5.2.5 Control Registers

### **5.2.5.1** Memory map

ARM base address: 0x2000\_0000



## **General Control Registers:**

| Offset<br>Address  | Name          | Description                              |  |  |  |  |  |
|--------------------|---------------|------------------------------------------|--|--|--|--|--|
| 0x0000             | EMC_CFG0      | EMC general control register             |  |  |  |  |  |
| 0x0004             | EMC_CFG1      | EMC PHY control register                 |  |  |  |  |  |
| 0x0008 -<br>0x000C | Reserved      |                                          |  |  |  |  |  |
| 0x0010             | EMC_CFG0_CS0  | EMC CS0 device configuration register    |  |  |  |  |  |
| 0x0014             | EMC_CFG0_CS1  | EMC CS1 device configuration register    |  |  |  |  |  |
| 0x0018 -<br>0x001C | Reserved      |                                          |  |  |  |  |  |
| 0x0020             | EMC_CFG0_ACH0 | EMC AXI channel 0 configuration register |  |  |  |  |  |
| 0x0024             | EMC_CFG1_ACH0 | EMC AXI channel 0 configuration register |  |  |  |  |  |
| 0x0028             | EMC_CFG0_ACH1 | EMC AXI channel 1 configuration register |  |  |  |  |  |
| 0x002C             | EMC_CFG1_ACH1 | EMC AXI channel 1 configuration register |  |  |  |  |  |
| 0x0030             | EMC_CFG0_HCH2 | EMC AHB channel 2 configuration register |  |  |  |  |  |
| 0x0034             | EMC_CFG1_HCH2 | EMC AHB channel 2 configuration register |  |  |  |  |  |
| 0x0038             | EMC_CFG0_HCH3 | EMC AHB channel 2 configuration register |  |  |  |  |  |
| 0x003C             | EMC_CFG1_HCH3 | EMC AHB channel 3 configuration register |  |  |  |  |  |
| 0x0040             | EMC_CFG0_HCH4 | EMC AHB channel 4 configuration register |  |  |  |  |  |
| 0x0044             | EMC_CFG1_HCH4 | EMC AHB channel 4 configuration register |  |  |  |  |  |
| 0x0048             | EMC_CFG0_HCH5 | EMC AHB channel 5 configuration register |  |  |  |  |  |
| 0x004C             | EMC_CFG1_HCH5 | EMC AHB channel 5 configuration register |  |  |  |  |  |
| 0x0050             | EMC_CFG0_HCH6 | EMC AHB channel 6 configuration register |  |  |  |  |  |
| 0x0054             | EMC_CFG1_HCH6 | EMC AHB channel 6 configuration register |  |  |  |  |  |
| 0x0058             | EMC_CFG0_HCH7 | EMC AHB channel 7 configuration register |  |  |  |  |  |
| 0x005C             | EMC_CFG1_HCH7 | EMC AHB channel 7 configuration register |  |  |  |  |  |
| 0x0060             | EMC_CFG0_HCH8 | EMC AHB channel 8 configuration register |  |  |  |  |  |
| 0x0064             | EMC_CFG1_HCH8 | EMC AHB channel 8 configuration register |  |  |  |  |  |
| 0x0068 -<br>0x009C | Reserved      |                                          |  |  |  |  |  |
| 0x00A0             | EMC_STS0      | EMC status                               |  |  |  |  |  |
| 0x00A4             | EMC_STS1      | EMC status                               |  |  |  |  |  |
| 0x00A8             | EMC_STS2      | EMC status                               |  |  |  |  |  |
| 0x00AC             | EMC_STS3      | EMC status                               |  |  |  |  |  |
| 0x00B0 -<br>0x00BC | Reserved      |                                          |  |  |  |  |  |
| 0x00C0             | EMC_STS0_ACH0 | EMC AXI channel 0 status                 |  |  |  |  |  |
| 0x00C4             | EMC_STS0_ACH1 | EMC AXI channel 1 status                 |  |  |  |  |  |



| 0x00C8             | EMC_STS0_HCH2 | EMC AHB channel 2 status |
|--------------------|---------------|--------------------------|
| 0x00CC             | EMC_STS0_HCH3 | EMC AHB channel 3 status |
| 0x00D0             | EMC_STS0_HCH4 | EMC AHB channel 4 status |
| 0x00D4             | EMC_STS0_HCH5 | EMC AHB channel 5 status |
| 0x00D8             | EMC_STS0_HCH6 | EMC AHB channel 6 status |
| 0x00DC             | EMC_STS0_HCH7 | EMC AHB channel 7 status |
| 0x00E0             | EMC_STS0_HCH8 | EMC AHB channel 8 status |
| 0x00E4 -<br>0x00FC | Reserved      |                          |
|                    |               | \ (7A)                   |

# **Delay Line Control Registers:**

| Offset<br>Address | Name                                                               | Description                                           |  |  |  |  |  |
|-------------------|--------------------------------------------------------------------|-------------------------------------------------------|--|--|--|--|--|
| 0x0100            | EMC_DMEM_DL0                                                       | EMC delay line control register for clkdmem_out_dl    |  |  |  |  |  |
| 0x0104            | EMC_DMEM_DL1                                                       | EMC delay line control register for dqs_ie_dl         |  |  |  |  |  |
| 0x0108            | EMC_DMEM_DL2                                                       | EMC delay line control register for dqs_out_dl        |  |  |  |  |  |
| 0x010C            | EMC_DMEM_DL3                                                       | EMC delay line control register for clkwr_dl          |  |  |  |  |  |
| 0x0110            | EMC_DMEM_DL4                                                       | EMC delay line control register for dqs_gate_pre_dl_0 |  |  |  |  |  |
| 0x0114            | EMC_DMEM_DL5 EMC delay line control register for dqs_gate_pre_dl_1 |                                                       |  |  |  |  |  |
| 0x0118            | EMC_DMEM_DL6                                                       | EMC delay line control register for dqs_gate_pre_dl_2 |  |  |  |  |  |
| 0x011C            | EMC_DMEM_DL7                                                       | EMC delay line control register for dqs_gate_pre_dl_3 |  |  |  |  |  |
| 0x0120            | EMC_DMEM_DL8                                                       | EMC delay line control register for dqs_gate_pst_dl_0 |  |  |  |  |  |
| 0x0124            | EMC_DMEM_DL9                                                       | EMC delay line control register for dqs_gate_pst_dl_1 |  |  |  |  |  |
| 0x0128            | EMC_DMEM_DL10                                                      | EMC delay line control register for dqs_gate_pst_dl_2 |  |  |  |  |  |
| 0x012C            | EMC_DMEM_DL11                                                      | EMC delay line control register for dqs_gate_pst_dl_3 |  |  |  |  |  |
| 0x0130            | EMC_DMEM_DL12                                                      | EMC delay line control register for dqs_in_pos_dl_0   |  |  |  |  |  |
| 0x0134            | EMC_DMEM_DL13                                                      | EMC delay line control register for dqs_in_pos_dl_1   |  |  |  |  |  |



| 0x0138             | EMC_DMEM_DL14 | EMC delay line control register for |
|--------------------|---------------|-------------------------------------|
|                    |               | dqs_in_pos_dl_2                     |
| 0x013C             | EMC_DMEM_DL15 | EMC delay line control register for |
|                    |               | dqs_in_pos_dl_3                     |
| 0x0140             | EMC_DMEM_DL16 | EMC delay line control register for |
|                    |               | dqs_in_neg_dl_0                     |
| 0x0144             | EMC_DMEM_DL17 | EMC delay line control register for |
|                    |               | dqs_in_neg_dl_1                     |
| 0x0148             | EMC_DMEM_DL18 | EMC delay line control register for |
|                    |               | dqs_in_neg_dl_2                     |
| 0x014C             | EMC_DMEM_DL19 | EMC delay line control register for |
|                    |               | dqs_in_neg_dl_3                     |
| 0x0150 -<br>0x016C | Reserved      |                                     |
| 0x0170             | EMC_CFG0_DLL  | EMC DLL configuration register      |
| 0x0174             | EMC_STS0_DLL  | EMC DLL status                      |
| 0x0178 -<br>0x017C | Reserved      |                                     |
|                    |               |                                     |

# **DMEM Control Registers:**

| Offset<br>Address  | Name      | Description                |
|--------------------|-----------|----------------------------|
| 0x0180             | EMC_DCFG0 | EMC DMEM control registers |
| 0x0184             | EMC_DCFG1 | EMC DMEM control registers |
| 0x0188             | EMC_DCFG2 | EMC DMEM control registers |
| 0x018C             | EMC_DCFG3 | EMC DMEM control registers |
| 0x0190             | EMC_DCFG4 | EMC DMEM control registers |
| 0x0194             | EMC_DCFG5 | EMC DMEM control registers |
| 0x0198             | EMC_DCFG6 | EMC DMEM control registers |
| 0x019C             | EMC_DCFG7 | EMC DMEM control registers |
| 0x01A0             | EMC_DCFG8 | EMC DMEM control registers |
| 0x01A4 –<br>0x01FC | Reserved  |                            |
|                    |           |                            |

# 5.2.5.2 Register Descriptions

# 5.2.5.2.1 EMC\_CFG0



Description: EMC general control register

This register is EMC general control register, shared by all external memories.

| 0x0000 |               |               | EMC                               | gener                 | al con                      | trol reg                     | gister | (Reset | set 0x00000C45) |                     |                  |        |       |     | EMC_0     | CFG0 |
|--------|---------------|---------------|-----------------------------------|-----------------------|-----------------------------|------------------------------|--------|--------|-----------------|---------------------|------------------|--------|-------|-----|-----------|------|
| Bit    | 31            | 30            | 29                                | 28                    | 27                          | 26                           | 25     | 24     | 23              | 22                  | 21               | 20     | 19    | 18  | 17        | 16   |
| Name   | rf_lo<br>ck_b | rf_lo<br>ck_a | Reserved                          |                       |                             |                              |        |        |                 | rf_req_timeout_unit |                  |        |       |     |           | X    |
| Туре   | RW            | RW            |                                   |                       | R                           | 0                            |        |        |                 |                     |                  | R'     | W     |     |           |      |
| 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   | Rese          | erved         | rf_re<br>q_ti<br>meo<br>ut_e<br>n | rf_dv<br>c_en<br>dian | rf_a<br>uto_<br>gate<br>_en | rf_a<br>uto_<br>slee<br>p_en | Rese   | erved  |                 | d_queu<br>node      | Res<br>erve<br>d | rf_cs_ | _mode | rf_ | cs_positi | on   |
| Type   | R             | 0             | RW                                | RW                    | RW                          | RW                           | R      | 0      | R'              | w                   | RO               | R      | W     |     | RW        |      |
| Reset  | 0             | 0             | 0                                 | 0                     | 1                           | 1                            | 0      | 0      | 0               | 1                   | 0                | 0      | 0     | 1   | 1         | 0    |

| Field Name              | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                          |
|-------------------------|---------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rf_lock_b               | [31]    | R/W  | 1'h0           | This field provides a semaphore for two independent CPUs.                                                                                                                                            |
|                         |         |      |                | Semaphore signal with rf_lock_a                                                                                                                                                                      |
| rf_lock_a               | [30]    | R/W  | 1'h0           | This field provides a semaphore for two independent CPUs.                                                                                                                                            |
|                         |         |      |                | Semaphore signal with rf_lock_b                                                                                                                                                                      |
|                         | [29:24] | RO   | 0              | Reserved                                                                                                                                                                                             |
| rf_req_timeout_<br>unit | [23:16] | R/W  | 8'h0           |                                                                                                                                                                                                      |
|                         | [15:14] | RO   | 0              | Reserved                                                                                                                                                                                             |
| rf_req_timeout_<br>en   | [13]    | R/W  | 1'h0           | This field enables request timeout functionality                                                                                                                                                     |
|                         |         |      |                | 0: request timeout is disabled                                                                                                                                                                       |
| (2)                     |         |      |                | 1: request timeout is enabled                                                                                                                                                                        |
| rf_dvc_endian           | [12]    | R/W  | 1'h0           | This field indicates external memory data endian format.                                                                                                                                             |
|                         |         |      |                | 0: little-endian                                                                                                                                                                                     |
|                         |         |      |                | 1: big-endian                                                                                                                                                                                        |
|                         |         |      |                | This bit is only used to select external memory organizing format, not indicates bus endian and software endian. That is, software can execute correctly even if this bit is different with software |



| Field Name            | Bit   | Туре | Reset<br>Value | Description                                                                         |
|-----------------------|-------|------|----------------|-------------------------------------------------------------------------------------|
|                       |       |      |                | system endian.                                                                      |
|                       |       |      |                | This bit is recommended to be configured as the same as ARM system endian.          |
| rf_auto_gate_e<br>n   | [11]  | R/W  | 1'h1           | This field enables auto-gate mode for power saving.                                 |
|                       |       |      |                | 0: auto-gate mode is disabled                                                       |
|                       |       |      |                | 1: auto-gate mode is enabled                                                        |
|                       |       |      |                | This bit is recommended to be set.                                                  |
| rf_auto_sleep_<br>en  | [10]  | R/W  | 1'h1           | This field enables auto-sleep mode                                                  |
|                       |       |      |                | 0: automatically sleep mode is disabled, and software                               |
|                       |       |      |                | should make EMC sleep and wakeup manually                                           |
|                       |       |      |                | 1: automatically sleep mode is enabled, and EMC can enter sleep by itself           |
|                       |       |      |                | This his is an analysis of                                                          |
|                       | 10.01 | D.O. |                | This bit is recommended to be set.                                                  |
|                       | [9:8] | RO   | 0              | Reserved                                                                            |
| rf_cmd_queue_<br>mode | [7:6] | R/W  | 2'h1           | This field select command queue operating mode.                                     |
|                       |       |      |                | 0: 2-stage device burst                                                             |
|                       |       |      |                | 1: 2-stage device burst and 1-stage channel burst                                   |
|                       |       |      |                | 2: 2-stage device burst and 2-stage channel burst                                   |
|                       |       |      |                | 3: reserved                                                                         |
|                       |       |      |                | In normal cases, mode-1 is better to balance performance and delay.                 |
|                       | [5]   | RO   | 0              | Reserved                                                                            |
| rf_cs_mode            | [4:3] | R/W  | 2'h0           | This field selects the modes to merge CS to enlarge one CS space.                   |
| 0                     |       |      |                | Bit[0]: if set, the address space of CS0 and CS1 are merged to CS0                  |
| 0,0                   |       |      |                | Bit[1]: if set, the address space of CS0 and CS1 are merged to CS1                  |
|                       |       |      |                |                                                                                     |
| rf_cs_position        | [2:0] | R/W  | 3'h5           | This field indicates one software address range is mapped to which external memory. |
|                       |       |      |                | 0: CS mapping to HADDR[22]                                                          |
|                       |       |      |                | 1: CS mapping to HADDR[23]                                                          |
|                       |       |      |                | 2: CS mapping to HADDR[24]                                                          |
|                       |       |      |                | 3: CS mapping to HADDR[25]                                                          |
|                       |       |      |                | 4: CS mapping to HADDR[26]                                                          |



| Field Name | Bit | Туре | Reset Value Description |                                  |  |  |  |  |  |
|------------|-----|------|-------------------------|----------------------------------|--|--|--|--|--|
|            |     |      |                         | 5: CS mapping to HADDR[27]       |  |  |  |  |  |
|            |     |      |                         | 6: CS mapping to HADDR[28]       |  |  |  |  |  |
|            |     |      |                         | 7: CS mapping to HADDR[29]       |  |  |  |  |  |
|            |     |      |                         | Note: HADDR is software address. |  |  |  |  |  |
|            |     |      |                         |                                  |  |  |  |  |  |

## 5.2.5.2.2 EMC\_CFG1

Description: EMC PHY control register

This register is EMC PHY control register, shared by all external memories.

| 0x0004 |       |       | EMC PHY control register (Reset 0x00000000) |          |    |    |   |                      |                                     |                                     |                                    |                                   |                                           | EMC_0                                      | CFG1                                        |                            |
|--------|-------|-------|---------------------------------------------|----------|----|----|---|----------------------|-------------------------------------|-------------------------------------|------------------------------------|-----------------------------------|-------------------------------------------|--------------------------------------------|---------------------------------------------|----------------------------|
| Bit    | 31    | 30    | 29 28 27 26 25 24 23 22 21 20               |          |    |    |   |                      |                                     |                                     |                                    |                                   | 19                                        | 18                                         | 17                                          | 16                         |
| Name   |       |       |                                             | Reserved |    |    |   |                      |                                     |                                     |                                    |                                   |                                           |                                            |                                             |                            |
| Туре   |       |       |                                             |          |    |    |   | R                    | .0                                  |                                     |                                    |                                   |                                           |                                            |                                             |                            |
| 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   | rf_ck | e_sel | Reserved                                    |          |    |    |   | _dqs_<br>pop_se<br>I | rf_p<br>hy_d<br>qs_g<br>ate_<br>sel | rf_p<br>hy_d<br>ata_<br>out_<br>sel | rf_p<br>hy_d<br>qs_o<br>ut_s<br>el | rf_p<br>hy_d<br>qs_i<br>e_se<br>I | rf_p<br>hy_c<br>lkdm<br>em_i<br>n_se<br>l | rf_p<br>hy_c<br>lkdm<br>em_<br>out_<br>sel | rf_p<br>hy_c<br>lkdm<br>em_l<br>oop_<br>sel | rf_d<br>dr_<br>mod<br>e_en |
| Туре   | R     | W     |                                             | R        | 0  |    | R | W                    | 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                          |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                        |
|------------|---------|------|----------------|--------------------------------------------------------------------|
|            | [31:16] | RO   | 0              | Reserved                                                           |
| rf_cke_sel | [15:14] | R/W  | 2'h0           | This field selects DMEM CKE PAD output mode.                       |
|            |         |      |                | 0: DMEM CKE output mode 0 (normal mode for only CS[0] used)        |
|            |         |      |                | CKE mapping for CS[0], mode 0 is used when only one DMEM on CS 0.  |
|            |         |      |                | 1: DMEM CKE output mode 1 (special mode for CS[1] used)            |
|            |         |      |                | CKE mapping for CS[1], mode 1 is used when only one DMEM on CS[1]. |
|            |         |      |                | 2: DMEM CKE output mode 2 (special mode for CS[1] used)            |
|            |         |      |                | CKE mapping for all CSs, mode 2 is used when more                  |



| Bit     | Туре                    | Reset<br>Value                         | Description                                                                                                                                                                          |
|---------|-------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                         |                                        | than one DMEM on bus.                                                                                                                                                                |
|         |                         |                                        | 3: reserved                                                                                                                                                                          |
|         |                         |                                        | In normal cases, only one CKE is output to save PAD number, even if more than one DMEM are connected on bus. All DMEM share one CKE, so above options are provided for this sharing. |
| [13:10] | RO                      | 0                                      | Reserved                                                                                                                                                                             |
| [9:8]   | R/W                     | 2'h0                                   | This filed select DMEM DDR DQS gate signal loop back mode                                                                                                                            |
|         |                         |                                        | 0: DMEM DQS gate has only delay line delay                                                                                                                                           |
|         |                         |                                        | 1: DMEM DQS gate has delay line delay and loop back delay                                                                                                                            |
|         |                         |                                        | 2, 3: DMEM DQS gate has only loop back delay                                                                                                                                         |
| [7]     | R/W                     | 1'h0                                   | This filed select DMEM DDR DQS gate signal mode.                                                                                                                                     |
|         |                         |                                        | 0: DMEM DQS gate generating mode 0 (normal mode)                                                                                                                                     |
|         |                         |                                        | 1: DMEM DQS gate generating mode 1 (debug mode)                                                                                                                                      |
|         |                         |                                        | In normal cases, if the maximum frequency targets to about 200MHz or above, mode-0 is recommended to cover MIN tDQSCK and MAX tDQSCK.                                                |
|         |                         |                                        | If the maximum frequency is less than 160MHz, both modes works.                                                                                                                      |
| [6]     | R/W                     | 1'h0                                   | This filed select DMEM data output mode.                                                                                                                                             |
|         |                         |                                        | 0: DMEM data directly DFF output                                                                                                                                                     |
|         |                         |                                        | 1: DMEM data delay line controlled output                                                                                                                                            |
|         |                         |                                        | In normal cases, mode-0 is recommended for SDR,                                                                                                                                      |
|         |                         |                                        | and mode-1 is recommended for DDR.                                                                                                                                                   |
| [5]     | R/W                     | 1'h0                                   | This field selects DMEM DDR DQS output mode.                                                                                                                                         |
|         |                         |                                        | 0: DMEM DQS[3:0] output is DFF output.                                                                                                                                               |
|         |                         |                                        | 1: DMEM DQS[3:0] output is delay line output                                                                                                                                         |
| [4]     | R/W                     | 1'h0                                   | This field selects DMEM DDR DQS PAD IE mode.                                                                                                                                         |
|         |                         |                                        | 0: DMEM EMDQS[3:0] pad input enable signal is from DFF output.                                                                                                                       |
|         |                         |                                        | 1: DMEM EMDQS[3:0] pad input enable signal is from delay line output                                                                                                                 |
| [3]     | R/W                     | 1'h0                                   | This field selects DMEM sample clock mode.                                                                                                                                           |
|         | [13:10]<br>[9:8]<br>[7] | [13:10] RO [9:8] R/W  [6] R/W  [5] R/W | [13:10] RO 0 [9:8] R/W 2'h0  [6] R/W 1'h0  [5] R/W 1'h0                                                                                                                              |



| Field Name                  | Bit | Туре | Reset<br>Value | Description                                                                                 |
|-----------------------------|-----|------|----------------|---------------------------------------------------------------------------------------------|
|                             |     |      |                | 0: DMEM sample clock is from internal logic                                                 |
|                             |     |      |                | 1: DMEM sample clock is from out-of-chip (EMDQS[3:0] pad input)                             |
|                             |     |      |                | This field is only used by SDR to generate sample clock. For DDR, sample clock is from DQS. |
| rf_phy_clkdme<br>m_out_sel  | [2] | R/W  | 1'h0           | This field selects DMEM output clock mode.                                                  |
|                             |     |      |                | 0: DMEM CK/CK# output is DFF output                                                         |
|                             |     |      |                | 1: DMEM CK/CK# output is delay line output                                                  |
|                             |     |      |                | This field is used for both SDR and DDR, and mode-0 is recommended for them.                |
| rf_phy_clkdme<br>m_loop_sel | [1] | R/W  | 1'h0           | This field selects DMEM clock loopback mode.                                                |
|                             |     |      |                | 0: DMEM READ strobe clock loopback disable                                                  |
|                             |     |      |                | 1: DMEM READ strobe clock loopback enable                                                   |
|                             |     |      |                | This field is only used for SDR                                                             |
| rf_ddr_mode_e<br>n          | [0] | R/W  | 1'h0           | This field enables DDR mode for DMEM.                                                       |
|                             |     |      |                | 0: SDR-SDRAM mode for DMEM                                                                  |
|                             |     |      |                | 1: DDR-SDRAM mode for DMEM                                                                  |
|                             |     |      | A              |                                                                                             |

## 5.2.5.2.3 EMC\_CFG0\_CSx

Description: EMC CSx device configuration register

This register is used to configure device information on CSx for DMEM.

Each CS has an independent registers.



| 0x0010<br>0x0014 |    |    |          | EMC CS0 device configuration register (Reset 0x00000113)  EMC_CFG0_CS0  EMC CS1 device configuration register (Reset 0x00000113)  EMC_CFG0_CS1 |    |        |               |        |                  |        |           |        |      |       |                                    |                               |
|------------------|----|----|----------|------------------------------------------------------------------------------------------------------------------------------------------------|----|--------|---------------|--------|------------------|--------|-----------|--------|------|-------|------------------------------------|-------------------------------|
| Bit              | 31 | 30 | 29       | 29 28 27 26 25 24 23 22 21 20                                                                                                                  |    |        |               |        |                  |        |           |        | 19   | 18    | 17                                 | 16                            |
| Name             |    |    | Reserved |                                                                                                                                                |    |        |               |        |                  |        |           |        |      |       |                                    |                               |
| Туре             |    |    |          | RO                                                                                                                                             |    |        |               |        |                  |        |           |        |      |       |                                    |                               |
| 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             |    |    | Reserved | i                                                                                                                                              |    | rf_dbu | rst_wlen<br>x | gth_cs | Res<br>erve<br>d | rf_dbu | rst_rleng | th_csx | Rese | erved | rf_h<br>burst<br>_we<br>n_cs<br>_x | rf_h<br>burst<br>_ren<br>_csx |
| Туре             |    |    | RO       | RW                                                                                                                                             |    |        |               |        | RO               | RW     |           | R      | .0   | RW    | RW                                 |                               |
| Reset            | 0  | 0  | 0        | 0                                                                                                                                              | 0  | 0      | 0             | 1      | 0                | 0      | 0         | 1      | 0    | 0     | 1                                  | 1                             |

| Field Name                | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                   |
|---------------------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | [31:11] | RO   | 0              | Reserved                                                                                                                                                                                                                                      |
| rf_dburst_wlen<br>gth_csx | [10:8]  | R/W  | 3'h1           | This field indicates external device writing burst length  0: burst of 1 32-bit (NOT supported on 32-bit DDR)  1: burst of 2 32-bit  2: burst of 4 32-bit  3: burst of 8 32-bit  4: burst of 16 32-bit  5: reserved  6: reserved  7: reserved |
|                           |         |      |                | For DMEM, this field indicates device burst length for writing operation.                                                                                                                                                                     |
|                           | [7]     | RO   | 0              | Reserved                                                                                                                                                                                                                                      |
| rf_dburst_rlengt<br>h_csx | [6:4]   | R/W  | 3'h1           | This field indicates external device reading burst length  0: burst of 1 32-bit (NOT supported on 32-bit DDR)                                                                                                                                 |
|                           |         |      |                | 1: burst of 2 32-bit                                                                                                                                                                                                                          |
|                           |         |      |                | 2: burst of 4 32-bit                                                                                                                                                                                                                          |
|                           |         |      |                | 3: burst of 8 32-bit<br>4: burst of 16 32-bit                                                                                                                                                                                                 |
|                           |         |      |                | 5: reserved                                                                                                                                                                                                                                   |
|                           |         |      |                | 6: reserved                                                                                                                                                                                                                                   |
| •                         |         |      |                | 7: reserved                                                                                                                                                                                                                                   |
|                           |         |      |                | For DMEM, this field indicates device burst length for reading operation.                                                                                                                                                                     |



| Field Name            | Bit   | Туре | Reset<br>Value | Description                                                                                                              |
|-----------------------|-------|------|----------------|--------------------------------------------------------------------------------------------------------------------------|
|                       | [3:2] | RO   | 0              | Reserved                                                                                                                 |
| rf_hburst_wen_<br>csx | [1]   | R/W  | 1'h1           | This filed indicates AHB write operations mode                                                                           |
|                       |       |      |                | 0: one AHB burst is divided into several single accesses                                                                 |
|                       |       |      |                | 1: burst access                                                                                                          |
|                       |       |      |                | This bit is cleared only if SW issues commands on pSRAM or NOR-Flash. Otherwise, it should be set to improve efficiency. |
| rf_hburst_ren_c<br>sx | [0]   | R/W  | 1'h1           | This filed indicates AHB read operations mode                                                                            |
|                       |       |      |                | 0: one AHB burst is divided into several single accesses                                                                 |
|                       |       |      |                | 1: burst access                                                                                                          |
|                       |       |      |                | This bit is cleared only if SW issues commands on pSRAM or NOR-Flash. Otherwise, it should be set to improve efficiency. |
|                       |       |      |                |                                                                                                                          |

## 5.2.5.2.4 EMC\_CFG0\_ACHx

Description: EMC AXI channel x configuration register

This register is used to configure AXI channel x information.

Each AXI channel has an independent registers.

| 0x0020<br>0x0028 |                                              | <b>(</b> |      |            |          | -       | tion register (Reset 0x0000007C)<br>tion register (Reset 0x0000007C) |    |                                      |                      |    |               | EMC_CFG0_ACH0<br>EMC_CFG0_ACH1 |                 |         |        |
|------------------|----------------------------------------------|----------|------|------------|----------|---------|----------------------------------------------------------------------|----|--------------------------------------|----------------------|----|---------------|--------------------------------|-----------------|---------|--------|
| Bit              | 31                                           | 30       | 29   | 28         | 27       | 26      | 25                                                                   | 24 | 23                                   | 22                   | 21 | 20            | 19                             | 18              | 17      | 16     |
| Name             |                                              |          | Rese | erved      |          |         | rf_address_offset_chx                                                |    |                                      |                      |    |               |                                |                 |         |        |
| Туре             |                                              | RO       |      |            |          |         |                                                                      | 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             | rf_re<br>q_ti<br>meo<br>ut_e<br>n_wr<br>_chx |          | ı    | rf_req_tir | meout_th | r_wr_ch | Κ                                                                    |    | rf_a<br>uto_<br>slee<br>p_en<br>_chx | rf_ch<br>_en_<br>chx |    | ian_sw<br>chx |                                | _level_<br>_chx | rf_pri_ | wr_chx |
| Туре             | RW                                           |          |      |            | RW       |         | RW RW RW                                                             |    |                                      |                      |    | R             | RW I                           |                 | W       |        |
| Reset            | 0                                            | 0        | 0    | 0          | 0        | 0       | 0                                                                    | 0  | 0                                    | 1                    | 1  | 1             | 1                              | 1               | 0       | 0      |

| Field Name | Bit | Туре | Reset<br>Value | Description |
|------------|-----|------|----------------|-------------|
|------------|-----|------|----------------|-------------|



| Field Name                    | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                     |
|-------------------------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | [31:11] | RO   | 0              | Reserved                                                                                                                                                                                                                                                        |
| rf_address_offs<br>et_chx     | [25:16] | R/W  | 10'h0          |                                                                                                                                                                                                                                                                 |
| rf_req_timeout_<br>en_wr_chx  | [15]    | R/W  | 1'h0           | This field enables request timeout function for each axi write channel                                                                                                                                                                                          |
| rf_req_timeout_<br>thr_wr_chx | [14:8]  | R/W  | 7'0            | This field is used to set request timeout threshold value for each axi write channel.                                                                                                                                                                           |
| rf_auto_sleep_<br>en_chx      | [7]     | R/W  | 1'h0           | This field enables auto-sleep mode for each channel                                                                                                                                                                                                             |
|                               |         |      |                | 0: automatically sleep mode is disabled, and software should make the channel sleep and wakeup manually     1: automatically sleep mode is enabled, and the                                                                                                     |
|                               |         |      |                | channel can enter sleep by itself                                                                                                                                                                                                                               |
|                               |         |      |                | This bit is recommended to be set.                                                                                                                                                                                                                              |
| of als an also                | [6]     | DAM  | 1'h1           |                                                                                                                                                                                                                                                                 |
| rf_ch_en_chx                  | [6]     | R/W  | INI            | This field enables the channel.                                                                                                                                                                                                                                 |
|                               |         |      |                | 0: the channel is disabled                                                                                                                                                                                                                                      |
|                               |         |      |                | 1: the channel is enabled                                                                                                                                                                                                                                       |
| rf_endian_swt_<br>chx         | [5:4]   | R/W  | 2'h3           | This field selects switching mode for data endian                                                                                                                                                                                                               |
|                               |         |      |                | Endian switching mode                                                                                                                                                                                                                                           |
|                               |         |      |                | 0: byte switch                                                                                                                                                                                                                                                  |
|                               |         |      |                | 1: half switch                                                                                                                                                                                                                                                  |
|                               |         |      |                | 2: word switch (only for 64-bit AHB interface)                                                                                                                                                                                                                  |
|                               |         |      |                | 3: no switch                                                                                                                                                                                                                                                    |
|                               | */      |      | <b>J</b>       | Data endian switching function is provided for software in different endian domain. Data endian is different with AHB protocol endian, AHB endian is handled by hardware automatically. But data endian should be configured according to software requirement. |
| rf_req_level_wr<br>_chx       | [3:2]   | R/W  | 2'h3           | This field indicates the write command request level in AXI channel. The higher the level, the better the performance of AXI channel.                                                                                                                           |
|                               |         |      |                | 0 is the lowest priority and 3 is the highest priority                                                                                                                                                                                                          |
| rf_pri_wr_chx                 | [1:0]   | R/W  | 2'h0           | This field indicates write channel priority.                                                                                                                                                                                                                    |
|                               |         |      |                | 0 is the lowest priority and 3 is the highest priority                                                                                                                                                                                                          |
|                               |         |      |                |                                                                                                                                                                                                                                                                 |

## 5.2.5.2.5 EMC\_CFG1\_ACHx



Description: EMC AXI channel x configuration register

This register is used to configure AXI channel x information.

Each AXI channel has an independent registers.

| 0x0024<br>0x002C |                                              |    |                              |            |          | nfigura<br>nfigura | -  | EMC_CFG1_ACI |                  |                                   |                         |                             |    |                |         |        |
|------------------|----------------------------------------------|----|------------------------------|------------|----------|--------------------|----|--------------|------------------|-----------------------------------|-------------------------|-----------------------------|----|----------------|---------|--------|
| Bit              | 31                                           | 30 | 29 28 27 26 25 24 23 22 21 2 |            |          |                    |    |              |                  |                                   |                         |                             | 19 | 18             | 17      | 16     |
| Name             |                                              |    |                              | Reserved   |          |                    |    |              |                  |                                   |                         |                             |    |                |         |        |
| Туре             |                                              |    |                              |            |          |                    |    | R            | .0               |                                   |                         |                             |    |                |         |        |
| 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             | rf_re<br>q_ti<br>meo<br>ut_e<br>n_rd<br>_chx |    | !                            | rf_req_tir | meout_th | nr_rd_chx          | ζ. |              | Res<br>erve<br>d | rf_br<br>esp_<br>mod<br>e_ch<br>x | rf_fif<br>o_clr<br>_chx | rf_sy<br>nc_s<br>el_c<br>hx |    | _level_<br>chx | rf_pri_ | rd_chx |
| Type             | RW                                           | ·  |                              |            | RW       |                    |    |              | RO               | RW                                | RW                      | RW                          | R  | W              | R       | W      |
| Reset            | 0                                            | 0  | 0                            | 0          | 0        | 0                  | 0  | 0            | 0                | 0                                 | 0                       | 0                           | 1  | 1              | 0       | 0      |

| Field Name                    | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                               |
|-------------------------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | [31:16] | RO   | 0              | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| rf_req_timeout_<br>en_rd_chx  | [15]    | R/W  | 1'h0           | This field enables request timeout function for each axi read channel                                                                                                                                                                                                                                                                                     |
| rf_req_timeout_<br>thr_rd_chx | [14:8]  | R/W  | 7'h0           | This field is used to set request timeout threshold value for each axi read channel.                                                                                                                                                                                                                                                                      |
|                               | [7]     | RO   | 0              | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| rf_bresp_mode<br>_ch          | [6]     | R/W  | 0              | This filed indicates which mode is selected on issuing write response channel signals.  0: After WLAST signal  1: After the time data really write to DRAM                                                                                                                                                                                                |
| rf_fifo_clr_ch                | [5]     | R/W  | 0              | This field is used to clear all FIFOs within this channel, when write 1 to this bit                                                                                                                                                                                                                                                                       |
| rf_sync_sel_ch<br>x           | [4]     | R/W  | 1'h0           | This field indicates the AXI clock for this channel is asynchronous with EMC clock or synchronous with EMC clock.  0: Asynchronous  1: Synchronous  All channels can be configured to asynchronous mode, but only some of them can be configured to synchronous mode. Please refer to chip architecture document and clock document for synchronous clock |
|                               |         |      |                | group information.                                                                                                                                                                                                                                                                                                                                        |
| rf_req_level_rd               | [3:2]   | R/W  | 2'h3           | This field indicates the read command request level in                                                                                                                                                                                                                                                                                                    |



| Field Name    | Bit   | Туре | Reset<br>Value | Description                                                                   |
|---------------|-------|------|----------------|-------------------------------------------------------------------------------|
| _chx          |       |      |                | AXI channel. The higher the level, the better the performance of AXI channel. |
| rf_pri_rd_chx | [1:0] | R/W  | 2'h0           | This field indicates read channel priority.                                   |
|               |       |      |                | 0 is the lowest priority and 3 is the highest priority                        |

## 5.2.5.2.6 EMC\_CFG0\_HCHx

Description: EMC AHB channel x configuration register

This register is used to configure AHB channel x information.

Each AHB channel has an independent registers.

| 0x0030 |                              |                                  |                             |                                                                    |                  | onfigur                                                              |         | •       | •      |        |       | •   |       | EMC_C                                | _                    |      |
|--------|------------------------------|----------------------------------|-----------------------------|--------------------------------------------------------------------|------------------|----------------------------------------------------------------------|---------|---------|--------|--------|-------|-----|-------|--------------------------------------|----------------------|------|
| 0x0038 |                              |                                  | EMC                         | AHB (                                                              | СНЗ сс           | onfigur                                                              | ation i | registe | r (Res | et 0x0 | 001C3 | 1C) |       | EMC_C                                |                      |      |
| 0x0040 |                              |                                  | EMC                         | EMC AHB CH4 configuration register (Reset 0x0001C31C) EMC_CFG0     |                  |                                                                      |         |         |        |        |       |     |       |                                      |                      | HCH4 |
| 0x0048 |                              |                                  | EMC                         | EMC AHB CH5 configuration register (Reset 0x0001C31C) EMC_CFG0_HCH |                  |                                                                      |         |         |        |        |       |     |       |                                      | HCH5                 |      |
| 0x0050 |                              |                                  | EMC                         | AHB (                                                              | СН6 сс           | onfigur                                                              | ation i | registe | r (Res | et 0x0 | 001C3 | 1C) | E     | EMC_C                                | FG0_I                | HCH6 |
| 0x0058 |                              |                                  | EMC                         | AHB (                                                              | СН7 сс           | onfigur                                                              | ation i | registe | r (Res | et 0x0 | 001C3 | 1C) | E     | EMC_C                                | FG0_I                | HCH7 |
| 0x0060 |                              |                                  | EMC                         | AHB (                                                              | СН8 сс           | onfigur                                                              | ation i | registe | r (Res | et 0x0 | 001C3 | 1C) | E     | EMC_C                                | FG0_I                | HCH8 |
| Bit    | 31                           | 30                               | 29                          | 9 28 27 26 25 24 23 22 21 20 19 18                                 |                  |                                                                      |         |         |        |        |       |     | 17    | 16                                   |                      |      |
| Name   |                              |                                  |                             | Reserved                                                           |                  |                                                                      |         |         |        |        |       |     |       | rf_a<br>uto_<br>slee<br>p_en<br>_chx | rf_ch<br>_en_<br>chx |      |
| Туре   |                              |                                  |                             | RO                                                                 |                  |                                                                      |         |         |        |        |       |     |       | RW                                   | RW                   |      |
| Reset  | 0                            | 0                                | 0                           | 0                                                                  | 0                | 0                                                                    | 0       | 0       | 0      | 0      | 0     | 0   | 0     | 0                                    | 0                    | 1    |
| Bit    | 15                           | 14                               | 13                          | 12                                                                 | 11               | 10                                                                   | 9       | 8       | 7      | 6      | 5     | 4   | 3     | 2                                    | 1                    | 0    |
| Name   | rf_rb<br>uf_m<br>ode_<br>chx | rf_w<br>buf_<br>mod<br>e_ch<br>x | rf_sy<br>nc_s<br>el_c<br>hx | rf_h burst _tim eout _en_ chx                                      | Res<br>erve<br>d | I it hourst wength inc I is I it hourst rength incr I it endian sw I |         |         |        |        |       |     | rf_pr | i_chx                                |                      |      |
| Туре   | RW                           | RW                               | RW                          | RW                                                                 | RO               |                                                                      | RW      |         | RO     | RW     |       |     | RW    |                                      | RW                   |      |
| Reset  | 1                            | 1                                | 0                           | 0                                                                  | 0                | 0                                                                    | 1       | 1       | 0      | 0      | 0     | 1   | 1     | 1                                    | 0                    | 0    |

| Field Name               | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                 |
|--------------------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | [31:18] | RO   | 0              | Reserved                                                                                                                                                    |
| rf_auto_sleep_<br>en_chx | [17]    | R/W  | 1'h0           | This field enables auto-sleep mode for each channel                                                                                                         |
|                          |         |      |                | 0: automatically sleep mode is disabled, and software should make the channel sleep and wakeup manually     1: automatically sleep mode is enabled, and the |



| Field Name                   | Bit  | Туре | Reset<br>Value | Description                                                                                                                                                                                                              |
|------------------------------|------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |      |      |                | channel can enter sleep by itself                                                                                                                                                                                        |
|                              |      |      |                | This bit is recommended to be set.                                                                                                                                                                                       |
| rf_ch_en_chx                 | [16] | R/W  | 1'h1           | This field enables the channel.                                                                                                                                                                                          |
|                              |      |      |                | 0: the channel is disabled 1: the channel is enabled                                                                                                                                                                     |
| rf_rbuf_mode_c<br>hx         | [15] | R/W  | 1'h1           | This filed indicates which operation mode is selected on read bursts.                                                                                                                                                    |
|                              |      |      |                | Single operation mode     Pipeline operation mode                                                                                                                                                                        |
|                              |      |      |                | Pipeline operation can achieve better write performance, so this mode is preferred in normal case.                                                                                                                       |
| rf_wbuf_mode_<br>chx         | [14] | R/W  | 1'h1           | This filed indicates single-buffer or double-buffer is used on write bursts, and also indicates which operation mode is selected                                                                                         |
|                              |      |      |                | 0: Single buffer and single operation mode                                                                                                                                                                               |
|                              |      |      |                | 1: Double buffer and pipeline operation mode                                                                                                                                                                             |
|                              |      |      |                | Double buffer and pipeline mode can achieve better write performance, so this mode is preferred in normal case, especially for mass data transfers.                                                                      |
|                              |      |      | 0              | Single buffer is used in some special cases, mainly for CPU, because:                                                                                                                                                    |
|                              |      |      |                | - double-buffer may lead to larger latency between CPU transfer done and external memory transfer done                                                                                                                   |
|                              | 71   |      |                | - double-buffer may lead to larger wait time for consecutive read operation.                                                                                                                                             |
| rf_sync_sel_ch<br>x          | [13] | R/W  | 1'h0           | This field indicates the AHB clock for this channel is asynchronous with EMC clock or synchronous with EMC clock.                                                                                                        |
| 0,0                          | •    |      |                | 0: Asynchronous 1: Synchronous                                                                                                                                                                                           |
|                              |      |      |                | All channels can be configured to asynchronous mode, but only some of them can be configured to synchronous mode. Please refer to chip architecture document and clock document for synchronous clock group information. |
| rf_hburst_timeo<br>ut_en_chx | [12] | R/W  | 1'h0           | This field enable a timeout engine for debugging.                                                                                                                                                                        |
|                              |      |      |                | This timeout engine is only used for AHB read operations. And in normal using, this be should be kept low.                                                                                                               |



| Field Name                     | Bit    | Туре  | Reset<br>Value | Description                                                                                                                                            |
|--------------------------------|--------|-------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | [11]   | RO    | 0              | Reserved                                                                                                                                               |
| rf_hburst_wlen<br>gth_incr_chx | [10:8] | R/W   | 3'h3           | This filed indicates how to divide AHB INCR writing burst.                                                                                             |
|                                |        |       |                | If a AHB write burst is INCR and HLENGTH is 0, the AHB burst is divided into several sub-bursts, and the sub-burst length is defined by this register. |
|                                |        |       |                | 0: 2 32-bit                                                                                                                                            |
|                                |        |       |                | 1: 4 32-bit                                                                                                                                            |
|                                |        |       |                | 2: 6 32-bit                                                                                                                                            |
|                                |        |       |                | 3: 8 32-bit                                                                                                                                            |
|                                |        |       |                | 4: 10 32-bit                                                                                                                                           |
|                                |        |       |                | 5: 12 32-bit<br>6: 14 32-bit                                                                                                                           |
|                                |        |       |                | 7: 16 32-bit                                                                                                                                           |
|                                | [7]    | RO    | 0              | Reserved                                                                                                                                               |
| rf_hburst_rlengt               | [6:4]  | R/W   | 3'h1           | This filed indicates how to divide AHB INCR reading                                                                                                    |
| h_incr_chx                     | [0.4]  | IX/VV | 3111           | burst.                                                                                                                                                 |
|                                |        |       |                |                                                                                                                                                        |
|                                |        |       |                | If a AHB read burst is INCR and HLENGTH is 0, the AHB burst is divided into several sub-bursts, and the sub-burst length is defined by this register.  |
|                                |        |       |                | 0: 2 32-bit                                                                                                                                            |
|                                |        |       |                | 1: 4 32-bit                                                                                                                                            |
|                                |        |       |                | 2: 6 32-bit                                                                                                                                            |
|                                |        |       |                | 3: 8 32-bit                                                                                                                                            |
|                                |        |       |                | 4: 10 32-bit                                                                                                                                           |
|                                |        |       |                | 5: 12 32-bit                                                                                                                                           |
|                                |        |       |                | 6: 14 32-bit                                                                                                                                           |
|                                |        |       |                | 7: 16 32-bit                                                                                                                                           |
| rf_endian_swt_<br>chx          | [3:2]  | R/W   | 2'h3           | This field selects switching mode for data endian                                                                                                      |
|                                |        |       |                | Endian switching mode                                                                                                                                  |
|                                |        |       |                | 0: byte switch                                                                                                                                         |
|                                |        |       |                | 1: half switch                                                                                                                                         |
|                                |        |       |                | 2: word switch (only for 64-bit AHB interface)                                                                                                         |
|                                |        |       |                | 3: no switch                                                                                                                                           |
|                                |        |       |                | Data endian switching function is provided for software in different endian domain. Data endian is different with AHB protocol endian, AHB endian is   |
|                                |        |       |                | handled by hardware automatically. But data endian should be configured according to software requirement.                                             |
| rf_pri_chx                     | [1:0]  | R/W   | 2'h0           | This field indicates channel priority.                                                                                                                 |
|                                |        |       |                |                                                                                                                                                        |



| Field Name | Bit | Туре | Reset<br>Value | Description                                            |  |  |  |  |  |
|------------|-----|------|----------------|--------------------------------------------------------|--|--|--|--|--|
|            |     |      |                | 0 is the lowest priority and 3 is the highest priority |  |  |  |  |  |
|            |     |      |                |                                                        |  |  |  |  |  |

## 5.2.5.2.7 EMC\_CFG1\_HCHx

Description: EMC AHB channel x configuration register

This register is used to configure AHB channel x information.

Each AHB channel has an independent registers.

| 0x0034 |    |    | EMC  | AHB (                                                         | CH2 co | onfigur | ation | registe | r (Res                                    | et 0x0                 | 00000  | 00) | E  | EMC_C | FG1_I | HCH2          |  |  |  |
|--------|----|----|------|---------------------------------------------------------------|--------|---------|-------|---------|-------------------------------------------|------------------------|--------|-----|----|-------|-------|---------------|--|--|--|
| 0x003C |    |    | EMC  | EMC AHB CH3 configuration register (Reset 0x00000000)         |        |         |       |         |                                           |                        |        |     |    |       |       | EMC_CFG1_HCH3 |  |  |  |
| 0x0044 |    |    | EMC  | EMC AHB CH4 configuration register (Reset 0x00000000) EMC_CFG |        |         |       |         |                                           |                        |        |     |    |       |       | ICH4          |  |  |  |
| 0x004C |    |    | EMC  | AHB (                                                         | СН5 сс | onfigur | ation | registe | r (Res                                    | et 0x0                 | 000000 | 00) | E  | EMC_C | FG1_I | HCH5          |  |  |  |
| 0x0054 |    |    | EMC  | AHB (                                                         | СН6 сс | onfigur | ation | registe | r (Res                                    | et 0x0                 | 000000 | 00) | E  | EMC_C | FG1_I | HCH6          |  |  |  |
| 0x005C |    |    | EMC  | AHB (                                                         | СН7 сс | onfigur | ation | registe | r (Res                                    | et 0x0                 | 000000 | 00) | E  | EMC_C | FG1_I | ICH7          |  |  |  |
| 0x0064 |    |    | EMC  | AHB (                                                         | СН8 сс | onfigur | ation | registe | r (Res                                    | et 0x0                 | 00000  | 00) | E  | EMC_C | FG1_I | HCH8          |  |  |  |
| Bit    | 31 | 30 | 29   | 28                                                            | 27     | 26      | 25    | 24      | 23                                        | 22                     | 210    | 20  | 19 | 18    | 17    | 16            |  |  |  |
| Name   |    |    | Rese | erved                                                         |        |         |       |         | rf_address_offset_chx                     |                        |        |     |    |       |       |               |  |  |  |
| Туре   |    |    | R    | 0                                                             |        |         |       |         | 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   |    |    |      | Rese                                                          | erved  |         |       |         | rf_re<br>q_ti<br>meo<br>ut_e<br>n_ch<br>x | rf_req_timeout_thr_chx |        |     |    |       |       |               |  |  |  |
| Туре   |    |    |      | R                                                             | .0     |         |       |         | RW                                        | RW                     |        |     |    |       |       |               |  |  |  |
| Reset  | 0  | 0  | 0    | 0                                                             | 0      | 0       | 0     | 0       | 0                                         | 0                      | 0      | 0   | 0  | 0     | 0     | 0             |  |  |  |
|        |    |    |      |                                                               |        |         |       |         |                                           |                        |        |     |    |       |       |               |  |  |  |

| Field Name                 | Bit     | Туре | Reset<br>Value | Description                                                                 |
|----------------------------|---------|------|----------------|-----------------------------------------------------------------------------|
|                            | [31:26] | RO   | 0              | Reserved                                                                    |
| rf_address_offs<br>et_chx  | [25:16] | R/W  | 10'h0          |                                                                             |
|                            | [15:8]  | RO   | 0              | Reserved                                                                    |
| rf_req_timeout_<br>en      | [7]     | R/W  | 1'h0           | This field enables request timeout function for each channel                |
| rf_req_timeout_<br>thr_chx | [6:0]   | R/W  | 7'h0           | This field is used to set request timeout threshold value for each channel. |
|                            |         |      |                |                                                                             |



# 5.2.5.2.8 EMC\_STS3

Description: EMC status

This register indicates EMC status.

| 0x00AC | ,                                    |                                      | EMC                                  | status                                   | (Rese                                | t 0x80                               | 07FFF                               | F)                                  |                                     |                                     |                                     |                                     |                                     |                                     | EMC_                                | STS3                                |
|--------|--------------------------------------|--------------------------------------|--------------------------------------|------------------------------------------|--------------------------------------|--------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|
| Bit    | 31                                   | 30                                   | 29                                   | 29 28 27 26 25 24 23 22 21 20 19 18 17 1 |                                      |                                      |                                     |                                     |                                     |                                     |                                     |                                     |                                     |                                     | 16                                  |                                     |
| Name   | rfem<br>c_idl<br>e_sy<br>nc          |                                      |                                      |                                          |                                      |                                      | Rese                                | erved                               |                                     |                                     |                                     |                                     |                                     | rfdl_<br>cpst<br>_idle<br>_syn<br>c | rfdm<br>em_i<br>dle_<br>sync        | rfsel<br>_idle<br>_syn<br>c         |
| Туре   | RO                                   |                                      | RO                                   |                                          |                                      |                                      |                                     |                                     |                                     |                                     |                                     |                                     | RO                                  | RO                                  | RO                                  |                                     |
| Reset  | 1                                    | 0                                    | 0                                    | 0                                        | 0                                    | 0                                    | 0                                   | 0                                   | 0                                   | 0                                   | 0                                   | 0                                   | 0                                   | 1                                   | 1                                   | 1                                   |
| Bit    | 15                                   | 14                                   | 13                                   | 12                                       | 11                                   | 10                                   | 9                                   | 8                                   | 7                                   | 6                                   | 5                                   | 4                                   | 3                                   | 2                                   | 1                                   | 0                                   |
| Name   | rfah<br>b_idl<br>e_ch<br>15_s<br>ync | rfah<br>b_idl<br>e_ch<br>14_s<br>ync | rfah<br>b_idl<br>e_ch<br>13_s<br>ync | rfah<br>b_idl<br>e_ch<br>12_s<br>ync     | rfah<br>b_idl<br>e_ch<br>11_s<br>ync | rfah<br>b_idl<br>e_ch<br>10_s<br>ync | rfah<br>b_idl<br>e_ch<br>9_sy<br>nc | rfah<br>b_idl<br>e_ch<br>8_sy<br>nc | rfah<br>b_idl<br>e_ch<br>7_sy<br>nc | rfah<br>b_idl<br>e_ch<br>6_sy<br>nc | rfah<br>b_idl<br>e_ch<br>5_sy<br>nc | rfah<br>b_idl<br>e_ch<br>4_sy<br>nc | rfah<br>b_idl<br>e_ch<br>3_sy<br>nc | rfah<br>b_idl<br>e_ch<br>2_sy<br>nc | rfah<br>b_idl<br>e_ch<br>1_sy<br>nc | rfah<br>b_idl<br>e_ch<br>0_sy<br>nc |
| Туре   | RO                                   | RO                                   | RO                                   | RO                                       | RO                                   | RO                                   | RO                                  | RO                                  | RO                                  | RO                                  | RO                                  | RO                                  | RO                                  | RO                                  | RO                                  | RO                                  |
| Reset  | 1                                    | 1                                    | 1                                    | 1                                        | 1                                    | 1                                    | 1                                   | 1                                   | 1                                   | 1                                   | 1                                   | 1                                   | 1                                   | 1                                   | 1                                   | 1                                   |

| Field Name               | Bit     | Туре | Reset<br>Value | Description                                                   |
|--------------------------|---------|------|----------------|---------------------------------------------------------------|
| rfemc_idle_syn<br>c      | [31]    | RO   | 1'h1           | This bit indicates EMC is in IDLE status.                     |
|                          | [30:19] | RO   | 0              | Reserved                                                      |
| rfdl_cpst_idle_s<br>ync  | [18]    | RO   | 1'h1           | This bit indicates delay line compensation is in IDLE status. |
| rfdmem_idle_sy<br>nc     | [17]    | RO   | 1'h1           | This bit indicates DMEM is in IDLE status.                    |
| rfsel_idle_sync          | [16]    | RO   | 1'h1           | This bit indicates CH MUX is in IDLE status.                  |
| rfahb_idle_ch1<br>5_sync | [15]    | RO   | 1'h1           | This bit indicates CH15 is in IDLE status.                    |
| rfahb_idle_ch1<br>4_sync | [14]    | RO   | 1'h1           | This bit indicates CH14 is in IDLE status.                    |
| rfahb_idle_ch1<br>3_sync | [13]    | RO   | 1'h1           | This bit indicates CH13 is in IDLE status.                    |
| rfahb_idle_ch1<br>2_sync | [12]    | RO   | 1'h1           | This bit indicates CH12 is in IDLE status.                    |
| rfahb_idle_ch1<br>1_sync | [11]    | RO   | 1'h1           | This bit indicates CH11 is in IDLE status.                    |
| rfahb_idle_ch1<br>0_sync | [10]    | RO   | 1'h1           | This bit indicates CH10 is in IDLE status.                    |



| Field Name              | Bit | Туре | Reset<br>Value | Description                               |
|-------------------------|-----|------|----------------|-------------------------------------------|
| rfahb_idle_ch9<br>_sync | [9] | RO   | 1'h1           | This bit indicates CH9 is in IDLE status. |
| rfahb_idle_ch8<br>_sync | [8] | RO   | 1'h1           | This bit indicates CH8 is in IDLE status. |
| rfahb_idle_ch7<br>_sync | [7] | RO   | 1'h1           | This bit indicates CH7 is in IDLE status. |
| rfahb_idle_ch6<br>_sync | [6] | RO   | 1'h1           | This bit indicates CH6 is in IDLE status. |
| rfahb_idle_ch5<br>_sync | [5] | RO   | 1'h1           | This bit indicates CH5 is in IDLE status. |
| rfahb_idle_ch4<br>_sync | [4] | RO   | 1'h1           | This bit indicates CH4 is in IDLE status. |
| rfahb_idle_ch3<br>_sync | [3] | RO   | 1'h1           | This bit indicates CH3 is in IDLE status. |
| rfahb_idle_ch2<br>_sync | [2] | RO   | 1'h1           | This bit indicates CH2 is in IDLE status. |
| rfahb_idle_ch1<br>_sync | [1] | RO   | 1'h1           | This bit indicates CH1 is in IDLE status. |
| rfahb_idle_ch0<br>_sync | [0] | RO   | 1'h1           | This bit indicates CH0 is in IDLE status. |
|                         |     |      |                |                                           |

## 5.2.5.2.9 EMC\_DMEM\_DLx

Description: EMC delay line control register

These registers are used to configure the DMEM delay lines in EMC PHY.

| EMC_DMEM_DL0  | 0x0100 | clkdmem_out_dl.    |
|---------------|--------|--------------------|
| EMC_DMEM_DL1  | 0x0104 | dqs_ie_dl.         |
| EMC_DMEM_DL2  | 0x0108 | dqs_out_dl.        |
| EMC_DMEM_DL3  | 0x010C | clkwr_dl.          |
| EMC_DMEM_DL4  | 0x0110 | dqs_gate_pre_dl_0. |
| EMC_DMEM_DL5  | 0x0114 | dqs_gate_pre_dl_1. |
| EMC_DMEM_DL6  | 0x0118 | dqs_gate_pre_dl_2. |
| EMC_DMEM_DL7  | 0x011C | dqs_gate_pre_dl_3. |
| EMC_DMEM_DL8  | 0x0120 | dqs_gate_pst_dl_0. |
| EMC_DMEM_DL9  | 0x0124 | dqs_gate_pst_dl_1. |
| EMC_DMEM_DL10 | 0x0128 | dqs_gate_pst_dl_2. |
| EMC_DMEM_DL11 | 0x012C | dqs_gate_pst_dl_3. |
| EMC_DMEM_DL12 | 0x0130 | dqs_in_pos_dl_0.   |
| EMC_DMEM_DL13 | 0x0134 | dqs_in_pos_dl_1.   |
| EMC DMEM DL14 | 0x0138 | das in pos dl 2.   |



| EMC_DMEM_DL15 | 0x013C | dqs_in_pos_dl_3 |
|---------------|--------|-----------------|
| EMC_DMEM_DL16 | 0x0140 | dqs_in_neg_dl_0 |
| EMC_DMEM_DL17 | 0x0144 | dqs_in_neg_dl_1 |
| EMC_DMEM_DL18 | 0x0148 | dqs_in_neg_dl_2 |
| EMC_DMEM_DL19 | 0x014C | dqs_in_neg_dl_3 |

| 0x0100 |                            |    | EMC | delay                                                   | line D   | L0 cor       | trol re | gister | (Rese                 | t 0x000            | 00000  | ))  |               | EMC_  | DMEM          | _DL0 |  |  |  |
|--------|----------------------------|----|-----|---------------------------------------------------------|----------|--------------|---------|--------|-----------------------|--------------------|--------|-----|---------------|-------|---------------|------|--|--|--|
| 0x0104 |                            |    | EMC | delay                                                   | line D   | L1 cor       | trol re | gister | (Reset                | t 0x000            | 000000 | ))  |               | EMC_  | DMEM          | _DL1 |  |  |  |
| 0x0108 |                            |    | EMC | delay                                                   | line D   | L2 cor       | trol re | gister | (Reset                | t 0x000            | 000000 | ))  |               | EMC_  | DMEM          | _DL2 |  |  |  |
| 0x010C |                            |    | EMC | delay                                                   | line D   | EMC_DMEM_DL3 |         |        |                       |                    |        |     |               |       |               |      |  |  |  |
| 0x0110 |                            |    | EMC | delay                                                   | line D   | EMC_DMEM_DL4 |         |        |                       |                    |        |     |               |       |               |      |  |  |  |
| 0x0114 |                            |    | EMC | delay                                                   | line D   | EMC_DMEM_DL  |         |        |                       |                    |        |     |               |       |               |      |  |  |  |
| 0x0118 |                            |    | EMC | delay                                                   | line D   | L6 cor       | trol re | gister | (Reset                | t 0x000            | 000000 | ))  |               | EMC_  | DMEM          | _DL6 |  |  |  |
| 0x011C |                            |    | EMC | delay                                                   | line D   | L7 cor       | trol re | gister | (Reset                | t 0x000            | 000000 | ))  |               | EMC_  | DMEM          | _DL7 |  |  |  |
| 0x0120 |                            |    | EMC | delay                                                   | line D   | L8 cor       | trol re | gister | (Reset                | t 0x000            | 000000 | ) 🔷 |               | EMC_  | DMEM          | _DL8 |  |  |  |
| 0x0124 |                            |    | EMC | delay                                                   | line D   | L9 cor       | trol re | gister | (Reset                | t 0x000            | 00000  | )   |               | EMC_  | DMEM          | _DL9 |  |  |  |
| 0x0128 |                            |    | EMC | delay                                                   | line D   | L10 co       | ntrol r | egiste | r (Res                | et 0x0(            | 00000  | 0)  | E             | EMC_D | MEM_          | DL10 |  |  |  |
| 0x012C |                            |    | EMC | delay                                                   | line D   | L11 co       | ntrol r | egiste | r (Res                | et 0x0(            | 000000 | 0)  | E             | EMC_D | MEM_          | DL11 |  |  |  |
| 0x0130 |                            |    | EMC | delay                                                   | line D   | L12 co       | ntrol r | egiste | r (Res                | et 0x0(            | 00000  | 0)  | E             | MC_D  | MEM_          | DL12 |  |  |  |
| 0x0134 |                            |    | EMC | delay                                                   | line D   | L13 co       | ntrol r | egiste | r (Res                | et 0x0             | 000000 | 0)  | EMC_DMEM_DL13 |       |               |      |  |  |  |
| 0x0138 |                            |    | EMC | EMC delay line DL14 control register (Reset 0x00000000) |          |              |         |        |                       |                    |        |     |               |       | EMC_DMEM_DL14 |      |  |  |  |
| 0x013C |                            |    | EMC | delay                                                   | line D   | L15 co       | ntrol r | egiste | r (Res                | et 0x0(            | 000000 | 0)  | EMC_DMEM_DL15 |       |               |      |  |  |  |
| 0x0140 |                            |    | EMC | delay                                                   | line D   | L16 co       | ntrol r | egiste | r (Res                | et 0x0(            | 000000 | 0)  | EMC_DMEM_DL16 |       |               |      |  |  |  |
| 0x0144 |                            |    | EMC | delay                                                   | line D   | L17 co       | ntrol r | egiste | r (Res                | et 0x0             | 000000 | 0)  | EMC_DMEM_DL17 |       |               |      |  |  |  |
| 0x0148 |                            |    | EMC | delay                                                   | line D   | L18 co       | ntrol r | egiste | r (Res                | et 0x0(            | 000000 | 0)  | EMC_DMEM_DL18 |       |               |      |  |  |  |
| 0x014C |                            |    | EMC | delay                                                   | line D   | L19 co       | ntrol r | egiste | r (Res                | et 0x0(            | 000000 | 0)  | EMC_DMEM_DL19 |       |               |      |  |  |  |
| Bit    | 31                         | 30 | 29  | 28                                                      | 27       | 26           | 25      | 24     | 23                    | 22                 | 21     | 20  | 19            | 18    | 17            | 16   |  |  |  |
| Name   |                            |    |     |                                                         |          |              |         | Rese   | erved                 |                    |        |     |               |       |               |      |  |  |  |
| Туре   |                            |    |     |                                                         |          |              |         | R      | 10                    |                    |        |     |               |       |               |      |  |  |  |
| Reset  | 0                          | 0  | 0   | 0                                                       | 0        | 0            | 0       | 0      | 0                     | 0                  | 0      | 0   | 0             | 0     | 0             | 0    |  |  |  |
| Bit    | 15                         | 14 | 13  | 13 12 11 10 9 8 7 6 5 4                                 |          |              |         |        |                       |                    |        |     |               | 2     | 1             | 0    |  |  |  |
| Name   | rf_xx<br>x_cp<br>st_e<br>n |    |     | rf                                                      | dl_xxx_c | nt           |         |        | rf_xx<br>x_dl<br>_inv | x_dl rf_xxx_dl_sel |        |     |               |       |               |      |  |  |  |
| Туре   | RW                         |    |     |                                                         | RO       |              |         |        | RW                    | RW                 |        |     |               |       |               |      |  |  |  |
| Reset  | 0                          | 0  | 0   | 0                                                       | 0        | 0            | 0       | 0      | 0                     | 0                  | 0      | 0   | 0             | 0     | 0             | 0    |  |  |  |
| 1      |                            |    |     |                                                         |          |              |         |        |                       |                    |        |     | <u> </u>      |       | <u> </u>      |      |  |  |  |

| Field Name     | Bit    | Туре | Reset<br>Value | Description                                                                                           |
|----------------|--------|------|----------------|-------------------------------------------------------------------------------------------------------|
|                | [31:6] | RO   | 0              | Reserved                                                                                              |
| rf_xxx_cpst_en | [15]   | R/W  | 1'h0           | This field enables the delay line to be compensated automatically by DLL                              |
| rfdl_xxx_cnt   | [14:8] | RO   | 7'h00          | This field indicate the count of delay                                                                |
| rf_xxx_dl_inv  | [7]    | R/W  | 1'h0           | This field provides an inverting option for signal through delay line.  0: no inverting  1: inverting |



| Field Name    | Bit   | Туре | Reset<br>Value | Description                                   |  |  |  |  |  |
|---------------|-------|------|----------------|-----------------------------------------------|--|--|--|--|--|
| rf_xxx_dl_sel | [6:0] | R/W  | 7'h00          | This field controls delay value of delay line |  |  |  |  |  |
|               |       |      |                |                                               |  |  |  |  |  |

# 5.2.5.2.10 EMC\_CFG0\_DLL

Description: EMC DLL configuration register

This register is used to configure DLL information.

| 0x0170 |                 | EMC DLL configuration register (Reset 0x00000000) EMC_CFG0 |                                                                                                                                                                                                                                                                             |                                           |    |    |    |    |    |    |   |   | CFG0           | DLL |   |   |
|--------|-----------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|----|----|----|----|----|----|---|---|----------------|-----|---|---|
| Bit    | 31              | 30                                                         | 29                                                                                                                                                                                                                                                                          | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |    |    |    |    |    |   |   |                | 16  |   |   |
| Name   |                 | Reservedc                                                  |                                                                                                                                                                                                                                                                             |                                           |    |    |    |    |    |    |   |   | rf_dl_cpst_thr |     |   |   |
| Туре   |                 | RO W 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   | rfdll_<br>error | rfdll_<br>lock<br>ed                                       | rf_dl_cpst_gr<br>oup     rf_dl<br>_cps<br>_cps<br>_tsta<br>_rt     rf_dl<br>_aut<br>_cps<br>_t_en     rf_dll<br>_aut<br>_clr<br>_en     rf_dll<br>_aut<br>_clr<br>_en     rf_dll<br>_rf_dll<br>_rf_dll<br>_rf_dll<br>_en     rf_dll<br>_rf_dll<br>_rf_dll<br>_rf_dll<br>_en |                                           |    |    |    |    |    |    |   |   |                |     |   |   |
| Туре   | RO              | RO                                                         | R                                                                                                                                                                                                                                                                           | W                                         | RW | RW | RW | RW | RW | RW |   |   |                |     |   |   |
| Reset  | 0               | 0                                                          | 0                                                                                                                                                                                                                                                                           | 0                                         | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0              | 0   | 0 | 0 |

| Field Name           | Bit     | Туре | Reset<br>Value | Description                                                                |
|----------------------|---------|------|----------------|----------------------------------------------------------------------------|
|                      | [31:20] | RO   | 0              | Reserved                                                                   |
| rf_dll_err_clr       | [20]    | W    | 1'h0           | This field is used to clear DLL error in bit[15], when write 1 to this bit |
| rf_dl_cpst_thr       | [19:16] | R/W  | 4'h0           | This field is the threshold to start one compensation                      |
| rfdll_error          | [15]    | RO   | 1'h0           | This field is set if DLL error happens                                     |
| rfdll_locked         | [14]    | RO   | 1'h0           | This field indicates DLL is locked or not                                  |
|                      |         |      |                | 1: DLL LOCKED 0: DLL UNLOCKED                                              |
| rf_dl_cpst_grou<br>p | [13:12] | R/W  | 2'h0           | This field enables the group of delay lines to be compensated.             |
| rf_dl_cpst_start     | [11]    | R/W  | 1'h0           | This field is used to start one compensation.                              |
| rf_dl_cpst_en        | [10]    | R/W  | 1'h0           | This field enables the DLL compensation.                                   |
|                      |         |      |                | 0: the DLL compensation is disabled 1: the DLL compensation is enabled     |



| Field Name             | Bit   | Туре | Reset<br>Value | Description                                                               |
|------------------------|-------|------|----------------|---------------------------------------------------------------------------|
| rf_dll_auto_clr_<br>en | [9]   | R/W  | 1'h0           | This field enables automatically reset DLL                                |
| rf_dll_clr             | [8]   | R/W  | 1'h0           | This field is to reset DLL                                                |
| rf_dll_en              | [7]   | R/W  | 1'h0           | This field enables the DLL.  0: the DLL is disabled 1: the DLL is enabled |
| rf_dll_init            | [6:0] | R/W  | 7'h0           | This field is used to configure DLL searching start value                 |

## 5.2.5.2.11 EMC\_DCFG0

Description: EMC DMEM control registers

This register is used to configure external DMEM.

| 0x0180 |                                    | EMC DMEM control register (Reset 0x0000BF13) EMC_DCFG0 |                                              |                                              |                                     |                                    |                       |                            |                  |       |          |      |    | CFG0              |         |            |
|--------|------------------------------------|--------------------------------------------------------|----------------------------------------------|----------------------------------------------|-------------------------------------|------------------------------------|-----------------------|----------------------------|------------------|-------|----------|------|----|-------------------|---------|------------|
| Bit    | 31                                 | 30                                                     | 29                                           | 28                                           | 27                                  | 26                                 | 25                    | 24                         | 23               | 22    | 21       | 20   | 19 | 18                | 17      | 16         |
| Name   |                                    | Reserved                                               |                                              |                                              |                                     |                                    |                       |                            |                  |       |          |      |    |                   |         |            |
| Туре   |                                    | 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   | drf_<br>auto<br>_ref<br>_allc<br>s | drf_<br>auto<br>_ref<br>_en                            | drf_<br>alter<br>nativ<br>e_m<br>ode1<br>_en | drf_<br>alter<br>nativ<br>e_m<br>ode0<br>_en | drf_c<br>lkdm<br>em_<br>out_<br>sel | drf_c<br>lkdm<br>em_<br>out_<br>en | drf_r<br>owhi<br>t_en | drf_<br>data<br>_wid<br>th | Res<br>erve<br>d | drf_c | column_r | node |    | ito_pre<br>sition | drf_rov | w_mod<br>e |
| Туре   | RW                                 | RW                                                     | RW                                           | RW                                           | RW                                  | RW                                 | RW                    | RW                         | RO               | RW RW |          |      |    | R\                | W       |            |
| Reset  | 1                                  | 0                                                      | 1                                            | 1                                            | 1                                   | 1                                  | 1                     | 1                          | 0                | 0     | 0        | 1    | 0  | 0                 | 1       | 1          |

| Field Name          | Bit     | R/W | Default<br>Value | Description                                                                                                                                                                                             |
|---------------------|---------|-----|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | [31:16] | RO  | 0                | Reserved                                                                                                                                                                                                |
| drf_auto_ref_all cs | [15]    | R/W | 1'h1             | This bit indicates auto-refresh mode for multi-DRAM on bus.  0: CSs are auto-refresh one by one 1: CSs are auto-refresh at the same time  If there is no refresh current issues, mode-1 is recommended. |



| Field Name                   | Bit   | R/W | Default | Description                                                                                                                                                                       |
|------------------------------|-------|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |       | _   | Value   |                                                                                                                                                                                   |
| drf_auto_ref_en              | [14]  | R/W | 1'h0    | This bit opens auto-refresh functions for both SDR and DDR.                                                                                                                       |
|                              |       |     |         | 0: hardware auto-refresh function is disabled     1: hardware auto-refresh function is enabled                                                                                    |
|                              |       |     |         | During device initialization or re-configuration, this bit should be cleared, and in other cases, this bit MUST be kept opened to guarantee data in device is correctly retained. |
| drf_alternative_<br>mode1_en | [13]  | R/W | 1'h1    | This bit enables alternative bank pre-charge or active during pre-charge or active                                                                                                |
|                              |       |     |         | 0: disabled                                                                                                                                                                       |
|                              |       |     |         | 1: enabled                                                                                                                                                                        |
|                              |       |     |         | This bit should be always set to improve efficiency.                                                                                                                              |
| drf_alternative_<br>mode0_en | [12]  | R/W | 1'h1    | This bit enables alternative bank pre-charge or active during access                                                                                                              |
|                              |       |     |         | 0: disabled<br>1: enabled                                                                                                                                                         |
|                              |       |     |         | This bit should be always set to improve efficiency.                                                                                                                              |
| drf_clkdmem_o<br>ut_sel      | [11]  | R/W | 1'h1    | This bit select DMEM output clock phase.                                                                                                                                          |
| drf_clkdmem_o<br>ut_en       | [10]  | R/W | 1'h1    | This bit enable DMEM output clock on EMCLKDP and EMCLKDM.                                                                                                                         |
|                              |       |     |         | 0: DMEM clock output is closed                                                                                                                                                    |
|                              |       |     |         | 1: DMEM clock output is opened                                                                                                                                                    |
| drf_rowhit_en                | [9]   | R/W | 1'h1    | This bit enables row-hit detect logic to remove redundant pre-charge and active operations.                                                                                       |
|                              |       |     |         | 0: row-hit detecting function is disabled                                                                                                                                         |
| .01                          |       |     |         | 1: row-hit detecting function is enabled                                                                                                                                          |
|                              |       |     |         | This bit should be always set to improve efficiency.                                                                                                                              |
| drf_data_width               | [8]   | R/W | 1'h1    | This bit selects device data bus width                                                                                                                                            |
|                              |       |     |         | 0: 16-bit<br>1: 32-bit                                                                                                                                                            |
|                              | [7]   | RO  | 0       | Reserved                                                                                                                                                                          |
| drf_column_mo<br>de          | [6:4] | R/W | 3'h1    | This field indicates device column mode:                                                                                                                                          |



| Field Name                | Bit   | R/W | Default<br>Value | Description                                                                |
|---------------------------|-------|-----|------------------|----------------------------------------------------------------------------|
|                           |       |     |                  | 0: 8-bit                                                                   |
|                           |       |     |                  | 1: 9-bit                                                                   |
|                           |       |     |                  | 2: 10-bit                                                                  |
|                           |       |     |                  | 3: 11-bit                                                                  |
|                           |       |     |                  | 4: 12-bit                                                                  |
|                           |       |     |                  | 5: reserved                                                                |
|                           |       |     |                  | 6: reserved                                                                |
|                           |       |     |                  | 7: reserved                                                                |
|                           |       |     |                  | This field should be configured according to device type.                  |
| drf_auto_pre_p<br>osition | [3:2] | R/W | 2'h0             | This field indicates auto pre-charge and pre-charge all bank bit position. |
|                           |       |     |                  | 0: A[10]                                                                   |
|                           |       |     |                  | 1: A[11]                                                                   |
|                           |       |     |                  | 2: A[12]                                                                   |
|                           |       |     |                  | 3: A[13]                                                                   |
|                           |       |     |                  | This field should be configured according to device                        |
|                           |       |     |                  | type.                                                                      |
| drf_row_mode              | [1:0] | R/W | 2'h3             | This field indicates device row mode:                                      |
|                           |       |     |                  | 0: 11-bit                                                                  |
|                           |       |     |                  | 1: 12-bit                                                                  |
|                           |       |     |                  | 2: 13-bit                                                                  |
|                           |       |     |                  | 3: 14-bit                                                                  |
|                           |       |     | <i>y</i>         | This field should be configured according to device type.                  |
|                           |       |     |                  |                                                                            |

# 5.2.5.2.12 EMC\_DCFG1

Description: EMC DMEM control registers



| 0x0184 |    |       | EMC   | EMC DMEM control register (Reset 0x0338243 |    |           |      |    |           |           |    |    |          | Е         | MC_D | CFG1 |  |
|--------|----|-------|-------|--------------------------------------------|----|-----------|------|----|-----------|-----------|----|----|----------|-----------|------|------|--|
| Bit    | 31 | 30    | 29    | 28                                         | 27 | 26        | 25   | 24 | 23        | 22        | 21 | 20 | 19       | 18        | 17   | 16   |  |
| Name   |    | drf_  | t_rtr |                                            |    | drf_t_wtr |      |    |           | drf_t_rtw |    |    |          | drf_t_ras |      |      |  |
| Туре   |    | R     | W     |                                            |    | R'        | W    |    |           | R         | W  |    |          | RW        |      |      |  |
| Reset  | 0  | 0     | 0     | 0                                          | 0  | 0         | 1    | 1  | 0         | 0         | 1  | 1  | 1        | 0         | 0    | 0    |  |
| Bit    | 15 | 14    | 13    | 12                                         | 11 | 10        | 9    | 8  | 7         | 6         | 5  | 4  | 3        | 2         | 1    | 0    |  |
| Name   |    | drf_t | t_rrd |                                            |    | drf_      | t_wr |    | drf_t_rcd |           |    |    | drf_t_rp |           |      |      |  |
| Туре   |    | R     | W     |                                            | RW |           |      |    | RW        |           |    |    | RW       |           |      |      |  |
| Reset  | 0  | 0     | 1     | 0                                          | 0  | 0 1 0 0   |      |    |           | 0 0 1 1   |    |    | 0        | 1         | 0    | 0    |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                         |
|------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| drf_t_rtr  | [31:28] | R/W  | 4'h0           | Timing parameter: read-to-read turn-around time between different CSs T is clk_emc/2 cycle, that is, external memory clock                          |
| drf_t_wtr  | [27:24] | R/W  | 4'h3           | cycle.  Timing parameter: write-to-read turn-around time T is clk_emc/2 cycle, that is, external memory clock cycle.                                |
| drf_t_rtw  | [23:20] | R/W  | 4'h3           | Timing parameter: read-to-write turn-around time T is clk_emc/2 cycle, that is, external memory clock cycle.                                        |
| drf_t_ras  | [19:16] | R/W  | 4'h8           | Timing parameter: tRAS-MIN  (drf_t_ras+1)*T >= tRAS-MIN  T is clk_emc/2 cycle, that is, external memory clock cycle.                                |
| drf_t_rrd  | [15:12] | R/W  | 4'h2           | Timing parameter: tRRD  (drf_t_rrd+1)*T >= tRRD  T is clk_emc/2 cycle, that is, external memory clock cycle.                                        |
| drf_t_wr   | [11:8]  | R/W  | 4'h4           | Timing parameter: tWR  For SDR, (drf_t_wr+1)*T >= tWR  For DDR, (drf_t_wr -1)*T >= tWR  T is clk_emc/2 cycle, that is, external memory clock cycle. |
| drf_t_rod  | [7:4]   | R/W  | 4'h3           | Timing parameter: tRCD  (drf_t_rcd+1)*T >= tRCD  T is clk_emc/2 cycle, that is, external memory clock cycle.                                        |
| drf_t_rp   | [3:0]   | R/W  | 4'h4           | Timing parameter: tRP  (drf_t_rp+1)*T >= tRP  T is clk_emc/2 cycle, that is, external memory clock cycle.                                           |
|            |         |      |                |                                                                                                                                                     |



# 5.2.5.2.13 EMC\_DCFG2

Description: EMC DMEM control registers

This register is used to configure external DMEM.

| 0x0188 |      |       | EMC                       | DMEN                                   | l contr | ol reg | ister (F | Reset ( | )x1A26    | 61000) |   |    | EMC_DC |   |   |   |  |
|--------|------|-------|---------------------------|----------------------------------------|---------|--------|----------|---------|-----------|--------|---|----|--------|---|---|---|--|
| Bit    | 31   | 30    | 29                        | 29 28 27 26 25 24 23 22 21 20 19 18 17 |         |        |          |         |           |        |   | 16 |        |   |   |   |  |
| Name   | Rese | erved |                           |                                        | drf_f   | t_rfc  |          |         | drf_t_xsr |        |   |    |        |   |   |   |  |
| Туре   | R    | 0     |                           |                                        | R'      | W      |          |         |           |        |   | R  | w      |   |   |   |  |
| Reset  | 0    | 0     | 0                         | 1                                      | 1       | 0      | 1        | 0       | 0         | 0      | 1 | 0  | 0      | 1 | 1 | 0 |  |
| Bit    | 15   | 14    | 13                        | 12                                     | 11      | 10     | 9        | 8       | 7         | 6      | 5 | 4  | 3      | 2 | 1 | 0 |  |
| Name   |      |       | drf_t_ref drf_t_mrd       |                                        |         |        |          |         |           |        |   |    |        |   |   |   |  |
| Туре   |      |       | RW                        |                                        |         |        |          |         |           |        |   | RW |        |   |   |   |  |
| Reset  | 0    | 0     | 0 1 0 0 0 0 0 0 0 0 0 0 0 |                                        |         |        |          |         |           | 0      |   |    |        |   |   |   |  |

| [31:30] | RO      |             |                                                                                                              |
|---------|---------|-------------|--------------------------------------------------------------------------------------------------------------|
| 100.041 |         | 0           | Reserved                                                                                                     |
| [29:24] | R/W     | 6'h1A       | Timing parameter: tRFC (drf_t_rfc+2)*T >= tRFC T is clk_emc/2 cycle, that is, external memory clock cycle.   |
| [23:16] | R/W     | 8'h26       | Timing parameter: tXSR  (drf_t_xsr+2)*T >= tXSR  T is clk_emc/2 cycle, that is, external memory clock cycle. |
| [15:4]  | R/W     | 12'h10<br>0 | Auto-refresh interval time (drf_t_ref+1)*Tref*(row number) <= tREF Tref is clk_emc_ref cycle.                |
| [3:0]   | R/W     | 4'h0        | Timing parameter: tMRD  (drf_t_mrd+2)*T >= tMRD  T is clk_emc/2 cycle, that is, external memory clock cycle. |
|         | [23:16] | [23:16] R/W | [23:16] R/W 8'h26 [15:4] R/W 12'h10                                                                          |

# 5.2.5.2.14 EMC\_DCFG3

Description: EMC DMEM control registers



| 0x018C |                             |                      | EMC  | DMEN            | I contr | ol reg | ister (F                               | Reset (                | )x003F           | BFFF)                                   | )  |    |           | Е         | MC_D | CFG3 |
|--------|-----------------------------|----------------------|------|-----------------|---------|--------|----------------------------------------|------------------------|------------------|-----------------------------------------|----|----|-----------|-----------|------|------|
| Bit    | 31                          | 30                   | 29   | 28              | 27      | 26     | 25                                     | 24                     | 23               | 22                                      | 21 | 20 | 19        | 18        | 17   | 16   |
| Name   |                             |                      | Rese | erved           |         |        | drf_s<br>ampl<br>e_au<br>to_rs<br>t_en | drf_s<br>ampl<br>e_rst | Res<br>erve<br>d | drf_<br>auto<br>_sle<br>ep_<br>mod<br>e |    | dı | rf_auto_s | sleep_t_r | ef   | •    |
| Туре   |                             |                      | R    | 0               |         |        | RW                                     | RW                     | RO               | RW                                      | RW |    |           |           |      |      |
| Reset  | 0                           | 0                    | 0    | 0               | 0       | 0      | 0                                      | 0                      | 0                | 0                                       | 1  | 1  | 1         | 1         | 1    | 1    |
| Bit    | 15                          | 14                   | 13   | 12              | 11      | 10     | 9                                      | 8                      | 7                | 6                                       | 5  | 4  | 3         | 2         | 1    | 0    |
| Name   | drf_r<br>ef_c<br>nt_rs<br>t | ref_c<br>nt_d<br>one |      | drf_ref_cnt_thr |         |        |                                        |                        |                  |                                         |    |    |           |           |      |      |
| Туре   | RW                          | RO                   | RW   |                 |         |        |                                        |                        |                  |                                         |    |    |           |           |      |      |
| Reset  | 1                           | 0                    | 1    | 1               | 1       | 1      | 1                                      | 1                      | 1                | 1                                       | 1  | 1  | 1         | 1         | 1    | 1    |

| Field Name                 | Bit     | Туре | Reset<br>Value | Description                                                                                                                            |
|----------------------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------|
|                            | [31:26] | RO   | 0              | Reserved                                                                                                                               |
| drf_sample_aut<br>o_rst_en | [25]    | R/W  | 1'h0           | This bit enables an auto-reset function for sampling logic.                                                                            |
|                            |         |      |                | 0: read data FIFO cannot be reset automatically                                                                                        |
|                            |         |      |                | 1: read data FIFO is reset automatically during auto-refresh or resume                                                                 |
| drf_sample_rst             | [24]    | R/W  | 1'h0           | This bit is used to reset DMEM sample FIFO pointer.                                                                                    |
|                            |         |      |                | Active high.                                                                                                                           |
|                            |         |      |                | 0: read data FIFO is released to work                                                                                                  |
|                            |         |      |                | 1: read data FIFO is held and reset                                                                                                    |
|                            |         |      |                | This bit is a debugging bit, and should not be used in normal condition.                                                               |
| 0,0                        |         |      |                | Because this bit cannot be cleared automatically. To reset sample FIFO pointer, software should set this bit, and then clear this bit. |
|                            | [23]    | RO   | 0              | Reserved                                                                                                                               |
| drf_auto_sleep<br>_mode    | [22]    | R/W  | 1'h0           | This bit selects auto-sleep mode                                                                                                       |
|                            |         |      |                | 0: normal mode                                                                                                                         |
|                            |         |      |                | 1: all rows are guarantee to refresh at least one time before sleep                                                                    |
|                            |         |      |                | In normal cases, mode-0 is recommended and this bit is cleared to 0.                                                                   |



| Field Name               | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                               |
|--------------------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          |         |      |                | This bit is valid only if rf_auto_sleep_en is set.                                                                                                                                                        |
| drf_auto_sleep<br>_t_ref | [21:16] | R/W  | 6'h3F          | If drf_auto_sleep_mode is set to 1, this field indicates auto-refresh interval in special refresh mode before sleep.  If drf_auto_sleep_mode is cleared to 0, this field is DON'T CARE.                   |
| drf_ref_cnt_rst          | [15]    | R/W  | 1'h1           | This bit is used to reset and hold refresh counter.  0: refresh counter is released to count  1: refresh counter is held and reset  If drf_auto_sleep_mode is cleared to 0, this bit should be kept high. |
| ref_cnt_done             | [14]    | RO   | 1'h0           | This bit indicates refresh counter done status                                                                                                                                                            |
| drf_ref_cnt_thr          | [13:0]  | R/W  | 14'h3F<br>FF   | If drf_auto_sleep_mode is set to 1, this field is refresh counter threshold. The number should be configured to (row number – 1).  If drf_auto_sleep_mode is cleared to 0, this field is DON'T CARE.      |
|                          |         |      |                |                                                                                                                                                                                                           |

# 5.2.5.2.15 EMC\_DCFG4

Description: EMC DMEM control registers

| 0x0190 |                  | •                           | EMC              | DMEN         | 1 contr | rol reg       | ister (l | Reset ( | 0000x0 | 0000) |    |    | EMC_DCFG4              |                            |                            |                       |  |  |
|--------|------------------|-----------------------------|------------------|--------------|---------|---------------|----------|---------|--------|-------|----|----|------------------------|----------------------------|----------------------------|-----------------------|--|--|
| Bit    | 31               | 30                          | 29               | 28           | 27      | 26            | 25       | 24      | 23     | 22    | 21 | 20 | 19                     | 18                         | 17                         | 16                    |  |  |
| Name   | Res<br>erve<br>d | dsoft<br>_cm<br>d_all<br>cs | Res<br>erve<br>d | dsoft<br>_cs | cmd_c   | chip_sl<br>ep | Reserved |         |        |       |    |    | dsoft<br>_self<br>_ref | dsoft<br>_ld_<br>mdr<br>eg | dsoft<br>_aut<br>o_re<br>f | dsoft<br>_pre<br>_all |  |  |
| Туре   | RO               | RW                          | RO               | RW           | R       | .0            |          |         | RO     |       |    | 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   |                  |                             |                  | drf_mode_reg |         |               |          |         |        |       |    |    |                        |                            |                            |                       |  |  |
| Туре   |                  |                             |                  | RW           |         |               |          |         |        |       |    |    |                        |                            |                            |                       |  |  |
| Reset  | 0                | 0                           | 0                | 0            | 0       | 0             | 0        | 0       | 0      | 0     | 0  | 0  | 0                      | 0                          | 0                          | 0                     |  |  |

| Field Name          | Bit  | Туре | Reset<br>Value | Description                                                         |
|---------------------|------|------|----------------|---------------------------------------------------------------------|
|                     | [31] | RO   | 0              | Reserved                                                            |
| dsoft_cmd_allc<br>s | [30] | R/W  | 1'h0           | This bit select software command issued mode for multi-DRAM on bus. |



| Field Name         | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                |
|--------------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    |         |      |                | If cleared, software command is issued one CS at one time, the CS number is dsoft_cs.  If set, software command is issued on all CSs at the same time, and the dsoft_cs is DON'T CARE.                                                     |
|                    | [29]    | RO   | 0              | Reserved                                                                                                                                                                                                                                   |
| dsoft_cs           | [28]    | R/W  | 1'h0           | Only if dsoft_cmd_allcs is cleared, this register is used.  1'h0: software command is issued on CS0 1'h1: software command is issued on CS1                                                                                                |
| cmd_chip_slee<br>p | [27:26] | RO   | 2'h0           | Sleep status for each CS.  [0]: CS0  [1]: CS1  If one CS sleeps, the related bit is set.  If one CS is resumed, the related bit is cleared.                                                                                                |
|                    | [25:21] | RO   | 0              | Reserved                                                                                                                                                                                                                                   |
| dsoft_resume       | [20]    | R/W  | 1'h0           | Software-issued EXIT SELF REFRESH (RESUME) command Write: start RESUME command Read: RESUME command status                                                                                                                                 |
| dsoft_self_ref     | [19]    | R/W  | 1'h0           | Software-issued SELF REFRESH command Write: start SELF REFRESH command Read: SELF REFRESH command status                                                                                                                                   |
| dsoft_ld_mdreg     | [18]    | R/W  | 1'h0           | Software-issued LOAD MODE REGISTER command Write: start LOAD MODE REGISTER command Read: LOAD MODE REGISTER command status                                                                                                                 |
| dsoft_auto_ref     | [17]    | R/W  | 1'h0           | Software-issued AUTO REFRESH command Write: start AUTO REFRESH command Read: AUTO REFRESH command status                                                                                                                                   |
| dsoft_pre_all      | [16]    | R/W  | 1'h0           | Software-issued PRECHARGE ALL BANK command Write: start PRECHARGE ALL BANK command Read: PRECHARGE ALL BANK command status                                                                                                                 |
| drf_mode_reg       | [15:0]  | R/W  | 16'h0          | SDRAM mode register.  This value is loaded into SDRAM during write 1 to dsoft_Id_mdreg. And this value isn't used by controller.  Bit[15:14]: mode register select (mapping to bank)  Bit[13: 0]: mode register value (mapping to address) |
|                    |         |      |                |                                                                                                                                                                                                                                            |

# 5.2.5.2.16 EMC\_DCFG5



Description: EMC DMEM control registers

| 0x0194 |                  |          | EMC      | DMEN             | 1 contr          | ol reg | ister (F | Reset ( | 0x0062           | 20208)   |           |       |                  | Е                   | MC_D     | CFG5 |
|--------|------------------|----------|----------|------------------|------------------|--------|----------|---------|------------------|----------|-----------|-------|------------------|---------------------|----------|------|
| Bit    | 31               | 30       | 29       | 9 28 27 26 25 24 |                  |        |          |         |                  | 22       | 21        | 20    | 19               | 18                  | 17       | 16   |
| Name   |                  | Reserved |          |                  |                  |        |          |         | d                | rf_clkdm | em_in_s   | el    | Res<br>erve<br>d | rve drf_dqs_out_sel |          | _sel |
| Туре   |                  |          |          | RO               |                  |        |          |         |                  | RW       |           |       |                  | RW                  |          |      |
| Reset  | 0                | 0        | 0        | 0                | 0                | 0      | 0        | 0       | 0                | 1        | 1         | 0     | 0                | 0                   | 1        | 0    |
| Bit    | 15               | 14       | 13       | 12               | 11               | 10     | 9        | 8       | 7                | 6        | 5         | 4     | 3                | 2                   | 1        | 0    |
| Name   | Res<br>erve<br>d | drf_     | wdm_late | ency             | Res<br>erve<br>d | drf_   | rdm_late | ency    | Res<br>erve<br>d | drf_v    | vdata_lat | tency |                  | drf_rdata           | _latency |      |
| Type   | RO               |          | RW       |                  | RO RW            |        |          | RO      |                  | RW       |           |       | R                | W                   |          |      |
| Reset  | 0                | 0        | 0        | 0                | 0                | 0      | 1        | 0       | 0                | 0        | 0         | 0     | 1                | 0                   | 0        | 0    |

| Field Name             | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                             |
|------------------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | [31:24] | RO   | 0              | Reserved                                                                                                                                                                                                                                                |
| drf_clkdmem_in<br>_sel | [23:20] | R/W  | 4'h6           | Timing adjustment: sample clock latency The unit is clk_emc cycle.                                                                                                                                                                                      |
|                        | [19]    | RO   | 0              | Reserved                                                                                                                                                                                                                                                |
| drf_dqs_out_se<br>I    | [18:16] | R/W  | 3'h2           | Timing adjustment: DQS output latency The unit is clk_emc cycle.                                                                                                                                                                                        |
|                        | [15]    | RO   | 0              | Reserved                                                                                                                                                                                                                                                |
| drf_wdm_latenc<br>y    | [14:12] | R/W  | 3'h0           | Timing adjustment: write DM latency The unit is clk_emc cycle.                                                                                                                                                                                          |
|                        | [11]    | RO   | 0              | Reserved                                                                                                                                                                                                                                                |
| drf_rdm_latenc<br>y    | [10:8]  | R/W  | 3'h2           | Timing adjustment: read DM latency The unit is clk_emc cycle.  IMPORTANT: if drf_rdm_latency is configured to 7, DM is kept high in whole read burst instead of 7-cycle-delay. This option is used for DDR because DM is DON'T CARE during read bursts. |
|                        | [7]     | RO   | 0              | Reserved                                                                                                                                                                                                                                                |
| drf_wdata_late<br>ncy  | [6:4]   | R/W  | 3'h0           | Timing adjustment: write data latency The unit is clk_emc cycle.                                                                                                                                                                                        |
| drf_rdata_laten<br>cy  | [3:0]   | R/W  | 4'h8           | Timing adjustment: read data latency The unit is clk_emc cycle.                                                                                                                                                                                         |



### 5.2.5.2.17 EMC\_DCFG6

Description: EMC DMEM control registers

This register is used to configure external DMEM.

| 0x0198 |    |    | EMC | DMEN | 1 contr | ol reg | ister (F | Reset (  | 0x0040    | 0020) |    |    |    | Е  | MC_D | CFG6 |
|--------|----|----|-----|------|---------|--------|----------|----------|-----------|-------|----|----|----|----|------|------|
| Bit    | 31 | 30 | 29  | 28   | 27      | 26     | 25       | 24       | 23        | 22    | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    |    |     |      |         |        | dr       | f_dqs_ga | ate_pst_: | sel   |    |    |    |    |      |      |
| Туре   |    |    | RW  |      |         |        |          |          |           |       |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0   | 0    | 0       | 0      | 0        | 0        | 0         | 1     | 0  | 0  | 0  | 0  | 0    | 0    |
| Bit    | 15 | 14 | 13  | 12   | 11      | 10     | 9        | 8        | 7         | 6     | 5  | 4  | 3  | 2  | 1    | 0    |
| Name   |    |    |     |      |         |        | dr       | f_dqs_ga | ate_pre_: | sel   |    |    |    |    |      |      |
| Туре   |    |    | RW  |      |         |        |          |          |           |       |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0   | 0    | 0       | 0      | 0        | 0        | 0         | 0     | 1  | 0  | 0  | 0  | 0    | 0    |

| Field Name               | Bit     | Туре | Reset<br>Value | Description                                                                    |
|--------------------------|---------|------|----------------|--------------------------------------------------------------------------------|
| drf_dqs_gate_p<br>st_sel | [31:16] | R/W  | 16'h40         | Timing adjustment: DQS gate pst signal delay select The unit is clk_emc cycle. |
| drf_dqs_gate_p<br>re_sel | [15:0]  | R/W  | 16'h20         | Timing adjustment: DQS gate pre signal delay select The unit is clk_emc cycle. |
|                          |         |      |                |                                                                                |

# 5.2.5.2.18 EMC\_DCFG7

Description: EMC DMEM control registers

| 0x019C |    |       | EMC | DMEN | 1 contr | ol reg | ister (F | Reset ( | 0x00F0  | 000E) |    |         | EMC_DCFG7 |    |    |    |
|--------|----|-------|-----|------|---------|--------|----------|---------|---------|-------|----|---------|-----------|----|----|----|
| Bit    | 31 | 30    | 29  | 28   | 27      | 26     | 25       | 24      | 23      | 22    | 21 | 20      | 19        | 18 | 17 | 16 |
| Name   |    |       |     |      |         |        |          | drf_dqs | _ie_sel |       |    |         |           |    |    |    |
| Type   |    | RW    |     |      |         |        |          |         |         |       |    |         |           |    |    |    |
| Reset  | 0  | 0     | 0   | 0    | 0       | 0      | 0        | 0       | 1       | 1     | 1  | 1       | 0         | 0  | 0  | 0  |
| Bit    | 15 | 14    | 13  | 12   | 11      | 10     | 9        | 8       | 7       | 6     | 5  | 4       | 3         | 2  | 1  | 0  |
| Name   |    |       |     | Rese | erved   |        |          |         |         |       |    | drf_dqs | _oe_sel   |    |    |    |
| Type   |    | RO RW |     |      |         |        |          |         |         |       |    |         |           |    |    |    |
| Reset  | 0  | 0     | 0   | 0    | 0       | 0      | 0        | 0       | 0       | 0     | 0  | 0       | 1         | 1  | 1  | 0  |



| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                  |
|----------------|---------|------|----------------|------------------------------------------------------------------------------|
| drf_dqs_ie_sel | [31:16] | R/W  | 16'hF0         | Timing adjustment: DQS PAD IE signal delay select The unit is clk_emc cycle. |
|                | [15:8]  | RO   | 0              | Reserved                                                                     |
| drf_dqs_oe_sel | [7:0]   | R/W  | 8'h0E          | Timing adjustment: DQS PAD OE signal delay select The unit is clk_emc cycle. |
|                |         |      |                |                                                                              |

# 5.2.5.2.19 EMC\_DCFG8

Description: EMC DMEM control registers

This register is used to configure external DMEM.

| 0x01A0 |    |                                                                                                                                                              | EMC | DMEN | I contr | ol reg | ister (F | Reset (  | 0x0040   | 0001) |   |          |         | EMC_DCFG8 |   |   |  |
|--------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|---------|--------|----------|----------|----------|-------|---|----------|---------|-----------|---|---|--|
| Bit    | 31 | 30         29         28         27         26         25         24         23         22         21         20         19         18         17         16 |     |      |         |        |          |          |          |       |   |          |         |           |   |   |  |
| Name   |    |                                                                                                                                                              |     |      |         |        |          | drf_data | a_ie_sel |       |   |          |         |           |   |   |  |
| Туре   |    | RW                                                                                                                                                           |     |      |         |        |          |          |          |       |   |          |         |           |   |   |  |
| Reset  | 0  | 0                                                                                                                                                            | 0   | 0    | 0       | 0      | 0        | 0        | 0        | 1     | 0 | 0        | 0       | 0         | 0 | 0 |  |
| Bit    | 15 | 14                                                                                                                                                           | 13  | 12   | 11      | 10     | 9        | 8        | 7        | 6     | 5 | 4        | 3       | 2         | 1 | 0 |  |
| Name   |    |                                                                                                                                                              |     | Rese | erved   |        |          |          |          |       |   | drf_data | _oe_sel |           |   |   |  |
| Туре   |    | RO RW                                                                                                                                                        |     |      |         |        |          |          |          |       |   |          |         |           |   |   |  |
| Reset  | 0  | 0                                                                                                                                                            | 0   | 0    | 0       | 0      | 0        | 0        | 0        | 0     | 0 | 0        | 0       | 0         | 0 | 1 |  |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                   |
|-----------------|---------|------|----------------|-------------------------------------------------------------------------------|
| drf_data_ie_sel | [31:16] | R/W  | 16'h40         | Timing adjustment: data PAD IE signal delay select The unit is clk_emc cycle. |
|                 | [15:8]  | RO   | 0              | Reserved                                                                      |
| drf_data_oe_se  | [7:0]   | R/W  | 8'h01          | Timing adjustment: data PAD OE signal delay select The unit is clk_emc cycle. |
|                 |         |      |                |                                                                               |

# 5.2.6 Application Notes

# 5.2.6.1 Application Notes



### 5.2.6.1.1 16-Bit SDR-SDRAM Configuration 1

#### Condition:

- CAS Latency is 2
- Burst Length is 2 16-bit
- **DLL OFF**

### Configure EMC:

```
(Suppose SDR-SDRAM is connected on CS0)
```

```
0x0000
              0x00000C45 (Default)
0x0004
              0x00000002 (Default)
0x0010
              0x0000003
0x0020
              0x000000FC (Default)
              0x0000000C + (rf_sync_sel_ch0<<4)
0x0024
              0x0003C31C + (rf_sync_sel_ch2<<13)
0x0030
0x0034
              0x00000000 (Default)
0x0180
              0x0000BE00 + (drf_row_mode<<0)
                   + (drf_column_mode<<4)
0x0184
              0x00000000 + (drf_t_rp<<0)
                   + (drf_t_rcd<<4)
                   + (drf_t_wr<<8)
                   + (drf_t_rrd<<12)
                   + (drf_t_ras<<16)
                   + (drf_t_rtw<<20)
                   + (drf_t_wtr<<24)
                   + (drf_t_rtr<<28)
0x0188
              0x00000000 + (drf_t_wrd << 0)
                   + (drf_t_ref<<4)
                   + (drf_t_xsr<<16)
                  + (drf_t_rfc<<24)
              0x00400007
0x0194
```

## Initialize external memory after configuring EMC:

0x00100001

```
0x40010000
0x0190
```

0x01A0

Wait until bit-16 of 0x0190 is cleared

0x0190 -- 0x40020000

Wait until bit-17 of 0x0190 is cleared

0x0190 -- 0x40020000

Wait until bit-17 of 0x0190 is cleared

-- 0x40040000 + (drf\_mode\_reg<<0) 0x0190

Wait until bit-18 of 0x0190 is cleared

-- 0x40040000 + (drf\_ext\_mode\_reg<<0) 0x0190

Wait until bit-18 of 0x0190 is cleared

# Open auto-refresh after initializing external memory:

Set 1 to bit 14 of 0x0180

# Description:

rf\_sync\_sel\_chx: if the HCLK of this channel is synchronous with clk\_emc, this bit can be set to improve performance.



- I drf\_row\_mode: row address bit select. See memory device specifications for this information.
- I drf\_column\_mode: column address bit select. See memory device specifications for this information.
- I drf\_t\_ref: Maximum Refresh period (or tREF).
  - (drf\_t\_ref+1)\*T\_cycle\*(row number) <= tREF. T\_cycle is clk\_emc\_ref cycle time. It's important that clk\_emc\_ref is different with clk\_emc. Normally, clk\_emc\_ref is a fixed-frequency clock with low frequency.
- drf\_t\_rfc: Minimum AUTO-REFRESH period (or tRFC). (drf\_t\_rfc+2)\*T\_cycle >= tRFC.
- drf\_t\_rp: Minimum PRECHARGE command period time (or tRP).
  (drf\_t\_rp+1)\*T\_cycle >= tRP.
- I drf\_t\_rcd: Minimum ACTIVE to READ or WRITE delay (or minimum RAS to CAS delay, or tRCD).
  - $(drf_t_rcd+1)^T_cycle >= tRCD.$
- drf\_t\_rrd: Minimum ACTIVE to ACTIVE (in different bank) time (or tRRD).
  (drf\_t\_rrd+1)\*T\_cycle >= tRRD.
- drf\_t\_wr: Minimum Write recovery time (or minimum last data-in to PRECHARGE time, or tWR, or tDPL, or tRDL).
  - $(drf_t_wr+1)^*T_cycle >= tWR.$
- drf\_t\_xsr: Minimum SELF-REFRESH time (tRAS for Micron, Samsung, etc).
  (drf\_t\_xsr+1)\*T\_cyle >= this minimum time.
- I drf\_t\_ras: Minimum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MIN).
  - $(drf_t_as+1)^T_cyle >= tRAS-MIN.$
- I drf\_t\_mrd: Minimum LOAD MODE REGISTER to ACTIVE or REFRESH delay (or tMRD).
  - $(drf_t_mrd+2)^T_cycle >= tMRD.$
- drf\_mode\_reg: Mode Register. drf\_mode\_reg[13:0] is mapped to A[13:0] and drf\_mode\_reg[15:14] is mapped to BA[1:0]. It's IMPORTANT that CAS Latency MUST be configured to 2 and Burst Length MUST be configured to 2 16-bit.
- I drf\_ext\_mode\_reg: Extended Mode Register

### 5.2.6.1.2 16-Bit SDR-SDRAM Configuration 2

### Condition:

- I CAS Latency is 3
- I Burst Length is 2 16-bit

# Configure EMC:

(Suppose SDR-SDRAM is connected on CS0)

- I 0x0000 -- 0x00000C45 (Default)
  I 0x0004 -- 0x00000002 (Default)
- I 0x0010 -- 0x00000003
- I 0x0020 -- 0x000000FC (Default)
- I 0x0024 -- 0x0000000C + (rf\_sync\_sel\_ch0<<4)
- ...
  I 0x0030 -- 0x0003C31C + (rf\_sync\_sel\_ch2<<13)
- I 0x0034 -- 0x00000000 (Default)
- I 0x0180 -- 0x0000BE00 + (drf\_row\_mode<<0)
  - + (drf\_column\_mode<<4)



```
0x0184
               0x000000000 + (drf t rp << 0)
                    + (drf_t_rcd<<4)
                   + (drf_t_wr<<8)
                   + (drf_t_rrd<<12)
                    + (drf_t_ras<<16)
                    + (drf_t_rtw<<20)
                    + (drf_t_wtr<<24)
                    + (drf_t_rtr<<28)
0x0188
               0x00000000 + (drf_t_wrd<<0)
                    + (drf_t_ref<<4)
                    + (drf_t_xsr<<16)
                    + (drf_t_rfc<<24)
0x0194
               0x00600209
0x01A0
               0x00400001
```

### Initialize external memory after configuring EMC:

- I 0x0190 -- 0x40010000
- Wait until bit-16 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- I Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- I Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf mode reg<<0)
- I Wait until bit-18 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_ext\_mode\_reg<<0)
- I Wait until bit-18 of 0x0190 is cleared

### Open auto-refresh after initializing external memory:

I Set 1 to bit-14 of 0x0180

### Description:

- I rf\_sync\_sel\_chx: if the HCLK of this channel is synchronous with clk\_emc, this bit can be set to improve performance.
- I drf\_row\_mode: row address bit select. See memory device specifications for this information.
- I drf\_column\_mode: column address bit select. See memory device specifications for this information.
- I drf t\_ref: Maximum Refresh period (or tREF).
  - (drf t ref+1)\*T cycle\*(row number) <= tREF. T cycle is clk emc ref cycle time.
  - It's important that clk\_emc\_ref is different with clk\_emc. Normally, clk\_emc\_ref is a fixed-frequency clock with low frequency.
  - drf\_t\_rfc: Minimum AUTO-REFRESH period (or tRFC).
    - $(drf_t_rfc+2)^T_cycle >= tRFC.$
- I drf\_t\_rp: Minimum PRECHARGE command period time (or tRP).
  - $(drf_t_p+1)^T_cycle >= tRP.$
- I drf\_t\_rcd: Minimum ACTIVE to READ or WRITE delay (or minimum RAS to CAS delay, or tRCD).
  - $(drf_t_rcd+1)^T_cycle >= tRCD.$
- drf\_t\_rrd: Minimum ACTIVE to ACTIVE (in different bank) time (or tRRD).
  (drf\_t\_rrd+1)\*T\_cycle >= tRRD.
- I drf\_t\_wr: Minimum Write recovery time (or minimum last data-in to PRECHARGE time, or tWR, or tDPL, or tRDL).



 $(drf_t_wr+1)^*T_cycle >= tWR.$ 

- I drf\_t\_xsr: Minimum SELF-REFRESH time (tRAS for Micron, Samsung, etc). (drf\_t\_xsr+1)\*T\_cyle >= this minimum time.
- I drf\_t\_ras: Minimum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MIN).

 $(drf_t_as+1)*T_cyle >= tRAS-MIN.$ 

I drf\_t\_mrd: Minimum LOAD MODE REGISTER to ACTIVE or REFRESH delay (or tMRD).

 $(drf_t_mrd+2)^*T_cycle >= tMRD.$ 

- I drf\_mode\_reg: Mode Register. drf\_mode\_reg[13:0] is mapped to A[13:0] and drf\_mode\_reg[15:14] is mapped to BA[1:0]. It's IMPORTANT that CAS Latency MUST be configured to 3 and Burst Length MUST be configured to 2 16-bit.
- I drf ext mode reg: Extended Mode Register

### 5.2.6.1.3 32-Bit SDR-SDRAM Configuration 1

### Condition:

- I CAS Latency is 2
- I Burst Length is 1 32-bit or 2 32-bit

### Configure EMC:

```
(Suppose SDR-SDRAM is connected on CS0)
```

```
I 0x0000 -- 0x00000C45 (Default)
```

I 0x0004 -- 0x00000002 (Default)
I 0x0010 -- 0x00000003 if Burst Length is 1 32-bit

I (0x0010 -- 0x000000113 if Burst Length is 2 32-bit) (Default)

I 0x0020 -- 0x000000FC (Default)

I 0x0024 -- 0x0000000C + (rf\_sync\_sel\_ch0<<4)

... I 0x0030 -- 0x0003C31C + (rf\_sync\_sel\_ch2<<13)

I 0x0034 -- 0x00000000 (Default)

I 0x0180 -- 0x0000BF00 + (drf\_row\_mode<<0)

+ (drf\_column\_mode<<4)

I 0x0184 --  $0x00000000 + (drf_t_p < 0)$ 

+ (drf\_t\_rcd<<4)

+ (drf\_t\_wr<<8)

+ (drf\_t\_rrd<<12)

+ (drf\_t\_ras<<16)

+ (drf\_t\_rtw<<20)

+ (drf\_t\_wtr<<24)

+ (drf\_t\_rtr<<28)

I 0x0188 -- 0x00000000 + (drf\_t\_wrd<<0)

+ (drf\_t\_ref<<4)

+ (drf\_t\_xsr<<16)

+ (drf\_t\_rfc<<24)

i 0x0194 -- 0x00400007 i 0x01A0 -- 0x00100001

Initialize external memory after configuring EMC:

I 0x0190 -- 0x40010000



- I Wait until bit-16 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_mode\_reg<<0)
- I Wait until bit-18 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_ext\_mode\_reg<<0)
- I Wait until bit-18 of 0x0190 is cleared

### Open auto-refresh after initializing external memory:

I Set 1 to bit 14 of 0x0180

### Description:

- I rf\_sync\_sel\_chx: if the HCLK of this channel is synchronous with clk\_emc, this bit can be set to improve performance.
- I drf\_row\_mode: row address bit select. See memory device specifications for this information.
- I drf\_column\_mode: column address bit select. See memory device specifications for this information.
- I drf\_t\_ref: Maximum Refresh period (or tREF).
  - (drf\_t\_ref+1)\*T\_cycle\*(row number) <= tREF. T\_cycle is clk\_emc\_ref cycle time. It's important that clk\_emc\_ref is different with clk\_emc. Normally, clk\_emc\_ref is a fixed-frequency clock with low frequency.
- I drf\_t\_rfc: Minimum AUTO-REFRESH period (or tRFC).
  - $(drf\ t\ rfc+2)*T\ cycle >= tRFC.$
- I drf\_t\_rp: Minimum PRECHARGE command period time (or tRP).
  - $(drf_t_p+1)^T_cycle >= tRP.$
- I drf\_t\_rcd: Minimum ACTIVE to READ or WRITE delay (or minimum RAS to CAS delay, or tRCD).
  - (drf t rcd+1)\*T cycle >= tRCD.
- I drf\_t\_rrd: Minimum ACTIVE to ACTIVE (in different bank) time (or tRRD). (drf\_t\_rrd+1)\*T\_cycle >= tRRD.
- drf\_t\_wr: Minimum Write recovery time (or minimum last data-in to PRECHARGE time, or tWR, or tDPL, or tRDL).
  - $(drf_t_wr+1)^*T_cycle >= tWR.$
- drf\_t\_xsr: Minimum SELF-REFRESH time (tRAS for Micron, Samsung, etc).
  (drf\_t\_xsr+1)\*T\_cyle >= this minimum time.
- drf\_t\_ras: Minimum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MIN).
  - $(drf_t_as+1)*T_cyle >= tRAS-MIN.$
- drf\_t\_mrd: Minimum LOAD MODE REGISTER to ACTIVE or REFRESH delay (or tMRD).
  - $(drf_t_mrd+2)^T_cycle >= tMRD.$
- I drf\_mode\_reg: Mode Register. drf\_mode\_reg[13:0] is mapped to A[13:0] and drf\_mode\_reg[15:14] is mapped to BA[1:0]. It's IMPORTANT that CAS Latency MUST be configured to 2 and Burst Length MUST be configured to 1 32-bit or 2 32-bit.
- I drf\_ext\_mode\_reg: Extended Mode Register

#### 5.2.6.1.4 32-Bit SDR-SDRAM Configuration 2



#### Condition:

- I CAS Latency is 3
- I Burst Length is 1 32-bit or 2 32-bit

## Configure EMC:

```
(Suppose SDR-SDRAM is connected on CS0)
   0x0000
                  0x00000C45 (Default)
   0x0004
                  0x00000002 (Default)
   0x0010
                  0x00000003 if Burst Length is 1 32-bit
                  0x00000113 if Burst Length is 2 32-bit)
   (0x0010
   0x0020
                  0x00000FC (Default)
   0x0024
                  0x0000000C + (rf_sync_sel_ch0<<4)
   0x0030
                  0x0003C31C + (rf_sync_sel_ch2<<13)
   0x0034
                  0x00000000 (Default)
   0x0180
                  0x0000BF00 + (drf row mode << 0)
                      + (drf_column_mode<<4)
   0x0184
                  0x00000000 + (drf_t_rp << 0)
                      + (drf_t_rcd<<4)
                      + (drf_t_wr<<8)
                      + (drf_t_rrd<<12)
                      + (drf_t_ras<<16)
                      + (drf_t_rtw<<20)
                      + (drf_t_wtr<<24)
                      + (drf_t_rtr<<28)
   0x0188
                  0x00000000 + (drf_t wrd << 0)
                      + (drf_t_ref<<4)
                      + (drf_t_xsr<<16)
                      + (drf_t_rfc<<24)
   0x0194
                  0x00600209 (Default)
   0x01A0
                  0x00400001
```

### Initialize external memory after configuring EMC:

```
I 0x0190 -- 0x40010000
```

Wait until bit-16 of 0x0190 is cleared

I 0x0190 -- 0x40020000

Wait until bit-17 of 0x0190 is cleared

1 0x0190 -- 0x40020000

Wait until bit-17 of 0x0190 is cleared

0x0190 -- 0x40040000 + (drf\_mode\_reg<<0)

Wait until bit-18 of 0x0190 is cleared

0x0190 -- 0x40040000 + (drf\_ext\_mode\_reg<<0)

Wait until bit-18 of 0x0190 is cleared

#### Open auto-refresh after initializing external memory:

I Set 1 to bit 14 of 0x0180

#### Description:

- I rf\_sync\_sel\_chx: if the HCLK of this channel is synchronous with clk\_emc, this bit can be set to improve performance.
- I drf\_row\_mode: row address bit select. See memory device specifications for this information.



- drf column mode: column address bit select. See memory device specifications for this information.
- drf\_t\_ref: Maximum Refresh period (or tREF).
  - (drf\_t\_ref+1)\*T\_cycle\*(row number) <= tREF. T\_cycle is clk\_emc\_ref cycle time. It's important that clk\_emc\_ref is different with clk\_emc. Normally, clk\_emc\_ref is a fixed-frequency clock with low frequency.
- drf\_t\_rfc: Minimum AUTO-REFRESH period (or tRFC).  $(drf_t_rfc+2)^T_cycle >= tRFC.$
- drf\_t\_rp: Minimum PRECHARGE command period time (or tRP).  $(drf_t_p+1)^T_cycle >= tRP.$
- drf\_t\_rcd: Minimum ACTIVE to READ or WRITE delay (or minimum RAS to CAS delay, or tRCD).
  - $(drf_t_rcd+1)^T_cycle >= tRCD.$
- drf\_t\_rrd: Minimum ACTIVE to ACTIVE (in different bank) time (or tRRD).  $(drf_t_rd+1)^T_cycle >= tRRD.$
- drf\_t\_wr: Minimum Write recovery time (or minimum last data-in to PRECHARGE time, or tWR, or tDPL, or tRDL).
  - $(drf_t_wr+1)^*T_cycle >= tWR.$
- drf t xsr: Minimum SELF-REFRESH time (tRAS for Micron, Samsung, etc).  $(drf_t_x_s_t_1)^*T_cyle >= this minimum time.$
- drf t ras: Minimum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MIN).
  - $(drf_t_as+1)*T_cyle >= tRAS-MIN.$
- drf t\_mrd: Minimum LOAD MODE REGISTER to ACTIVE or REFRESH delay (or tMRD).
  - $(drf_t_mrd+2)^*T_cycle >= tMRD.$
- drf mode reg: Mode Register, drf mode reg[13:0] is mapped to A[13:0] and drf mode reg[15:14] is mapped to BA[1:0]. It's IMPORTANT that CAS Latency MUST be configured to 3 and Burst Length MUST be configured to 1 32-bit or 2
- drf\_ext\_mode\_reg: Extended Mode Register

### 5.2.6.1.5 16-Bit DDR-SDRAM Configuration 1

#### Condition:

- CAS Latency is 2
- Burst Length is 2 16-bit

### Configure EMC:

```
(Suppose DDR-SDRAM is connected on CS0)
```

- 0x0000 0x00000C45 (Default) 0x00000049 0x0004 0x0010 0x0000003 0x0020
- 0x000000FC (Default)
- 0x0024 0x0000000C + (rf\_sync\_sel\_ch0<<4)
- 0x0030 0x0003C31C + (rf\_sync\_sel\_ch2<<13)
- 0x00000000 (Default) 0x0034
- 0x0180 0x0000BE00 + (drf\_row\_mode<<0)
  - + (drf\_column\_mode<<4)
- 0x0184  $0x00000000 + (drf_t_rp << 0)$



```
+ (drf_t_rcd<<4)
                      + (drf_t_wr<<8)
                      + (drf_t_rrd<<12)
                      + (drf_t_ras<<16)
                      + (drf_t_rtw<<20)
                      + (drf_t_wtr<<24)
                      + (drf_t_rtr<<28)
    0x0188
                  0x00000000 + (drf_t_wrd<<0)
                      + (drf_t_ref<<4)
                      + (drf_t_xsr<<16)
                      + (drf_t_rfc<<24)
    0x0194
                  0x00622728
    0x0198
                  0x00080004
    0x019C
                  0x00F0000E
    0x01A0
                  0x00F0000E
Configure delay lines:
DLL OFF:
clk_emc: 200MHz
    0x010C
                  0x0000018
    0x0110
                  0x000000C
    0x0114
                  0x000000C
    0x0118
                  0x000000C
    0x011C
                  0x000000C
    0x0120
                  0x000000C
    0x0124
                  0x000000C
    0x0128
                  0x000000C
    0x012C
                  0x000000C
    0x0130
                  0x00000018
    0x0134
                  0x00000018
    0x0138
                  0x00000018
    0x013C
                  0x00000018
    0x0140
                  0x00000018
    0x0144
                  0x00000018
    0x0148
                  0x00000018
                  0x00000018
    0x014C
clk_emc: 400MHz
    0x010C
                  0x000000C
    0x0110
                  0x00000006
    0x0114
                  0x00000006
    0x0118
                  0x00000006
    0x011C
                  0x00000006
    0x0120
                  0x00000006
    0x0124
             --
                  0x00000006
    0x0128
             --
                  0x00000006
    0x012C
                  0x00000006
             --
    0x0130
                  0x000000C
             --
    0x0134
             --
                  0x0000000C
    0x0138
                  0x000000C
    0x013C
                  0x000000C
    0x0140
                  0x000000C
    0x0144
                  0x000000C
```

0x0148

0x014C

0x000000C

0x000000C



### DLL ON:

```
0x0170
             0x00011080
0x010C
             0x00008040
0x0110
             0x00008020
0x0114
             0x00008020
0x0118
             0x00008020
0x011C
             0x00008020
0x0120
             0x00008020
0x0124
             0x00008020
0x0128
             0x00008020
0x012C
             0x00008020
0x0130
             0x00008040
             0x00008040
0x0134
0x0138
             0x00008040
0x013C
             0x00008040
0x0140
             0x00008040
0x0144
             0x00008040
0x0148
             0x00008040
0x014C
             0x00008040
0x0170
             0x00011480
```

## Initialize external memory after configuring EMC:

- I 0x0190 -- 0x40010000
- Wait until bit-16 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- I Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_mode\_reg<<0)
- I Wait until bit-18 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_ext\_mode\_reg<<0)
- I Wait until bit-18 of 0x0190 is cleared

# Open auto-refresh after initializing external memory:

I Set 1 to bit 14 of 0x0180

### Description:

- I rf\_sync\_sel\_chx: if the HCLK of this channel is synchronous with clk\_emc, this bit can be set to improve performance.
- drf\_row\_mode: row address bit select. See memory device specifications for this information.
- drf\_column\_mode: column address bit select. See memory device specifications for this information.
- I drf\_t\_ref: Maximum Refresh period (or tREF).
  - (drf\_t\_ref+1)\*T\_cycle\*(row number) <= tREF. T\_cycle is clk\_emc\_ref cycle time. It's important that clk\_emc\_ref is different with clk\_emc. Normally, clk\_emc\_ref is a fixed-frequency clock with low frequency.
- I drf\_t\_rfc: Minimum AUTO-REFRESH period (or tRFC).
  - $(drf_t_rfc+2)^T_cycle >= tRFC.$
- I drf\_t\_rp: Minimum PRECHARGE command period time (or tRP).
   (drf\_t\_rp+1)\*T\_cycle >= tRP.
- I drf\_t\_rcd: Minimum ACTIVE to READ or WRITE delay (or minimum RAS to CAS delay, or tRCD).



```
(drf\ t\ rcd+1)*T\ cycle >= tRCD.
```

- drf\_t\_rrd: Minimum ACTIVE to ACTIVE (in different bank) time (or tRRD).
  (drf\_t\_rrd+1)\*T\_cycle >= tRRD.
- I drf\_t\_wr: Minimum Write recovery time (or minimum last data-in to PRECHARGE time, or tWR, or tDPL, or tRDL).

```
(drf_t_wr -1)^*T_cycle >= tWR.
```

- I drf\_t\_xsr: Minimum SELF-REFRESH time (tRAS for Micron, Samsung, etc). (drf\_t\_xsr+1)\*T\_cyle >= this minimum time.
- I drf\_t\_ras: Minimum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MIN).

```
(drf_t_as+1)^T_cyle >= tRAS-MIN.
```

- drf\_t\_wtr: Minimum WRITE-to-READ turn-around time. (drf\_t\_wtr+1)\*T\_cycle >= tWTR+2.
- I drf\_t\_mrd: Minimum LOAD MODE REGISTER to ACTIVE or REFRESH delay (or tMRD).

```
(drf_t_mrd+2)^T_cycle >= tMRD.
```

- drf\_mode\_reg: Mode Register. drf\_mode\_reg[13:0] is mapped to A[13:0] and drf\_mode\_reg[15:14] is mapped to BA[1:0]. It's IMPORTANT that CAS Latency MUST be configured to 2 and Burst Length MUST be configured to 2 16-bit.
- I drf\_ext\_mode\_reg: Extended Mode Register

## 5.2.6.1.6 16-Bit DDR-SDRAM Configuration 2

### Condition:

- I CAS Latency is 3
- I Burst Length is 2 16-bit

#### Configure EMC:

```
(Suppose DDR-SDRAM is connected on CS0)
```

```
0x0000
              0x00000C45 (Default)
0x0004
              0x00000049
0x0010
              0x00000003
0x0020
              0x000000FC (Default)
0x0024
              0x0000000C + (rf_sync_sel_ch0<<4)
0x0030
              0x0003C31C + (rf_sync_sel_ch2<<13)
0x0034
              0x00000000 (Default)
0x0180
              0x0000BE00 + (drf_row_mode<<0)
                   + (drf_column_mode<<4)
0x0184
              0x00000000 + (drf_t_rp << 0)
                   + (drf_t_rcd<<4)
                   + (drf_t_wr<<8)
                   + (drf_t_rrd<<12)
                   + (drf_t_ras<<16)
                   + (drf_t_rtw<<20)
                   + (drf_t_wtr<<24)
                   + (drf_t_rtr<<28)
0x0188
              0x00000000 + (drf_t wrd << 0)
                   + (drf_t_ref<<4)
```

+ (drf\_t\_xsr<<16)



### + (drf\_t\_rfc<<24)

I 0x0194 -- 0x0062272A I 0x0198 -- 0x00200010 I 0x019C -- 0x00F0000E I 0x01A0 -- 0x00F0000E

### Configure delay lines:

### DLL OFF:

### clk\_emc: 200MHz

0x010C 0x0000018 0x0110 0x000000C 0x0114 0x000000C 0x0118 0x000000C 0x011C 0x000000C 0x0120 0x000000C 0x0124 0x000000C 0x0128 0x000000C 0x012C 0x000000C 0x0130 0x00000018 0x0134 0x00000018 0x0138 --0x0000018 0x013C 0x0000018 0x0140 --0x0000018 0x0144 --0x0000018 0x0148 --0x0000018

0x0000018

### clk\_emc: 400MHz

0x014C

0x010C 0x000000C 0x0110 --0x00000006 0x0114 0x00000006 0x0118 0x00000006 0x011C 0x00000006 0x0120 0x00000006 0x0124 0x00000006 0x0128 0x00000006 0x012C 0x00000006 0x0130 0x000000C 0x0134 0x0000000C 0x0138 0x000000C 0x013C 0x000000C 0x0140 0x000000C 0x0144 0x0000000C 0x0148 0x0000000C 0x014C 0x0000000C

### DLL ON:

0x0170 0x00011080 0x010C --0x00008040 0x0110 --0x00008020 0x00008020 0x0114 0x0118 0x00008020 0x011C 0x00008020 0x0120 0x00008020 0x0124 0x00008020 0x0128 0x00008020



```
0x012C
             0x00008020
0x0130
             0x00008040
0x0134
             0x00008040
0x0138
             0x00008040
0x013C
             0x00008040
0x0140
             0x00008040
0x0144
             0x00008040
             0x00008040
0x0148
0x014C
             0x00008040
0x0170
             0x00011480
```

## Initialize external memory after configuring EMC:

- I 0x0190 -- 0x40010000
- I Wait until bit-16 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_mode\_reg<<0)
- Wait until bit-18 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_ext\_mode\_reg<<0
- Wait until bit-18 of 0x0190 is cleared

### Open auto-refresh after initializing external memory:

I Set 1 to bit 14 of 0x0180

### Description:

- I rf\_sync\_sel\_chx: if the HCLK of this channel is synchronous with clk\_emc, this bit can be set to improve performance.
- I drf\_row\_mode: row address bit select. See memory device specifications for this information.
- I drf\_column\_mode: column address bit select. See memory device specifications for this information.
- I drf\_t\_ref: Maximum Refresh period (or tREF).
  - (drf\_t\_ref+1)\*T\_cycle\*(row number) <= tREF. T\_cycle is clk\_emc\_ref cycle time. It's important that clk\_emc\_ref is different with clk\_emc. Normally, clk\_emc\_ref is a fixed-frequency clock with low frequency.
- I drf\_t\_rfc: Minimum AUTO-REFRESH period (or tRFC).
  - $(drf_t_rfc+2)*T_cycle >= tRFC.$
- I drf\_t\_rp: Minimum PRECHARGE command period time (or tRP).
  - $(drf_t_p+1)^T_cycle >= tRP.$
- drf\_t\_rcd: Minimum ACTIVE to READ or WRITE delay (or minimum RAS to CAS delay, or tRCD).
  - $(drf_t_rcd+1)^T_cycle >= tRCD.$
- I drf\_t\_rrd: Minimum ACTIVE to ACTIVE (in different bank) time (or tRRD).
  (drf\_t\_rrd+1)\*T\_cycle >= tRRD.
- I drf\_t\_wr: Minimum Write recovery time (or minimum last data-in to PRECHARGE time, or tWR, or tDPL, or tRDL).
  - $(drf_t_wr -1)^*T_cycle >= tWR.$
- I drf\_t\_xsr: Minimum SELF-REFRESH time (tRAS for Micron, Samsung, etc).
  (drf\_t\_xsr+1)\*T\_cyle >= this minimum time.
- I drf\_t\_ras: Minimum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MIN).
  - $(drf_t_as+1)^T_cyle >= tRAS-MIN.$



- drf t wtr: Minimum WRITE-to-READ turn-around time.  $(drf_t_wtr+1)^*T_cycle >= tWTR+2.$
- drf\_t\_mrd: Minimum LOAD MODE REGISTER to ACTIVE or REFRESH delay (or tMRD).
  - $(drf_t_mrd+2)^*T_cycle >= tMRD.$
- drf\_mode\_reg: Mode Register. drf\_mode\_reg[13:0] is mapped to A[13:0] and drf\_mode\_reg[15:14] is mapped to BA[1:0]. It's IMPORTANT that CAS Latency MUST be configured to 2 and Burst Length MUST be configured to 2 16-bit.
- drf ext mode reg: Extended Mode Register

## 5.2.6.1.7 32-Bit DDR-SDRAM Configuration 1

#### Condition:

- CAS Latency is 2
- Burst Length is 2 32-bit

### Configure EMC:

```
(Suppose SDR-SDRAM is connected on CS0)
```

```
0x0000
              0x00000C45 (Default)
```

0x0004 0x00000049

0x0010 0x00000113 (Default)

0x0020 0x000000FC (Default) 0x0024

0x0000000C + (rf\_sync\_sel\_ch0<<4)

0x0030 0x0003C31C + (rf\_sync\_sel\_ch2<<13)

0x0034 0x00000000 (Default)

0x0180 0x0000BF00 + (drf\_row\_mode<<0)

+ (drf\_column\_mode<<4)

0x0184  $0x00000000 + (drf_t rp << 0)$ 

+ (drf\_t\_rcd<<4)

+ (drf\_t\_wr<<8)

+ (drf\_t\_rrd<<12)

+ (drf\_t\_ras<<16)

+ (drf\_t\_rtw<<20)

+ (drf\_t\_wtr<<24)

+ (drf\_t\_rtr<<28)

0x0188 0x00000000 + (drf\_t\_wrd<<0)

+ (drf\_t\_ref<<4)

+ (drf\_t\_xsr<<16)

+ (drf\_t\_rfc<<24)

0x0194 0x00622728

0x0198 0x00200010

0x019C 0x00F0000E

0x01A0 0x00F0000E

## Configure delay lines:

### DLL OFF:

clk\_emc: 200MHz

0x010C 0x00000018 0x0110 0x000000C



```
0x0114
            0x000000C
0x0118
            0x000000C
            0x000000C
0x011C
0x0120
            0x000000C
0x0124
            0x000000C
0x0128
            0x000000C
0x012C
            0x000000C
0x0130
            0x0000018
0x0134
            0x0000018
0x0138
            0x0000018
0x013C
            0x0000018
0x0140
            0x0000018
0x0144
            0x0000018
0x0148
            0x0000018
0x014C
            0x0000018
```

### clk\_emc: 400MHz

0x010C 0x0000000C 0x0110 0x00000006 0x0114 0x00000006 0x0118 0x0000006 0x011C 0x00000006 0x0120 0x0000006 0x0124 0x00000006 0x0128 0x0000006 0x012C 0x0000006 0x0130 0x000000C 0x0134 0x0000000C 0x0138 0x000000C 0x013C 0x000000C 0x0140 0x000000C 0x0144 0x000000C 0x0148 --0x0000000C 0x014C 0x000000C

#### DLL ON:

0x0170 0x00011080 0x010C 0x00008040 0x0110 0x00008020 0x0114 0x00008020 0x0118 0x00008020 0x00008020 0x011C 0x0120 0x00008020 0x0124 0x00008020 0x0128 0x00008020 0x012C 0x00008020 0x0130 0x00008040 0x0134 0x00008040 0x0138 0x00008040 0x013C 0x00008040 0x0140 0x00008040 0x0144 0x00008040 0x0148 0x00008040 0x014C --0x00008040 0x0170 0x00011480

Initialize external memory after configuring EMC:



- I 0x0190 -- 0x40010000
- Wait until bit-16 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- I Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- I Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_mode\_reg<<0)
- I Wait until bit-18 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_ext\_mode\_reg<<0)
- I Wait until bit-18 of 0x0190 is cleared

### Open auto-refresh after initializing external memory:

Set 1 to bit 14 of 0x0180

#### Description:

- I rf\_sync\_sel\_chx: if the HCLK of this channel is synchronous with clk\_emc, this bit can be set to improve performance.
- I drf\_row\_mode: row address bit select. See memory device specifications for this information.
- I drf\_column\_mode: column address bit select. See memory device specifications for this information.
- I drf\_t\_ref: Maximum Refresh period (or tREF).
  - (drf\_t\_ref+1)\*T\_cycle\*(row number) <= tREF. T\_cycle is clk\_emc\_ref cycle time.
  - It's important that clk\_emc\_ref is different with clk\_emc. Normally, clk\_emc\_ref is a fixed-frequency clock with low frequency.
- I drf\_t\_rfc: Minimum AUTO-REFRESH period (or tRFC).
  - $(drf_t_rfc+2)^T_cycle >= tRFC.$
- I drf\_t\_rp: Minimum PRECHARGE command period time (or tRP).
  - $(drf_t_p+1)^T_cycle >= tRP.$
- drf\_t\_rcd: Minimum ACTIVE to READ or WRITE delay (or minimum RAS to CAS delay, or tRCD).
  - $(drf_t_rcd+1)^T_cycle >= tRCD.$
- I drf\_t\_rrd: Minimum ACTIVE to ACTIVE (in different bank) time (or tRRD).
  - $(drf_t_rd+1)^T_cycle >= tRRD.$
- I drf\_t\_wr: Minimum Write recovery time (or minimum last data-in to PRECHARGE time, or tWR, or tDPL, or tRDL).
  - (drf t wr -1)\*T cycle >= tWR.
- I drf\_t\_xsr: Minimum SELF-REFRESH time (tRAS for Micron, Samsung, etc).
  - (drf\_t\_xsr+1)\*T\_cyle >= this minimum time.
- drf\_t\_ras: Minimum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MIN).
  - $(drf_t_as+1)^T_cyle >= tRAS-MIN.$
- drf\_t\_wtr: Minimum WRITE-to-READ turn-around time.
  - $(drf_t wtr+1)*T_cycle >= tWTR+2.$
- I drf\_t\_mrd: Minimum LOAD MODE REGISTER to ACTIVE or REFRESH delay (or tMRD).
  - $(drf_t_mrd+2)^*T_cycle >= tMRD.$
- I drf\_mode\_reg: Mode Register. drf\_mode\_reg[13:0] is mapped to A[13:0] and drf\_mode\_reg[15:14] is mapped to BA[1:0]. It's IMPORTANT that CAS Latency MUST be configured to 2 and Burst Length MUST be configured to 2 16-bit.
- I drf\_ext\_mode\_reg: Extended Mode Register



### 5.2.6.1.8 32-Bit DDR-SDRAM Configuration 2

#### Condition:

- CAS Latency is 3
- Burst Length is 2 32-bit

## Configure EMC:

```
(Suppose SDR-SDRAM is connected on CS0)
```

```
0x0000
              0x00000C45 (Default)
0x0004
              0x00000049
0x0010
              0x00000113 (Default)
0x0020
              0x000000FC (Default)
0x0024
              0x0000000C + (rf_sync_sel_ch0<<4)
              0x0003C31C + (rf_sync_sel_ch2<<13)
0x0030
              0x00000000 (Default)
0x0034
0x0180
              0x0000BF00 + (drf_row_mode<<0)
                   + (drf_column_mode<<4)
0x0184
              0x00000000 + (drf_t_rp<<0)
                  + (drf_t_rcd<<4)
                  + (drf_t_wr<<8)
                   + (drf_t_rrd<<12)
                  + (drf_t_ras<<16)
                  + (drf_t_rtw<<20)
                   + (drf_t_wtr<<24)
                   + (drf_t_rtr<<28)
              0x00000000 + (drf_t_wrd << 0)
0x0188
```

- - + (drf t ref<<4)
  - + (drf\_t\_xsr<<16)
  - + (drf\_t\_rfc<<24)
- 0x0062272A 0x0194
- 0x0198 0x00400020 (Default)
- 0x019C 0x00F0000E
- 0x01A0 0x00F0000E

# Configure delay lines:

### DLL OFF:

#### clk\_emc: 200MHz

0x010C --0x00000018 0x0110 0x000000C 0x0114 0x000000C 0x0118 0x000000C 0x011C 0x000000C 0x0120 0x000000C 0x0124 0x000000C 0x0128 0x000000C 0x012C 0x000000C 0x0130 0x0000018 0x0134 0x00000018 0x0138 0x0000018 0x013C 0x00000018 0x0140 0x0000018 0x0144 0x00000018 0x0148 0x00000018



I 0x014C -- 0x00000018

### clk\_emc: 400MHz

0x010C 0x000000C 0x0110 0x00000006 0x0114 0x00000006 0x0118 0x00000006 0x011C 0x00000006 0x0120 0x00000006 0x0124 0x00000006 0x0128 0x00000006 0x012C 0x00000006 0x0130 0x000000C 0x0134 0x000000C 0x0138 --0x000000C 0x013C 0x000000C --0x0140 --0x000000C 0x0144 0x000000C --0x0148 0x000000C 0x014C 0x000000C

### DLL ON:

0x0170 0x00011080 0x00008040 0x010C 0x0110 0x00008020 0x0114 0x00008020 0x0118 0x00008020 0x011C 0x00008020 0x0120 0x00008020 0x0124 0x00008020 0x00008020 0x0128 0x012C 0x00008020 0x0130 0x00008040 0x0134 0x00008040 0x0138 0x00008040 0x013C 0x00008040 0x0140 0x00008040 0x0144 0x00008040 0x0148 0x00008040 0x014C 0x00008040 0x0170 0x00011480

### Initialize external memory after configuring EMC:

- 0x0190 -- 0x40010000
- Wait until bit-16 of 0x0190 is cleared
- 0x0190 -- 0x40020000
- Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40020000
- I Wait until bit-17 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_mode\_reg<<0)
- I Wait until bit-18 of 0x0190 is cleared
- I 0x0190 -- 0x40040000 + (drf\_ext\_mode\_reg<<0)
- Wait until bit-18 of 0x0190 is cleared

Open auto-refresh after initializing external memory:

I Set 1 to bit 14 of 0x0180



#### Description:

- I rf\_sync\_sel\_chx: if the HCLK of this channel is synchronous with clk\_emc, this bit can be set to improve performance.
- I drf\_row\_mode: row address bit select. See memory device specifications for this information.
- I drf\_column\_mode: column address bit select. See memory device specifications for this information.
- I drf\_t\_ref: Maximum Refresh period (or tREF).
  - (drf\_t\_ref+1)\*T\_cycle\*(row number) <= tREF. T\_cycle is clk\_emc\_ref cycle time.

    It's important that clk\_emc\_ref is different with clk\_emc. Normally, clk\_emc\_ref is a fixed-frequency clock with low frequency.
- drf\_t\_rfc: Minimum AUTO-REFRESH period (or tRFC). (drf\_t\_rfc+2)\*T\_cycle >= tRFC.
- I drf\_t\_rp: Minimum PRECHARGE command period time (or tRP)
   (drf\_t\_rp+1)\*T\_cycle >= tRP.
- I drf\_t\_rcd: Minimum ACTIVE to READ or WRITE delay (or minimum RAS to CAS delay, or tRCD).
  - $(drf_t_rcd+1)^*T_cycle >= tRCD.$
- I drf\_t\_rrd: Minimum ACTIVE to ACTIVE (in different bank) time (or tRRD).
  (drf\_t\_rrd+1)\*T\_cycle >= tRRD.
- I drf\_t\_wr: Minimum Write recovery time (or minimum last data-in to PRECHARGE time, or tWR, or tDPL, or tRDL).
  (drf t wr -1)\*T cycle >= tWR.
- drf\_t\_xsr: Minimum SELF-REFRESH time (tRAS for Micron, Samsung, etc).
  (drf\_t\_xsr+1)\*T\_cyle >= this minimum time.
- I drf\_t\_ras: Minimum ACTIVE to PRECHARGE time (or minimum row active time, or tRAS-MIN).
  - $(drf_t_as+1)*T_cyle >= tRAS-MIN.$
- I drf\_t\_wtr: Minimum WRITE-to-READ turn-around time. (drf\_t\_wtr+1)\*T\_cycle >= tWTR+2.
- I drf\_t\_mrd: Minimum LOAD MODE REGISTER to ACTIVE or REFRESH delay (or tMRD).
  - $(drf_t_mrd+2)^*T_cycle >= tMRD.$
- I drf\_mode\_reg: Mode Register. drf\_mode\_reg[13:0] is mapped to A[13:0] and drf\_mode\_reg[15:14] is mapped to BA[1:0]. It's IMPORTANT that CAS Latency MUST be configured to 2 and Burst Length MUST be configured to 2 16-bit.
- drf\_ext\_mode\_reg: Extended Mode Register

### 5.2.6.1.9 Software-Controlled Sleep

EMC supports software-controlled manual-sleep. The sleep and wakeup tasks must run in on-chip memory, and software must guarantee no new access issued and check current access completed.

# **DMEM Sleep task:**

Step1: Software program jumps to on-chip memory and guarantee no new access issued on DMEM.

Step2: Clear drf\_auto\_ref\_en to disable AUTO-REFRESH function



Step3: Polling **rfemc\_idle\_sync** in EMC\_STS3 until it's set, and then waiting for at least 50 EMC cycles.

Step4: Set dsoft\_pre\_all, then polling this bit until it's cleared.

Step5: Set dsoft\_self\_ref, then polling this bit until it's cleared.

Step6: Clear drf\_clkdmem\_out\_en to close DMEM output clock (optional).

Step7: Software can close EMC core clock and sleep.

#### **DMEM Wakeup task:**

Step1: Set **drf\_clkdmem\_out\_en** to open DMEM output clock after software wakes up on on-chip RAM.

Step2: Set dsoft\_resume, then polling this bit until it's cleared.

Step3: Set drf\_auto\_ref\_en to enable AUTO-REFRESH function.

Step4: Software can jump to DMEM to run.

### 5.2.6.1.10 Hardware-Controlled Auto-Sleep

EMC supports hardware-controlled auto-sleep. To enable this function, software need do the following configuring.

I set rf auto sleep en to 1

I set all rf\_auto\_sleep\_en\_chx to 1 (optional, but recommended)

I clear drf auto sleep mode to 0

I keep drf ref cnt rst to 1

### 5.2.6.2 Limitation Summary

### I SDR Maximum Speed Limitation:

In many cases, out-of-chip loop mode isn't used for SDR to save PADs, it leads to impact on maximum speed. From timing budget analysis, the key issue of SDR speed is that it is difficult to reduce delay from clock output to sample DFFs. So we have to balance this delay by delaying sample clock as possible, but if sample clock delay is too big, the skew between FF and SS cannot be controlled very well. As a result, to some (-8) SDR, tAC is 7ns, same as the (-10) SDR, EMC has to support 100MHz even if SDR itself can work on 125MHz. Out-of-chip loop mode can improve this performance because of similar path between output clock and sample clock.

#### WRAP-Mode AHB Burst Issues:

WRAP-mode bursts can keep WRAP feature during AHB bursts mapping to channel bursts. But this feature cannot be kept during channel bursts mapping to device bursts to simplify hardware design, even if external memory is also in wrap mode. In order to reduce performance impacts, for SMEM, INCR mode is recommended. And for DMEM, short burst length is recommended.

#### I DMEM Chip Select Limitation:

Unlike SMEM, DMEM only supports up to 2 chip selects at the same time. And the 2 chip selects MUST follow the rules:



Ø If one chip select is used for DMEM, any of CS0, CS1 can be chosen.



### 5.3 NFC

### 5.3.1 Overview

The module implements a flexible controller for NAND flash memory. It manages the read/write interactions between a master host system and the external NAND Flash memory units. Master configures the NFC and initiates it to start the memory operation. For read/write access, NFC exchanges data with both internal data memory and spare memory through external AHB interface. Configurable features and internal configuration registers make it easy to adapt a variety memory device types.

NFC has an 8-bit/16-bit wide bus. And support page size of 512 / 1k / 2k / 4k /8k bytes. Moreover an internal hardware ECC encoder and decoder are provided and the external master can acquire the ECC by accessing adequate internal register.

# 5.3.2 Features

- I Compatible to ONFI V1.0
- I Support bus width of 8/16 bits
- I Support Page size of 512/1K/2K/4K/8K Bytes.
- I Support Address Cycle of 3/4/5
- I Support at most 8-page consecutive read for memories with 512 bytes page.
- I Support SuperAND Flash memory;
- I Support NAND access with both micro-code and fixed-sequence command;
- I Support data order switch between NFC\_DMEM and NAND Flash device;
- I Support Hardware ECC encoder and decoder
- I Support ECC of 1/2/4/8/12/16/24 bits with info length 1~1024 Bytes
- I Support Hardware DMA transfer mode.

# 5.3.3 Signal Description

NAND Flash controller includes below signals.

**Table 5.3-1 NAND Flash Controller PIN List** 

| Pin Name       | 1/0 | Width | Description                                      |
|----------------|-----|-------|--------------------------------------------------|
| nfc_cen        | 0   | 1     | Chip enable, active low, work as CS0.            |
| nfc_cle        | 0   | 1     | Command latch enable, active high.               |
| nfc_ale        | 0   | 1     | Address latch enable, active high.               |
| nfc_ren        | 0   | 1     | Read enable, active low.                         |
| nfc_wen        | 0   | 1     | Write enable, active low.                        |
| nfc_data_oe    | 0   | 1     | Data output enable                               |
| nfc_data_out   | 0   | 16    | Data output                                      |
| nfc_data_in    | I   | 16    | Data input                                       |
| nfc_rbn        | I   | 1     | Ready/busy output, high for ready, low for busy. |
| clk_nfc        | I   | 1     | Nand Flash clock signals                         |
| nfc_rst_n      | I   | 1     | Nand Flash reset signals                         |
| nfc_wpn        | 0   | 1     | Write protect, active low.                       |
| nfc_bigend_en  | I   | 1     | Nand Flash endian signals                        |
| ptest_icg_mode | I   | 1     | Nand ptest mode select                           |



| Pin Name        | I/O | Width | Description                               |
|-----------------|-----|-------|-------------------------------------------|
| Int_req_nfc     | 0   | 1     | Nand Flash interrupt signals              |
| nfc_dmem_clk    | 0   | 1     | Nand flash main data memory clock         |
| nfc_dmem_cen    | 0   | 1     | Nand flash main data memory chip enable   |
| nfc_dmem_wen    | 0   | 4     | Nand flash main data memory write enable  |
| nfc_dmem_addr   | 0   | 11    | Nand flash main data memory address       |
| nfc_dmem_wdata  | 0   | 32    | Nand flash main data memory write data    |
| nfc_dmem_rdata  | I   | 32    | Nand flash main data memory read data     |
| nfc_smem_clk    | 0   | 1     | Nand flash spare data memory clock        |
| nfc_smem_cen    | 0   | 1     | Nand flash spare data memory chip enable  |
| nfc_smem_wen    | 0   | 4     | Nand flash spare data memory write enable |
| nfc_smem_addr   | 0   | 7     | Nand flash spare data memory address      |
| nfc_smem_wdata  | 0   | 32    | Nand flash spare data memory write data   |
| nfc_smem_rdata  | I   | 32    | Nand flash spare data memory read data    |
| dma_req_nfc_tx  | 0   | 1     | DMA Request for write data                |
| dma_req_nfc_rx  | 0   | 1     | DMA Request for read data                 |
| dma_ack_nfc_tx  | I   | 1     | DMA Acknowledge to Write                  |
| dma_ack_nfc_rx  | I   | 1     | DMA Acknowledge to read                   |
| AHB Signals Set |     |       | Nand Flash AHB signals set                |

# 5.3.4 Function Description

### 5.3.4.1 Function abstract

The NFC's application is as below.



Figure 5.3-1 NFC Application

The NFC can read or write external NAND Flash memory, it supports up to 2 devices. When read, NFC gets data from extern NAND Flash memory and saves to internal memory, then transfers them to external memory through DMA channel; when write, work data may be transferred to internal memory through DMA channel, then NFC send them to extern NAND Flash memory.



NFC exchange NAND Flash memory data and other memory data with a specified NAND Flash memory interface. Its block diagram is shown in below.



Figure 5.3-2 NFC Block Diagram

### 5.3.4.2 Memory Start/End Address Register

To support at most 4-page consecutive program/erase, the controller has 4 start address registers. For read operation, if the block number is more than one page, it will equal to one read batch operation.

Sequential operation will not be supported, that is, the start address and end address should be in the same page.

For large page NAND, the read batch and multi-plan operations are forbidden. Only the access for the first page can be processed, the other page process will be ignored.

During read operation, multi-page read means read "batch" command. For example, supposed that block\_num is 4, and read data from NAND, the controller will continuously read 4 times.

Besides, if the M\_END\_ADDR n is 32'hFFFF\_FFFF, it means the rest of current page specified by the M\_END\_ADDR n will be read out.

### 5.3.4.3 Timing Parameter Register

The read/write timing is shown in fellow.



Description of these parameters

| Parameter | Default | Description                                                      |
|-----------|---------|------------------------------------------------------------------|
| ACS       | 1       | Setup time for both ALE and CLE. tACS = n * Tclk                 |
| RWL       | 7       | Active low pulse width for both RE and WE. tRWH = (n + 1) * Tclk |



| Parameter | Default | Description                                                                                                                                                                                    |
|-----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RWH       | 1       | Hold time for both RE and WE. $tRWL = (n + 1) * Tclk$                                                                                                                                          |
| RR        | 3       | Ready to RE low. When $n \le 3$ , $tRR = (n + 1) * Tclk$ . Otherwise $tRR = (2n - 2) * Tclk$                                                                                                   |
| ACR       | 5       | CLE to RE ready. ALE to RE ready. tACR = (n + 1) * Tclk                                                                                                                                        |
| CEH       | 7       | To terminate a Sequential Row Read operation set the Chip Enable signal to High for more than tCEH. tCEH=n * Tclk. For Flash without Sequential Read operation, this field must be set to 4'h0 |

The following describes the cycles for some states



PH\_2ND\_CMD is same as PH\_1ST\_CMD







PH\_WAIT\_WRITE/PH\_WAIT\_RESET is same as PH\_WAIT\_READ







### PH\_STATUS\_READ: ACR=2



### 5.3.4.4 FSM in Fixed-Sequence Command

The following picture depicts the State Machine for NAND access.





Figure 5.3-3 NFC Main FSM

- 1. (nfc\_reset | nfc\_rb\_syn3) & nfc\_start0
- 2. sp\_program | mp\_program
- 3. mp\_erase & !mp\_last\_page
- 4. read & !addvance read = (sp\_read | mp\_read | id\_read | seq\_read)
- 5. seq\_read & !mp\_last\_page
- 6. mp\_read & !mp\_last\_page
- 7. read
- 8. mp\_program & !mp\_last\_page

## 5.3.4.5 Modified FSM for Sub-Command





Figure 5.3-4 NFC Sub FSM

- 1. (nfc\_reset | nfc\_rb\_syn3) & nfc\_start0
- 2. sp\_program | mp\_program
- 3. mp\_erase & !mp\_last\_page

4. read & !addvance

- read = (sp\_read | mp\_read | id\_read | seq\_read)
- 5. seq\_read & !mp\_last\_page
- 6. mp\_read & !mp\_last\_page
- 7. read
- 8. mp\_program & !mp\_last\_page
- 9. for command sub-command
- 10/12. for address sub-command
- 11. pt\_turn | cmd\_mode
- 13/14 for waitRB sub-command
- 15/16. for read sub-command
- 17/18. for write sub-command

#### 5.3.5 **Micro-Instruction**

#### 5.3.5.1 **Instruction Abstract**

| Instruction | Code | Description                                        |  |
|-------------|------|----------------------------------------------------|--|
| Command     | 0xFD | Send one command to NAND Flash.                    |  |
|             |      | Command supported by all kinds of NAND Flash, e.g. |  |



| Instruction | Code | Description                                                                                                                                                                                                                 |
|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |      | 0x50, 0x60 etc                                                                                                                                                                                                              |
| Address     | 0xF1 | Address specified in address input cycle. E.g. 0xA5F1: send 0xA5 to NAND as one input address.  Active one address latch cycle.                                                                                             |
| WaitRB      | 0xF2 | Wait for the end of NAND busy, that is, to detect one positive edge of R/B input signal.                                                                                                                                    |
| ReadWord    | 0xF3 | Word number (0 ~255).  E.g. 0xFFF3: Read 256 words from NAND Flash. Initiate one or more read cycle  When BusSize = 8, the "Word" indicate 8bits  When BusSize = 16, the "Word" indicate 16bits                             |
| ReadBlock   | 0xF4 | Block number.  Number of Block (one block = 256 words).  E.g. 0x00F4: Read 1 blocks 256 words from NAND  When BusSize = 8, the "Word" indicate 8bits  When BusSize = 16, the "Word" indicate 16bits                         |
| WriteWord   | 0xF6 | Word number. (0~255) E.g. 0x10F6: Write 17 words into NAND Flash. Initiate one or more write cycle, including data, ID and status When BusSize = 8, the "Word" indicate 8bits When BusSize = 16, the "Word" indicate 16bits |
| WriteBlock  | 0xF7 | Block number.  Number of Block (one block = 256 words).  E.g. 0x02F4: Write 3 blocks (768 words) into NAND  When BusSize = 8, the "Word" indicate 8bits  When BusSize = 16, the "Word" indicate 16bits                      |
| DeactiveCS  | 0xF9 | Number of idle cycle. At most 16 cycles once. This instruction is used to stop sequential access.                                                                                                                           |
| Nop         | 0xFA | Wait for some idle clock cycles. At most 16 cycle once.                                                                                                                                                                     |

### 5.3.5.2 Instruction Format

| Bits    | 15 ~ 8     | 7 ~ 0 |
|---------|------------|-------|
| Context | Parameters | Codes |

### 5.3.5.3 Instruction FIFO

Software can issue at most 33 instructions once. And the number of one command batch can be specified by the INST\_NUM. The real number of instruction is INST\_NUM + 2. For example, if INST\_NUM = 5'hE, that means there are 16 instructions waiting to execute in Instruction FIFO. The INST\_NUM field should not larger than 5'h1E which indicate the number of 33.

| No. Instruction A | Idress Inst. Entry Name |
|-------------------|-------------------------|
|-------------------|-------------------------|



| No. | Instruction Address | Inst. Entry Name |
|-----|---------------------|------------------|
| 0   | 0x0060              | M_START_ADDR0    |
| 1   | 0x0064              | M_START_ADDR1    |
| 2   | 0x0068              | M_START_ADDR2    |
| 3   | 0x006C              | M_START_ADDR3    |
| 4   | 0x0070              | M_START_ADDR4    |
| 5   | 0x0074              | M_START_ADDR5    |
| 6   | 0x0078              | M_START_ADDR6    |
| 7   | 0x007C              | M_START_ADDR7    |
| 8   | 0x0080              | M_END_ADDR0      |
| 9   | 0x0084              | M_END_ADDR1      |
| 10  | 0x0088              | M_END_ADDR2      |
| 11  | 0x008C              | M_END_ADDR3      |
| 12  | 0x0090              | M_END_ADDR4      |
| 13  | 0x0094              | M_END_ADDR5      |
| 14  | 0x0098              | M_END_ADDR6      |
| 15  | 0x009C              | M_END_ADDR7      |

Note: when in micro-instruction mode, the structure of NFC\_CMD register will be different from when it in fix command mode. Please refer to the NFC\_CMD registers description for details.

NFC will execute instructions as the following sequence:

| Sequence | <b>Executed CMD Position</b> | Sequence | Executed CMD Position |
|----------|------------------------------|----------|-----------------------|
| 0        | NFC_CMD[15:0]                | 17       | M_END_ADDR0[15:0]     |
| 1        | M_START_ADDR0[15:0]          | 18       | M_END_ADDR0[31:16]    |
| 2        | M_START_ADDR0[31:16]         | 19       | M_END_ADDR1[15:0]     |
| 3        | M_START_ADDR1[15:0]          | 20       | M_END_ADDR1[31:16]    |
| 4        | M_START_ADDR1[31:16]         | 21       | M_END_ADDR2[15:0]     |
| 5        | M_START_ADDR2[15:0]          | 22       | M_END_ADDR2[31:16]    |
| 6        | M_START_ADDR2[31:16]         | 23       | M_END_ADDR3[15:0]     |
| 7        | M_START_ADDR3[15:0]          | 24       | M_END_ADDR3[31:16]    |
| 8        | M_START_ADDR3[31:16]         | 25       | M_END_ADDR4[15:0]     |
| 9        | M_START_ADDR4[15:0]          | 26       | M_END_ADDR4[31:16]    |
| 10       | M_START_ADDR4[31:16]         | 27       | M_END_ADDR5[15:0]     |
| 11       | M_START_ADDR5[15:0]          | 28       | M_END_ADDR5[31:16]    |
| 12       | M_START_ADDR5[31:16]         | 29       | M_END_ADDR6[15:0]     |
| 13       | M_START_ADDR6[15:0]          | 30       | M_END_ADDR6[31:16]    |
| 14       | M_START_ADDR6[31:16]         | 31       | M_END_ADDR7[15:0]     |



| Sequence | Executed CMD Position | Sequence | Executed CMD Position |
|----------|-----------------------|----------|-----------------------|
| 15       | M_START_ADDR7[15:0]   | 32       | M_END_ADDR7[31:16]    |
| 16       | M_START_ADDR7[31:16]  |          |                       |

### 5.3.5.4 Instruction Examples

This section will illustrate how to use the above instructions when accessing one type of NAND Flash. As to K9F1208D0A, please refer to the following table..

Example.1 Read one page with 528 bytes from No. 32 Page

| Instruction List  |                 | Program Mask Code              |
|-------------------|-----------------|--------------------------------|
| 0x00FD            | //CMD 00        | NFC_CMD [15:00] = 0x00FD       |
| 0x00F1            | //ADDR 00       | M_START_ADDR0 [15:00] = 0x00F1 |
| 0x00F1            | //ADDR 00       | M_START_ADDR0 [31:16] = 0x00F1 |
| 0x20F1            | //ADDR 20       | M_START_ADDR1 [15:00] = 0x20F1 |
| 0x00F1            | //ADDR 00       | M_START_ADDR1 [31:16] = 0x20F1 |
| 0x00F2            | //WAIT RB       | M_START_ADDR2 [15:00] = 0x00F2 |
| 0x01F4            | //Read 2 blocks | M_START_ADDR2 [31:16] = 0x01F4 |
| //Run the command |                 | NFC_CMD [31:00] = 0x8005_00FD  |

Example.2 Three Plane Block Erase

| Instruction List  |           | Program Mask Code                |
|-------------------|-----------|----------------------------------|
| 0x60FD            | //CMD 60  | NFC_CMD [15:00] = 0x60FD         |
| 0x00F1            | //ADDR 00 | M_START_ADDR0 [15:00] = 0x00F1   |
| 0x00F1            | //ADDR 00 | M_START_ADDR0 [31:16] = 0x00F1   |
| 0x00F1            | //ADDR 00 | M_START_ADDR1 [15:00] = 0x00F1   |
| 0x60FD            | //CMD 60  | M_START_ADDR1 [31:16] = 0x60FD   |
| 0x00F1            | //ADDR 00 | $M_START_ADDR2 [15:00] = 0x00F1$ |
| 0x01F1            | //ADDR 01 | M_START_ADDR2 [31:16] = 0x01F1   |
| 0x00F1            | //ADDR 00 | M_START_ADDR3 [15:00] = 0x00F1   |
| 0x60FD            | //CMD 60  | M_START_ADDR3 [31:16] = 0x60FD   |
| 0x00F1            | //ADDR 00 | M_START_ADDR 4 [15:00] = 0x00F1  |
| //Run the command |           | NFC_CMD [31:00] = 0x8008_60FD    |

Example.3 SUPERAND read one page

| Instruction List Program Mask Code | Instruction List | Program Mask Code |
|------------------------------------|------------------|-------------------|
|------------------------------------|------------------|-------------------|



| 0x00FD            | //CMD 00         | NFC_CMD [15:00] = 0x00FD         |
|-------------------|------------------|----------------------------------|
| 0x00F1            | //ADDR 00        | M_START_ADDR0 [15:00] = 0x00F1   |
| 0x00F1            | //ADDR 00        | M_START_ADDR0 [31:16] = 0x00F1   |
| 0x20F1            | //ADDR 20        | $M_START_ADDR1 [15:00] = 0x20F1$ |
| 0x00F1            | //ADDR 00        | M_START_ADDR1 [31:16] = 0x00F1   |
| 0x00F2            | //WAITRB         | $M_START_ADDR2 [15:00] = 0x00F2$ |
| 0x00F4            | //read one block | $M_START_ADDR2 [31:16] = 0x00F4$ |
| 0xF0FD            | //stop command   | $M_START_ADDR3 [15:00] = 0xF0FD$ |
| //Run the command |                  | NFC_CMD [31:00] = 0x8006_00FD    |

#### Note:

- 1. Two consequence micro-instructions have one clock turn-around time.
- 2. The tRR should be controlled by inside one or more NOP instructions.

# 5.3.6 Control Registers

# **5.3.6.1 Memory map**

ARM base address: 0x6000\_0000

| Offset Address     | Name            | Description                    |
|--------------------|-----------------|--------------------------------|
| 0x0000             | NFC_CMD         | NAND operation command         |
| 0x0004             | NFC_CFG0        | NAND operation configuration 0 |
| 0x0008             | NFC_CFG1        | NAND operation configuration 1 |
| 0x000C             | Reserved        |                                |
| 0x0010             | NFC_TIMING      | NAND operation timings         |
| 0x0014             | NFC_TIMEOUT     | NAND timeout configuration     |
| 0x0018             | NFC_ID_STS      | ID or status read result       |
| 0x001C             | Reserved        |                                |
| 0x0020             | NFC_INT_STS_EN  | Interrupt source               |
| 0x0024             | NFC_INT_CLR_RAW | Interrupt source enable        |
| 0x0028 ~<br>0x002C | Reserved        |                                |
| 0x0030             | NFC_ECC_CFG0    | Configure ECC0                 |
| 0x0034             | NFC_ECC_CFG1    | Configure ECC1                 |
| 0x0038 ~<br>0x003C | Reserved        |                                |
| 0x0040             | NFC_ECC_STS0    | ECC Status0                    |
| 0x0044             | NFC_ECC_STS1    | ECC Status1                    |
| 0x0048             | NFC_ECC_STS2    | ECC Status2                    |
| 0x004C             | NFC_ECC_STS3    | ECC Status3                    |
| 0x0050 ~<br>0x005C | Reserved        |                                |



| Offset Address  | Name          | Description                                   |
|-----------------|---------------|-----------------------------------------------|
| 0x0060          | M_START_ADDR0 | Memory start address 0                        |
| 0x0064          | M_START_ADDR1 | Memory start address 1                        |
| 0x0068          | M_START_ADDR2 | Memory start address 2                        |
| 0x006C          | M_START_ADDR3 | Memory start address 3                        |
| 0x0070          | M_START_ADDR4 | Memory start address 4                        |
| 0x0074          | M_START_ADDR5 | Memory start address 5                        |
| 0x0078          | M_START_ADDR6 | Memory start address 6                        |
| 0x007C          | M_START_ADDR7 | Memory start address 7                        |
| 0x0080          | M_END_ADDR0   | Memory end address 0                          |
| 0x0084          | M_END_ADDR1   | Memory end address 1                          |
| 0x0088          | M_END_ADDR2   | Memory end address 2                          |
| 0x008C          | M_END_ADDR3   | Memory end address 3                          |
| 0x0090          | M_END_ADDR4   | Memory end address 4                          |
| 0x0094          | M_END_ADDR5   | Memory end address 5                          |
| 0x0098          | M_END_ADDR6   | Memory end address 6                          |
| 0x009C          | M_END_ADDR7   | Memory end address 7                          |
| NFC Internal Me | emory         |                                               |
| 0x2000~0x3FFF   | NFC_DMEM      | Can be accessed through DMA software channel. |
| 0x4000~0x43FF   | NFC_SMEM      | Can be accessed through DMA software channel. |

# 5.3.6.2 Register Descriptions

### 5.3.6.2.1 NFC\_CMD

Description: NAND operation command.

| 0x0000 |           |         | NAN                              | D oper | ration | comm | and (fo | or fixed | sequ | ence c | omma | nd) |   | NFC_CMD |    |    |
|--------|-----------|---------|----------------------------------|--------|--------|------|---------|----------|------|--------|------|-----|---|---------|----|----|
| Bit    | 31        | 30      | 29 28 27 26 25 24 23 22 21 20 19 |        |        |      |         |          |      |        |      |     |   |         | 17 | 16 |
| Name   | VALI<br>D |         |                                  |        |        |      |         |          |      |        |      |     |   | BLK_NUM |    |    |
| Type   | R/W       | W RO 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   |           |         |                                  |        |        |      |         | CI       | MD   |        |      |     |   |         |    |    |
| Туре   |           |         |                                  |        |        |      |         | R        | W    |        |      |     |   |         |    |    |
| Reset  | 0         | 0       | 0                                | 0      | 0      | 0    | 0       | 0        | 0    | 0      | 0    | 0   | 0 | 0       | 0  | 0  |

| Field Name | Bit | Туре | Reset<br>Value | Description |
|------------|-----|------|----------------|-------------|
|------------|-----|------|----------------|-------------|



| VALID   | [31]    | R/W | 1'h0  | Write '1' to indicate a valid command, it will be cleared by HW after complete the command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|---------|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | [30:19] | RO  | 12'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| BLK_NUM | [18:16] | R/W | 3'h0  | Block number. Number of consecutive page/plane operations.  0: 1-page operation  1: 2-page operation   7: 8-page operation  When accessing the device with 4k bytes of one page, this field will be ignored. Only one page can be accessed once. For multi-plane operations, if this field is zero, it will be the same as a single-page operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| CMD     | [15:0]  | R/W | 16'h0 | Commands supported by most of NAND Flash. They are 00/50/90/FF/80/60/70/71/FD.  For large page (2112 bytes per page), only 00h is supported in read command. For small page (512 bytes per page), either 00h or 01h is determined by the tenth address bit.  In case of multi-plane operations, it is indicated by BLK_NO field in Command register.  Moreover, all control signals can be directly assigned by MCU programming. Here, all output signals can be used as GPIO. When Command [7:0] is 8'h5A, {rd,cle,ale,cen,wen,ren,wpn,data_oen} = Command[15:8]. If rd is 1 and data_oen is 0, the DATA will be stored into DATA_BUF register, otherwise, wdata will be driven by DATA register.  For advance device, the second cycle command will be 30h.  For area switching, area pointer is specified by command[15:8]. For example, command[15:0] = 16'h50fd, it means changing point to spare area.  Moreover, this command is invalid for this kind of device with 2k bytes per page. |

| 0x0000 |           |          | NAN    | D oper                        | ation | comma | and (fo | r micr | o-code | e way) |   |   |   |          | NFC_ | CMD |  |
|--------|-----------|----------|--------|-------------------------------|-------|-------|---------|--------|--------|--------|---|---|---|----------|------|-----|--|
| Bit    | 31        | 30       | 29     | 29 28 27 26 25 24 23 22 21 20 |       |       |         |        |        |        |   |   |   |          | 17   | 16  |  |
| Name   | VALI<br>D | Reserved |        |                               |       |       |         |        |        |        |   |   |   | INST_NUM |      |     |  |
| Туре   | R/W       |          | RO R/W |                               |       |       |         |        |        |        |   |   |   |          |      |     |  |
| 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   |           |          |        |                               |       |       |         | CI     | MD     |        |   |   |   |          |      |     |  |
| Туре   |           | R/W      |        |                               |       |       |         |        |        |        |   |   |   |          |      |     |  |
| Reset  | 0         | 0        | 0      | 0                             | 0     | 0     | 0       | 0      | 0      | 0      | 0 | 0 | 0 | 0        | 0    | 0   |  |

| Field Name Bit | Type | Reset | Description |
|----------------|------|-------|-------------|



|          |         |     | Value |                                                                                             |
|----------|---------|-----|-------|---------------------------------------------------------------------------------------------|
| VALID    | [31]    | R/W | 1'h0  | Write '1' to indicate a valid command, it will be cleared by HW after complete the command. |
|          | [30:21] | RO  | 10'h0 | Reserved                                                                                    |
| INST_NUM | [20:16] | R/W | 5'h0  | The number of micro-instructions is INST_NUM + 1.                                           |
| CMD      | [15:0]  | R/W | 16'h0 | The first micro-code                                                                        |

The commands support most of NAND Flash. All commands are listed below.

#### Table xx NAND Command List

|                         |        | Command                 | d Sequence              |
|-------------------------|--------|-------------------------|-------------------------|
| Command                 | Encode | 1 <sup>st</sup> . Cycle | 2 <sup>nd</sup> . Cycle |
| Read                    | 00h    | 00h                     |                         |
|                         |        | 01h                     |                         |
| Read C                  | 50h    | 50h                     |                         |
| Read ID                 | 90h    | 90h                     |                         |
| Reset                   | FFh    | FFh                     |                         |
| Page Program(True)      | 80h    | 80h                     | 10h                     |
| Page Program(Dummy)     |        | 80h                     | 11h                     |
| Block Erase             | 60h    | 60h                     | D0h                     |
| Multi-Plane Block Erase |        | 60h—60h                 | D0h                     |
| Read Status             | 70h    | 70h                     |                         |
| Read Multi-Plane Status | 71h    | 71h                     |                         |
| GPIO                    | FEh    |                         |                         |
| Area switch             | FDh    |                         |                         |

For large page (2112 byte per page), only 00h is supported in read command. For small page (512byte per page), either 00h or 01h is determined by the tenth address bit.

In case of multi-plane operations, it is indicated by Block Number field in Command register.

Moreover, all control signals can be directly assigned by MCU programming. Here, all output signals can be used as GPIO. When Command [7:0] is 8'h5A, {rd,cle,ale,cen,wen,ren,wpn,data\_oen} = Command[15:8]. If rd is 1 and data\_oen is 0, the DATA will be stored into DataBuf register; otherwise, wdata will be driven by DATA

For advance device, the second cycle command will be 30h.

For area witching, area pointer is specified by command [15:8]. For example, command [15:0] =16'h50fd, it means changing point to spare area. Moreover, this command is invalid for this kind of device with 2kbyte per page.

### 5.3.6.2.2 NFC\_CFG0

register.

Description: NFC Configuration 0



| 0x0004 |                         |                 | NFC | config    | juratio | n (rese | t 0x01 | )           |       |            |                          |                                |                                |                 | NFC_CFG0                |                  |  |  |
|--------|-------------------------|-----------------|-----|-----------|---------|---------|--------|-------------|-------|------------|--------------------------|--------------------------------|--------------------------------|-----------------|-------------------------|------------------|--|--|
| Bit    | 31                      | 30              | 29  | 28        | 27      | 26      | 25     | 24          | 23    | 22         | 21                       | 20                             | 19                             | 18              | 17                      | 16               |  |  |
| Name   |                         |                 | Res | Reserved  |         |         |        | NFC_SP_SIZE |       |            |                          |                                |                                |                 |                         |                  |  |  |
| Туре   |                         |                 | F   | RO        |         |         |        | R/W         |       |            |                          |                                |                                |                 |                         |                  |  |  |
| 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   | NFC<br>_CM<br>D_S<br>ET | ADV<br>ANC<br>E |     | CYCL<br>E | P/      | AGE_TYI | PE     | Rese        | erved | CS_<br>SEL | DEV<br>_BU<br>S_SI<br>ZE | NFC<br>_ME<br>M_S<br>WIT<br>CH | ME<br>M_N<br>FC_<br>SWI<br>TCH | NFC<br>_WP<br>N | NFC<br>_CM<br>D_C<br>LR | NFC<br>_RB<br>_N |  |  |
| Туре   | R/W                     | R/W             | R   | W         |         | R/W     |        | R           | 0     | R/W        | R/W                      | R/W                            | R/W                            | R/W             | wo                      | RO               |  |  |
| Reset  | 0                       | 0               | 0   | 0         | 0       | 0       | 0      | 0           | 0     | 0          | 0                        | 0                              | 0                              | 0               | 0                       | 1                |  |  |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | [31:26] | RO   | 6'h0           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| NFC_SP_SIZE | [25:16] | R/W  | 10'h00         | For SLC, the spare area is relatively fixed value for every 512Bytes main area data.  For MLC, the spare area is not integral multiple of 16bytes for every 512Bytes main area data, and then software should specify the spare area size.  To simple the software configuration, there are some default values which are used more frequently for different PageSize will be set. The special value of 10'h00 will do this function.  When "NFC_SP_SIZE" == 10'h0, the real Spare area size will be set to following value, but not 0.  PageSize == 512Bytes: spare size is 16Bytes.  PageSize == 1K Bytes: spare size is 64 Bytes  PageSize == 2K Bytes: spare size is 224 Bytes  PageSize == 4K Bytes: spare size is 448 Bytes.  When "NFC_SP_SIZE!= 10'h0", the real Spare area size will be set to the set value add 1, and the default value will be invalided.  E.g.  0x001, indicate 2 bytes  0x0FF, indicate 128 bytes  0x3FF, indicate 1024 bytes |
| NFC_CMD_SET | [15]    | R/W  | 1'h0           | CMD Set mode 0: Signal Command operation; 1: Micro-Instruction operation. It is auto clear to 0 after this process is done.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ADVANCE     | [14]    | R/W  | 1'h0           | Advance. Flash memory has 2 <sup>nd</sup> cycle read command (30h). Active high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



|                |         |     |      | (If NFC_CMD_SET = 1, this bit is ignored)                                                                                                                                                         |
|----------------|---------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADDR_CYCLE     | [13:12] | R/W | 2'h0 | Address cycles of NAND flash memory, work with ADV flag as follows.  00: 3 address cycles  01: 4 address cycles  10: 5 address cycles  11: Reserved  (If NFC_CMD_SET = 1, these bits are ignored) |
| PAGE_TYPE      | [11:9]  | R/W | 3'h0 | Page type 000: 512 Bytes / Page 001: 1K Bytes / Page 010: 2K Byte / Page 011: 4K Byte / Page 100: 8K Byte / Page Others: Reserved (If NFC_CMD_SET = 1, these bits are ignored)                    |
|                | [8:7]   | RO  | 2'h0 | Reserved                                                                                                                                                                                          |
| CS_SEL         | [6]     | R/W | 1'h0 | CS select 0: CS0 is valid, CS1 is invalid 1: CS1 is valid, CS0 is invalid                                                                                                                         |
| DEV_BUS_SIZE   | [5]     | R/W | 1'h0 | Device bus size 0: x8 device 1: x16 device                                                                                                                                                        |
| NFC_MEM_SWITCH | [4]     | R/W | 1'h0 | NFC to memory endian switch                                                                                                                                                                       |
| MEM_NFC_SWITCH | [3]     | R/W | 1'h0 | Memory to NFC endian switch                                                                                                                                                                       |
| NFC_WPN        | [2]     | R/W | 1'h0 | Nand write protection. Active low. 0: Protection. 1: Not Protection                                                                                                                               |
| NFC_CMD_CLR    | [1]     | WO  | 1'h0 | Write 1 to this bit to clear the controller command                                                                                                                                               |
| NFC_RBN        | [0]     | RO  | 1'h1 | Whether Nand Flash is busy. 0: Busy 1: Not Busy                                                                                                                                                   |
|                |         |     |      |                                                                                                                                                                                                   |

# 5.3.6.2.3 NFC\_CFG1

Description: NFC configuration 1



| 0x0008 |    |                         | NFC | config | juratio | n (rese | et 0x00 | )     |    |    |    |     |     |    | NFC_              | CFG1              |
|--------|----|-------------------------|-----|--------|---------|---------|---------|-------|----|----|----|-----|-----|----|-------------------|-------------------|
| Bit    | 31 | 30                      | 29  | 28     | 27      | 26      | 25      | 24    | 23 | 22 | 21 | 20  | 19  | 18 | 17                | 16                |
| Name   |    | Reserved                |     |        |         |         |         |       |    |    |    |     |     |    |                   |                   |
| Туре   | 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   |    |                         |     |        |         |         | Res     | erved |    |    |    |     |     |    | DMA<br>_RX<br>_EN | DMA<br>_TX<br>_EN |
| Туре   | RO |                         |     |        |         |         |         |       |    |    |    | R/W | R/W |    |                   |                   |
| Reset  | 0  | 0                       | 0   | 0      | 0       | 0       | 0       | 0     | 0  | 0  | 0  | 0   | 0   | 0  | 0                 | 0                 |

| Field Name | Bit    | Туре | Reset<br>Value | Description            |
|------------|--------|------|----------------|------------------------|
|            | [31:2] | RO   | 30'h0          | Reserved               |
| DMA_RX_EN  | [1]    | R/W  | 1'h0           | NFC DMA RX mode enable |
| DMA_TX_EN  | [0]    | R/W  | 1'h0           | NFC DMA TX mode enable |

# 5.3.6.2.4 NFC\_TIMING

Description: NAND operation timing parameters.

| 0x0010 |             |     | NAN     | D ope | ration t | iming | (reset    | 0x1C6 | 55_1C2 | 21) |    |    | NFC_TIMING |     |    |    |  |
|--------|-------------|-----|---------|-------|----------|-------|-----------|-------|--------|-----|----|----|------------|-----|----|----|--|
| Bit    | 31          | 30  | 29      | 28    | 27       | 26    | 25        | 24    | 23     | 22  | 21 | 20 | 19         | 18  | 17 | 16 |  |
| Name   |             |     | CE      | ΞH    |          |       |           |       | RR     |     |    |    | ACR        |     |    |    |  |
| Туре   |             | R/W |         |       |          |       |           |       | R/W    |     |    |    |            | R/W |    |    |  |
| Reset  | 0           | 0   | 0 1 1 1 |       |          |       | 0 0 0 1 1 |       |        |     | 0  | 0  | 1 0 1      |     |    |    |  |
| Bit    | 15          | 14  | 13      | 12    | 11       | 10    | 9         | 8     | 7      | 6   | 5  | 4  | 3          | 2   | 1  | 0  |  |
| Name   |             |     | RI      | VL    |          |       |           |       | RWH    |     |    |    | ACS        |     |    |    |  |
| Туре   |             | R/W |         |       |          |       |           | R/W   |        |     |    |    | R/W        |     |    |    |  |
| Reset  | 0 0 0 1 1 1 |     |         |       |          | 1     | 0         | 0     | 0      | 0   | 1  | 0  | 0          | 0   | 0  | 1  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                   |
|------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CEH        | [31:26] | R/W  | 6'h7           | To terminate a Sequential Row Read operation set the Chip Enable signal to High for more than tCEH. tCEH = n * Tclk For Flash without Sequential Read operation, this field must be set to 0. |
| RR         | [25:21] | R/W  | 5'h3           | Ready to RE low<br>$tRR = (n + 1) * Tclk$ , when $n \le 3$<br>tRR = (2n - 2) * Tclk, otherwise                                                                                                |
| ACR        | [20:16] | R/W  | 5'h5           | CLE to RE ready, ALE to RE ready                                                                                                                                                              |



|     |         |     |      | tACR = (n + 1) * Tclk                                           |
|-----|---------|-----|------|-----------------------------------------------------------------|
| RWL | [15:10] | R/W | 6'h7 | Active low pulse width for both RE and WE tRWL = (n + 1) * Tclk |
| RWH | [9:5]   | R/W | 5'h1 | Hold time for both RE and WE tRWH = (n + 1) * Tclk              |
| ACS | [4:0]   | R/W | 5'h1 | Setup time for both ALE and CLE tACS = n * Tclk                 |

All these parameters make up of NAND read/write timing control, their definitions and relations are shown in Figure xx.

# **5.3.6.2.5 NFC\_TIMEOUT**

Description: Timeout to detect NAND R/B busy period.

| 0x0014 |    |    | Time | out to | detect | NANI | R/B k | ousy p | eriod ( | reset 0 | x3fffff |    |    | NFC | _TIME | OUT |
|--------|----|----|------|--------|--------|------|-------|--------|---------|---------|---------|----|----|-----|-------|-----|
| Bit    | 31 | 30 | 29   | 28     | 27     | 26   | 25    | 24     | 23      | 22      | 21      | 20 | 19 | 18  | 17    | 16  |
| Name   |    |    |      |        |        |      |       | TIM    | EOUT    |         |         |    |    |     |       |     |
| Туре   |    |    |      |        |        |      |       | R      | :/W     |         |         |    |    |     |       |     |
| Reset  | 0  | 0  | 0    | 0      | 0      | 0    | 0     | 0      | 0       | 0       | 1       | 1  | 1  | 1   | 1     | 1   |
| Bit    | 15 | 14 | 13   | 12     | 11     | 10   | 9     | 8      | 7       | 6       | 5       | 4  | 3  | 2   | 1     | 0   |
| Name   |    |    |      |        |        |      |       | TIM    | EOUT    |         |         |    |    |     |       |     |
| Туре   |    |    | R/W  |        |        |      |       |        |         |         |         |    |    |     |       |     |
| Reset  | 1  | 1  | 1    | 1      | 1      | 1    | 1     | 1      | 1       | 1       | 1       | 1  | 1  | 1   | 1     | 1   |

| Field Name | Bit    | Туре | Reset<br>Value | Description                             |
|------------|--------|------|----------------|-----------------------------------------|
| TIMEOUT    | [31:0] | R/W  | 32'h3fffff     | Timeout to detect NAND R/B busy period. |

### 5.3.6.2.6 NFC\_ID\_STATUS

Description: NFC ID or status result.



| 0x0018 |    |    | NFC | ID or s                                                                                                                                           | status | result |   |       |      |   |   |   |   | NFC_I | ID_ST | ATUS |
|--------|----|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|---|-------|------|---|---|---|---|-------|-------|------|
| Bit    | 31 | 30 | 29  | 29         28         27         26         25         24         23         22         21         20         19         18         17         16 |        |        |   |       |      |   |   |   |   |       |       | 16   |
| Name   |    |    |     |                                                                                                                                                   |        |        |   | ID_ST | ATUS |   |   |   |   |       |       |      |
| Туре   |    |    |     |                                                                                                                                                   |        |        |   | R     | 0    |   |   |   |   |       |       |      |
| 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   |    |    |     |                                                                                                                                                   |        |        |   | ID_ST | ATUS |   |   |   |   |       |       |      |
| Туре   |    |    |     | RO                                                                                                                                                |        |        |   |       |      |   |   |   |   |       |       |      |
| Reset  | 0  | 0  | 0   | 0                                                                                                                                                 | 0      | 0      | 0 | 0     | 0    | 0 | 0 | 0 | 0 | 0     | 0     | 0    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                       |
|------------|--------|------|----------------|-----------------------------------------------------------------------------------|
| ID_STATUS  | [31:0] | RO   | 32'h0          | The result of either ID read or status read operation is stored in this register. |

# 5.3.6.2.7 NFC\_INT\_STS\_EN

Description: NFC interrupts status and enables signals

| 0x0020 |    |    | NFC | interru | ıpt sta | tus a    | nd en | able | 4  |    |    |                    | I                  | NFC_II                  | NT_ST                            | S_EN                             |
|--------|----|----|-----|---------|---------|----------|-------|------|----|----|----|--------------------|--------------------|-------------------------|----------------------------------|----------------------------------|
| Bit    | 31 | 30 | 29  | 28      | 27      | 26       | 25    | 24   | 23 | 22 | 21 | 20                 | 19                 | 18                      | 17                               | 16                               |
| Name   |    |    |     |         |         | Reserved | i     |      |    |    |    | INT_<br>TO_<br>STS | INT_<br>WP_<br>STS | INT_<br>ERR<br>_ST<br>S | INT_<br>ECC<br>_DO<br>NE_<br>STS | INT_<br>NFC<br>_DO<br>NE_<br>STS |
| Туре   |    |    |     |         |         | RO       |       |      |    |    |    | RO                 | RO                 | RO                      | RO                               | 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   |    |    |     |         |         | Reserved | i     |      |    |    |    | INT_<br>TO_<br>EN  | INT_<br>WP_<br>EN  | INT_<br>ERR<br>_EN      | INT_<br>ECC<br>_DO<br>NE_<br>EN  | INT_<br>NFC<br>_DO<br>NE_<br>EN  |
| Туре   |    | RO |     |         |         |          |       |      |    |    |    | R/W                | 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                                |

| Field Name           | Bit     | Туре | Reset<br>Value | Description                    |
|----------------------|---------|------|----------------|--------------------------------|
|                      | [31:21] | RO   | 11'h0          | Reserved                       |
| INT_TO_STS           | [20]    | RO   | 1'h0           | Masked INT_TO interrupt.       |
| INT_WP_STS           | [19]    | RO   | 1'h0           | Masked INT_WP interrupt.       |
| INT_ERR_STS          | [18]    | RO   | 1'h0           | Masked INT_ERR interrupt.      |
| INT_ECC_<br>DONE_STS | [17]    | RO   | 1'h0           | Masked INT_ECC_DONE interrupt. |



| INT_NFC_<br>DONE_STS | [16]   | RO  | 1'h0  | Masked INT_NFC_DONE interrupt.                                                                                      |
|----------------------|--------|-----|-------|---------------------------------------------------------------------------------------------------------------------|
|                      | [15:5] | RO  | 11'h0 | Reserved                                                                                                            |
| INT_TO_EN            | [4]    | R/W | 1'h0  | Interrupt when NAND access timeout. Set '1' to enable this interrupt.                                               |
| INT_WP_EN            | [3]    | R/W | 1'h0  | Interrupt when programming or erasing NAND in write-protection mode. Set '1' to enable this interrupt.              |
| INT_ERR_EN           | [2]    | R/W | 1'h0  | Interrupt when AHB tries to modify some configuration when NAND is in processing. Set '1' to enable this interrupt. |
| INT_ECC_<br>DONE_EN  | [1]    | R/W | 1'h0  | Interrupt when ECC calculation is done. Set '1' to enable this interrupt.                                           |
| INT_NFC_<br>DONE_EN  | [0]    | R/W | 1'h0  | Interrupt when NAND operation finishing. Set '1' to enable this interrupt.                                          |

#### Note:

When writing (ECC encode) NAND Flash, the INT\_ECC\_DONE interrupt is occurred before INT\_NFC\_DONE interrupt;

When reading (ECC decode) NAND Flash, the INT\_ECC\_DONE interrupt is occurred after INT\_NFC\_DONE interrupt.

### 5.3.6.2.8 NFC\_INT\_CLR\_RAW

Description: NFC interrupts clear and raw status

| 0x0024 |    |    | NFC          | interru | ıpt cle | ar and   | raw |    |    |    |    |                        | NF                     | C_INT                   | _CLR_                                | RAW                              |
|--------|----|----|--------------|---------|---------|----------|-----|----|----|----|----|------------------------|------------------------|-------------------------|--------------------------------------|----------------------------------|
| Bit    | 31 | 30 | 29           | 28      | 27      | 26       | 25  | 24 | 23 | 22 | 21 | 20                     | 19                     | 18                      | 17                                   | 16                               |
| Name   |    |    |              |         | ı       | Reserved | 1   |    |    |    |    | INT_<br>TO_<br>CLR     | INT_<br>WP_<br>CLR     | INT_<br>ERR<br>_CL<br>R | INT_<br>ECC<br>_DO<br>NE_<br>CLR     | INT_<br>NFC<br>_DO<br>NE_<br>CLR |
| Туре   |    |    | RO R/W R/W R |         |         |          |     |    |    |    |    |                        | R/W                    | R/W                     | R/W                                  |                                  |
| 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   |    |    |              |         | ı       | Reserved | i   |    |    |    |    | INT_<br>TO_<br>RA<br>W | INT_<br>WP_<br>RA<br>W | INT_<br>ERR<br>_RA<br>W | INT_<br>ECC<br>_DO<br>NE_<br>RA<br>W | INT_<br>NFC<br>_DO<br>NE_<br>RAW |
| Type   |    | RO |              |         |         |          |     |    |    |    |    | RO                     | RO                     | RO                      | RO                                   | RO                               |
| Reset  | 0  | 0  | 0            | 0       | 0       | 0        | 0   | 0  | 0  | 0  | 0  | 0                      | 0                      | 0                       | 0                                    | 0                                |

| Field Name | Bit     | Туре | Reset<br>Value | Description             |
|------------|---------|------|----------------|-------------------------|
|            | [31:21] | RO   | 11'h0          | Reserved                |
| INT_TO_CLR | [20]    | R/W  | 1'h0           | Clear INT_TO interrupt. |



| INT_WP_CLR  | [19]   | R/W | 1'h0  | Clear INT_WP interrupt.       |
|-------------|--------|-----|-------|-------------------------------|
| INT_ERR_CLR | [18]   | R/W | 1'h0  | Clear INT_ERR interrupt.      |
| INT_ECC_    | [17]   | R/W | 1'h0  | Clear INT_ECC_DONE interrupt. |
| DONE_CLR    |        |     |       |                               |
| INT_NFC_    | [16]   | R/W | 1'h0  | Clear INT_NFC_DONE interrupt. |
| DONE_CLR    |        |     |       |                               |
|             | [15:5] | RO  | 11'h0 | Reserved                      |
| INT_TO_RAW  | [4]    | RO  | 1'h0  | Raw INT_TO interrupt.         |
| INT_WP_RAW  | [3]    | RO  | 1'h0  | Raw INT_WP interrupt.         |
| INT_ERR_RAW | [2]    | RO  | 1'h0  | Raw INT_ERR interrupt.        |
| INT_ECC_    | [1]    | RO  | 1'h0  | Raw INT_ECC_DONE interrupt.   |
| DONE_RAW    |        |     |       |                               |
| INT_NFC_    | [0]    | RO  | 1'h0  | Raw INT_NFC_DONE interrupt.   |
| DONE_RAW    |        |     |       |                               |

# 5.3.6.2.9 NFC\_ECC\_CFG0

Description: ECC Configure 0.

| 0x0030 |     |             | ECC    | Con       | figure | (Reset | 32'hF | 0000) |                  |    |        |    |                               | NFC_                   | ECC_                    | CFG0                   |
|--------|-----|-------------|--------|-----------|--------|--------|-------|-------|------------------|----|--------|----|-------------------------------|------------------------|-------------------------|------------------------|
| Bit    | 31  | 30          | 29     | 28        | 27     | 26     | 25    | 24    | 23               | 22 | 21     | 20 | 19                            | 18                     | 17                      | 16                     |
| Name   |     | ECC_SEC_POS |        |           |        |        |       |       | ECC_SEC_SIZE     |    |        |    |                               |                        |                         |                        |
| Туре   | R/W |             |        |           |        |        |       |       |                  |    |        | R  | W                             |                        |                         |                        |
| Reset  | 0   | 0           | 0      | 0 0 0 0 0 |        |        |       |       | 0                | 0  | 0      | 0  | 1                             | 1                      | 1                       | 1                      |
| Bit    | 15  | 14          | 13     | 12        | 11     | 10     | 9     | 8     | 7                | 6  | 5      | 4  | 3                             | 2                      | 1                       | 0                      |
| Name   |     | Rese        | erved  |           |        | ECC_   | NUM_  |       | Res<br>erve<br>d | E  | CC_MOI | DΕ | ECC<br>_SP<br>_EN<br>DIA<br>N | ECC<br>_DE<br>COD<br>E | ECC<br>_AU<br>TO_<br>EN | ECC<br>_AC<br>T<br>IVE |
| Туре   |     | R           | RO R/W |           |        |        |       |       | RO               |    | R/W    |    | R/W                           | R/W                    | R/W                     | WO                     |
| Reset  | 0   | 0           | 0      | 0         | 0      | 0      | 0     | 0     | 0                | 0  | 0      | 0  | 0                             | 0                      | 0                       | 0                      |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                                                           |
|--------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------|
| ECC_SEC_POS  | [31:24] | R/W  | 8'h0           | ECC sector position of read or write data when ECC is enabled.                                        |
| ECC_SEC_SIZE | [23:16] | R/W  | 8'hf           | Spare sector area size, not the whole spare area size. E.g. 8'h0, size is 1 byte 8'h1, size is 2 byte |



|               |         |     |      | 8'hFF, size is 256 Bytes<br>(Default is 16 bytes)                                                                                                                         |
|---------------|---------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [15:12] | RO  | 5'h0 | Reserved                                                                                                                                                                  |
| ECC_NUM       | [11:8]  | R/W | 4'h0 | The times to evaluate ECC. E.g. 4'h0, number is 1 4'h3, number is 4 4'h7, number is 8                                                                                     |
|               | [7]     | RO  | 1'h0 | Reserved                                                                                                                                                                  |
| ECC_MODE      | [6:4]   | R/W | 3'b0 | ECC mode. 000: 1 Bits 001: 2 Bits. 010: 4 Bits 011: 8 Bits 100: 12 Bits 101: 16 Bits 110: 24 Bits 111: Reserved                                                           |
| ECC_SP_ENDIAN | [3]     | R/W | 1'h0 | ECC spare memory endian.                                                                                                                                                  |
| ECC_DECODE    | [2]     | R/W | 1'h0 | This bit indicated whether the ECC act as encoder or decoder.  0: encoder  1: decoder                                                                                     |
| ECC_AUTO_EN   | [1]     | R/W | 1'h0 | If set this bit 1'b1, then the ECC function will be active in auto mode, and the ECC_ACTIVE will be ignored.  (It is not auto cleared, and SW should write 0 to clear it) |
| ECC_ACTIVE    | [0]     | WO  | 1'b0 | Software writes this bit active the start ECC for encoding or decoding.  (If ECC_AUTO_EN =1, it is no used)  (It is auto cleared to 0 after write 1)                      |

5.3.6.2.10 NFC\_ECC\_CFG1

Description: ECC Configure 1.



| 0x0034 |                              |    | ECC     | Con     | figure | (Reset | 32'h1         | FF) |    |    |        |         |    | NFC_ | ECC_ | CFG1 |
|--------|------------------------------|----|---------|---------|--------|--------|---------------|-----|----|----|--------|---------|----|------|------|------|
| Bit    | 31                           | 30 | 29      | 28      | 27     | 26     | 25            | 24  | 23 | 22 | 21     | 20      | 19 | 18   | 17   | 16   |
| Name   |                              |    | Reserve | d       |        |        | ECC_MAIN_ADDR |     |    |    |        |         |    |      |      |      |
| Туре   |                              | RO |         |         |        |        | R/W           |     |    |    |        |         |    |      |      |      |
| Reset  | 0                            | 0  | 0       | 0       | 0      | 0      | 0             | 0   | 0  | 1  | 1      | 1       | 1  | 1    | 1    | 1    |
| Bit    | 15                           | 14 | 13      | 12      | 11     | 10     | 9             | 8   | 7  | 6  | 5      | 4       | 3  | 2    | 1    | 0    |
| Name   | EC<br>C_L<br>OC<br>ATI<br>ON |    |         | Reserve | d      |        |               |     |    |    | ECC_IN | FO_SIZE |    |      |      |      |
| Туре   | R/W                          |    |         | RO      |        |        |               |     |    |    | R      | W       |    |      |      |      |
| Reset  | 0                            | 0  | 0       | 0       | 0      | 0      | 0             | 1   | 1  | 1  | 1      | 1       | 1  | 1    | 1    | 1    |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                           |
|---------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [31:27] | RO   | 5'h0           | Reserved                                                                                                                                                                                                                                                                                                                                              |
| ECC_MAIN_ADDR | [26:16] | R/W  | 11'h0          | ECC_MAIN_ADDR (Unit Words) Then, this register indicates the beginning address of the ECC parity in the main area when the ECC_LOCATION is 1, while the micro-code operation is processed.  Note, the ECC_MAIN_ADDR may not nearly follow the valid main data; it can be located at any address in the main area.  The unit is words, not bytes.  Eg. |
|               |         |      |                | 11'h0: address = 0 word (0 byte)  11'h80: address = 128 words (512 bytes)                                                                                                                                                                                                                                                                             |
| ECC_LOCATION  | [15]    | R/W  | 1'b0           | This register indicates where the ECC bits located.  0: ECC is located in the spare memory buffer  1: ECC is located in the main memory buffer                                                                                                                                                                                                        |
| 4 (/)         | [14:10] | RO   | 5'h0           | Reserved                                                                                                                                                                                                                                                                                                                                              |
| ECC_INFO_SIZE | [9:0]   | R/W  | 10'h1FF        | ECC_INFO_SIZE (Unit Bytes) This register indicates the ECC information bytes; the ECC will be encoded or decoded based on these data. it ranges from 1 Byte to 1K Bytes. The real size is the set value adds 1. e.g. 10'h0: 1 Bytes 10'h1FF: 512Bytes (default) 10'h3FF: 1K Bytes Note:                                                               |



|  | In following two cases, the ECC_INFO_SIZE should be configured to word (32bits) aligned. |
|--|------------------------------------------------------------------------------------------|
|  | 1) ECC_LOCATION = 1                                                                      |
|  | 2) (ECC_LOCATION = 0) & (ECC_NUM != 4'h0);                                               |

Demonstration of the ECC parameters indicated.



Figure 1 is a reference of main and spare buffer.

Figure 2 is when the ECC\_LOCATION = 0, where the ECC parity is located in the spare area.

ECC\_INFO\_SIZE indicates the ECC information data size.

ECC\_SEC\_SIZE indicates every sector's bytes size in the spare area;

ECC\_SEC\_POS indicates the beginning address of parity in each sector,

ECC NUM indicates the times to calculate the ECC, here 2 times will be calculated.

Figure 3 is when the ECC\_LOCATION = 1, where the ECC parity is located after the information data in the main area.

MAIN\_AREA\_DATA\_SIZE indicates the main data information size, which may be bigger or equal to the ECC\_INFO\_SIZE \* (ECC\_NUM + 1)

### 5.3.6.2.11 NFC\_ECC\_STS0



| 0x0040 |     |            | ECC        | Status | 5            |        |      |    |     |    |             |    |              | NFC    | ECC_ | STS0 |  |
|--------|-----|------------|------------|--------|--------------|--------|------|----|-----|----|-------------|----|--------------|--------|------|------|--|
| Bit    | 31  | 30         | 29         | 28     | 27           | 26     | 25   | 24 | 23  | 22 | 21          | 20 | 19           | 18     | 17   | 16   |  |
| Name   | RSV | ECC_<br>ST | ERR_<br>S3 |        | ECC_ERR_NUM3 |        |      |    |     |    | ERR_S<br>S2 |    | ECC_ERR_NUM2 |        |      |      |  |
| Туре   | RO  | R          | .0         |        |              | RO     |      |    | RO  | R  | .0          |    | 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   | RSV | ECC_<br>ST | ERR_<br>S1 |        | ECC          | _ERR_N | IUM1 |    | RSV |    | ERR_S<br>S0 |    | ECC          | _ERR_N | IUMO |      |  |
| Туре   | RO  | R          | 0          | RO     |              |        |      |    | RO  | R  | .0          |    | RO           |        |      |      |  |
| Reset  | 0   | 0          | 0          | 0      | 0            | 0      | 0    | 0  | 0   | 0  | 0           | 0  | 0            | 0      | 0    | 0    |  |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                            |
|--------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | [31]    | RO   | 1'h0           | Reserved                                                                                                                                                                                                                                                                               |
| ECC_ERR_STS3 | [22:21] | RO   | 2'h0           | It indicates the 3 <sup>rd</sup> ECC Error Status                                                                                                                                                                                                                                      |
| ECC_ERR_NUM3 | [28:24] | RO   | 5'h0           | It indicates the 3 <sup>rd</sup> ECC Error Numbers.                                                                                                                                                                                                                                    |
|              | [23]    | RO   | 1'h0           | Reserved                                                                                                                                                                                                                                                                               |
| ECC_ERR_STS2 | [22:21] | RO   | 2'h0           | It indicates the 2 <sup>nd</sup> ECC Error Status                                                                                                                                                                                                                                      |
| ECC_ERR_NUM2 | [20:16] | RO   | 5'h0           | It indicates the 2 <sup>nd</sup> ECC Error Numbers.                                                                                                                                                                                                                                    |
|              | [15]    | RO   | 1'h0           | Reserved                                                                                                                                                                                                                                                                               |
| ECC_ERR_STS1 | [14:13] | RO   | 2'h0           | It indicates the 1 <sup>st</sup> ECC Error Status                                                                                                                                                                                                                                      |
| ECC_ERR_NUM1 | [12:8]  | RO   | 5'h0           | It indicates the 1 <sup>st</sup> ECC Error Numbers.                                                                                                                                                                                                                                    |
|              | [7]     | RO   | 1'h0           | Reserved                                                                                                                                                                                                                                                                               |
| ECC_ERR_STS0 | [6:5]   | RO   | 2'h0           | It indicates the 0 <sup>th</sup> ECC Error Status                                                                                                                                                                                                                                      |
|              | 31      |      |                | 2'b00: indicate jump out from SS step. (NO Error) 2'b01: indicate jump from search done in internal CHIEN. (Errors can be corrected) 2'b10: indicate jump from search done in last CHIEN. (Errors maybe not corrected) 2'b11: indicate jump from ELP step.( Errors can't be corrected) |
| ECC_ERR_NUM0 | [4:0]   | RO   | 5'h0           | It indicates the 0 <sup>th</sup> ECC Error Numbers.  5'h0: indicate no error  5'h1F: indicate more errors that can't be correted.  >5'h0 and < 5'h1F: indicate the error numbers.                                                                                                      |

#### Note:

When the ECC\_ERR\_NUM value is 0x00, then it means the corresponding sector's ECC is not decoded or there is no error occurred;

When the ECC\_ERR\_NUM is all 0x1F, then it means the corresponding sector's ECC is decoded and the error number is out of the capacity of the decoder.

When the ECC\_ERR\_NUM and ECC\_ERR\_STS registers are arranged in pairs, it have the different meanings: (suppose the ECC correct capacity is "t", and error number is "r")



| ECC_ERR_STS | ECC_ERR_NUM | Status                                      | Note                                                      |
|-------------|-------------|---------------------------------------------|-----------------------------------------------------------|
| 00          | 0           | No error                                    | When there are large amount errors, maybe this situation. |
| 01          | 0 < r < t   | Errors in capacity                          |                                                           |
|             | = = t       | Errors but not sure (in or out of capacity) | Not sure (especially for ECC mode0)                       |
| 10          | 0 < r < t   | Errors in capacity                          | X                                                         |
|             | = = t       | Errors but not sure (in or out of capacity) | Not sure (especially for ECC mode1)                       |
|             | = = 5'h1F   | Errors out of capacity                      |                                                           |
| 11          | = = 5'h1F   | Errors out of capacity                      |                                                           |

# 5.3.6.2.12 NFC\_ECC\_STS1

| 0x0044 |     |            | ECC        | C Status |              |        |      |    |     |                        |             |    |     | NFC    | ECC_ | STS1 |
|--------|-----|------------|------------|----------|--------------|--------|------|----|-----|------------------------|-------------|----|-----|--------|------|------|
| Bit    | 31  | 30         | 29         | 28       | 27           | 26     | 25   | 24 | 23  | 22                     | 21          | 20 | 19  | 18     | 17   | 16   |
| Name   | RSV | ECC_<br>ST | ERR_<br>S7 |          | ECC_ERR_NUM7 |        |      |    | RSV | ECC_ERR_S ECC_ERR_NUM6 |             |    |     |        |      |      |
| Type   | RO  | R          | 0          |          |              | RO     |      |    | RO  | RO 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   | RSV | ECC_<br>ST | ERR_<br>S5 |          | ECC          | _ERR_N | IUM5 |    | RSV |                        | ERR_S<br>S4 |    | ECC | _ERR_N | IUM4 |      |
| Туре   | RO  | R          | 0          | RO       |              |        |      |    | RO  | RO                     |             |    | RO  |        |      |      |
| Reset  | 0   | 0          | 0          | 0        | 0            | 0      | 0    | 0  | 0   | 0                      | 0           | 0  | 0   | 0      | 0    | 0    |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                                                                |
|--------------|---------|------|----------------|------------------------------------------------------------------------------------------------------------|
|              | [31]    | RO   | 1'h0           | Reserved                                                                                                   |
| ECC_ERR_STS7 | [22:21] | RO   | 2'h0           | It indicates the 7 <sup>th</sup> ECC Error Status                                                          |
| ECC_ERR_NUM7 | [28:24] | RO   | 5'h0           | It indicates the 7 <sup>th</sup> ECC Error Numbers.                                                        |
| 0.0          | [23]    | RO   | 1'h0           | Reserved                                                                                                   |
| ECC_ERR_STS6 | [22:21] | RO   | 2'h0           | It indicates the 6 <sup>th</sup> ECC Error Status                                                          |
| ECC_ERR_NUM6 | [20:16] | RO   | 5'h0           | It indicates the 6 <sup>th</sup> ECC Error Numbers.                                                        |
|              | [15]    | RO   | 1'h0           | Reserved                                                                                                   |
| ECC_ERR_STS5 | [14:13] | RO   | 2'h0           | It indicates the 5 <sup>th</sup> ECC Error Status                                                          |
| ECC_ERR_NUM5 | [12:8]  | RO   | 5'h0           | It indicates the 5 <sup>th</sup> ECC Error Numbers.                                                        |
|              | [7]     | RO   | 1'h0           | Reserved                                                                                                   |
| ECC_ERR_STS4 | [6:5]   | RO   | 2'h0           | It indicates the 4 <sup>th</sup> ECC Error Status <b>2'b00:</b> indicate jump out from SS step. (NO Error) |



|              |       |    |      | 2'b01: indicate jump from search done in internal CHIEN. (Errors can be corrected)                                                                                                |
|--------------|-------|----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |       |    |      | 2'b10: indicate jump from search done in last CHIEN. (Errors maybe not corrected)                                                                                                 |
|              |       |    |      | 2'b11: indicate jump from ELP step.( Errors can't be corrected)                                                                                                                   |
| ECC_ERR_NUM4 | [4:0] | RO | 5'h0 | It indicates the 4 <sup>th</sup> ECC Error Numbers.  5'h0: indicate no error  5'h1F: indicate more errors that can't be correted.  >5'h0 and < 5'h1F: indicate the error numbers. |

# 5.3.6.2.13 NFC\_ECC\_STS2

| 0x0048 |     |            | ECC         | Status | 3              |       |      |   |     |                   |             |    | NFC_ECC_STS1 |               |    |    |  |
|--------|-----|------------|-------------|--------|----------------|-------|------|---|-----|-------------------|-------------|----|--------------|---------------|----|----|--|
| Bit    | 31  | 30         | 29          | 28     | 28 27 26 25 24 |       |      |   |     | 22                | 21          | 20 | 19           | 18            | 17 | 16 |  |
| Name   | RSV |            | ERR_<br>S11 |        | ECC_           | ERR_N | UM11 |   | RSV | ECC_ERR_S<br>TS10 |             |    | ECC_         | ECC_ERR_NUM10 |    |    |  |
| Type   | RO  | R          | 0           |        | RO RO          |       |      |   |     |                   | 0           | RO |              |               |    |    |  |
| 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   | RSV | ECC_<br>ST | ERR_<br>S9  |        | ECC_ERR_NUM9   |       |      |   | RSV |                   | ERR_S<br>S8 |    | ECC_ERR_NUM8 |               |    |    |  |
| Туре   | RO  | R          | .0          |        | RO             |       |      |   |     | R                 | 0           | RO |              |               |    |    |  |
| Reset  | 0   | 0          | 0           | 0      | 0              | 0     | 0    | 0 | 0   | 0                 | 0           | 0  | 0            | 0             | 0  | 0  |  |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                        |
|---------------|---------|------|----------------|------------------------------------------------------------------------------------|
|               | [31]    | RO   | 1'h0           | Reserved                                                                           |
| ECC_ERR_STS11 | [22:21] | RO   | 2'h0           | It indicates the 11 <sup>th</sup> ECC Error Status                                 |
| ECC_ERR_NUM11 | [28:24] | RO   | 5'h0           | It indicates the 11 <sup>th</sup> ECC Error Numbers.                               |
|               | [23]    | RO   | 1'h0           | Reserved                                                                           |
| ECC_ERR_STS10 | [22:21] | RO   | 2'h0           | It indicates the 10 <sup>th</sup> ECC Error Status                                 |
| ECC_ERR_NUM10 | [20:16] | RO   | 5'h0           | It indicates the 10 <sup>th</sup> ECC Error Numbers.                               |
|               | [15]    | RO   | 1'h0           | Reserved                                                                           |
| ECC_ERR_STS9  | [14:13] | RO   | 2'h0           | It indicates the 9 <sup>th</sup> ECC Error Status                                  |
| ECC_ERR_NUM9  | [12:8]  | RO   | 5'h0           | It indicates the 9 <sup>th</sup> ECC Error Numbers.                                |
|               | [7]     | RO   | 1'h0           | Reserved                                                                           |
| ECC_ERR_STS8  | [6:5]   | RO   | 2'h0           | It indicates the 8 <sup>th</sup> ECC Error Status                                  |
|               |         |      |                | 2'b00: indicate jump out from SS step. (NO Error)                                  |
|               |         |      |                | 2'b01: indicate jump from search done in internal CHIEN. (Errors can be corrected) |
|               |         |      |                | 2'b10: indicate jump from search done in last CHIEN. (Errors maybe not corrected)  |



|              |       |    |      | 2'b11: indicate jump from ELP step.( Errors can't be corrected)                                                                                                                   |
|--------------|-------|----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ECC_ERR_NUM8 | [4:0] | RO | 5'h0 | It indicates the 8 <sup>th</sup> ECC Error Numbers.  5'h0: indicate no error  5'h1F: indicate more errors that can't be correted.  >5'h0 and < 5'h1F: indicate the error numbers. |

# 5.3.6.2.14 NFC\_ECC\_STS3

| 0x004C |     |             | ECC         | Status | 3    |        |      |    |     |    |             |    |               | NFC.          | ECC_ | STS1 |  |
|--------|-----|-------------|-------------|--------|------|--------|------|----|-----|----|-------------|----|---------------|---------------|------|------|--|
| Bit    | 31  | 30          | 29          | 28     | 27   | 26     | 25   | 24 | 23  | 22 | 21          | 20 | 19            | 18            | 17   | 16   |  |
| Name   | RSV | ECC_<br>ST: | ERR_<br>S15 |        | ECC_ | _ERR_N | UM15 |    | RSV |    | ERR_S<br>14 |    | ECC_          | ECC_ERR_NUM14 |      |      |  |
| Туре   | RO  | R           | .0          |        |      | RO     |      |    | RO  | R  | 0           |    | 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   | RSV | ECC_<br>ST  | ERR_<br>S13 |        | ECC_ | _ERR_N | UM13 |    | RSV |    | ERR_S<br>12 |    | ECC_ERR_NUM12 |               |      |      |  |
| Туре   | RO  | R           | .0          |        | RO   |        |      |    |     | R  | RO RO       |    |               |               |      |      |  |
| Reset  | 0   | 0           | 0           | 0      | 0    | 0      | 0    | 0  | 0   | 0  | 0           | 0  | 0             | 0             | 0    | 0    |  |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [31]    | RO   | 1'h0           | Reserved                                                                                                                                                                                                                                                                                                                                      |
| ECC_ERR_STS15 | [22:21] | RO   | 2'h0           | It indicates the 15 <sup>th</sup> ECC Error Status                                                                                                                                                                                                                                                                                            |
| ECC_ERR_NUM15 | [28:24] | RO   | 5'h0           | It indicates the 15 <sup>th</sup> ECC Error Numbers.                                                                                                                                                                                                                                                                                          |
|               | [23]    | RO   | 1'h0           | Reserved                                                                                                                                                                                                                                                                                                                                      |
| ECC_ERR_STS14 | [22:21] | RO   | 2'h0           | It indicates the 14 <sup>th</sup> ECC Error Status                                                                                                                                                                                                                                                                                            |
| ECC_ERR_NUM14 | [20:16] | RO   | 5'h0           | It indicates the 14 <sup>th</sup> ECC Error Numbers.                                                                                                                                                                                                                                                                                          |
|               | [15]    | RO   | 1'h0           | Reserved                                                                                                                                                                                                                                                                                                                                      |
| ECC_ERR_STS13 | [14:13] | RO   | 2'h0           | It indicates the 13 <sup>th</sup> ECC Error Status                                                                                                                                                                                                                                                                                            |
| ECC_ERR_NUM13 | [12:8]  | RO   | 5'h0           | It indicates the 13 <sup>th</sup> ECC Error Numbers.                                                                                                                                                                                                                                                                                          |
|               | [7]     | RO   | 1'h0           | Reserved                                                                                                                                                                                                                                                                                                                                      |
| ECC_ERR_STS12 | [6:5]   | RO   | 2'h0           | It indicates the 12 <sup>th</sup> ECC Error Status  2'b00: indicate jump out from SS step. (NO Error)  2'b01: indicate jump from search done in internal CHIEN. (Errors can be corrected)  2'b10: indicate jump from search done in last CHIEN. (Errors maybe not corrected)  2'b11: indicate jump from ELP step.( Errors can't be corrected) |



| ECC_ERR_NUM12 | [4:0] | RO | 5'h0 | It indicates the 12 <sup>th</sup> ECC Error Numbers. |
|---------------|-------|----|------|------------------------------------------------------|
|               |       |    |      | 5'h0: indicate no error                              |
|               |       |    |      | 5'h1F: indicate more errors that can't be correted.  |
|               |       |    |      | >5'h0 and < 5'h1F: indicate the error numbers.       |

# 5.3.6.2.15 NFC\_START\_ADDRx

Description: Start address for the x(0~7) page operation

| 0x0060 Start address for the 0 <sup>th</sup> page operation / NFC                           |                 |      |      |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|-----------------|------|------|--|--|--|--|--|--|--|--|
| Micro-Instruction Registers 0                                                               | NFC_START_ADDR0 |      |      |  |  |  |  |  |  |  |  |
| 0x0064 Start address for the 1 <sup>st</sup> page operation / Micro-Instruction Registers 1 | NFC_START_ADDR1 |      |      |  |  |  |  |  |  |  |  |
| 0x0068 Start address for the 2 <sup>nd</sup> page operation / Micro-Instruction Registers 2 | STAF            | RT_A | DDR2 |  |  |  |  |  |  |  |  |
| 0x006C Start address for the 3 <sup>rd</sup> page operation / Micro-Instruction Registers 3 | STAF            | RT_A | DDR3 |  |  |  |  |  |  |  |  |
| 0x0070 Start address for the 4 <sup>th</sup> page operation / Micro-Instruction Registers 4 | STAF            | RT_A | DDR4 |  |  |  |  |  |  |  |  |
| 0x0074 Start address for the 5 <sup>th</sup> page operation / Micro-Instruction Registers 5 | NFC_START_ADDR5 |      |      |  |  |  |  |  |  |  |  |
| 0x0078 Start address for the 6 <sup>th</sup> page operation / Micro-Instruction Registers 6 | NFC_START_ADDR6 |      |      |  |  |  |  |  |  |  |  |
| 0x007C Start address for the 7 <sup>th</sup> page operation / Micro-Instruction Registers 7 | NFC_START_ADDR7 |      |      |  |  |  |  |  |  |  |  |
| Bit 31 30 29 28 27 26 25 24 23 22 21 20 19                                                  | 18              | 17   | 16   |  |  |  |  |  |  |  |  |
| Name START_ADDRx                                                                            |                 |      |      |  |  |  |  |  |  |  |  |
| Type R/W                                                                                    |                 |      |      |  |  |  |  |  |  |  |  |
| 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 START_ADDRx                                                                            | START_ADDRx     |      |      |  |  |  |  |  |  |  |  |
|                                                                                             | R/W             |      |      |  |  |  |  |  |  |  |  |
| <b>Type</b> R/W                                                                             |                 |      |      |  |  |  |  |  |  |  |  |



| Field Name  | Bit    | Туре | Reset<br>Value | Description                                                                           |
|-------------|--------|------|----------------|---------------------------------------------------------------------------------------|
| START_ADDRx | [31:0] | R/W  | 32'h0          | Start address for the x(0~7) page operation, or the Micro-Instruction Register x(0~7) |

### 5.3.6.2.16 NFC\_END\_ADDRx

Description: End address for the  $x(0\sim7)$  page operation

| 0x0080 |    |    |                         |                                                                                        |    | the 0 <sup>th</sup><br>Regis |               | operat | ion / |    |    |    | 1             | NFC_E | ND_A          | DDR0 |  |  |
|--------|----|----|-------------------------|----------------------------------------------------------------------------------------|----|------------------------------|---------------|--------|-------|----|----|----|---------------|-------|---------------|------|--|--|
| 0x0084 |    |    |                         | addres<br>o-Instr                                                                      |    |                              | NFC_END_ADDR1 |        |       |    |    |    |               |       |               |      |  |  |
| 0x0088 |    |    |                         | addres<br>o-Instr                                                                      |    | NFC_END_ADDR2                |               |        |       |    |    |    |               |       |               |      |  |  |
| 0x008C |    |    |                         | addres<br>o-Instr                                                                      |    | 1                            | NFC_E         | ND_A   | DDR3  |    |    |    |               |       |               |      |  |  |
| 0x0090 |    |    |                         | End address for the 4 <sup>th</sup> page operation / Micro-Instruction Registers 12    |    |                              |               |        |       |    |    |    |               |       | ND_A          | DDR4 |  |  |
| 0x0094 |    |    |                         | End address for the 5 <sup>th</sup> page operation /<br>Micro-Instruction Registers 13 |    |                              |               |        |       |    |    |    |               |       | NFC_END_ADDR5 |      |  |  |
| 0x0098 |    |    |                         | End address for the 6 <sup>th</sup> page operation /<br>Micro-Instruction Registers 14 |    |                              |               |        |       |    |    |    |               |       | NFC_END_ADDR6 |      |  |  |
| 0x009C |    |    |                         |                                                                                        |    | the 7 <sup>th</sup><br>Regis |               | •      | ion/  |    |    |    | NFC_END_ADDR7 |       |               |      |  |  |
| Bit    | 31 | 30 | 29                      | 28                                                                                     | 27 | 26                           | 25            | 24     | 23    | 22 | 21 | 20 | 19            | 18    | 17            | 16   |  |  |
| Name   |    |    |                         | END_ADDRx                                                                              |    |                              |               |        |       |    |    |    |               |       |               |      |  |  |
| Туре   |    |    |                         | R/W                                                                                    |    |                              |               |        |       |    |    |    |               |       |               |      |  |  |
| 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   |    |    |                         | END_ADDRx                                                                              |    |                              |               |        |       |    |    |    |               |       |               |      |  |  |
| Туре   |    |    |                         | R/W                                                                                    |    |                              |               |        |       |    |    |    |               |       |               |      |  |  |
| Reset  | 0  | 0  | 0                       | 0                                                                                      | 0  | 0                            | 0             | 0      | 0     | 0  | 0  | 0  | 0             | 0     | 0             | 0    |  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                         |
|------------|--------|------|----------------|-------------------------------------------------------------------------------------|
| END_ADDRx  | [31:0] | R/W  | 32'h0          | End address for the x(0~7) page operation or the Micro-Instruction Register x(8~15) |

# 5.3.7 ECC

SC6820 NAND Flash Controller consist one powerful internal error checking and correcting module. It supports configurations of different parameters including coding size, redundancy size, and correct capacity.



Main function is to checking and correcting errors when read and write nand flash. When write (or program) nand flash, starting this module to encode the written data and save the encode data to the spare area; when read nand flash, starting this module to decode the read data and correct the error data.

In this module, the ECC support 1~ 1K bytes information bits ECC encoder and decoder. The supported information and redundancies configuration as following:

| ECC MODE | Correct-capacity | Redundancies bits | Notes                  |
|----------|------------------|-------------------|------------------------|
| 0        | 1 bits           | 14                | Info size 1 ~ 1K Bytes |
| 1        | 2 bits           | 28                | Info size 1 ~ 1K Bytes |
| 2        | 4 bits           | 56                | Info size 1 ~ 1K Bytes |
| 3        | 8 bits           | 112               | Info size 1 ~ 1K Bytes |
| 4        | 12 bits          | 168               | Info size 1 ~ 1K Bytes |
| 5        | 16 bits          | 224               | Info size 1 ~ 1K Bytes |
| 6        | 24 bits          | 336               | Info size 1 ~ 1K Bytes |

For detail information about ECC module, please refer to "SC6820 ECC Module Design Specification"

### 5.3.8 Application Notes

Before configure module, set some global parameters, Set bit[8] of 0x2090\_0200 to enable NFC clock; Set or reset bit[5] of 0x2090\_0210 to reset NFC module;

#### 5.3.8.1 Non-DMA fixed-sequence Program Flow

For programming:

- 1. Software write data to the internal main buffer (0x6000\_2000) and spare buffer (0x6000\_4000).
- Set NFC\_CFG0 for basic parameters including: MEM\_NFC\_SWITCH, DEV\_BUS\_SIZE, CS\_SEL, PAGE\_TYPE, ADD\_CYCLE, ADVANCE, NFC\_CMD\_SET = 0, NFC\_SP\_SIZE. Also NFC\_WPN should be set 1 to un-protect the Nand
- For different NAND, the timing parameters are different, the NFC\_TIMING register should be set relatively
- 4. Set NFC\_START\_ADDR0 ~ 7 and NFC\_END\_ADDR0~7 to indicate the start and end address which will be write to.
- 5. If ECC function is used, the NFC\_ECC\_CFG0 and NFC\_ECC\_CFG1 should be set to configure the ECC parameters including: ECC\_DECODE, ECC\_SP\_ENDIAN, ECC\_MODE, ECC\_NUM, ECC\_SEC\_SIZE, ECC\_SEC\_POS and ECC\_INFO\_SIZE. if the automatic way is selected, the ECC\_AUTO\_EN register should be set to 1. The ECC\_ACTIVE\_EN will used if one manual calculate the ECC and used this function independly.
- 6. Set **NFC\_INT\_STS\_EN** register, for basic function, the INT\_NFC\_DONE\_EN should set 1. The INT\_ECC\_DONE\_EN can be omitted either the ECC function is used or not in programming nand process.
- Write NFC\_CMD register to start the programming process with BLK\_NUM inside.
- 8. After the INT\_NFC\_DONE interrupt is occurred, the programming is done.



#### 5.3.8.2 Non-DMA fixed-sequence read Flow

#### For reading:

- Set NFC\_CFG0 for basic parameters including: MEM\_NFC\_SWITCH, DEV\_BUS\_SIZE, CS\_SEL, PAGE\_TYPE, ADD\_CYCLE, ADVANCE, NFC\_CMD\_SET = 0, NFC\_SP\_SIZE. Also NFC\_WPN should be set 1 to un-protect the Nand
- For different NAND, the timing parameters are different, the NFC\_TIMING register should be set relatively
- 3. Set NFC\_START\_ADDR0 ~ 7 and NFC\_END\_ADDR0~7 to indicate the start and end address which will be write to.
- 4. If ECC function is used, the NFC\_ECC\_CFG0 and NFC\_ECC\_CFG1 should be set to configure the ECC parameters including: ECC\_DECODE, ECC\_SP\_ENDIAN, ECC\_MODE, ECC\_NUM, ECC\_SEC\_SIZE, ECC\_SEC\_POS and ECC\_INFO\_SIZE. if the automatic way is selected, the ECC\_AUTO\_EN register should be set to 1. The ECC\_ACTIVE\_EN will used if one manual calculate the ECC and used this function independly.
- 5. Set **NFC\_INT\_STS\_EN** register, for basic function, the INT\_NFC\_DONE\_EN should set 1. If ECC is used , the INT\_ECC\_DONE\_EN should be set
- Write NFC\_CMD register to start the programming process with BLK\_NUM inside.
- If ECC\_AUTO\_EN is set, after the INT\_ECC\_DONE interrupt is occurred, the read is done; then after the INT\_NFC\_DONE interrupt is occurred, the read is done
- 8. Software read data from the internal main buffer (0x6000\_2000) and spare buffer (0x6000\_4000).





Figure 5.3-5 NFC Non-DMA Fixed Sequence

#### 5.3.8.3 Non-DMA Micro- Code Programming Flow

For programming:

- Software write data to the internal main buffer (0x6000\_2000) and spare buffer (0x6000\_4000).
- If ECC function is used, the NFC\_ECC\_CFG0 and NFC\_ECC\_CFG1 should be set to configure the ECC parameters including: ECC\_DECODE, ECC\_SP\_ENDIAN, ECC\_MODE, ECC\_NUM, ECC\_SEC\_SIZE, ECC\_SEC\_POS and ECC\_INFO\_SIZE. In micro-code mode, the ECC automatically way cannot be used. Software should write ECC\_ACTIVE\_EN to manually start the ECC function.
- 3. After the ECC is done, software should copy the spare buffer data to the heel of data of main buffer.
- Set NFC\_CFG0 for basic parameters including: MEM\_NFC\_SWITCH, DEV\_BUS\_SIZE, CS\_SEL, PAGE\_TYPE, ADD\_CYCLE, ADVANCE, NFC\_CMD\_SET = 1, NFC\_SP\_SIZE. Also NFC\_WPN should be set 1 to un-protect the Nand
- For different NAND, the timing parameters are different, the NFC\_TIMING register should be set relatively



- For Micro-code mode, the address registers are act as Micro-Instruction Registers, Software write these registers based on the selected NAND command/address/data sequence, the code number will be set on the NFC\_CMD registers
- 7. Set **NFC\_INT\_STS\_EN** register, for basic function, the INT\_NFC\_DONE\_EN should set 1.
- Write NFC\_CMD register to start the programming process with INST\_NUM inside.
- 9. After the INT\_NFC\_DONE interrupt is occurred, the programming is done.

#### 5.3.8.4 Non-DMA Micro- Code Reading Flow

For reading:

- Set NFC\_CFG0 for basic parameters including: MEM\_NFC\_SWITCH, DEV\_BUS\_SIZE, CS\_SEL, PAGE\_TYPE, ADD\_CYCLE, ADVANCE, NFC\_CMD\_SET = 1, NFC\_SP\_SIZE.
- For different NAND, the timing parameters are different, the NFC\_TIMING register should be set relatively
- For Micro-code mode, the address registers are act as Micro-Instruction Registers, Software write these registers based on the selected NAND command/address/data sequence, the code number will be set on the NFC\_CMD registers
- Set NFC\_INT\_STS\_EN register, for basic function, the INT\_NFC\_DONE\_EN should set 1.
- Write NFC\_CMD register to start the programming process with INST\_NUM inside.
- 6. Wait the ECC is done
- If ECC is used, software should copy the heel date of main buffer to spare buffer.
- 8. If ECC function is used, the NFC\_ECC\_CFG0 and NFC\_ECC\_CFG1 should be set to configure the ECC parameters including: ECC\_DECODE, ECC\_SP\_ENDIAN, ECC\_MODE, ECC\_NUM, ECC\_SEC\_SIZE, ECC\_SEC\_POS and ECC\_INFO\_SIZE. In micro-code mode, the ECC automatically way cannot be used. Software should write ECC\_ACTIVE\_EN to manually start the ECC function.
- 9. After the INT NFC DONE interrupt is occurred, the reading is done.
- 10. Software read data from the internal main buffer (0x6000\_2000) and spare buffer (0x6000\_4000).





Figure 5.3-6 NFC Non-DMA Micro Code

#### 5.3.8.5 DMA fixed-sequence Program Flow

For programming:

- 1. Configure the DMA channel parameters, where the DMA target address is 0x6000\_2000 and linked target address is 0x6000\_4000
- Set NFC\_CFG0 for basic parameters including: MEM\_NFC\_SWITCH, DEV\_BUS\_SIZE, CS\_SEL, PAGE\_TYPE, ADD\_CYCLE, ADVANCE, NFC\_CMD\_SET = 0, NFC\_SP\_SIZE. Also NFC\_WPN should be set 1 to un-protect the Nand
- 3. Set DMA\_TX\_EN of NFC\_CFG1 to enable the hardware DMA transfer.
- For different NAND, the timing parameters are different, the NFC\_TIMING register should be set relatively
- Set NFC\_START\_ADDR0 ~ 7 and NFC\_END\_ADDR0~7 to indicate the start and end address which will be write to.



- 6. If ECC function is used, the NFC\_ECC\_CFG0 and NFC\_ECC\_CFG1 should be set to configure the ECC parameters including: ECC\_DECODE, ECC\_SP\_ENDIAN, ECC\_MODE, ECC\_NUM, ECC\_SEC\_SIZE, ECC\_SEC\_POS and ECC\_INFO\_SIZE. if the automatic way is selected, the ECC\_AUTO\_EN register should be set to 1. The ECC\_ACTIVE\_EN will used if one manual calculate the ECC and used this function independly.
- Set NFC\_INT\_STS\_EN register, for basic function, the INT\_NFC\_DONE\_EN should set 1. The INT\_ECC\_DONE\_EN can be omitted either the ECC function is used or not in programming nand process.
- Write NFC\_CMD register to start the programming process with BLK\_NUM inside.
- 9. After the INT\_NFC\_DONE interrupt is occurred, the programming is done.

#### 5.3.8.6 DMA fixed-sequence read Flow

For reading:

- Configure the DMA channel parameters, where the DMA source address is 0x6000 2000 and linked source address is 0x6000 4000
- Set NFC\_CFG0 for basic parameters including: MEM\_NFC\_SWITCH, DEV\_BUS\_SIZE, CS\_SEL, PAGE\_TYPE, ADD\_CYCLE, ADVANCE, NFC\_CMD\_SET = 0, NFC\_SP\_SIZE. Also NFC\_WPN should be set 1 to un-protect the Nand
- 3. Set DMA RX EN of NFC CFG1 to enable the hardware DMA receiving.
- For different NAND, the timing parameters are different, the NFC\_TIMING register should be set relatively
- Set NFC\_START\_ADDR0 ~ 7 and NFC\_END\_ADDR0~7 to indicate the start and end address which will be write to.
- 6. If ECC function is used, the NFC\_ECC\_CFG0 and NFC\_ECC\_CFG1 should be set to configure the ECC parameters including: ECC\_DECODE, ECC\_SP\_ENDIAN, ECC\_MODE, ECC\_NUM, ECC\_SEC\_SIZE, ECC\_SEC\_POS and ECC\_INFO\_SIZE. if the automatic way is selected, the ECC\_AUTO\_EN register should be set to 1. The ECC\_ACTIVE\_EN will used if one manual calculate the ECC and used this function independly.
- Set NFC\_INT\_STS\_EN register, for basic function, the INT\_NFC\_DONE\_EN should set 1. If ECC is used, the INT\_ECC\_DONE\_EN should be set
- Write NFC\_CMD register to start the programming process with BLK\_NUM inside.
- 9. After the DMA DONE is occurred, then the reading process is done.





Figure 5.3-7 NFC DMA Fixed Sequence

### 5.3.8.7 DMA Micro- Code Programming Flow

For programming:

- Configure the DMA channel parameters, where the DMA target address is 0x6000\_2000
- Set DMA\_TX\_EN of NFC\_CFG1 to enable the hardware DMA transfer and start DMA.
- 3. Wait for the DMA\_DONE interrupt.
- If ECC function is used, the NFC\_ECC\_CFG0 and NFC\_ECC\_CFG1 should be set to configure the ECC parameters including: ECC\_DECODE, ECC\_SP\_ENDIAN, ECC\_MODE, ECC\_NUM, ECC\_SEC\_SIZE, ECC\_SEC\_POS and ECC\_INFO\_SIZE. In micro-code mode, the ECC



- automatically way cannot be used. Software should write ECC\_ACTIVE\_EN to manually start the ECC function.
- After the ECC is done, software should copy the spare buffer data to the heel of data of main buffer.
- Set NFC\_CFG0 for basic parameters including: MEM\_NFC\_SWITCH, DEV\_BUS\_SIZE, CS\_SEL, PAGE\_TYPE, ADD\_CYCLE, ADVANCE, NFC\_CMD\_SET = 1, NFC\_SP\_SIZE. Also NFC\_WPN should be set 1 to un-protect the Nand
- For different NAND, the timing parameters are different, the NFC\_TIMING register should be set relatively
- For Micro-code mode, the address registers are act as Micro-Instruction Registers, Software write these registers based on the selected NAND command/address/data sequence, the code number will be set on the NFC\_CMD registers
- Set NFC\_INT\_STS\_EN register, for basic function, the INT\_NFC\_DONE\_EN should set 1.
- Write NFC\_CMD register to start the programming process with INST\_NUM inside.
- 11. After the INT NFC DONE interrupt is occurred, the programming is done.

#### 5.3.8.8 DMA Micro-Code Reading Flow

For reading:

- 1. Configure the DMA channel parameters, where the DMA source address is 0x6000\_2000 and linked source address is 0x6000\_4000
- 2. Set DMA\_RX\_EN of NFC\_CFG1 to enable the hardware DMA receiving
- Set NFC\_CFG0 for basic parameters including: MEM\_NFC\_SWITCH, DEV\_BUS\_SIZE, CS\_SEL, PAGE\_TYPE, ADD\_CYCLE, ADVANCE, NFC\_CMD\_SET = 1, NFC\_SP\_SIZE.
- For different NAND, the timing parameters are different, the NFC\_TIMING register should be set relatively
- For Micro-code mode, the address registers are act as Micro-Instruction Registers, Software write these registers based on the selected NAND command/address/data sequence, the code number will be set on the NFC\_CMD registers
- Set NFC\_INT\_STS\_EN register, for basic function, the INT\_NFC\_DONE\_EN should set 1.
- Write NFC\_CMD register to start the programming process with INST\_NUM inside.
- 8. Wait the ECC is done
- If ECC is used,software should copy the heel date of main buffer to spare buffer.
- 10. If ECC function is used, the NFC\_ECC\_CFG0 and NFC\_ECC\_CFG1 should be set to configure the ECC parameters including: ECC\_DECODE, ECC\_SP\_ENDIAN, ECC\_MODE, ECC\_NUM, ECC\_SEC\_SIZE, ECC\_SEC\_POS and ECC\_INFO\_SIZE. In micro-code mode, the ECC automatically way cannot be used. Software should write ECC\_ACTIVE\_EN to manually start the ECC function.
- 11. After the INT\_NFC\_DONE interrupt is occurred, the reading is done.
- 12. Start DMA
- 13. Wait for the DMA\_DONE interrupt.





Figure 5.3-8 NFC DMA Micro Code

### 5.4 DMA Controller

### 5.4.1 Overview

The Direct Memory Access (DMA) controller is used to accelerate data transfer between different peripherals and memories without processor core's intervention. 32-channel AHB-based DMA controller improves data transfer efficiency.

This controller can also support several work modes. The DMA controller support a 2-D transfer which means a total transfer is divided into several blocks and each request only responded with one block transfer.

#### 5.4.2 Features

- I 32 channels. Each channel can be enabled and configured independently
- 4-level priority. Priority can be configured independently for each channel. The channels with the same priority are selected with robin-round algorithm
- I Configurable block wait time



- 1 28 channels are used by hardware, and the other 4 channels can be used dedicatedly as software request
- Each channel can be configured as whole transfer executed after one request or one block executed after one request
- I Each channel can be configured in normal mode
- I Each channel can be configured in linked list mode
- Each channel can be configured in infinite burst mode
- I The transfer support both byte (8 bit), half-word (16 bit) and word (32 bit). If in word format, a user can re-arrange the byte sequence beyond a word to adapt for different system requirement
- Each channel can be programmed to allocate a channel user identity (UID), which can be used to calculate this user's "channel control register" base-address.

# 5.4.3 Function Description

The Direct Memory Access (DMA) is essential part of both DSP platform and ARM processor platform, and in both platform it is used to accelerate data transfer between the different peripherals and memories, without any DSP/ARM core intervention.

DMA transfer is carried out in either an untouched data format or in a restructured data format, depending on the requirements of the particular applications.

DMA controller has two masters, one is dedicated for read operation and the other is dedicated for write, supporting reading and writing data simultaneously on differently layers.

### 5.4.3.1 DMA Channel Description

The DMA controller supports 32 logic channels and each channel can be enabled and configured independently.

For hardware-request, the sources are from different clock domains, the synchronization logic for requests and acknowledges are implemented in the DMA controller.

#### 5.4.3.2 DMA Work Modes

The DMA contains 32 independent programmable logic channels that support 32 different applications at the same time. Besides, for each channel, it can work in normal mode, linked list mode or soft list mode according to the applications.

"Normal Mode". In Normal mode, the channel will be initialized, configured and enabled by software. After receiving request from hardware or software, DMA begin to transfer a block, or the total data according to the configuration information.

"Linked List Mode". In Linked List mode, the channel will be initialized and enabled by software. While in the selected channel, nothing but an address pointer is valid. Base on the linked list pointer, DMA can load the channel configuration information by itself, and begin to transfer according to the newly loaded configuration. If the newly loaded configuration information has the "LLEnd" bit active, then this means that it is the last node of the linked list. And if "LLEnd" is set active, the bit "DMAChnLLPtr" is invalid.

"Soft List Mode". In Soft List mode, the channel will be initialized and enable by software. Besides, software also needs to maintain a list out side of DMA. Each node



of the list contains 8-word full channel configuration information. Software will let DMA know the list base address and the list size and how many nodes are there in the list. DMA will automatically load the channel configuration information as long as the list counter is nonzero.

#### 5.4.3.3 Two-Dimensional Transfer

A 2-Dimension transfer divides a whole transfer length into several transfer blocks. One block will be transferred after one request. The transfer block also composed of several elements. An "element" is an atomic unit of a burst transfer, which can be byte, half-word or word. A user can place a gap between the boundary of elements or blocks, which means an address leap is supported during burst transfer.

#### 5.4.3.4 Channel Arbitration

The DMA controller provides configurable 4-level priority for each channel in register DMA\_PRIORITY0 or DMA\_PRIORITY1, and each channel can be configured independently in one of the four priority levels.

The channel with higher priority is always granted more early than the channel with lower priority -3 > 2 > 1 > 0.

The channels with the same priority are granted by robin-round rule.

#### 5.4.3.5 DMA Interrupt Description

For each channel, there are two interrupt sources: the whole transfer completed interrupt and one burst completed interrupt. Each interrupt source can be enabled or disabled. The masked and raw interrupt status can be read and cleared through AHB.

For linked list mode, the whole transfer completed interrupt indicates all linked list nodes are completed.

### 5.4.4 DMA Logic Request Channels

There are totally 32 logic request channels in arm side, 16 logic request channels in dsp side. Once a channel is allocated with a UID, then the base-address of "channel control register" can be calculated as follows (n is channel number).

 $0x2010\ 0400 + 0x0020*n$ 

Table 5-2 DMA logci request channels

| UID | Channel User | Description      |
|-----|--------------|------------------|
| 1   | UART0 TX     | UART0 TX request |
| 2   | UART0 RX     | UART0 RX request |
| 3   | UART1 TX     | UART1 TX request |
| 4   | UART1 RX     | UART1 RX request |
| 5   | UART2 TX     | UART2 TX request |
| 6   | UART2 RX     | UART2 RX request |
| 7   | IIS0 TX      | IIS0 TX request  |
| 8   | IIS0 RX      | IIS0 RX request  |
| 9   | EPT_RX       | EPT RX request   |



| UID | Channel User | Description         |
|-----|--------------|---------------------|
| 10  | EPT_TX       | EPT TX request      |
| 11  | VB DA0       | VBC DAC0 TX request |
| 12  | VB DA1       | VBC DAC1 TX request |
| 13  | VB AD0       | VBC ADC0 TX request |
| 14  | VB AD1       | VBC ADC1 TX request |
| 15  | SIM0 TX      | SIM 0 TX request    |
| 16  | SIM0 RX      | SIM 0 RX request    |
| 17  | SIM1 TX      | SIM 1 TX request    |
| 18  | SIM1 RX      | SIM 1 RX request    |
| 19  | SPI0 TX      | SPI0 TX request     |
| 20  | SPI0 RX      | SPI0 RX request     |
| 21  | ROT          | Rotation request    |
| 22  | SPI1 TX      | SPI1 TX request     |
| 23  | SPI1 RX      | SPI1 RX request     |
| 24  | IIS1 TX      | IIS1 TX request     |
| 25  | IIS1 RX      | IIS1 RX request     |
| 26  | NFC TX       | NFC TX request      |
| 27  | NFC RX       | NFC RX request      |
| 28  |              |                     |
| 29  | DRM RAW      | DRM raw request     |
| 30  | DRM CPT      | DRM cpt request     |
| 31  |              |                     |
| 32  |              |                     |

### Note:

The UID is fixed by AISC, while the Channel User is configurable; Each UID can be configured to complete anyone of the 32 Channel User's function.

# 5.4.5 Control Registers

# 5.4.5.1 Memory map

ARM base address: 0x2010\_0000

| Offset<br>Addr | Register Name     | Register Description           |
|----------------|-------------------|--------------------------------|
| 0x0000         | DMA_BLK_WAIT      | Block Wait time register       |
| 0x0004         | DMA_CHN_EN_STATUS | Channel enable register        |
| 0x0008         | DMA_LINK_LIST_EN  | Link List Mode enable register |



| Offset<br>Addr | Register Name                    | Register Description                              |
|----------------|----------------------------------|---------------------------------------------------|
| 0x000C         | DMA_SOFT_LIST_EN                 | Soft List Mode enable register                    |
| 0x0010         | DMA_SOFT_LIST_SIZE               | Soft List size register                           |
| 0x0014         | DMA_SOFT_LIST_CMD                | Soft list command register                        |
| 0x0018         | DMA_SOFT_LIST_STATUS             | Soft list mode status register                    |
| 0x001C         | DMA_SOFT_LIST_BADDR              | Base address register of soft list mode           |
| 0x0020         | DMA_PRI_CFG0                     | Channel Priority register                         |
| 0x0024         | DMA_PRI_CFG1                     | Channel Priority register                         |
| 0x0028         | Reserved.                        |                                                   |
| 0x002C         | Reserved.                        |                                                   |
| 0x0030         | DMA_INT_MASK_STATUS              | DMA Masked interrupt status register              |
| 0x0034         | DMA_INT_RAW_STATUS               | DMA Raw interrupt status register                 |
| 0x0038         | Reserved.                        |                                                   |
| 0x003C         | Reserved.                        |                                                   |
| 0x0040         | DMA_LLIST_DONE_INT_EN            | Interrupt enable register of Link list done.      |
| 0x0044         | DMA_BLOCK_DONE_INT_EN            | Interrupt enable register of Burst done           |
| 0x0048         | DMA_TRANS_DONE_INT_EN            | Interrupt enable register of Transaction done     |
| 0x004C         | Reserved.                        |                                                   |
| 0x0050         | DMA_LLIST_DONE_ INT_ MASK_STATUS | Masked status of Link list done interrupt.        |
| 0x0054         | DMA_BLOCK_DONE_INT_MASK_STATUS   | Masked status of block done interrupt.            |
| 0x0058         | DMA_TRANS_DONE_INT_MASK_STATUS   | Masked status of<br>Transaction done<br>interrupt |
| 0x005C         | Reserved.                        |                                                   |
| 0x0060         | DMA_LLIST_DONE_ INT_ RAW_STATUS  | Raw status of Link List done interrupt.           |
| 0x0064         | DMA_BLOCK_DONE_INT_ RAW _STATUS  | Raw status of BLock done interrupt.               |
| 0x0068         | DMA_TRANS_DONE_INT_ RAW _STATUS  | Raw status of<br>Transaction done<br>interrupt.   |



| Offset<br>Addr    | Register Name            | Register Description                 |  |  |  |  |  |
|-------------------|--------------------------|--------------------------------------|--|--|--|--|--|
| 0x006C            | Reserved.                |                                      |  |  |  |  |  |
| 0x0070            | DMA_LLIST_DONE_ INT_ CLR | Clear interrupt of Link<br>List done |  |  |  |  |  |
| 0x0074            | DMA_BURST_DONE_INT_ CLR  | Clear interrupt of Burst done.       |  |  |  |  |  |
| 0x0078            | DMA_TRANS_DONE_INT_ CLR  | Clear interrupt of Transaction done. |  |  |  |  |  |
| 0x007C            | Reserved.                |                                      |  |  |  |  |  |
| 0x0080            | DMA_SOFT_REQ             | Soft channel request                 |  |  |  |  |  |
| 0x0084            | DMA_STATUS               | DMA Status                           |  |  |  |  |  |
| 0x0088            | DMA_REQ_PEND             | Pending request status.              |  |  |  |  |  |
| 0x008C            | Reserved.                |                                      |  |  |  |  |  |
| 0x0090            | DMA_WRAP_START_ADDR      | Start address of WRAP mode.          |  |  |  |  |  |
| 0x0094            | DMA_WRAP_END_ADDR        | End address of WRAP mode.            |  |  |  |  |  |
| 0x0098            | DMA_CHN_UID_CFG0         | User ID of channels                  |  |  |  |  |  |
| 0x009C            | DMA_CHN_UID_CFG1         | User ID of channels                  |  |  |  |  |  |
| 0x00A0            | DMA_CHN_UID_CFG2         | User ID of channels                  |  |  |  |  |  |
| 0x00A4            | DMA_CHN_UID_CFG3         | User ID of channels                  |  |  |  |  |  |
| 0x00A8            | DMA_CHN_UID_CFG4         | User ID of channels                  |  |  |  |  |  |
| 0x00AC            | DMA_CHN_UID_CFG5         | User ID of channels                  |  |  |  |  |  |
| 0x00B0            | DMA_CHN_UID_CFG6         | User ID of channels                  |  |  |  |  |  |
| 0x00B4            | Reserved.                |                                      |  |  |  |  |  |
| 0x00B8            | Reserved.                |                                      |  |  |  |  |  |
| 0x00BC            | Reserved.                |                                      |  |  |  |  |  |
| 0x00C0            | DMA_CHN_EN_SET           | User ID of channels                  |  |  |  |  |  |
| 0x00C4            | DMA_CHN_EN_CLR           | User ID of channels                  |  |  |  |  |  |
| 0x00C8-<br>0x0400 | Reserved.                |                                      |  |  |  |  |  |
| 0x0400            | CHN0_CFG                 | Channel 0 configure register         |  |  |  |  |  |
| 0x0404            | CHN0_TOTAL_LEN           | Channel 0 total length               |  |  |  |  |  |
| 0x0408            | CHN0_SRC_ADDR            | Channel 0 Source<br>Address          |  |  |  |  |  |
| 0x040C            | CHN0_DEST_ADDR           | Channel 0 Destination<br>Address     |  |  |  |  |  |
| 0x0410            | CHN0_LLIST_PTR           | Channel 0 Link list pointer address  |  |  |  |  |  |



| Offset            | Register Name                                           | Pogistor Description                          |
|-------------------|---------------------------------------------------------|-----------------------------------------------|
| Addr              | Register Name                                           | Register Description                          |
| 0x0414            | CHN0_ELEM_POSTM                                         | Channel 0 Element post-modification           |
| 0x0418            | CHN0_SRC_BLOCK_POSTM                                    | Channel 0 Source<br>Block post-modification   |
| 0x041C            | CHN0_DEST_BLOCK_POSTM                                   | Channel 0 Destination Block post-modification |
| 0x0420-<br>0x043C | Channel 1 configure register, definition as channel 0.  |                                               |
| 0x0440-<br>0x045C | Channel 2 configure register, definition as channel 0.  | (0)                                           |
| 0x0460-<br>0x047C | Channel 3 configure register, definition as channel 0.  | ·. O                                          |
| 0x0480-<br>0x049C | Channel 4 configure register, definition as channel 0.  |                                               |
| 0x0480-<br>0x049C | Channel 4 configure register, definition as channel 0.  |                                               |
| 0x04A0-<br>0x04BC | Channel 5 configure register, definition as channel 0.  | ~                                             |
| 0x04C0-<br>0x04DC | Channel 6 configure register, definition as channel 0.  |                                               |
| 0x04E0-<br>0x04FC | Channel 7 configures register, definition as channel 0. |                                               |
| 0x0500-<br>0x051C | Channel 8 configure register, definition as channel 0.  |                                               |
| 0x0520-<br>0x053C | Channel 9 configure register, definition as channel 0.  |                                               |
| 0x0540-<br>0x055C | Channel 10 configure register, definition as channel 0. |                                               |
| 0x0560-<br>0x057C | Channel 11 configure register, definition as channel 0. |                                               |
| 0x0580-<br>0x059C | Channel 12 configure register, definition as channel 0. |                                               |
| 0x05A0-<br>0x05BC | Channel 13 configure register, definition as channel 0. |                                               |
| 0x05C0-<br>0x05DC | Channel 14 configure register, definition as channel 0. |                                               |
| 0x05E0-<br>0x05FC | Channel 15 configure register, definition as channel 0. |                                               |
| 0x0600-<br>0x061C | Channel 16 configure register, definition as channel 0. |                                               |
| 0x0620-           | Channel 17 configure register, definition as            |                                               |



| Offset<br>Addr    | Register Name                                           | Register Description |
|-------------------|---------------------------------------------------------|----------------------|
| 0x063C            | channel 0.                                              |                      |
| 0x0640-<br>0x065C | Channel 18 configure register, definition as channel 0. |                      |
| 0x0660-<br>0x067C | Channel 19 configure register, definition as channel 0. |                      |
| 0x0680-<br>0x069C | Channel 20 configure register, definition as channel 0. |                      |
| 0x06A0-<br>0x06BC | Channel 21 configure register, definition as channel 0. |                      |
| 0x06C0-<br>0x06DC | Channel 22 configure register, definition as channel 0. | . 6                  |
| 0x06E0-<br>0x06FC | Channel 23 configure register, definition as channel 0. |                      |
| 0x0700-<br>0x071C | Channel 24 configure register, definition as channel 0. |                      |
| 0x0720-<br>0x073C | Channel 25 configure register, definition as channel 0. |                      |
| 0x0740-<br>0x075C | Channel 26 configure register, definition as channel 0. |                      |
| 0x0760-<br>0x077C | Channel 27 configure register, definition as channel 0. |                      |
| 0x0780-<br>0x079C | Channel 28 configure register, definition as channel 0. |                      |
| 0x07A0-<br>0x07BC | Channel 29 configure register, definition as channel 0. |                      |
| 0x07C0-<br>0x07DC | Channel 30 configure register, definition as channel 0. |                      |
| 0x07E0-<br>0x07FC | Channel 31 configure register, definition as channel 0. |                      |

# 5.4.5.2 Register Descriptions

# 5.4.5.2.1 DMA\_BLK\_WAIT

Description: Block Wait time register



| 0x0000 |    |    | Bloc                | k Wait                                   | time r | egiste | r (rese | t 0x00            | 00_000 | 00) |    |         |                | DMA | BLK_ | WAIT |
|--------|----|----|---------------------|------------------------------------------|--------|--------|---------|-------------------|--------|-----|----|---------|----------------|-----|------|------|
| Bit    | 31 | 30 | 29                  | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |        |         |                   |        |     |    |         |                |     |      |      |
| Name   |    |    |                     |                                          |        |        | S       | OFT_BL0           | OCK_WA | NT  |    |         |                |     |      |      |
| Туре   |    |    |                     | R/W                                      |        |        |         |                   |        |     |    |         |                |     |      |      |
| 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   |    |    |                     | Reserved                                 | i      |        |         | PAU<br>SE_<br>REQ |        |     | HA | ARD_BL0 | OCK_W <i>F</i> | AIT |      |      |
| Type   |    |    |                     | RO R/W R/W                               |        |        |         |                   |        |     |    |         |                |     |      |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 |                                          |        |        |         |                   |        | 0   | 0  | 0       |                |     |      |      |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                                |
|-----------------|---------|------|----------------|--------------------------------------------------------------------------------------------|
| SOFT_BLOCK_WAIT | [31:16] | R/W  | 16'h0          | The software channel waiting time between the data transfer burst. The unit is HCLK cycle. |
|                 | [15:9]  | RO   | 7'h0           | Reserved                                                                                   |
| PAUSE_REQ       | [8]     | R/W  | 1'h0           | Active high, Request to pause DMA;                                                         |
| HARD_BLOCK_WAIT | [7:0]   | R/W  | 8'h0           | The hardware channel waiting time between the data transfer burst. The unit is HCLK cycle  |

# 5.4.5.2.2 DMA\_CHN\_EN\_STATUS

Description: Channels enable status register

| 0x0004 |    |                               | Char          | nel en | able s | tatus r | egiste | r (rese | et 0x00 | 00_00 | 00) |    | DM | A_CHN | I_EN_S | STAT<br>US |
|--------|----|-------------------------------|---------------|--------|--------|---------|--------|---------|---------|-------|-----|----|----|-------|--------|------------|
| Bit    | 31 | 30                            | 29            | 28     | 27     | 26      | 25     | 24      | 23      | 22    | 21  | 20 | 19 | 18    | 17     | 16         |
| Name   |    | CHN_EN_STATUS                 |               |        |        |         |        |         |         |       |     |    |    |       |        |            |
| Туре   |    | 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   |    |                               | CHN_EN_STATUS |        |        |         |        |         |         |       |     |    |    |       |        |            |
| Туре   |    | RO                            |               |        |        |         |        |         |         |       |     |    |    |       |        |            |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |               |        |        |         |        |         |         |       |     |    |    |       |        |            |

| Field-Name    | Bit    | Туре | Reset<br>Value | Description                           |
|---------------|--------|------|----------------|---------------------------------------|
| CHN_EN_STATUS | [31:0] | RO   | 32'h0          | Status of Channel Enable, Active high |

# 5.4.5.2.3 DMA\_LINK\_LIST\_EN

Description: Link List Mode enable register



| 0x0008 |    |    | Link                                      | List M                    | ode er | nable r | egiste | r (rese | t 0x00 | 00_00 | 00) |   | DM | A_LIN | K_LIS | T_EN |
|--------|----|----|-------------------------------------------|---------------------------|--------|---------|--------|---------|--------|-------|-----|---|----|-------|-------|------|
| Bit    | 31 | 30 | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                           |        |         |        |         |        |       |     |   |    |       |       |      |
| Name   |    |    |                                           | LINK_LIST_EN              |        |         |        |         |        |       |     |   |    |       |       |      |
| Туре   |    |    |                                           | R/W                       |        |         |        |         |        |       |     |   |    |       |       |      |
| 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   |    |    |                                           | LINK_LIST_EN              |        |         |        |         |        |       |     |   |    |       |       |      |
| Туре   |    |    | RW                                        |                           |        |         |        |         |        |       |     |   |    |       |       |      |
| Reset  | 0  | 0  | 0                                         | 0 0 0 0 0 0 0 0 0 0 0 0 0 |        |         |        |         |        |       |     |   |    |       |       |      |

| Field Name   | Bit    | Туре | Reset<br>Value | Description                                |
|--------------|--------|------|----------------|--------------------------------------------|
| LINK_LIST_EN | [31:0] | R/W  | 32'h0          | Channel Link List Mode Enable, Active high |

#### 5.4.5.2.4 DMA\_SOFT\_LIST\_EN

Description: Soft List Mode enable register

| 0x000C |    |    | Soft                      | List M                                    | ode er | nable re | egiste | r (rese | t 0x00 | 00_000 | 00) |   | DM | A_SOF | T_LIS | T_EN |
|--------|----|----|---------------------------|-------------------------------------------|--------|----------|--------|---------|--------|--------|-----|---|----|-------|-------|------|
| Bit    | 31 | 30 | 29                        | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |          |        |         |        |        |     |   |    |       |       |      |
| Name   |    |    |                           | SOFT_LIST_EN                              |        |          |        |         |        |        |     |   |    |       |       |      |
| Туре   |    |    | 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   |    |    |                           | SOFT_LIST_EN                              |        |          |        |         |        |        |     |   |    |       |       |      |
| Туре   |    |    | R/W                       |                                           |        |          |        |         |        |        |     |   |    |       |       |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                           |        |          |        |         |        |        |     |   |    |       |       |      |

| Field Name   | Bit    | Туре | Reset<br>Value | Description                                |
|--------------|--------|------|----------------|--------------------------------------------|
| SOFT_LIST_EN | [31:0] | R/W  | 32'h0          | Channel Soft List Mode Enable, Active high |

# 5.4.5.2.5 DMA\_SOFT\_LIST\_SIZE

Description: Soft List size register



| 0x0010 |    |    | Soft     | List siz                                  | ze regi | ister (r | eset 0 | x0000_ | _0000) |   |   |   | DMA | \_SOF | T_LIS | Γ_SIZ<br>E |
|--------|----|----|----------|-------------------------------------------|---------|----------|--------|--------|--------|---|---|---|-----|-------|-------|------------|
| Bit    | 31 | 30 | 29       | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |          |        |        |        |   |   |   |     |       |       |            |
| Name   |    |    | Reserved |                                           |         |          |        |        |        |   |   |   |     |       |       |            |
| Туре   |    |    |          | 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   |    |    |          | SOFT_LIST_SIZE                            |         |          |        |        |        |   |   |   |     |       |       |            |
| Туре   |    |    | R/W      |                                           |         |          |        |        |        |   |   |   |     |       |       |            |
| Reset  | 0  |    |          |                                           |         |          |        |        |        |   |   |   |     |       |       |            |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                    |
|----------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [31:16] | RO   | 16'h0          | Reserved                                                                                                                                                                                                                                                       |
| SOFT_LIST_SIZE | [15:0]  | R/W  | 16'h0          | The size of the request list. When the DMA reaches the end of list, it starts from the beginning again.  For example, if SOFT_LIST_SIZE is equal to 5, then SW can set maximum (N) 5 requests to DMA. And if SOFT_LIST_EN is active, this value can't be zero. |

# 5.4.5.2.6 DMA\_SOFT\_LIST\_CMD

Description: Soft list command register

| 0x0014 |    |                                                | Soft | list co | mman | d regis | ter (re | set 0x | 0000_0 | 0000) |   |   | DMA | \_SOF | T_LIS | Γ_CM<br>D |
|--------|----|------------------------------------------------|------|---------|------|---------|---------|--------|--------|-------|---|---|-----|-------|-------|-----------|
| Bit    | 31 | 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |      |         |      |         |         |        |        |       |   |   |     |       |       |           |
| Name   |    |                                                |      |         |      |         |         | Rese   | erved  |       |   |   |     |       |       |           |
| Туре   |    | 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   |    | SOFT_LIST_CNT_INCR                             |      |         |      |         |         |        |        |       |   |   |     |       |       |           |
| Туре   |    | wo                                             |      |         |      |         |         |        |        |       |   |   |     |       |       |           |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                |      |         |      |         |         |        |        |       |   |   |     |       |       |           |

| Field Name         | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                |
|--------------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | [31:16] | RO   | 16'h0          | Reserved                                                                                                                                                                                                                                                                   |
| SOFT_LIST_CNT_INCR | [15:0]  | WO   | 16'h0          | Soft List Counter Increase, Write Only.  It counts the number of pending SW request in the list. Every time the SW adds new requests to the list, SW must increase the counter by writing to this register.  And when DMA completes one request, DMA decrease the counter. |



|  | Note: Since the Soft List Counter is 16 bits, |
|--|-----------------------------------------------|
|  | the SW must ensure that overflow can't        |
|  | happen.                                       |
|  |                                               |

#### 5.4.5.2.7 DMA\_SOFT\_LIST\_STATUS

Description: Soft list mode status register

| 0x0018 |    |    | Soft                        | list mo                                | ode sta | itus re | gister | (reset  | 0x000  | 0_000 | 0) |   | DM | A_SOF | T_LIS | T_ST<br>ATUS |
|--------|----|----|-----------------------------|----------------------------------------|---------|---------|--------|---------|--------|-------|----|---|----|-------|-------|--------------|
| Bit    | 31 | 30 | 29                          | 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |         |        |         |        |       |    |   |    |       |       |              |
| Name   |    |    |                             |                                        |         |         | SO     | FT_LIST | _REQ_F | PTR   |    |   |    |       |       |              |
| Туре   |    |    |                             | 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   |    |    |                             | SOFT_LIST_CNT                          |         |         |        |         |        |       |    |   |    |       |       |              |
| Туре   |    |    |                             | RO                                     |         |         |        |         |        |       |    |   |    |       |       |              |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                        |         |         |        |         |        |       |    |   |    |       |       |              |

| Field Name        | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                         |
|-------------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SOFT_LIST_REQ_PTR | [31:16] | RO   | 16'h0          | Indicating which request DMA is going to serving. And corresponding SoftListSize, SW can know the situation of the request list and replace new requests to the old ones. This method can make SW and DMA synchronized.                                                                                                                                             |
| SOFT_LIST_CNT     | [15:0]  | RO   | 16'h0          | Counter value, maximum number of pending request is 2 <sup>16</sup> .  Note: When in Soft List Mode, no request and acknowledge will occur, the condition {SOFT_LIST_CNT!= 0} means request and SW regards the condition {SOFT_LIST_CNT = 0} as acknowledge.  In this case, SW can only focus on the request list and don't care when these requests are completed. |

# 5.4.5.2.8 DMA\_SOFT\_LIST\_BADDR

Description: Base address register of soft list mode



| 0x001C |    |                             | Base                | addre                                     | ess reg | ister c | of soft | list mo | ode (re | set 0x | 0000_0 | 0000) | DM | A_SOF | T_LIS | T_BA<br>DDR |
|--------|----|-----------------------------|---------------------|-------------------------------------------|---------|---------|---------|---------|---------|--------|--------|-------|----|-------|-------|-------------|
| Bit    | 31 | 30                          | 29                  | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |         |         |         |         |        |        |       |    |       |       |             |
| Name   |    |                             | SOFT_LIST_BASE_ADDR |                                           |         |         |         |         |         |        |        |       |    |       |       |             |
| Туре   |    |                             | R/W                 |                                           |         |         |         |         |         |        |        |       |    |       |       |             |
| 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   |    |                             |                     | SOFT_LIST_BASE_ADDR                       |         |         |         |         |         |        |        |       |    |       |       |             |
| Туре   |    |                             | R/W                 |                                           |         |         |         |         |         |        |        |       |    |       |       |             |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                     |                                           |         |         |         |         |         |        |        |       |    |       |       |             |

| Field Name          | Bit    | Туре | Reset<br>Value | Description                                                                                                |
|---------------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------|
| SOFT_LIST_BASE_ADDR | [31:0] | R/W  | 32'h0          | Pointing the beginning address of Soft List Request. The lowest 2 bits must be "00", and can't be changed. |

# 5.4.5.2.9 DMA\_PRI\_CFG0

Description: Channel Priority register

| 0x0020 |      |       | Chan | nel Pr              | iority | registe | r (rese   | et 0x00 | 00_00     | 00)   |           |       | DMA_PRI_CFG0     |       |       |       |  |
|--------|------|-------|------|---------------------|--------|---------|-----------|---------|-----------|-------|-----------|-------|------------------|-------|-------|-------|--|
| Bit    | 31   | 30    | 29   | 28                  | 27     | 26      | 25        | 24      | 23        | 22    | 21        | 20    | 19               | 18    | 17    | 16    |  |
| Name   | CHN1 | 5_PRI | CHN1 | CHN14_PRI CHN13_PRI |        | CHN1    | CHN12_PRI |         | CHN11_PRI |       | CHN10_PRI |       | CHN9_PRI         |       | B_PRI |       |  |
| Туре   | R/   | W     | R/   | R/W R/W             |        | W       | R/        | W       | 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    | 15   | 14    | 13   | 12                  | 11     | 10      | 9         | 8       | 7         | 6     | 5         | 4     | 3                | 2     | 1     | 0     |  |
| Name   | CHN7 | _PRI  | CHN  | PRI                 | CHN    | 5_PRI   | CHN       | 1_PRI   | CHN       | 3_PRI | CHN2      | 2_PRI | CHN <sup>2</sup> | 1_PRI | CHN   | )_PRI |  |
| Туре   | 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         | 0     | 0                | 0     | 0     | 0     |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description         |
|------------|---------|------|----------------|---------------------|
| CHN15_PRI  | [31:30] | R/W  | 2'h0           | Channel 15 Priority |
| CHN14_PRI  | [29:28] | R/W  | 2'h0           | Channel 14 Priority |
| CHN13_PRI  | [27:26] | R/W  | 2'h0           | Channel 13 Priority |
| CHN12_PRI  | [25:24] | R/W  | 2'h0           | Channel 12 Priority |
| CHN11_PRI  | [23:22] | R/W  | 2'h0           | Channel 11 Priority |
| CHN10_PRI  | [21:20] | R/W  | 2'h0           | Channel 10 Priority |
| CHN19_PRI  | [19:18] | R/W  | 2'h0           | Channel 9 Priority  |
| CHN8_PRI   | [17:16] | R/W  | 2'h0           | Channel 8 Priority  |



| CHN7_PRI | [15:14] | R/W | 2'h0 | Channel 7 Priority                                                                 |
|----------|---------|-----|------|------------------------------------------------------------------------------------|
| CHN6_PRI | [13:12] | R/W | 2'h0 | Channel 6 Priority                                                                 |
| CHN5_PRI | [11:10] | R/W | 2'h0 | Channel 5 Priority                                                                 |
| CHN4_PRI | [9:8]   | R/W | 2'h0 | Channel 4 Priority                                                                 |
| CHN3_PRI | [7:6]   | R/W | 2'h0 | Channel 3 Priority                                                                 |
| CHN2_PRI | [5:4]   | R/W | 2'h0 | Channel 2 Priority                                                                 |
| CHN1_PRI | [3:2]   | R/W | 2'h0 | Channel 1 Priority                                                                 |
| CHN0_PRI | [1:0]   | R/W | 2'h0 | Channel 0 Priority, 2'b00 means lowest priority, and 2'b11 means highest priority. |

#### 5.4.5.2.10 DMA\_PRI\_CFG1

Description: Channel Priority register

| 0x0024 |      |       | Char | nel Pr              | iority | registe | r (rese             | et 0x00 | 00_00 | 00)       |      |           | DMA_PRI_CFG1 |           |      |       |  |
|--------|------|-------|------|---------------------|--------|---------|---------------------|---------|-------|-----------|------|-----------|--------------|-----------|------|-------|--|
| Bit    | 31   | 30    | 29   | 28                  | 27     | 26      | 25                  | 24      | 23    | 22        | 21   | 20        | 19           | 18        | 17   | 16    |  |
| Name   | CHN3 | 1_PRI | CHN3 | :HN30_PRI CHN29_PRI |        | CHN2    | CHN28_PRI CHN27_PRI |         |       | CHN26_PRI |      | CHN25_PRI |              | CHN24_PRI |      |       |  |
| Туре   | 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    | 0         | 0            | 0         | 0    | 0     |  |
| Bit    | 15   | 14    | 13   | 12                  | 11     | 10      | 9                   | 8       | 7     | 6         | 5    | 4         | 3            | 2         | 1    | 0     |  |
| Name   | CHN2 | 3_PRI | CHN2 | 2_PRI               | CHN2   | 1_PRI   | CHN2                | 0_PRI   | CHN1  | 9_PRI     | CHN1 | 8_PRI     | CHN1         | 7_PRI     | CHN1 | 6_PRI |  |
| Туре   | R/   | W     | R/   | W                   | R/     | W       | R                   | R/W     |       | W         | R/   | W         | R/W          |           | R/W  |       |  |
| Reset  | 0    | 0     | 0    | 0                   | 0      | 0       | 0                   | 0       | 0     | 0         | 0    | 0         | 0            | 0         | 0    | 0     |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description         |
|------------|---------|------|----------------|---------------------|
| CHN31_PRI  | [31:30] | R/W  | 2'h0           | Channel 31 priority |
| CHN30_PRI  | [29:28] | R/W  | 2'h0           | Channel 30 priority |
| CHN29_PRI  | [27:26] | R/W  | 2'h0           | Channel 29 Priority |
| CHN28_PRI  | [25:24] | R/W  | 2'h0           | Channel 28 Priority |
| CHN27_PRI  | [23:22] | R/W  | 2'h0           | Channel 27 Priority |
| CHN26_PRI  | [21:20] | R/W  | 2'h0           | Channel 26 Priority |
| CHN25_PRI  | [19:18] | R/W  | 2'h0           | Channel 25 Priority |
| CHN24_PRI  | [17:16] | R/W  | 2'h0           | Channel 24 Priority |
| CHN23_PRI  | [15:14] | R/W  | 2'h0           | Channel 23 priority |
| CHN22_PRI  | [13:12] | R/W  | 2'h0           | Channel 22 priority |
| CHN21_PRI  | [11:10] | R/W  | 2'h0           | Channel 21 Priority |
| CHN20_PRI  | [9:8]   | R/W  | 2'h0           | Channel 20 Priority |
| CHN19_PRI  | [7:6]   | R/W  | 2'h0           | Channel 19 Priority |



| CHN18_PRI | [5:4] | R/W | 2'h0 | Channel 18 Priority |
|-----------|-------|-----|------|---------------------|
| CHN17_PRI | [3:2] | R/W | 2'h0 | Channel 17 Priority |
| CHN16_PRI | [1:0] | R/W | 2'h0 | Channel 16 Priority |

#### 5.4.5.2.11 DMA\_INT\_MASK\_STATUS

Description: DMA Masked interrupt status register

| 0x0030 |    | DMA Masked interrupt status register (reset 0x0000_0000)  DMA_INT_MASK_STA |    |    |    |    |    |         |         |    |    |    |    |    | STA<br>TUS |    |
|--------|----|----------------------------------------------------------------------------|----|----|----|----|----|---------|---------|----|----|----|----|----|------------|----|
| Bit    | 31 | 30                                                                         | 29 | 28 | 27 | 26 | 25 | 24      | 23      | 22 | 21 | 20 | 19 | 18 | 17         | 16 |
| Name   |    |                                                                            |    |    |    |    | IN | IT_MASI | C_STATI | JS |    |    |    |    |            |    |
| Туре   |    |                                                                            |    |    |    |    |    | R       | 0       |    |    |    |    |    |            |    |
| 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   |    | INT_MASK_STATUS                                                            |    |    |    |    |    |         |         |    |    |    |    |    |            |    |
| Туре   |    | RO                                                                         |    |    |    |    |    |         |         |    |    |    |    |    |            |    |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                              |    |    |    |    |    |         |         |    |    |    |    |    |            |    |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                                                                                                                                            |
|-----------------|--------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT_MASK_STATUS | [31:0] | RO   | 32'h0          | Channel31 to channel0 interrupt mask status.  Int_mask_status = Trans_done_int_mask_stauts   Burst_done_int_mask_status   LList_done_int_mask_status ; |

#### 5.4.5.2.12 DMA\_INT\_RAW\_STATUS

Description: DMA Raw interrupt status register

| 0x0034 |    | DMA Raw interrupt status register (reset 0x0000_0000)  DMA_INT_RAW_ST |    |    |    |    |    |        |        |    |    |    |    | STAT |    |    |
|--------|----|-----------------------------------------------------------------------|----|----|----|----|----|--------|--------|----|----|----|----|------|----|----|
| Bit    | 31 | 30                                                                    | 29 | 28 | 27 | 26 | 25 | 24     | 23     | 22 | 21 | 20 | 19 | 18   | 17 | 16 |
| Name   |    |                                                                       |    |    |    |    | 11 | NT_RAW | _STATU | IS |    |    |    |      |    |    |
| Туре   |    |                                                                       |    |    |    |    |    | R      | 0      |    |    |    |    |      |    |    |
| 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   |    | INT_RAW_STATUS                                                        |    |    |    |    |    |        |        |    |    |    |    |      |    |    |
| Type   |    | RO                                                                    |    |    |    |    |    |        |        |    |    |    |    |      |    |    |
| Reset  | 0  | 0                                                                     | 0  | 0  | 0  | 0  | 0  | 0      | 0      | 0  | 0  | 0  | 0  | 0    | 0  | 0  |

| Field Name     | Bit    | Туре | Reset<br>Value | Description                                                                              |
|----------------|--------|------|----------------|------------------------------------------------------------------------------------------|
| INT_RAW_STATUS | [31:0] | RO   | 32'h0          | Channel31 to channel0 interrupt raw status.  Int_mask_status = Trans_done_int_raw_stauts |



|  | Burst_done_int_raw_status   |
|--|-----------------------------|
|  | LList_done_int_raw_status ; |

#### 5.4.5.2.13 DMA\_LLIST\_DONE\_INT\_EN

Description: Interrupt enable register of Link list done

| 0x0040 |    |     |    | rupt er<br>00_00  |    | egiste | r of Li | nk list | done (  | reset |    |    | DM | A_LLI | _  | NE_I<br>T_EN |
|--------|----|-----|----|-------------------|----|--------|---------|---------|---------|-------|----|----|----|-------|----|--------------|
| Bit    | 31 | 30  | 29 | 28                | 27 | 26     | 25      | 24      | 23      | 22    | 21 | 20 | 19 | 18    | 17 | 16           |
| Name   |    |     |    |                   |    |        | LL      | ST_DOI  | NE_INT_ | EN    |    |    |    |       |    |              |
| Туре   |    |     |    |                   |    |        |         | R       | W       |       |    |    |    |       |    |              |
| 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   |    |     |    | LLIST_DONE_INT_EN |    |        |         |         |         |       |    |    |    |       |    |              |
| Туре   |    | R/W |    |                   |    |        |         |         |         |       |    |    |    |       |    |              |
| Reset  | 0  | 0   | 0  | 0                 | 0  | 0      | 0       | 0       | 0       | 0     | 0  | 0  | 0  | 0     | 0  | 0            |

| Field Name        | Bit    | Туре | Reset<br>Value | Description                                                |
|-------------------|--------|------|----------------|------------------------------------------------------------|
| LLIST_DONE_INT_EN | [31:0] | R/W  | 32'h0          | Channel31 to channel0 all link list done interrupt enable. |

# 5.4.5.2.14 DMA\_BLOCK\_DONE\_INT\_EN

Description: Interrupt enable register of block done

| 0x0044 |    |    | Interrupt enable register of block done (reset 0x0000_0000)  DMA_BLOCK_DO INT |                   |    |    |     |        |        |     |    |    |    |    | ONE_<br>T_EN |    |
|--------|----|----|-------------------------------------------------------------------------------|-------------------|----|----|-----|--------|--------|-----|----|----|----|----|--------------|----|
| Bit    | 31 | 30 | 29                                                                            | 28                | 27 | 26 | 25  | 24     | 23     | 22  | 21 | 20 | 19 | 18 | 17           | 16 |
| Name   |    |    |                                                                               |                   |    |    | BLO | OCK_DO | NE_INT | _EN |    |    |    |    |              |    |
| Туре   |    |    |                                                                               |                   |    |    |     | R      | W      |     |    |    |    |    |              |    |
| 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   |    |    |                                                                               | BLOCK_DONE_INT_EN |    |    |     |        |        |     |    |    |    |    |              |    |
| Туре   |    |    |                                                                               | R/W               |    |    |     |        |        |     |    |    |    |    |              |    |
| Reset  | 0  | 0  | 0                                                                             | 0                 | 0  | 0  | 0   | 0      | 0      | 0   | 0  | 0  | 0  | 0  | 0            | 0  |

| Field Name        | Bit    | Туре | Reset<br>Value | Description                                            |
|-------------------|--------|------|----------------|--------------------------------------------------------|
| BLOCK_DONE_INT_EN | [31:0] | R/W  | 32'h0          | Channel31 to channel0 one burst done interrupt enable. |

#### 5.4.5.2.15 DMA\_TRANS\_DONE\_INT\_EN



Description: Interrupt enable register of transaction done

| 0x0048 |    |    |     | rupt er<br>00_00        |    | egiste | r of tra | nsact | ion do | ne (res | set |    | DMA | _TRAN |    | NE_I<br>T_EN |
|--------|----|----|-----|-------------------------|----|--------|----------|-------|--------|---------|-----|----|-----|-------|----|--------------|
| Bit    | 31 | 30 | 29  | 28                      | 27 | 26     | 25       | 24    | 23     | 22      | 21  | 20 | 19  | 18    | 17 | 16           |
| Name   |    |    |     | TRANS_DONE_INT_EN       |    |        |          |       |        |         |     |    |     |       |    |              |
| Туре   |    |    |     | R/W                     |    |        |          |       |        |         |     |    |     |       |    |              |
| 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   |    |    |     | TRANS_DONE_INT_EN       |    |        |          |       |        |         |     |    |     |       |    |              |
| Туре   |    |    | R/W |                         |    |        |          |       |        |         |     |    |     |       |    |              |
| Reset  | 0  | 0  | 0   |                         |    |        |          |       |        |         |     |    |     |       |    |              |

| Field Name        | Bit    | Туре | Reset<br>Value | Description                                                                            |
|-------------------|--------|------|----------------|----------------------------------------------------------------------------------------|
| TRANS_DONE_INT_EN | [31:0] | R/W  | 32'h0          | Channel31 to channel0 transaction or one node in link list mode done interrupt enable. |

# 5.4.5.2.16 DMA\_LLIST\_DONE\_INT\_ MASK\_STATUS

Description: Masked status of Link list done interrupt

| 0x0050 |    |    |                                 | ed sta<br>00_00                           |  | Link li | ist dor | e inte | rrupt (ı | reset |  |  |  | A_LLIS<br>_ MAS | _ | _ |
|--------|----|----|---------------------------------|-------------------------------------------|--|---------|---------|--------|----------|-------|--|--|--|-----------------|---|---|
| Bit    | 31 | 30 | 29                              | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |  |         |         |        |          |       |  |  |  |                 |   |   |
| Name   |    |    | LLIST_DONE_ INT_ MASK_STATUS    |                                           |  |         |         |        |          |       |  |  |  |                 |   |   |
| Туре   |    |    | 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   |    |    | LLIST_DONE_ INT_ MASK_STATUS    |                                           |  |         |         |        |          |       |  |  |  |                 |   |   |
| Туре   |    | RO |                                 |                                           |  |         |         |        |          |       |  |  |  |                 |   |   |
| Reset  | 0  |    |                                 |                                           |  |         |         |        |          |       |  |  |  |                 |   |   |

| Field Name                         | Bit    | Туре | Reset<br>Value | Description                                                 |
|------------------------------------|--------|------|----------------|-------------------------------------------------------------|
| LLIST_DONE_<br>INT_<br>MASK_STATUS | [31:0] | RO   | 32'h0          | Channel31 to channel0 link list done interrupt mask status. |

# 5.4.5.2.17 DMA\_BLOCK\_DONE\_INT\_MASK\_STATUS

Description: Masked status of block done interrupt



| 0x0054 |    |    | Mask                      | ked sta                      | itus of | block | done i | interru | pt (res | set 0x0 | 000_0 | 000) |    | A_BLO |    |    |
|--------|----|----|---------------------------|------------------------------|---------|-------|--------|---------|---------|---------|-------|------|----|-------|----|----|
| Bit    | 31 | 30 | 29                        | 28                           | 27      | 26    | 25     | 24      | 23      | 22      | 21    | 20   | 19 | 18    | 17 | 16 |
| Name   |    |    |                           | BLOCK_DONE_ INT_ MASK_STATUS |         |       |        |         |         |         |       |      |    |       |    |    |
| Туре   |    |    |                           | RO                           |         |       |        |         |         |         |       |      |    |       |    |    |
| 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   |    |    |                           | BLOCK_DONE_ INT_ MASK_STATUS |         |       |        |         |         |         |       |      |    |       |    |    |
| Туре   |    |    |                           | RO                           |         |       |        |         |         |         |       |      |    |       |    |    |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |                              |         |       |        |         |         |         |       |      |    |       |    |    |

| Field Name                         | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------|--------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BLOCK_DONE_<br>INT_<br>MASK_STATUS | [31:0] | RO   | 32'h0          | Channel31 to channel0 one block done interrupt mask status.  block_done_int_mask_status = block_done_int_raw_status & block_done_int_en block done interrupt is import in infinite mode, sine total length of transaction is unknown, and a burst will be executed after every DMA request.  DMA will not clear any interrupt status by itself. |

# 5.4.5.2.18 DMA\_TRANS\_DONE\_INT\_MASK\_STATUS

Description: Masked status of transaction done interrupt

| 0x0058 |    |                             |                             | ed sta<br>00_00                           | itus of<br>00) | transa | ction  | done i | nterru  | pt (res | et |   |   | _TRAN |   |    |
|--------|----|-----------------------------|-----------------------------|-------------------------------------------|----------------|--------|--------|--------|---------|---------|----|---|---|-------|---|----|
| Bit    | 31 | 30                          | 29                          | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                |        |        |        |         |         |    |   |   |       |   | 16 |
| Name   |    |                             |                             |                                           |                | TF     | RANS_D | ONE_IN | T_ MASI | K_STAT  | US |   |   |       |   |    |
| Туре   |    |                             | 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   |    |                             | TRANS_DONE_INT_ MASK_STATUS |                                           |                |        |        |        |         |         |    |   |   |       |   |    |
| Туре   |    | RO                          |                             |                                           |                |        |        |        |         |         |    |   |   |       |   |    |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                             |                                           |                |        |        |        |         |         |    |   |   |       |   |    |

| Field Name                     | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                            |
|--------------------------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRANS_DONE_INT_<br>MASK_STATUS | [31:0] | RO   | 32'h0          | Channel31 to channel0 one transaction or a node of link list done interrupt mask status.  Trans_done_int_mask_status =  Trans_done_int_raw_status &  Trans_done_int_en |



# 5.4.5.2.19 DMA\_LLIST\_DONE\_INT\_RAW\_STATUS

Description: RAW status of Link list done interrupt

| 0x0060 |    |    | RAW                       | status                                   | s of Li | nk list | done i | nterru | pt (res | et 0x0 | 000_0 | 000) |   | A_LLI:<br>IT_RA |   |   |
|--------|----|----|---------------------------|------------------------------------------|---------|---------|--------|--------|---------|--------|-------|------|---|-----------------|---|---|
| Bit    | 31 | 30 | 29                        | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |         |        |        |         |        |       |      |   |                 |   |   |
| Name   |    |    |                           | LLIST_DONE_ INT_ RAW _STATUS             |         |         |        |        |         |        |       |      |   |                 |   |   |
| Туре   |    |    |                           | 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   |    |    |                           | LLIST_DONE_ INT_ RAW _STATUS             |         |         |        |        |         |        |       |      |   |                 |   |   |
| Туре   |    |    | RO                        |                                          |         |         |        |        |         |        |       |      |   |                 |   |   |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                          |         |         |        |        |         |        |       |      |   |                 |   |   |

| Field Name                      | Bit    | Туре | Reset<br>Value | Description                                                    |
|---------------------------------|--------|------|----------------|----------------------------------------------------------------|
| LLIST_DONE_ INT_<br>RAW _STATUS | [31:0] | RO   | 32'h0          | Channel31 to channel0 all link list done interrupt raw status. |

# 5.4.5.2.20 DMA\_BLOCK\_DONE\_INT\_RAW\_STATUS

Description: RAW status of block done interrupt

| 0x0064 |    |    | RAW                          | status                                   | s of blo | ock do | ne inte | errupt  | (reset  | 0x000 | 0_000 | <b>)</b> ) |   | _BLO<br>IT_RA |   |    |
|--------|----|----|------------------------------|------------------------------------------|----------|--------|---------|---------|---------|-------|-------|------------|---|---------------|---|----|
| Bit    | 31 | 30 | 29                           | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |          |        |         |         |         |       |       |            |   |               |   | 16 |
| Name   |    |    |                              |                                          |          | BL     | OCK_D   | ONE_ IN | IT_ RAW | _STAT | JS    |            |   |               |   |    |
| Туре   |    |    | RO                           |                                          |          |        |         |         |         |       |       |            |   |               |   |    |
| Reset  | 0  | 0  | 0                            |                                          |          |        |         |         |         |       |       |            |   |               | 0 |    |
| Bit    | 15 | 14 | 13                           | 12                                       | 11       | 10     | 9       | 8       | 7       | 6     | 5     | 4          | 3 | 2             | 1 | 0  |
| Name   |    |    | BLOCK_DONE_ INT_ RAW _STATUS |                                          |          |        |         |         |         |       |       |            |   |               |   |    |
| Туре   |    | RO |                              |                                          |          |        |         |         |         |       |       |            |   |               |   |    |
| Reset  | 0  |    |                              |                                          |          |        |         |         |         |       |       |            |   |               |   |    |

| Field Name                      | Bit    | Туре | Reset<br>Value | Description                                                |
|---------------------------------|--------|------|----------------|------------------------------------------------------------|
| BLOCK_DONE_ INT_<br>RAW _STATUS | [31:0] | RO   | 32'h0          | Channel31 to channel0 one block done interrupt RAW status. |

#### 5.4.5.2.21 DMA\_TRANS\_DONE\_INT\_RAW\_STATUS

Description: RAW status of Transaction done interrupt



| 0x0068 |    |    |                           | statu:                       |    | ansact | ion do | ne int | errupt | (reset |    |    |    | _TRAN |    |    |
|--------|----|----|---------------------------|------------------------------|----|--------|--------|--------|--------|--------|----|----|----|-------|----|----|
| Bit    | 31 | 30 | 29                        | 28                           | 27 | 26     | 25     | 24     | 23     | 22     | 21 | 20 | 19 | 18    | 17 | 16 |
| Name   |    |    |                           | TRANS_DONE_ INT_ RAW _STATUS |    |        |        |        |        |        |    |    |    |       |    |    |
| Туре   |    |    |                           |                              |    |        |        | R      | .0     |        |    |    |    |       |    |    |
| 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   |    |    |                           | TRANS_DONE_ INT_ RAW _STATUS |    |        |        |        |        |        |    |    |    |       |    |    |
| Туре   |    |    | RO                        |                              |    |        |        |        |        |        |    |    |    |       |    |    |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |                              |    |        |        |        |        |        |    |    |    |       |    |    |

| Field Name                 | Bit    | Туре | Reset<br>Value | Description                                                                             |
|----------------------------|--------|------|----------------|-----------------------------------------------------------------------------------------|
| TRANS_DONE_INT_RAW _STATUS | [31:0] | RO   | 32'h0          | Channel31 to channel0 one transaction or a node of link list done interrupt RAW status. |

# 5.4.5.2.22 DMA\_LLIST\_DONE\_INT\_CLR

Description: Clear interrupt of Link List done

| 0x0070 |    |                           | Clear | r interr | upt of | Link L | ist do | ne (res | set 0x0  | 000_0 | 000) |    | DM | DMA_LLIST_DONE_I<br>NT_CLR |    |    |  |
|--------|----|---------------------------|-------|----------|--------|--------|--------|---------|----------|-------|------|----|----|----------------------------|----|----|--|
| Bit    | 31 | 30                        | 29    | 28       | 27     | 26     | 25     | 24      | 23       | 22    | 21   | 20 | 19 | 18                         | 17 | 16 |  |
| Name   |    |                           |       |          |        |        | LLIS   | ST_DON  | E_ INT_0 | CLR   |      |    |    |                            |    |    |  |
| Туре   |    | 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   |    | LLIST_DONE_ INT_CLR       |       |          |        |        |        |         |          |       |      |    |    |                            |    |    |  |
| Туре   |    |                           |       |          |        |        |        | W       | 10       |       |      |    |    |                            |    |    |  |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |       |          |        |        |        |         |          |       |      |    |    |                            |    |    |  |

| Field Name         | Bit    | Туре | Reset<br>Value | Description                                               |
|--------------------|--------|------|----------------|-----------------------------------------------------------|
| LLIST_DONE_INT_CLR | [31:0] | WO   | 32'h0          | Channel31 to channel0 all link_list_done interrupt clear. |

# 5.4.5.2.23 DMA\_BLOCK\_DONE\_INT\_CLR

Description: Clear interrupt of Block done



| 0x0074 |    |    | Clea | r interr                | upt of | Block | done | (reset | 0x000 | 0_000 | 0) |    | DMA | _BLO |    | ONE_<br>_CLR |
|--------|----|----|------|-------------------------|--------|-------|------|--------|-------|-------|----|----|-----|------|----|--------------|
| Bit    | 31 | 30 | 29   | 28                      | 27     | 26    | 25   | 24     | 23    | 22    | 21 | 20 | 19  | 18   | 17 | 16           |
| Name   |    |    |      | BLOCK_DONE_ INT_CLR     |        |       |      |        |       |       |    |    |     |      |    |              |
| Туре   |    |    |      |                         |        |       |      | W      | 10    |       |    |    |     |      |    |              |
| 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   |    |    |      | BLOCK_DONE_ INT_CLR     |        |       |      |        |       |       |    |    |     |      |    |              |
| Туре   |    |    | wo   |                         |        |       |      |        |       |       |    |    |     |      |    |              |
| Reset  | 0  | 0  | 0    | 0 0 0 0 0 0 0 0 0 0 0 0 |        |       |      |        |       |       |    |    |     |      |    |              |

| Field Name         | Bit    | Туре | Reset<br>Value | Description                                       |
|--------------------|--------|------|----------------|---------------------------------------------------|
| BLOCK_DONE_INT_CLR | [31:0] | WO   | 32'h0          | Channel31 to channel0 Block Done interrupt clear. |

# 5.4.5.2.24 DMA\_TRANS\_DONE\_INT\_CLR

Description: Clear interrupt of Transaction done

| 0x0078 |    |    | Clear                     | r interr            | upt of | Trans | action | done   | (reset   | 0x000 | 0_0000 | )) | DMA | _TRAN |    | NE_I<br>_CLR |
|--------|----|----|---------------------------|---------------------|--------|-------|--------|--------|----------|-------|--------|----|-----|-------|----|--------------|
| Bit    | 31 | 30 | 29                        | 28                  | 27     | 26    | 25     | 24     | 23       | 22    | 21     | 20 | 19  | 18    | 17 | 16           |
| Name   |    |    |                           |                     |        |       | TRA    | NS_DOI | NE_ INT_ | CLR   |        |    |     |       |    |              |
| Туре   |    |    |                           |                     |        |       |        | N      | 10       |       |        |    |     |       |    |              |
| 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   |    |    |                           | TRANS_DONE_ INT_CLR |        |       |        |        |          |       |        |    |     |       |    |              |
| Туре   |    |    |                           |                     |        |       |        | V      | 10       |       |        |    |     |       |    |              |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |                     |        |       |        |        |          |       |        |    |     |       |    |              |

| Field Name         | Bit    | Туре | Reset<br>Value | Description                                                                    |
|--------------------|--------|------|----------------|--------------------------------------------------------------------------------|
| TRANS_DONE_INT_CLR | [31:0] | WO   | 32'h0          | Channel31 to channel0 transaction or a node of link list done interrupt clear. |

# 5.4.5.2.25 DMA\_SOFT\_REQ

Description: Soft channel request



| 0x0080 |    |    | Soft | chann                     | el requ | est (re | eset 0x | 0000_ | 0000) |    |    |    |    | DMA_ | SOFT | REQ |
|--------|----|----|------|---------------------------|---------|---------|---------|-------|-------|----|----|----|----|------|------|-----|
| Bit    | 31 | 30 | 29   | 28                        | 27      | 26      | 25      | 24    | 23    | 22 | 21 | 20 | 19 | 18   | 17   | 16  |
| Name   |    |    |      | SOFT_REQ                  |         |         |         |       |       |    |    |    |    |      |      |     |
| Туре   |    |    |      |                           |         |         |         | W     | 10    |    |    |    |    |      |      |     |
| 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   |    |    |      |                           |         |         |         | SOFT  | _REQ  |    |    |    |    |      |      |     |
| Туре   |    |    |      | wo                        |         |         |         |       |       |    |    |    |    |      |      |     |
| Reset  | 0  | 0  | 0    | 0 0 0 0 0 0 0 0 0 0 0 0 0 |         |         |         |       |       |    |    |    |    |      |      |     |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                     |
|------------|--------|------|----------------|-----------------------------------------------------------------------------------------------------------------|
| SOFT_REQ   | [31:0] | WO   | 32'h0          | Active high, Channel31 to channel0 software request. In software request mode, this signal starts the transfer. |

# **5.4.5.2.26 DMA\_STATUS**

Description: DMA Status

| 0x0084 |                         |                         | DMA                     | Statu                       | s (Res | et to 0 | x0000_ | E000) | 1    |        |        |    |    | DM     | 1A_ST/ | ATUS |
|--------|-------------------------|-------------------------|-------------------------|-----------------------------|--------|---------|--------|-------|------|--------|--------|----|----|--------|--------|------|
| Bit    | 31                      | 30                      | 29                      | 28                          | 27     | 26      | 25     | 24    | 23   | 22     | 21     | 20 | 19 | 18     | 17     | 16   |
| Name   | DMA<br>_BU<br>SY        | DMA<br>_PA<br>USE       |                         |                             |        |         |        |       | Rese | rved.  |        |    |    |        |        |      |
| Туре   | RO                      | RO                      |                         |                             |        |         |        |       | R    | 0      |        |    |    |        |        |      |
| 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   | HRE<br>ADY<br>_DM<br>AS | HRE<br>ADY<br>_DM<br>AW | HRE<br>ADY<br>_DM<br>AR |                             | MFS    | SM_STA  | TUS    |       |      | SFSM_S | STATUS |    |    | DFSM_S | STATUS |      |
| Туре   | RO                      | RO                      | RO                      |                             |        | RO      |        |       |      | R      | 0      |    |    | R      | 0      |      |
| Reset  | 1                       | 1                       | 1                       | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 |        |         |        |       |      |        |        |    | 0  |        |        |      |

| Field Name  | Bit     | R/W | Reset | Description                                             |
|-------------|---------|-----|-------|---------------------------------------------------------|
|             |         |     | Value |                                                         |
| DMA_BUSY    | [31]    | RO  | 1'h0  | 1'b1: DMA is busy.                                      |
|             |         |     |       | 1'b0: Main FSM is in IDLE state, and no request pending |
| DMA_PAUSE   | [30]    | RO  | 1'h0  | 1'b1: DMA in pause state                                |
|             |         |     |       | 1'b0: DMA is not in Pause Status                        |
|             | [28:16] | RO  | 14'h0 | Reserved.                                               |
| HREADY_DMAS | [15]    | RO  | 1'h1  | DMA AHB slave side HREADY signal                        |
| HREADY_DMAW | [14]    | RO  | 1'h1  | DMA AHB destination master side HREADY signal           |



| HREADY_DMAR | [13]   | RO | 1'h1 | DMA AHB source master side HREADY signal |
|-------------|--------|----|------|------------------------------------------|
| MFSM_STATUS | [12:8] | RO | 5'h0 | DMA AHB main FSM current state           |
| SFSM_STATUS | [7:4]  | RO | 4'h0 | DMA AHB source FSM current state         |
| DFSM_STATUS | [3:0]  | RO | 4'h0 | DMA AHB destination FSM current state    |

#### 5.4.5.2.27 DMA\_REQ\_PEND

Description: Pending request status.

| 0x0088 |    |    | Pend     | ling re                                   | quest | status | . (Rese | et to 0 | <b>(0000</b> _ | 0000) |   |   |   | DMA_I | REQ_F | PEND |
|--------|----|----|----------|-------------------------------------------|-------|--------|---------|---------|----------------|-------|---|---|---|-------|-------|------|
| Bit    | 31 | 30 | 29       | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |       |        |         |         |                |       |   |   |   |       |       |      |
| Name   |    |    | REQ_PEND |                                           |       |        |         |         |                |       |   |   |   |       |       |      |
| Туре   |    |    |          |                                           |       |        |         | R       | 0              |       |   |   |   |       |       |      |
| 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   |    |    |          |                                           |       |        |         | REQ_    | PEND           |       |   |   |   |       |       |      |
| Туре   |    |    |          | RO                                        |       |        |         |         |                |       |   |   |   |       |       |      |
| Reset  | 0  | 0  |          |                                           |       |        |         |         |                |       |   |   |   |       |       |      |

| Field-Name | Bit    | R/W | Reset<br>Value | Description          |
|------------|--------|-----|----------------|----------------------|
| REQ_PEND   | [31:0] | RO  | 0              | DMA pending request. |

# 5.4.5.2.28 DMA\_WRAP\_START\_ADDR

Description: Start address of WRAP mode

| 0x0090 |    |      | Start | addre | ss of \                 | WRAP                    | mode | (reset  | 0x000  | 0_000 | 0) |   | DMA_WRAP_START_<br>ADDR |    |    |    |  |
|--------|----|------|-------|-------|-------------------------|-------------------------|------|---------|--------|-------|----|---|-------------------------|----|----|----|--|
| Bit    | 31 | 30   | 29    | 28    | 27                      | 27 26 25 24 23 22 21 20 |      |         |        |       |    |   |                         | 18 | 17 | 16 |  |
| Name   |    | Rese | erved |       | WRAP_START_ADDR         |                         |      |         |        |       |    |   |                         |    |    |    |  |
| Туре   |    | R    | 0     |       |                         |                         |      |         |        | R     | W  |   |                         |    |    |    |  |
| 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   |    |      |       |       |                         |                         | WI   | RAP_STA | ART_AD | DR    |    |   |                         |    |    |    |  |
| Туре   |    |      |       | R/W   |                         |                         |      |         |        |       |    |   |                         |    |    |    |  |
| Reset  | 0  | 0    | 0     | 0     | 0 0 0 0 0 0 0 0 0 0 0 0 |                         |      |         |        |       |    |   |                         |    |    |    |  |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                    |
|-----------------|---------|------|----------------|--------------------------------|
|                 | [31:28] | RO   | 4'h0           | Reserved                       |
| WRAP_START_ADDR | [27:0]  | R/W  | 28'h0          | DMA Start Address in wrap mode |



# 5.4.5.2.29 DMA\_WRAP\_END\_ADDR

Description: End address of WRAP mode

| 0x0094 |    |      | End a | addres                  | s of W | /RAP r                                                                          | node ( | reset ( | )x0000 | _0000 | ) |   | DMA_WRAP_END_AD<br>DR |    |    |    |
|--------|----|------|-------|-------------------------|--------|---------------------------------------------------------------------------------|--------|---------|--------|-------|---|---|-----------------------|----|----|----|
| Bit    | 31 | 30   | 29    | 28                      | 27     | 27         26         25         24         23         22         21         20 |        |         |        |       |   |   |                       | 18 | 17 | 16 |
| Name   |    | Rese | erved |                         |        | WRAP_END_ADDR                                                                   |        |         |        |       |   |   |                       |    |    | •  |
| Туре   |    | R    | .0    |                         | R/W    |                                                                                 |        |         |        |       |   |   |                       |    |    |    |
| 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   |    |      |       |                         |        |                                                                                 | V      | /RAP_EI | ND_ADD | R     |   |   |                       |    |    |    |
| Туре   |    |      |       | R/W                     |        |                                                                                 |        |         |        |       |   |   |                       |    |    |    |
| Reset  | 0  | 0    | 0     | 0 0 0 0 0 0 0 0 0 0 0 0 |        |                                                                                 |        |         |        |       |   |   |                       | 0  |    |    |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                  |
|---------------|---------|------|----------------|------------------------------|
|               | [31:28] | RO   | 4'h0           | Reserved                     |
| WRAP_END_ADDR | [27:0]  | R/W  | 28'h0          | DMA End Address in wrap mode |

#### 5.4.5.2.30 DMA\_CHN\_UID\_CFG0

| 0x0098 |    |         | User | ID of o | channe    | els (res | set 0x0 | 0000_0 | 000) |         |    | DMA_CHN_UID_CFG0 |          |        |    |    |  |
|--------|----|---------|------|---------|-----------|----------|---------|--------|------|---------|----|------------------|----------|--------|----|----|--|
| Bit    | 31 | 30      | 29   | 28      | 27        | 26       | 25      | 24     | 23   | 22      | 21 | 20               | 19       | 18     | 17 | 16 |  |
| Name   |    | Reserve | d    |         | C         | HN3_UI   | D       |        | I    | Reserve | t  |                  | C        | HN2_UI | D  |    |  |
| Туре   |    | RO      |      |         |           | R/W      |         |        |      | RO      |    |                  |          | R/W    |    |    |  |
| 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   |    | Reserve | d    |         | C         | HN1_UI   | D       |        |      | Reserve | d  |                  | CHN0_UID |        |    |    |  |
| Туре   |    | RO      |      |         |           | R/W      |         |        | RO   |         |    |                  | R/W      |        |    |    |  |
| Reset  | 0  | 0       | 0    | 0       | 0 0 0 0 0 |          |         |        |      | 0       | 0  | 0                | 0        | 0      | 0  | 0  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                             |
|------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:29] | RO   | 3'h0           | Reserved.                                                                                                                                                               |
| CHN3_UID   | [28:24] | R/W  | 5'h0           | Channel 3 User ID number; Each DMA user, that may trigger DMA, has a unique ID number, and SW may assign a DMA channel to any one of them, no matter APB or AHB module; |
|            | [23:21] | RO   | 3'h0           | Reserved.                                                                                                                                                               |
| CHN2_UID   | [20:16] | R/W  | 5'h0           | Channel 2 User ID number;                                                                                                                                               |
|            | [15:13] | RO   | 3'h0           | Reserved.                                                                                                                                                               |



| CHN1_UID | [12:8] | R/W | 5'h0 | Channel 1 User ID number; |
|----------|--------|-----|------|---------------------------|
|          | [7:5]  | RO  | 3'h0 | Reserved.                 |
| CHN0_UID | [4:0]  | R/W | 5'h0 | Channel 0 User ID number; |

#### 5.4.5.2.31 DMA\_CHN\_UID\_CFG1

Description: User ID of channels

| 0x009C |    |         | User | ID of o | channe                                                                                     | els (res | set 0x0 | 0000_0 | 000)     |         |   |    | DMA_CHN_UID_CFG1 |     |    |    |  |
|--------|----|---------|------|---------|--------------------------------------------------------------------------------------------|----------|---------|--------|----------|---------|---|----|------------------|-----|----|----|--|
| Bit    | 31 | 30      | 29   | 28      | 28         27         26         25         24         23         22         21         20 |          |         |        |          |         |   | 20 | 19               | 18  | 17 | 16 |  |
| Name   |    | Reserve | d .  |         | C                                                                                          | :HN7_UI  | D       |        |          | Reserve | 4 |    | CHN6_UID         |     |    |    |  |
| Туре   |    | RO      |      |         |                                                                                            | R/W      |         |        |          | RO      |   |    |                  | R/W |    |    |  |
| 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            |     |    |    |  |
| Name   |    | Reserve | 1    |         | C                                                                                          | HN5_UI   | D       |        | Reserved |         |   |    | CHN4_UID         |     |    |    |  |
| Туре   |    | RO      |      |         | R/W                                                                                        |          |         |        |          | RO      |   |    | R/W              |     |    |    |  |
| Reset  | 0  | 0       | 0    | 0       | 0 0 0 0                                                                                    |          |         |        | 0        | 0       | 0 | 0  | 0                | 0   | 0  | 0  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                             |
|------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:29] | RO   | 3'h0           | Reserved.                                                                                                                                                               |
| CHN7_UID   | [28:24] | R/W  | 5'h0           | Channel 7 User ID number; Each DMA user, that may trigger DMA, has a unique ID number, and SW may assign a DMA channel to any one of them, no matter APB or AHB module; |
|            | [23:21] | RO   | 3'h0           | Reserved.                                                                                                                                                               |
| CHN6_UID   | [20:16] | R/W  | 5'h0           | Channel 6 User ID number;                                                                                                                                               |
|            | [15:13] | RO   | 3'h0           | Reserved.                                                                                                                                                               |
| CHN5_UID   | [12:8]  | R/W  | 5'h0           | Channel 5 User ID number;                                                                                                                                               |
|            | [7:5]   | RO   | 3'h0           | Reserved.                                                                                                                                                               |
| CHN4_UID   | [4:0]   | R/W  | 5'h0           | Channel 4 User ID number;                                                                                                                                               |

# 5.4.5.2.32 DMA\_CHN\_UID\_CFG2



| 0x00A0 |    |          | User | ID of o | channe  | els (res | set 0x0 | 0000_0 | 000)     |    |    |     | DMA_CHN_UID_CFG2 |           |    |    |  |
|--------|----|----------|------|---------|---------|----------|---------|--------|----------|----|----|-----|------------------|-----------|----|----|--|
| Bit    | 31 | 30       | 29   | 28      | 27      | 26       | 25      | 24     | 23       | 22 | 21 | 20  | 19               | 18        | 17 | 16 |  |
| Name   |    | Reserved | d    |         | С       | HN11_U   | ID      |        | Reserved |    |    |     | С                | CHN10_UID |    |    |  |
| Туре   |    | RO       |      |         |         | R/W      |         |        |          | RO |    |     |                  | R/W       |    |    |  |
| 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   |    | Reserved | t    |         | C       | HN9_UI   | D       |        | Reserved |    |    |     | CHN8_UID         |           |    |    |  |
| Туре   |    | RO       |      | R/W     |         |          |         |        | RO       |    |    | R/W |                  |           |    |    |  |
| Reset  | 0  | 0        | 0    | 0       | 0 0 0 0 |          |         |        | 0        | 0  | 0  | 0   | 0                | 0         | 0  | 0  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                              |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:29] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN11_UID  | [28:24] | R/W  | 5'h0           | Channel 11 User ID number; Each DMA user, that may trigger DMA, has a unique ID number, and SW may assign a DMA channel to any one of them, no matter APB or AHB module; |
|            | [23:21] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN10_UID  | [20:16] | R/W  | 5'h0           | Channel 10 User ID number;                                                                                                                                               |
|            | [15:13] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN9_UID   | [12:8]  | R/W  | 5'h0           | Channel 9 User ID number;                                                                                                                                                |
|            | [7:5]   | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN8_UID   | [4:0]   | R/W  | 5'h0           | Channel 8 User ID number;                                                                                                                                                |

# 5.4.5.2.33 DMA\_CHN\_UID\_CFG3

| 0x00A4 |    |         | User | ID of o   | channe         | els (res | set 0x0 | 0000_0 | 000)     |          |    |    | DMA_CHN_UID_CFG3 |           |    |    |  |
|--------|----|---------|------|-----------|----------------|----------|---------|--------|----------|----------|----|----|------------------|-----------|----|----|--|
| Bit    | 31 | 30      | 29   | 28        | 28 27 26 25 24 |          |         |        |          | 22       | 21 | 20 | 19               | 18        | 17 | 16 |  |
| Name   |    | Reserve | 4    |           | С              | HN15_U   | D       |        | Reserved |          |    |    | CHN14_UID        |           |    |    |  |
| Туре   |    | RO      |      |           |                | R/W      |         |        |          | RO       |    |    |                  | R/W       |    |    |  |
| 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   |    | Reserve | 1    |           | CHN13_UID      |          |         |        |          | Reserved |    |    |                  | CHN12_UID |    |    |  |
| Туре   |    | RO      |      |           |                | R/W      |         |        | RO       |          |    |    | R/W              |           |    |    |  |
| Reset  | 0  | 0       | 0    | 0 0 0 0 0 |                |          |         |        | 0        | 0        | 0  | 0  | 0                | 0         | 0  | 0  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                    |
|------------|---------|------|----------------|------------------------------------------------|
|            | [31:29] | RO   | 3'h0           | Reserved.                                      |
| CHN15_UID  | [28:24] | R/W  | 5'h0           | Channel 15 User ID number; Each DMA user, that |



|           |         |     |      | may trigger DMA, has a unique ID number, and SW may assign a DMA channel to any one of them, no matter APB or AHB module; |
|-----------|---------|-----|------|---------------------------------------------------------------------------------------------------------------------------|
|           | [23:21] | RO  | 3'h0 | Reserved.                                                                                                                 |
| CHN14_UID | [20:16] | R/W | 5'h0 | Channel 14 User ID number;                                                                                                |
|           | [15:13] | RO  | 3'h0 | Reserved.                                                                                                                 |
| CHN13_UID | [12:8]  | R/W | 5'h0 | Channel 13 User ID number;                                                                                                |
|           | [7:5]   | RO  | 3'h0 | Reserved.                                                                                                                 |
| CHN12_UID | [4:0]   | R/W | 5'h0 | Channel 12 User ID number;                                                                                                |

#### 5.4.5.2.34 DMA\_CHN\_UID\_CFG4

Description: User ID of channels

| 0x00A8 |    |          | Haar | ID of   | -h        | la /rac  | $\overline{}$ |        | DIMA     | CUN      | IIID ( | CEC 4 |                  |           |    |    |  |
|--------|----|----------|------|---------|-----------|----------|---------------|--------|----------|----------|--------|-------|------------------|-----------|----|----|--|
| UXUUA8 |    |          | User | וט סו פ | cnanne    | eis (res | set 0x0       | 0000_0 | 000)     |          |        |       | DMA_CHN_UID_CFG4 |           |    |    |  |
| Bit    | 31 | 30       | 29   | 28      | 27        | 26       | 25            | 24     | 23       | 22       | 21     | 20    | 19               | 18        | 17 | 16 |  |
| Name   |    | Reserved | ł    |         | С         | HN19_U   | ID            |        | Reserved |          |        |       | CHN18_UID        |           |    |    |  |
| Туре   |    | RO       |      |         |           | R/W      |               |        | RO       |          |        |       |                  | R/W       |    |    |  |
| 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   |    | Reserved | d    |         | CHN17_UID |          |               |        |          | Reserved |        |       |                  | CHN16_UID |    |    |  |
| Туре   |    | RO       |      | R/W     |           |          |               |        | RO       |          |        |       | R/W              |           |    |    |  |
| Reset  | 0  | 0        | 0    | 0       | 0 0 0 0   |          |               |        |          | 0        | 0      | 0     | 0                | 0         | 0  | 0  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                              |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:29] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN19_UID  | [28:24] | R/W  | 5'h0           | Channel 19 User ID number; Each DMA user, that may trigger DMA, has a unique ID number, and SW may assign a DMA channel to any one of them, no matter APB or AHB module; |
|            | [23:21] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN18_UID  | [20:16] | R/W  | 5'h0           | Channel 18 User ID number;                                                                                                                                               |
|            | [15:13] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN17_UID  | [12:8]  | R/W  | 5'h0           | Channel 17 User ID number;                                                                                                                                               |
|            | [7:5]   | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN16_UID  | [4:0]   | R/W  | 5'h0           | Channel 16 User ID number;                                                                                                                                               |

# 5.4.5.2.35 DMA\_CHN\_UID\_CFG5



| 0x00AC | ;  |         | User | ID of o | channe    | els (res | set 0x( | 0000_0 | 000)     |    |    |     | DMA_CHN_UID_CFG5 |           |    |    |  |
|--------|----|---------|------|---------|-----------|----------|---------|--------|----------|----|----|-----|------------------|-----------|----|----|--|
| Bit    | 31 | 30      | 29   | 28      | 27        | 26       | 25      | 24     | 23       | 22 | 21 | 20  | 19               | 18        | 17 | 16 |  |
| Name   |    | Reserve | d    |         | С         | HN23_U   | ID      |        | Reserved |    |    |     | С                | CHN22_UID |    |    |  |
| Туре   |    | RO      |      |         |           | R/W      |         |        |          | RO |    |     |                  | R/W       |    |    |  |
| 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   |    | Reserve | d    |         | С         | HN21_U   | ID      |        | Reserved |    |    |     | CHN20_UID        |           |    |    |  |
| Туре   |    | RO      |      | R/W     |           |          |         |        | RO       |    |    | R/W |                  |           |    |    |  |
| Reset  | 0  | 0       | 0    | 0       | 0 0 0 0 0 |          |         |        | 0        | 0  | 0  | 0   | 0                | 0         | 0  | 0  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                              |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:29] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN23_UID  | [28:24] | R/W  | 5'h0           | Channel 23 User ID number; Each DMA user, that may trigger DMA, has a unique ID number, and SW may assign a DMA channel to any one of them, no matter APB or AHB module; |
|            | [23:21] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN22_UID  | [20:16] | R/W  | 5'h0           | Channel 22 User ID number;                                                                                                                                               |
|            | [15:13] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN21_UID  | [12:8]  | R/W  | 5'h0           | Channel 21 User ID number;                                                                                                                                               |
|            | [7:5]   | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN20_UID  | [4:0]   | R/W  | 5'h0           | Channel 20 User ID number;                                                                                                                                               |

# 5.4.5.2.36 DMA\_CHN\_UID\_CFG6

| 0x00B0 |    |         | User | ID of     | channe         | els (res | set 0x0 | 0000_0 | 000)     |          |    |     | DMA_CHN_UID_CFG6 |           |    |    |  |  |
|--------|----|---------|------|-----------|----------------|----------|---------|--------|----------|----------|----|-----|------------------|-----------|----|----|--|--|
| Bit    | 31 | 30      | 29   | 28        | 28 27 26 25 24 |          |         |        |          | 22       | 21 | 20  | 19               | 18        | 17 | 16 |  |  |
| Name   |    | Reserve | 4    |           | С              | HN27_U   | D       |        | Reserved |          |    |     | С                | CHN26_UID |    |    |  |  |
| Туре   |    | RO      |      |           |                | R/W      |         |        |          | RO       |    |     |                  | R/W       |    |    |  |  |
| 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   |    | Reserve | 1    |           | CHN25_UID      |          |         |        |          | Reserved |    |     |                  | CHN24_UID |    |    |  |  |
| Type   |    | RO      |      |           |                | R/W      |         |        | RO       |          |    | R/W |                  |           |    |    |  |  |
| Reset  | 0  | 0       | 0    | 0 0 0 0 0 |                |          |         |        | 0        | 0        | 0  | 0   | 0                | 0         | 0  | 0  |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                    |
|------------|---------|------|----------------|------------------------------------------------|
|            | [31:29] | RO   | 3'h0           | Reserved.                                      |
| CHN27_UID  | [28:24] | R/W  | 5'h0           | Channel 27 User ID number; Each DMA user, that |



|           |         |     |      | may trigger DMA, has a unique ID number, and SW may assign a DMA channel to any one of them, no matter APB or AHB module; |
|-----------|---------|-----|------|---------------------------------------------------------------------------------------------------------------------------|
|           | [23:21] | RO  | 3'h0 | Reserved.                                                                                                                 |
| CHN26_UID | [20:16] | R/W | 5'h0 | Channel 26 User ID number;                                                                                                |
|           | [15:13] | RO  | 3'h0 | Reserved.                                                                                                                 |
| CHN25_UID | [12:8]  | R/W | 5'h0 | Channel 25 User ID number;                                                                                                |
|           | [7:5]   | RO  | 3'h0 | Reserved.                                                                                                                 |
| CHN24_UID | [4:0]   | R/W | 5'h0 | Channel 24 User ID number;                                                                                                |

#### 5.4.5.2.37 DMA\_CHN\_UID\_CFG7

Description: User ID of channels

| 0x00B4 |    |          | User | User ID of channels (reset 0x0000_0000) |           |        |    |    |          |    |    |    |           | DMA_CHN_UID_CFG7 |    |    |  |  |
|--------|----|----------|------|-----------------------------------------|-----------|--------|----|----|----------|----|----|----|-----------|------------------|----|----|--|--|
| Bit    | 31 | 30       | 29   | 28                                      | 27        | 26     | 25 | 24 | 23       | 22 | 21 | 20 | 19        | 18               | 17 | 16 |  |  |
| Name   |    | Reserved | d    |                                         | С         | HN31_U | ID |    | Reserved |    |    |    | С         | HN30_U           | ID |    |  |  |
| Туре   |    | RO       |      |                                         |           | R/W    |    |    | RO       |    |    |    |           | R/W              |    |    |  |  |
| 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   |    | Reserved | d    |                                         | CHN29_UID |        |    |    | Reserved |    |    |    | CHN28_UID |                  |    |    |  |  |
| Туре   |    | RO       |      | R/W                                     |           |        |    |    | RO       |    |    |    | R/W       |                  |    |    |  |  |
| Reset  | 0  | 0        | 0    | 0                                       | 0 0 0 0   |        |    | 0  | 0        | 0  | 0  | 0  | 0         | 0                | 0  |    |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                              |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:29] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN31_UID  | [28:24] | R/W  | 5'h0           | Channel 31 User ID number; Each DMA user, that may trigger DMA, has a unique ID number, and SW may assign a DMA channel to any one of them, no matter APB or AHB module; |
|            | [23:21] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN30_UID  | [20:16] | R/W  | 5'h0           | Channel 30 User ID number;                                                                                                                                               |
|            | [15:13] | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN29_UID  | [12:8]  | R/W  | 5'h0           | Channel 29 User ID number;                                                                                                                                               |
|            | [7:5]   | RO   | 3'h0           | Reserved.                                                                                                                                                                |
| CHN28_UID  | [4:0]   | R/W  | 5'h0           | Channel 28 User ID number;                                                                                                                                               |

#### 5.4.5.2.38 DMA\_CHN\_EN\_SET

Description: Set Channels enable register



| 0x00C0 |    |    | Set C | hanne                            | el enab | le reg | ister (r | eset 0 | x0000 | _0000) |   |   | DI | MA_CH | IN_EN | SET |
|--------|----|----|-------|----------------------------------|---------|--------|----------|--------|-------|--------|---|---|----|-------|-------|-----|
| Bit    | 31 | 30 | 29    | 29 28 27 26 25 24 23 22 21 20 19 |         |        |          |        |       |        |   |   |    |       | 17    | 16  |
| Name   |    |    |       | CHN_EN_SET                       |         |        |          |        |       |        |   |   |    |       |       |     |
| Туре   |    |    |       | wo                               |         |        |          |        |       |        |   |   |    |       |       |     |
| Reset  | 0  | 0  | 0     | 0                                | 0       | 0      | 0        | 0      | 0     | 0      | 0 | 0 | 0  | 0     | 0     | 0   |
| Bit    | 15 | 14 | 13    | 3 12 11 10 9 8 7 6 5 4 3 2 1 0   |         |        |          |        |       |        |   |   | 0  |       |       |     |
| Name   |    |    |       | CHN_EN_SET                       |         |        |          |        |       |        |   |   |    |       |       |     |
| Туре   |    |    |       | wo                               |         |        |          |        |       |        |   |   |    |       |       |     |
| Reset  | 0  | 0  | 0     | 0                                | 0       | 0      | 0        | 0      | 0     | 0      | 0 | 0 | 0  | 0     | 0     | 0   |

| Field Name | Bit    | Туре | Reset<br>Value | Description                     |
|------------|--------|------|----------------|---------------------------------|
| CHN_EN_SET | [31:0] | WO   | 32'h0          | Set Channel Enable, Active high |

#### 5.4.5.2.39 DMA\_CHN\_EN\_CLR

Description: Clear Channels enable register

| 0x00C4 |    |                                              | Clear      | r Chan     | nel en | able re | gister | (reset | 0x000 | 00_000 | 0) |   | DN | IA_CH | N_EN | CLR |
|--------|----|----------------------------------------------|------------|------------|--------|---------|--------|--------|-------|--------|----|---|----|-------|------|-----|
| Bit    | 31 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |            |            |        |         |        |        |       |        |    |   |    |       |      |     |
| Name   |    |                                              | CHN_EN_CLR |            |        |         |        |        |       |        |    |   |    |       |      |     |
| Туре   |    |                                              |            | 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   |    |                                              |            | CHN_EN_CLR |        |         |        |        |       |        |    |   |    |       |      |     |
| Туре   |    |                                              |            | wo         |        |         |        |        |       |        |    |   |    |       |      |     |
| Reset  | 0  | 0                                            | 0          | 0          | 0      | 0       | 0      | 0      | 0     | 0      | 0  | 0 | 0  | 0     | 0    | 0   |

| Field Name | Bit    | Туре | Reset<br>Value | Description                       |
|------------|--------|------|----------------|-----------------------------------|
| CHN_EN_CLR | [31:0] | WO   | 32'h0          | Clear Channel Enable, Active high |

# 5.4.5.2.40 CHNX\_CFG

Description: Channel X configure register, X = 0, 1, 2 ....31



| 0x0400 | + 0x20            | )*X              | Char       | nel X        | config | ure re       | gister | (reset       | 0xXXX | X_XX       | (X)                     |                          |      |       | CHNX                          | _CFG             |
|--------|-------------------|------------------|------------|--------------|--------|--------------|--------|--------------|-------|------------|-------------------------|--------------------------|------|-------|-------------------------------|------------------|
| Bit    | 31                | 30               | 29         | 28           | 27     | 26           | 25     | 24           | 23    | 22         | 21                      | 20                       | 19   | 18    | 17                            | 16               |
| Name   | LLIS<br>T_E<br>ND | Res<br>erve<br>d | SWT_<br>_S |              |        | DATA_<br>DTH |        | _DATA<br>DTH | REQ_I | MODE<br>EL | SRC<br>_WR<br>AP_<br>EN | DES<br>T_W<br>RAP<br>_EN | Rese | erved | NO_<br>AUT<br>O_C<br>LOS<br>E | Res<br>erve<br>d |
| Туре   | R/W               | R/W              | R/         | W            | R/     | R/W          |        | W            | R/    | W          | R/W                     | R/W                      | R    | .0    | R/W                           | RO               |
| Reset  | х                 | х                | х          | х            | х      | х            | х      | х            | х     | х          | х                       | х                        | х    | х     | х                             | х                |
| Bit    | 15                | 14               | 13         | 12           | 11     | 10           | 9      | 8            | 7     | 6          | 5                       | 4                        | 3    | 2     | 1                             | 0                |
| Name   |                   |                  |            | BLOCK_LENGTH |        |              |        |              |       |            |                         |                          |      |       |                               |                  |
| Туре   |                   |                  |            | R/W          |        |              |        |              |       |            |                         |                          |      |       |                               |                  |
| Reset  | х                 | х                | х          | х            | х      | х            | х      | х            | х     | х          | х                       | х                        | х    | х     | х                             | х                |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                         |
|-----------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LLIST_END       | [31]    | R/W  | 1'hx           | Active high, Link list end flag means this is the last one of the link list. When LLEnd is active, LLPtr means nothing.                                                             |
|                 | [30]    | R/W  | 1'hx           | Reserved.                                                                                                                                                                           |
| SWT_MODE_SEL    | [29:28] | R/W  | 2'hx           | DMA supports 4 kinds of Switch mode, they are: 2'b00: Un-switch Mode; 2'b01: Full Switch Mode, All the bytes within a word reversed; 2'b10: Switch Mode 0, In a word, the two bytes |
|                 |         |      |                | within each half-word reversed, and the position of the tow Half-words keep un-touched.                                                                                             |
|                 |         |      |                | 2'b11: Switch Mode 1, In a word, the two Half-words reversed, and the bytes within each Half-word keep un-touched.                                                                  |
|                 |         |      |                | For example: if DMA receives a word "0xABCD", and the result of endian switch is showed below:                                                                                      |
|                 |         |      |                | 2'b00: 0xABCD => 0xABCD                                                                                                                                                             |
|                 |         |      |                | 2'b01: 0xABCD => 0xDCBA                                                                                                                                                             |
|                 |         |      |                | 2'b10: 0xABCD => 0xBADC                                                                                                                                                             |
|                 |         |      |                | 2'b11: 0xABCD => 0xCDAB                                                                                                                                                             |
| 5 C)            |         |      |                | Note: In any switch mode, Full switch, switch mode0 or switch mode1, both the total length and block length MUST be WORD boundary, and if not, data may be lost in transfer.        |
| SRC_DATA_WIDTH  | [27:26] | R/W  | 2'hx           | Source data width. 00: byte. 01: half-word. 10: word.                                                                                                                               |
| DEST_DATA_WIDTH | [25:24] | R/W  | 2'hx           | Destination data width. 00: byte. 01: half-word. 10: word.                                                                                                                          |
| REQ_MODE_SEL    | [23:22] | R/W  | 2'hx           | Channel request mode selection signals                                                                                                                                              |
|                 |         |      |                | 2'b00: Normal mode, one request for one block.                                                                                                                                      |
|                 |         |      |                | 2'b01: Transaction mode, one request for the total length of one transaction.                                                                                                       |
|                 |         |      |                | 2'b10: List mode, one request for the whole link                                                                                                                                    |



|               |         |     |       | list. In soft List mode, DMA will execute transfer whenever the "counter" is unequal to zero;  2'b11: Infinite mode, the total length of the current channel is unknown, while block length is configured fixed. So DMA will always transfer a fixed length block whenever a corresponding dma_req is active.  Note:  1. In SoftList mode, "ReqModeSel" must be set to "2'b10", that is, one request for the whole list.  In Infinite mode, NoAutoClose should be set; |
|---------------|---------|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRC_WRAP_EN   | [21]    | R/W | 1'hx  | Active high, Source Address Wrapping Enable                                                                                                                                                                                                                                                                                                                                                                                                                            |
| DEST_WRAP_EN  | [20]    | R/W | 1'hx  | Active high, Destination Address Wrapping Enable                                                                                                                                                                                                                                                                                                                                                                                                                       |
|               | [19:18] | RO  | 2'hx  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| NO_AUTO_CLOSE | [17]    | R/W | 1'hx  | Channel No Auto-Close  0: ChnEn is set by ARM and cleared automatically after transferring the whole link list in link list mode, or the whole transaction in normal mode.  1: ChnEn is set and cleared only by ARM.  Note: in Soft list mode, this register value will be ignored.                                                                                                                                                                                    |
|               | [16]    | RO  | 1'hx  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| BLOCK_LENGTH  | [15:0]  | R/W | 16'hx | BlockLength The unit is BYTE.  Note: burst_length should be on maxium value of src_data_width and dest_data_width boundary;                                                                                                                                                                                                                                                                                                                                            |

# 5.4.5.2.41 CHNX\_ TOTAL\_LEN

Description: Channel X total length, X = 0, 1, 2 ....31

| 0x0404 | + 0x20 | )*X | Char | nel X    | total le | ength ( | reset ( | )xXXX     | x_xxx | (X) |    |    | CHNX_TOTAL_LEN |    |    |    |
|--------|--------|-----|------|----------|----------|---------|---------|-----------|-------|-----|----|----|----------------|----|----|----|
| Bit    | 31     | 30  | 29   | 28       | 27       | 26      | 25      | 24        | 23    | 22  | 21 | 20 | 19             | 18 | 17 | 16 |
| Name   |        |     | ſ    | Reserved | d        |         |         | TOTAL_LEN |       |     |    |    |                |    |    |    |
| Туре   |        |     |      | RO       |          |         |         | R/W       |       |     |    |    |                |    |    |    |
| Reset  | х      | x   | х    | х        | х        | х       | х       | х         | х     | х   | х  | х  | х              | х  | х  | х  |
| Bit    | 15     | 14  | 13   | 12       | 11       | 10      | 9       | 8         | 7     | 6   | 5  | 4  | 3              | 2  | 1  | 0  |
| Name   |        |     |      |          |          |         |         | TOTA      | _LEN  |     |    |    |                |    |    |    |
| Туре   |        | R/W |      |          |          |         |         |           |       |     |    |    |                |    |    |    |
| Reset  | х      | х   | х    | х        | х        | х       | х       | х         | х     | х   | х  | х  | х              | х  | х  | х  |

| Field Name | Bit     | Туре | Reset<br>Value | Description             |
|------------|---------|------|----------------|-------------------------|
|            | [31:25] | RO   | 7'hx           | Reserved                |
| TOTAL_LEN  | [24:0]  | R/W  | 25'hx          | Total transfers length. |



|  | The unit is BYTE.                                                          |
|--|----------------------------------------------------------------------------|
|  | Note: total length can be any value without concerning about Burst length. |

#### 5.4.5.2.42 CHNX\_SRC\_ADDR

Description: Channel X Source Address, X = 0, 1, 2 ....31

| 0x0408 | + 0x20 | )*X | Channel X Source Address (reset 0xXXXX_XXXX) CHNX_SRC_ADD |                                        |    |    |   |   |   |   |   |   |   |   | ADDR |   |
|--------|--------|-----|-----------------------------------------------------------|----------------------------------------|----|----|---|---|---|---|---|---|---|---|------|---|
| Bit    | 31     | 30  | 29                                                        | 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |    |   |   |   |   |   |   |   |   |      |   |
| Name   |        |     |                                                           | SRC_ADDR                               |    |    |   |   |   |   |   |   |   |   |      |   |
| Туре   |        |     |                                                           | R/W                                    |    |    |   |   |   |   |   |   |   |   |      |   |
| Reset  | х      | х   | х                                                         | x                                      |    |    |   |   |   |   |   |   |   |   |      |   |
| Bit    | 15     | 14  | 13                                                        | 12                                     | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0 |
| Name   |        |     |                                                           | SRC_ADDR                               |    |    |   |   |   |   |   |   |   |   |      |   |
| Туре   |        |     |                                                           | RW                                     |    |    |   |   |   |   |   |   |   |   |      |   |
| Reset  | х      | х   | х                                                         | х                                      | х  | х  | х | х | х | х | х | x | × | х | х    | х |

| Field Name | Bit    | Туре | Reset<br>Value | Description     |
|------------|--------|------|----------------|-----------------|
| SRC_ADDR   | [31:0] | R/W  | 32'hx          | Source address. |

#### 5.4.5.2.43 CHNX\_DEST\_ADDR

Description: Channel X Destination Address, X = 0, 1, 2 ....31

| 0x040C | + 0x2 | - 0x20*X Channel X Source Address (reset 0xXXXX_XXXX) |                                       |                                          |    |    |   |   |   |   |   |   | CHNX_DEST_ADDR |   |    |   |  |
|--------|-------|-------------------------------------------------------|---------------------------------------|------------------------------------------|----|----|---|---|---|---|---|---|----------------|---|----|---|--|
| Bit    | 31    | 30                                                    | 29                                    | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |    |   |   |   |   |   |   |                |   | 16 |   |  |
| Name   |       |                                                       | DEST_ADDR                             |                                          |    |    |   |   |   |   |   |   |                |   |    |   |  |
| Туре   |       |                                                       | R/W                                   |                                          |    |    |   |   |   |   |   |   |                |   |    |   |  |
| Reset  | х     | х                                                     | x x x x x x x x x x x x x x x x x x x |                                          |    |    |   |   |   |   |   |   | х              |   |    |   |  |
| Bit    | 15    | 14                                                    | 13                                    | 12                                       | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3              | 2 | 1  | 0 |  |
| Name   |       |                                                       | DEST_ADDR                             |                                          |    |    |   |   |   |   |   |   |                |   |    |   |  |
| Туре   |       | R/W                                                   |                                       |                                          |    |    |   |   |   |   |   |   |                |   |    |   |  |
| Reset  | х     | x x x x x x x x x x x x x x x x x x x                 |                                       |                                          |    |    |   |   |   |   |   |   |                |   |    |   |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description          |
|------------|--------|------|----------------|----------------------|
| DEST_ADDR  | [31:0] | R/W  | 32'hx          | Destination address. |

#### 5.4.5.2.44 CHNX\_LLIST\_PTR

Description: Channel X Link list pointer address,  $X = 0, 1, 2 \dots 31$ 



| 0x0410 | + 0x20 | )*X                                   | Char | nel X                                    | Link li | st poin | ter ad | dress | (reset | 0xXXX | X_XX | XX) | CHNX_LLIST_PTR |   |   |   |  |
|--------|--------|---------------------------------------|------|------------------------------------------|---------|---------|--------|-------|--------|-------|------|-----|----------------|---|---|---|--|
| Bit    | 31     | 30                                    | 29   | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |         |        |       |        |       |      |     |                |   |   |   |  |
| Name   |        |                                       |      | LLIST_PTR                                |         |         |        |       |        |       |      |     |                |   |   |   |  |
| Туре   |        |                                       |      | R/W                                      |         |         |        |       |        |       |      |     |                |   |   |   |  |
| Reset  | х      | х                                     | х    | x x x x x x x x x x x x x x x x x x x    |         |         |        |       |        |       |      |     |                |   |   |   |  |
| Bit    | 15     | 14                                    | 13   | 12                                       | 11      | 10      | 9      | 8     | 7      | 6     | 5    | 4   | 3              | 2 | 1 | 0 |  |
| Name   |        |                                       |      | LLIST_PTR                                |         |         |        |       |        |       |      |     |                |   |   |   |  |
| Туре   |        |                                       | RW   |                                          |         |         |        |       |        |       |      |     |                |   |   |   |  |
| Reset  | х      | x x x x x x x x x x x x x x x x x x x |      |                                          |         |         |        |       |        |       |      |     |                |   |   |   |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                    |
|------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| LLIST_PTR  | [31:0] | R/W  | 32'hx          | Link list pointer to the next node address.  MUST be on 8-word boundary.  So when writing, bit [4:0] is omitted; When reading, bit [4:0] is 0. |
|            |        |      |                | If LLEnd is set, indicating the current transaction is last one of the list, LLPtr is unused.                                                  |

# 5.4.5.2.45 CHNX\_ELEM\_POSTM

Description: Channel X Element post-modification, X = 0, 1, 2 ....31

| 0x0414 | + 0x20 | - 0x20*X Channel X Element post-modification (reset 0xXXXX_XXXX) |     |                                          |    |    |   |   |   |   |   |   | CHNX_ELEM_POSTM |   |   |    |  |
|--------|--------|------------------------------------------------------------------|-----|------------------------------------------|----|----|---|---|---|---|---|---|-----------------|---|---|----|--|
| Bit    | 31     | 30                                                               | 29  | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |    |   |   |   |   |   |   |                 |   |   | 16 |  |
| Name   |        | SRC_ELEM_POSTM                                                   |     |                                          |    |    |   |   |   |   |   |   |                 |   |   |    |  |
| Туре   |        |                                                                  | R/W |                                          |    |    |   |   |   |   |   |   |                 |   |   |    |  |
| Reset  | х      | х                                                                | х   | x x x x x x x x x x x x x x x            |    |    |   |   |   |   |   |   |                 | х |   |    |  |
| Bit    | 15     | 14                                                               | 13  | 12                                       | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3               | 2 | 1 | 0  |  |
| Name   |        | 4                                                                |     | DEST_ELEM_POSTM                          |    |    |   |   |   |   |   |   |                 |   |   |    |  |
| Туре   |        |                                                                  | A   | R/W                                      |    |    |   |   |   |   |   |   |                 |   |   |    |  |
| Reset  | х      | х                                                                | х   | х                                        | х  | х  | х | х | х | х | х | х | х               | х | х | х  |  |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                          |
|----------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRC_ELEM_POSTM | [31:16] | R/W  | 16'hx          | Sets the post-modification value of the source's current address during a block transfer. The value is in 2's complement format, which means that both positive and negative values are supported. The post-modification value is summed with the source current address following an element Read transfer.  Note:  The value must be set to an integer multiple of |
|                |         |      |                | the Source data width, setting it to a different value may yield unexpected behaviors.                                                                                                                                                                                                                                                                               |
|                |         |      |                | When DMA source master working in BURST,                                                                                                                                                                                                                                                                                                                             |



|                 |        |     |       | this register "src_elem_postm" is automatically set to "don't care", and DMA will manage HADDRdmar according to src_data_width;                                                                                                                                                                                                                                                 |
|-----------------|--------|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DEST_ELEM_POSTM | [15:0] | R/W | 16'hx | Sets the post-modification value of the destination's current address during a block transfer. The value is in 2's complement format, which means that both positive and negative values are supported. The post-modification value is summed with the destination current address following an element Write transfer.  Note:  The value must be set to an integer multiple of |
|                 |        |     |       | the Destination data width; setting it to a different value may yield unexpected behavior.                                                                                                                                                                                                                                                                                      |
|                 |        |     |       | When DMA destination master working in BURST, this register "dest_elem_postm" is automatically set to "don't care", and DMA will manage HADDRdmaw according to src_data_width;                                                                                                                                                                                                  |

# 5.4.5.2.46 CHNX\_SRC\_BLOCK\_POSTM

Description: Channel X Source Block post-modification, X = 0, 1, 2 ....31

| 0x0418 | + 0x20           | )*X  |                     | nel X           |    | e Bloc | k post- | -modif | ication | rese   |    | CHNX_SRC_BLOCK_<br>POSTM |    |    |    |    |  |
|--------|------------------|------|---------------------|-----------------|----|--------|---------|--------|---------|--------|----|--------------------------|----|----|----|----|--|
| Bit    | 31               | 30   | 29                  | 28              | 27 | 26     | 25      | 24     | 23      | 22     | 21 | 20                       | 19 | 18 | 17 | 16 |  |
| Name   | Res<br>erve<br>d | SRC_ | SURST_MODE Reserved |                 |    |        |         |        | SR      | CK_POS | ТМ | М                        |    |    |    |    |  |
| Туре   | RO               |      | R/W                 |                 | R  | .0     |         | R/W    |         |        |    |                          |    |    |    |    |  |
| Reset  | х                | х    | х                   | х               | х  | х      | х       | х      | х       | х      | х  | х                        | х  | х  | х  | х  |  |
| Bit    | 15               | 14   | 13                  | 12              | 11 | 10     | 9       | 8      | 7       | 6      | 5  | 4                        | 3  | 2  | 1  | 0  |  |
| Name   |                  |      |                     | SRC_BLOCK_POSTM |    |        |         |        |         |        |    |                          |    |    |    |    |  |
| Туре   |                  |      |                     |                 |    |        |         | R/W    |         |        |    |                          |    |    |    |    |  |
| Reset  | х                | х    | х                   | х               | х  | х      | х       | х      | х       | х      | х  | х                        | х  | х  | х  | х  |  |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                         |
|-----------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | [31]    | RO   | 1'hx           | Reserved.                                                                                                                                                           |
| SRC_BURST_MODE  | [30:28] | R/W  | 3'hx           | 000 – Single Transfer; NSEQ for each transfer;<br>001 – INCR for unspecified length<br>011 – INCR4;<br>101 – INCR8;<br>111 – INCR16;<br>No wrap burst is supported. |
|                 | [27:26] | RO   | 2'hx           | Reserved.                                                                                                                                                           |
| SRC_BLOCK_POSTM | [25:0]  | R/W  | 26'hx          | Sets the post-modification value of the source's current address, between the Read transfer of the                                                                  |



| last element in a source block to the first element of the next block during a cluster transfer. The value is in 2's complement, which means that both positive and negative values are supported. The post-modification value is summed with the source current address following a block Read transfer. |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Note:</b> The value must be set to an integer multiple of the data width; setting it to a different value may yield unexpected behavior.                                                                                                                                                               |

# 5.4.5.2.47 CHNX\_DEST\_BLOCK\_POSTM

Description: Channel X Destination Block post-modification, X = 0, 1, 2 ....31

| 0x041C | + 0x2            | Channel X Destination E |        |      |      |       |    | Block post-modification (reset |    |    |        |        |            | CHNX_DEST_BLOCK<br>_POSTM |    |    |  |
|--------|------------------|-------------------------|--------|------|------|-------|----|--------------------------------|----|----|--------|--------|------------|---------------------------|----|----|--|
| Bit    | 31               | 30                      | 29     | 28   | 27   | 26    | 25 | 24                             | 23 | 22 | 21     | 20     | 19         | 18                        | 17 | 16 |  |
| Name   | Res<br>erve<br>d | DEST                    | _BURST | _MOD | Rese | erved |    |                                |    | DE | ST_BLO | CK_POS | <b>STM</b> |                           |    |    |  |
| Туре   | RO               |                         | R/W RO |      |      | R/W   |    |                                |    |    |        |        |            |                           |    |    |  |
| Reset  | х                | х                       | х      | х    | х    | х     | х  | х                              | х  | X  | х      | х      | х          | х                         | х  | х  |  |
| Bit    | 15               | 14                      | 13     | 12   | 11   | 10    | 9  | 8                              | 7  | 6  | 5      | 4      | 3          | 2                         | 1  | 0  |  |
| Name   |                  | DEST_BLOCK_POSTM        |        |      |      |       |    |                                |    |    |        |        |            |                           |    |    |  |
| Туре   |                  | R/W                     |        |      |      |       |    |                                |    |    |        |        |            |                           |    |    |  |
| Reset  | х                | х                       | х      | х    | х    | х     | х  | х                              | Х  | х  | х      | х      | х          | х                         | х  | х  |  |

| Field Name       | Bit     | Type | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | [31]    | RO   | 1'hx           | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| DEST_BURST_MODE  | [30:28] | R/W  | 3'hx           | 000 – Single Transfer; NSEQ for each transfer;<br>001 – INCR for unspecified length<br>011 – INCR4;<br>101 – INCR8;<br>111 – INCR16;<br>No wrap burst is supported.                                                                                                                                                                                                                                                                                                                                                                                                       |
|                  | [27:26] | RO   | 2'hx           | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| DEST_BLOCK_POSTM | [25:0]  | R/W  | 26'hx          | Sets the post-modification value of the destination's current address, between the Read transfers of the last element in a current block to the first element of the next block during a cluster transfer. The value is in 2's Complement, which means that both positive and negative values are supported. The post-modification value is summed with the destination current address following a block Write transfer.  Note: The value bit must be set to a fixed multiple of the data width in bytes; setting it to a different value may yield unexpected behavior. |



#### 5.4.6 Application Notes

In link list mode, each link list pointer address MUST be on WORD boundary. DMA will read successive 8 words (from pointer to [pointer + 0x1C]) into DMA internal channel registers.

Data width on DMA slave port MUST be WORD. Reading or writing BYTE or HALF-WORD width data on DMA SLAVE port will cause error.

In present DMA design, total\_length can be any value without concerning about src/dest\_data\_width. But Block\_length should be on maxium value of src\_data\_width and dest\_data\_width boundary, for example, if src\_data\_width is WORD and dest\_data\_width is BYTE, then block\_length should be on WORD boundary. If total\_length is not on src/dest\_data\_width boundary, the last element of the last block may contain some redundancy bits which are not desired

# 5.5 MCU Interrupt Controller

#### 5.5.1 Overview

SC6820 provides a 32-channel interrupt controller to collect all interrupts from different modules to generate FIQ and IRQ to MCU.

# 5.5.2 Features

- I Provide 30 hardware IRQ interrupt from channels 2 to channel 31
- I Provide 30 hardware FIQ interrupt from channels 2 to channel 31
- Provide one software-trigged IRQ interrupt from channel 1
- Provide one software-trigged FIQ interrupt from channel 1
- Provide one special IRQ interrupt from channel 0
- Provide one special FIQ interrupt from channel 0
- Provide one interrupt sent to DSP, which is generated by all IRQ channel interrupt raw status OR bit by bit, with each channel enabled separately.
- ı
- Each IRQ or FIQ channel can be enabled or disabled independently
- Provide raw status for each IRQ or FIQ channel
- I Provide masked status for each IRQ or FIQ channel
- I Special IRQ or FIQ interrupt on channel 0 is used to latch some input signal status and trigger IRQ or FIQ interrupt by level detecting (not edge detecting)
- Special IRQ or FIQ interrupt on channel 0 is multiplexed from four independent input sources
- Provide raw status for each of four input sources on special channel
- Provide polarity control bit for each of four input sources on special channel
- Provide only one clear bit to clear all latches on special channel
- Each input source can be enabled or disabled independently on special channel

#### 5.5.3 Function Description

SC6820 interrupt controller provides four different functions – thirty channels of hardware-trigged IRQ and FIQ interrupts, one channel of software-trigged IRQ and FIQ interrupts, and five special latch channels, and one interrupt sent to DSP

#### 5.5.3.1 Hardware-Trigged Channels

Thirty channels are used as hardware-trigged channels, which are from channels 2 to channel 31, and their sources are specified in the above table.

The hardware-trigged function is the main function provided by the interrupt controller. The controller collects interrupt trigger signals from different hardware modules,



applies mask on them and generates MCU FIQ and IRQ. The controller only supports level trigging, and trigging level is high active. There is no DFF or latch to keep status on the hardware-trigged channel path. So this controller can be used to wakeup MCU sub-system during sleep with no working clock, but it needs each source latches the interrupt status.

The circuit is very simple on hardware-trigged channels, shown as follows.



Figure 5-9 Hardware-Trigged channels diagram

#### 5.5.3.2 Software-Trigged Channels

Software-trigged interrupt is assigned to channel 1, and the function is similar to other hardware interrupts. The difference between them is that the software-trigged interrupt is issued in interrupt controller by setting one bit. Similarly, this interrupt can be cleared by just clearing this bit. This interrupt cannot wake up the system.

#### 5.5.3.3 Special Latch Channels

There is one special IRQ channel and FIQ channel, assigned on IRQ channel 0 and FIQ channel 0. These two channels are special because they are connected with off-chip interrupt to wakeup MCU sub-system. However inside the Interrupt Controller they are the same priority and function with other channels.

#### 5.5.3.4 Interrupt sent to DSP

Interrupt sent to DSP is generated by all IRQ channel interrupt raw status OR bit by bit, with each channel enabled separately by register INT2DSP\_ENABLE.





Figure 5-10 Interrupts to DSP diagram

# 5.5.4 Interrupt Channel Assignment

The following table shows the detailed channel assignment for both IRQ and FIQ.

Table 5-3 Interrupt channel assignment table

| Channel<br>Number | Source                      |                                      | Description |
|-------------------|-----------------------------|--------------------------------------|-------------|
| 0                 | Special latch               | 0: UARTO RXD                         |             |
|                   | channel                     | 1: UARTO CTSN                        |             |
|                   |                             | 2: UART1 RXD                         |             |
|                   |                             | 3: UART2 RXD                         |             |
|                   |                             | 4: USB Input SE0                     |             |
|                   |                             | 5: UART2 CTSN                        |             |
|                   |                             | 6:csyspwrupreq                       |             |
| 1                 | Software-trigge             | ed channel                           |             |
| 2                 | UARTO Interru               | pt                                   |             |
| 3                 | UART1 Interru<br>CA5_PMU_IN | pt   CA5_L2CC_INT  <br>F CA5_NCT_INT |             |
| 4                 | UART2 Interru               | pt                                   |             |
| 5                 | Generic Timer               | 0 Interrupt                          |             |
| 6                 | Generic Timer               | 1 Interrupt                          |             |
| 7                 | Generic Timer               | 2 Interrupt   COMMTX                 |             |
| 8                 | GPIO Combine                | ed Interrupt   EIC                   |             |
| 9                 | SPI0 Interrupt              | SPI1 Interrupt                       |             |
| 10                | Keypad Interru              | pt                                   |             |
| 11                | 12C0   12C1 Int             | errupt                               |             |



| 12 | SIM0 Interrupt   SIM1 Interrupt                                   |                                                                                                        |
|----|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| 13 | PIU_SER_INT                                                       | Semaphore interrupts from DSP side;<br>there are 3 interrupts and they are<br>logically OR'ed together |
| 14 | PIU_CR_HINT   I2C2   I2C3                                         | Command/reply interrupt from DSP to MCU                                                                |
| 15 | DSP IRQ0                                                          |                                                                                                        |
| 16 | DSP IRQ1                                                          |                                                                                                        |
| 17 | System Timer Interrupt0                                           |                                                                                                        |
| 18 | EPT Interrupt                                                     |                                                                                                        |
| 19 | IIS0 Interrupt   IIS1 Interrupt                                   |                                                                                                        |
| 20 | DSP INT OR                                                        | All the DSP interrupt                                                                                  |
| 21 | DMA Interrupt                                                     |                                                                                                        |
| 22 | VBC Interrupt                                                     | X                                                                                                      |
| 23 | VSP Interrupt                                                     |                                                                                                        |
| 24 | Ana_ irq                                                          |                                                                                                        |
| 25 | ADI module Interrupt   GPU Interrupt                              |                                                                                                        |
| 26 | USB Interrupt                                                     |                                                                                                        |
| 27 | DCAM Interrupt                                                    |                                                                                                        |
| 28 | NFC                                                               |                                                                                                        |
| 29 | LCDC Interrupt                                                    |                                                                                                        |
| 30 | DRM Interrupt   SDIO0 Interrupt                                   |                                                                                                        |
| 31 | Bus_mon0   bus_mon1   SDIO1 interrupt   AXI_bus_mon0 AXI_bus_mon1 |                                                                                                        |

# 5.5.5 Control Registers

# **5.5.5.1 Memory map**

ARM base address: 0x8000\_3000

| Offset Address | Name             | Description                 |
|----------------|------------------|-----------------------------|
| 0x0000         | INT_IRQ_MASK_STS | IRQ masked status           |
| 0x0004         | INT_IRQ_RAW_STS  | IRQ raw status              |
| 0x0008         | INT_IRQ_ENABLE   | IRQ enable control          |
| 0x000C         | INT_IRQ_DISABLE  | IRQ disable control         |
| 0x0010         | INT_IRQ_SOFT     | IRQ software interrupt trig |
| 0x0014         | INT_IRQ_TEST_SRC | IRQ test source generating  |
| 0x0018         | INT_IRQ_TEST_SEL | IRQ test select             |
|                |                  |                             |
| 0x0020         | INT_FIQ_MASK_STS | FIQ masked status           |



| 0x0024 | INT_ FIQ_RAW_STS  | FIQ raw status              |
|--------|-------------------|-----------------------------|
| 0x0028 | INT_ FIQ_ENABLE   | FIQ enable control          |
| 0x002C | INT_ FIQ_DISABLE  | FIQ disable control         |
| 0x0030 | INT_ FIQ_SOFT     | FIQ software interrupt trig |
| 0x0034 | INT_ FIQ_TEST_SRC | FIQ test source generating  |
| 0x0038 | INT_ FIQ_TEST_SEL | FIQ test select             |

### 5.5.5.2 Register Descriptions

## 5.5.5.2.1 INT\_IRQ\_MASK\_STS

Description: IRQ masked status

| 0x0000 |    | IRQ masked status (reset 0x0) |    |                                           |    |    |    |         |        |    |   |   |   | INT_IRQ_MASK_STS |    |   |  |
|--------|----|-------------------------------|----|-------------------------------------------|----|----|----|---------|--------|----|---|---|---|------------------|----|---|--|
| Bit    | 31 | 30                            | 29 | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |    |    |         |        |    |   |   |   |                  | 16 |   |  |
| Name   |    |                               |    | INT_IRQ_MASK_STS                          |    |    |    |         |        |    |   |   |   |                  |    |   |  |
| Туре   |    | 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   |    |                               |    |                                           |    |    | IN | T_IRQ_I | MASK_S | TS |   |   |   |                  |    |   |  |
| Туре   |    | RO                            |    |                                           |    |    |    |         |        |    |   |   |   |                  |    |   |  |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0     |    |                                           |    |    |    |         |        |    |   |   |   |                  |    |   |  |

| Field Name       | Bit    | Туре | Reset<br>Value | Description                                                             |
|------------------|--------|------|----------------|-------------------------------------------------------------------------|
| INT_IRQ_MASK_STS | [31:0] | RO   | 32'h0          | IRQ interrupt channel masked status One bit for one channel Active high |

# 5.5.5.2.2 INT\_IRQ\_RAW\_STS

Description: IRQ raw status

| 0x0004 |    |                                                | IRQ r           | IRQ raw status (reset 0x0) |    |    |    |         |        |    |   |   | IN | INT_IRQ_RAW_STS |   |   |  |
|--------|----|------------------------------------------------|-----------------|----------------------------|----|----|----|---------|--------|----|---|---|----|-----------------|---|---|--|
| Bit    | 31 | 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                 |                            |    |    |    |         |        |    |   |   | 16 |                 |   |   |  |
| Name   |    |                                                | INT_IRQ_RAW_STS |                            |    |    |    |         |        |    |   |   |    |                 |   |   |  |
| Туре   |    |                                                |                 |                            |    |    |    | R       | 0      |    |   |   |    |                 |   |   |  |
| Reset  | 0  | 0                                              |                 |                            |    |    |    |         |        |    |   |   |    | 0               |   |   |  |
| Bit    | 15 | 14                                             | 13              | 12                         | 11 | 10 | 9  | 8       | 7      | 6  | 5 | 4 | 3  | 2               | 1 | 0 |  |
| Name   |    |                                                |                 |                            |    |    | IN | IT_IRQ_ | RAW_S1 | rs |   |   |    |                 |   |   |  |
| Туре   |    |                                                |                 |                            |    |    |    | R       | 0      |    |   |   |    |                 |   |   |  |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                |                 |                            |    |    |    |         |        |    |   |   |    |                 |   |   |  |



| Field Name      | Bit    | Туре | Reset<br>Value | Description                                                          |
|-----------------|--------|------|----------------|----------------------------------------------------------------------|
| INT_IRQ_RAW_STS | [31:0] | RO   | 32'h0          | IRQ interrupt channel raw status One bit for one channel Active high |

### 5.5.5.2.3 INT\_IRQ\_ENABLE

Description: IRQ enable control

| 0x0008 |    |    | IRQ 6                       | IRQ enable control (reset 0x0) INT_IRQ_ENABLE |    |    |   |        |         |   |   |                    |   |   |    | ABLE |
|--------|----|----|-----------------------------|-----------------------------------------------|----|----|---|--------|---------|---|---|--------------------|---|---|----|------|
| Bit    | 31 | 30 | 29                          | 29 28 27 26 25 24 23 22 21 20 19 18 17 16     |    |    |   |        |         |   |   |                    |   |   | 16 |      |
| Name   |    |    |                             | INT_IRQ_ENABLE                                |    |    |   |        |         |   |   |                    |   |   |    |      |
| Туре   |    |    |                             |                                               |    |    |   | R      | W       |   |   | <b>\rightarrow</b> |   |   |    |      |
| 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   |    |    |                             |                                               |    |    | I | NT_IRQ | _ENABLI | E |   |                    |   |   |    |      |
| Туре   |    |    | RW                          |                                               |    |    |   |        |         |   |   |                    |   |   |    |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                               |    |    |   |        |         |   |   |                    |   |   |    |      |

| Field-Name     | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                           |
|----------------|--------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT_IRQ_ENABLE | [31:0] | R/W  | 32'h0          | IRQ interrupt channel enable One bit for one channel  Write 1 to corresponding bit to enable the corresponding interrupt channel.  Write 0 to any bit is DO NOT CARE. |
|                |        |      |                | Write 1 to corresponding bit in INT_IRQ_DISABLE to clear enable bit.  Read status: 0: related channel is disabled 1: related channel is enabled                       |

## 5.5.5.2.4 INT\_IRQ\_DISABLE

Description: IRQ disable control



| 0x000c |    |                             | IRQ                                       | IRQ disable control (reset 0x0) INT_IRQ_DI |    |    |    |         |        |   |   |   |   |    | Q_DIS | ABLE |
|--------|----|-----------------------------|-------------------------------------------|--------------------------------------------|----|----|----|---------|--------|---|---|---|---|----|-------|------|
| Bit    | 31 | 30                          | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                                            |    |    |    |         |        |   |   |   |   | 16 |       |      |
| Name   |    |                             |                                           |                                            |    |    | I. | NT_IRQ_ | DISABL | E |   |   |   |    |       |      |
| Туре   |    |                             |                                           |                                            |    |    |    | W       | 10     |   |   |   |   |    |       |      |
| 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   |    |                             |                                           |                                            |    |    | 1  | NT_IRQ_ | DISABL | E |   |   |   |    |       |      |
| Туре   |    |                             |                                           |                                            |    |    |    | W       | 10     |   |   |   |   |    |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                           |                                            |    |    |    |         |        |   |   |   |   |    |       |      |

| Field-Name      | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                             |
|-----------------|--------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT_IRQ_DISABLE | [31:0] | WO   | 32'h0          | IRQ interrupt channel disable One bit for one channel  Write 1 to corresponding bit to disable the corresponding interrupt channel.  Write 0 to any bit is DO NOT CARE. |

## 5.5.5.2.5 INT\_IRQ\_SOFT

Description: IRQ software interrupt

| 0x0010 |                           |                         | IRQ s | IRQ software interrupt (reset 0x0) INT_ |    |    |      |       |    |    |    |    |    |    | _IRQ_                    | SOFT             |
|--------|---------------------------|-------------------------|-------|-----------------------------------------|----|----|------|-------|----|----|----|----|----|----|--------------------------|------------------|
| Bit    | 31                        | 30                      | 29    | 28                                      | 27 | 26 | 25   | 24    | 23 | 22 | 21 | 20 | 19 | 18 | 17                       | 16               |
| Name   |                           | Reserved                |       |                                         |    |    |      |       |    |    |    |    |    |    |                          |                  |
| Туре   |                           | 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   |                           |                         |       |                                         |    |    | Rese | erved |    |    |    |    |    |    | INT_<br>IRQ<br>_SO<br>FT | Res<br>erve<br>d |
| Туре   |                           | RO                      |       |                                         |    |    |      |       |    |    |    |    | wo | RO |                          |                  |
| Reset  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |                         |       |                                         |    |    |      |       |    |    | 0  | 0  | 0  |    |                          |                  |

| Field Name   | Bit    | Туре | Reset<br>Value | Description                                                                                               |
|--------------|--------|------|----------------|-----------------------------------------------------------------------------------------------------------|
|              | [31:2] | RO   | 30'h0          | Reserved                                                                                                  |
| INT_IRQ_SOFT | [1]    | WO   | 1'h0           | IRQ software interrupt Write 1 to active the software interrupt. Write 0 to clear the software interrupt. |
|              | [0]    | RO   | 1'h0           | Reserved                                                                                                  |



### 5.5.5.2.6 INT\_IRQ\_TEST\_SRC

Description: Test mode control: source generating

| 0x0014 |    |    | IRQ t                 | est so           | urce g | enerat | ting (re | eset 0x | (0) |    |    |    | INT | _IRQ_ | TEST             | SRC                              |
|--------|----|----|-----------------------|------------------|--------|--------|----------|---------|-----|----|----|----|-----|-------|------------------|----------------------------------|
| Bit    | 31 | 30 | 29                    | 28               | 27     | 26     | 25       | 24      | 23  | 22 | 21 | 20 | 19  | 18    | 17               | 16                               |
| Name   |    |    |                       | INT_IRQ_TEST_SRC |        |        |          |         |     |    |    |    |     |       |                  |                                  |
| Туре   |    |    |                       |                  |        |        |          | R       | W   |    |    |    |     |       |                  |                                  |
| 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   |    |    |                       |                  |        | IN     | T_IRQ_   | TEST_SF | RC  |    |    |    |     |       | Res<br>erve<br>d | INT_<br>IRQ<br>_TE<br>ST_<br>SRC |
| Туре   |    |    | R/W RO                |                  |        |        |          |         |     |    |    |    | R/W |       |                  |                                  |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 |                  |        |        |          |         |     |    |    |    | 0   | 0     | 0                |                                  |

| Field Name       | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                             |
|------------------|--------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT_IRQ_TEST_SRC | [31:0] | R/W  | 32'h0          | IRQ test mode control for source generating One bit for one channel, the bit[1] is reserved. This register is only used in test mode. When INT_IRQ_TEST_SEL is 1, Write 1 to corresponding bit to generate INT_IRQ_RAW_STS. If the corresponding channel is enabled, IRQ to MCU and INT_IRQ_MASK_STS is also generated. |

## 5.5.5.2.7 INT\_IRQ\_TEST\_SEL

Description: Test mode control: test select

| 0x0018 |    |          | IRQ t                   | est se | lect (re | eset 0x | (0) |         |    |    |    |    | IN. | T_IRQ | TEST | _SEL                             |
|--------|----|----------|-------------------------|--------|----------|---------|-----|---------|----|----|----|----|-----|-------|------|----------------------------------|
| Bit    | 31 | 30       | 29                      | 28     | 27       | 26      | 25  | 24      | 23 | 22 | 21 | 20 | 19  | 18    | 17   | 16                               |
| Name   |    | Reserved |                         |        |          |         |     |         |    |    |    |    |     |       |      |                                  |
| Туре   | RO |          |                         |        |          |         |     |         |    |    |    |    |     |       |      |                                  |
| 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   |    |          |                         |        |          |         | -   | Reserve | d  |    |    |    |     |       |      | INT_<br>IRQ<br>_TE<br>ST_<br>SEL |
| Type   |    |          | RO                      |        |          |         |     |         |    |    |    |    |     | R/W   |      |                                  |
| Reset  | 0  | 0        | 0 0 0 0 0 0 0 0 0 0 0 0 |        |          |         |     |         |    |    |    |    |     | 0     |      |                                  |

| Field Name | Bit    | Туре | Reset<br>Value | Description |
|------------|--------|------|----------------|-------------|
|            | [31:1] | RO   | 31'h0          | Reserved    |



| INT_IRQ_TEST_SEL | [0] | R/W | 1'h0                        | IRQ test mode enable                                        |  |  |  |  |
|------------------|-----|-----|-----------------------------|-------------------------------------------------------------|--|--|--|--|
|                  |     |     | Write 1 to enter test mode. |                                                             |  |  |  |  |
|                  |     |     |                             | In normal condition, this register MUST be configured to 0. |  |  |  |  |

### 5.5.5.2.8 INT\_FIQ\_MASK\_STS

Description: FIQ masked status

| 0x0020 |    |                  | FIQ r | FIQ masked status (reset 0x0) INT_FIQ_MASK_ST |    |    |    |         |         |    |    |    |    |    |    | STS |
|--------|----|------------------|-------|-----------------------------------------------|----|----|----|---------|---------|----|----|----|----|----|----|-----|
| Bit    | 31 | 30               | 29    | 28                                            | 27 | 26 | 25 | 24      | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
| Name   |    | INT_FIQ_MASK_STS |       |                                               |    |    |    |         |         |    |    |    |    |    |    |     |
| Туре   |    | 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   |    |                  |       |                                               |    |    | IN | T_FIQ_N | //ASK_S | TS |    |    |    |    |    |     |
| Туре   |    | RO               |       |                                               |    |    |    |         |         |    |    |    |    |    |    |     |
| Reset  | 0  | 0                | 0     | 0                                             | 0  | 0  | 0  | 0       | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0   |

| Field Name       | Bit    | Туре | Reset<br>Value | Description                                                               |
|------------------|--------|------|----------------|---------------------------------------------------------------------------|
| INT_FIQ_MASK_STS | [31:0] | RO   | 32'h0          | FIQ interrupt channel masked status  One bit for one channel  Active high |

## 5.5.5.2.9 INT\_FIQ\_RAW\_STS

Description: FIQ raw status

| 0x0024 |    |           | FIQ raw status (reset 0x0) |                           |    |    |    |         |        |    |    |    | INT_FIQ_RAW_STS |    |    |    |
|--------|----|-----------|----------------------------|---------------------------|----|----|----|---------|--------|----|----|----|-----------------|----|----|----|
| Bit    | 31 | 30        | 29                         | 28                        | 27 | 26 | 25 | 24      | 23     | 22 | 21 | 20 | 19              | 18 | 17 | 16 |
| Name   |    |           |                            | INT_FIQ_RAW_STS           |    |    |    |         |        |    |    |    |                 |    |    |    |
| Туре   |    | $\Lambda$ |                            |                           |    |    |    | R       | 0      |    |    |    |                 |    |    |    |
| 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   |    |           |                            |                           |    |    | 11 | IT_FIQ_ | RAW_ST | rs |    |    |                 |    |    |    |
| Туре   | RO |           |                            |                           |    |    |    |         |        |    |    |    |                 |    |    |    |
| Reset  | 0  | 0         | 0                          | 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |         |        |    |    |    |                 | 0  |    |    |

| Field-Name      | Bit    | Туре | Reset<br>Value | Description                                              |
|-----------------|--------|------|----------------|----------------------------------------------------------|
| INT_FIQ_RAW_STS | [31:0] | RO   | 32'h0          | FIQ interrupt channel raw status One bit for one channel |



## 5.5.5.2.10 INT\_FIQ\_ENABLE

Description: FIQ enable control

| 0x0028 |    |    | FIQ e          | FIQ enable control (reset 0x0) INT_FIQ_ENAB |    |    |    |        |         |    |    |    |    |    | ABLE |    |
|--------|----|----|----------------|---------------------------------------------|----|----|----|--------|---------|----|----|----|----|----|------|----|
| Bit    | 31 | 30 | 29             | 28                                          | 27 | 26 | 25 | 24     | 23      | 22 | 21 | 20 | 19 | 18 | 17   | 16 |
| Name   |    |    | INT_FIQ_ENABLE |                                             |    |    |    |        |         |    |    |    |    |    |      |    |
| Туре   |    |    | 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   |    |    |                |                                             |    |    | ı  | NT_FIQ | _ENABLI | E  |    |    |    |    |      |    |
| Туре   |    |    |                |                                             |    |    |    | R      | W       |    |    |    |    |    | ,    |    |
| Reset  | 0  | 0  | 0              | 0                                           | 0  | 0  | 0  | 0      | 0       | 0  | 0  | 0  | 0  | 0  | 0    | 0  |

| Field-Name     | Description |     |       |                                                                                                                                                                                                                                                                                                                        |
|----------------|-------------|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT_FIQ_ENABLE | [31:0]      | R/W | 32'h0 | FIQ interrupt channel enable One bit for one channel  Write 1 to corresponding bit to enable the corresponding interrupt channel.  Write 0 to any bit is DO NOT CARE.  Write 1 to corresponding bit in INT_FIQ_DISABLE to clear enable bit.  Read status: 0: related channel is disabled 1: related channel is enabled |

## 5.5.5.2.11 INT\_FIQ\_DISABLE

Description: FIQ disable control



| 0x002c |    |    | FIQ c                   | FIQ disable control (reset 0x0)        |    |    |   |         |        |   |   |   |   | INT_FIQ_DISABLE |   |    |  |  |
|--------|----|----|-------------------------|----------------------------------------|----|----|---|---------|--------|---|---|---|---|-----------------|---|----|--|--|
| Bit    | 31 | 30 | 29                      | 29 28 27 26 25 24 23 22 21 20 19 18 17 |    |    |   |         |        |   |   |   |   |                 |   | 16 |  |  |
| Name   |    |    |                         | INT_FIQ_DISABLE                        |    |    |   |         |        |   |   |   |   |                 |   |    |  |  |
| Туре   |    |    |                         | 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   |    |    |                         |                                        |    |    | 1 | NT_FIQ_ | DISABL | E |   |   |   |                 |   |    |  |  |
| Туре   |    |    |                         |                                        |    |    |   | W       | 10     |   |   |   |   |                 |   |    |  |  |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 |                                        |    |    |   |         |        |   |   | 0 | 0 |                 |   |    |  |  |

| Field-Name      | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                             |
|-----------------|--------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT_FIQ_DISABLE | [31:0] | WO   | 32'h0          | FIQ interrupt channel disable One bit for one channel  Write 1 to corresponding bit to disable the corresponding interrupt channel.  Write 0 to any bit is DO NOT CARE. |

## 5.5.5.2.12 INT\_FIQ\_SOFT

Description: FIQ software interrupt

| 0x0030 |    |                           | FIQ s | oftwa                               | re inte | rrupt ( | reset 0 | )x0)  |   |   |   |   |   | INT | NT_FIQ_SOFT              |                  |  |
|--------|----|---------------------------|-------|-------------------------------------|---------|---------|---------|-------|---|---|---|---|---|-----|--------------------------|------------------|--|
| Bit    | 31 | 30                        | 29    | 29 28 27 26 25 24 23 22 21 20 19 18 |         |         |         |       |   |   |   |   |   |     |                          | 16               |  |
| Name   |    |                           |       | Reserved                            |         |         |         |       |   |   |   |   |   |     |                          |                  |  |
| Туре   |    | 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   |    |                           |       |                                     |         |         | Rese    | erved |   |   |   |   |   |     | INT_<br>FIQ_<br>SOF<br>T | Res<br>erve<br>d |  |
| Туре   |    |                           | RO    |                                     |         |         |         |       |   |   |   |   |   |     | wo                       | RO               |  |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |       |                                     |         |         |         |       |   |   |   |   | 0 | 0   | 0                        |                  |  |

| Field Name   | Bit    | Туре | Reset<br>Value | Description                                                                                               |
|--------------|--------|------|----------------|-----------------------------------------------------------------------------------------------------------|
|              | [31:2] | RO   | 30'h0          | Reserved                                                                                                  |
| INT_FIQ_SOFT | [1]    | WO   | 1'h0           | FIQ software interrupt Write 1 to active the software interrupt. Write 0 to clear the software interrupt. |
|              | [0]    | RO   | 1'h0           | Reserved                                                                                                  |



### 5.5.5.2.13 INT\_FIQ\_TEST\_SRC

Description: Test mode control: source generating

| 0x0034 |    |            | FIQ t                         | est so | urce g | enerat | ing (re | set 0x  | 0)     |    |    |    | INT | _FIQ_ | TEST             | SRC                              |
|--------|----|------------|-------------------------------|--------|--------|--------|---------|---------|--------|----|----|----|-----|-------|------------------|----------------------------------|
| Bit    | 31 | 30         | 29                            | 28     | 27     | 26     | 25      | 24      | 23     | 22 | 21 | 20 | 19  | 18    | 17               | 16                               |
| Name   |    |            |                               |        |        |        | IN      | T_FIQ_1 | EST_SF | RC |    |    |     |       |                  |                                  |
| Туре   |    | 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   |    |            |                               |        |        | IN     | T_FIQ_1 | ΓEST_SF | КС     |    |    |    |     | C     | Res<br>erve<br>d | INT_<br>FIQ_<br>TES<br>T_S<br>RC |
| Туре   |    | R/W RO R/W |                               |        |        |        |         |         |        |    |    |    |     |       |                  |                                  |
| Reset  | 0  | 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |        |        |        |         |         |        |    |    |    |     |       |                  |                                  |

| Field Name       | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                             |
|------------------|--------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT_FIQ_TEST_SRC | [31:0] | R/W  | 32'h0          | IRQ test mode control for source generating One bit for one channel, the bit[1] is reserved. This register is only used in test mode. When INT_FIQ_TEST_SEL is 1, Write 1 to corresponding bit to generate INT_FIQ_RAW_STS. If the corresponding channel is enabled, FIQ to MCU and INT_FIQ_MASK_STS is also generated. |

## 5.5.5.2.14 INT\_FIQ\_TEST\_SEL

Description: Test mode control: test select

| 0x0038 |    |                             | FIQ t | est se | lect (re | eset 0x | (0) |          |       |    |    |    | IN. | T_FIQ | TEST | _SEL                             |
|--------|----|-----------------------------|-------|--------|----------|---------|-----|----------|-------|----|----|----|-----|-------|------|----------------------------------|
| Bit    | 31 | 30                          | 29    | 28     | 27       | 26      | 25  | 24       | 23    | 22 | 21 | 20 | 19  | 18    | 17   | 16                               |
| Name   |    |                             |       |        |          |         |     | Rese     | erved |    |    |    |     |       |      |                                  |
| Туре   |    | 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   |    |                             |       |        |          |         | -   | Reserved | d     |    |    |    |     |       |      | INT_<br>FIQ_<br>TES<br>T_S<br>EL |
| Туре   |    | RO                          |       |        |          |         |     |          |       |    |    |    |     | R/W   |      |                                  |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |       |        |          |         |     |          |       |    |    | 0  |     |       |      |                                  |

| Field Name | Bit    | Туре | Reset<br>Value | Description |
|------------|--------|------|----------------|-------------|
|            | [31:1] | RO   | 31'h0          | Reserved    |



| INT_FIQ_TEST_SEL | [0] | R/W | 1'h0 | FIQ test mode enable                                        |
|------------------|-----|-----|------|-------------------------------------------------------------|
|                  |     |     |      | Write 1 to enter test mode.                                 |
|                  |     |     |      | In normal condition, this register MUST be configured to 0. |

### 5.5.6 Application Notes

Interrupt Control's PCLK is open by default, so Software needs not to enable any bit and can access the register directly.

For IRQ and FIQ, the most important function is in the 30 hardware channel. They are connected to different hardware module. **Make sure that all the hardware modules' interrupt is level triggering, and triggering level is active high.** Once interrupt is generated, it should kept high until software clear it by setting interrupt clear bit in corresponding module. Following is the recommended flow for hardware channels.



#### 5.6 AXI Bus Monitor

#### 5.6.1 Overview

In SC6820, CPU and GPU access EMC through AXI interface. These two AXI interfaces share one bus monitor, we can set register to select one of them to monitor. Bus monitor could monitor the bus access on the AXI interface and provide the interrupts when a target reading from or writing to a target address. Only CHN\_INT register(0x00) could be cleared after reset, other registers would not be effected by reset.

#### 5.6.2 Features

SC6820 AXI bus monitor supports the following features:

- I Support AMBA AXI bus Read and Write monitoring;
- I Support AXI byte/half-word/word access monitoring;
- I Support AXI ID monitoring;
- I Support AXI burst type monitoring;
- I Support AXI burst length monitoring;
- I Support AXI WSTRB monitoring
- I Support AXI 64-bit data bus monitoring, by 64-bit data mask;



- I Support AXI 32-bit address space monitoring, for any address between minimal and maximum setting;
- I Support interrupt raw/mask status and interrupt enable;
- I Support triggered ADDR/DATA/SIZE/BURST/LEN/ID/WSTRB status.
- I Support limited multiple outstanding as EMC, 4 for read and 8 for write

## 5.6.3 Signal Description

## 5.6.4 Function Description

## 5.6.5 Control Registers

#### 5.6.5.1 Control Register Address Map

ARM base address: 0x20A0\_0000

| Offset<br>Address | Register Name | Register Description                       |
|-------------------|---------------|--------------------------------------------|
| 0x0~0x3           | CHN_INT       | Channel interrupt configure.               |
| 0x4~0x7           | CHN_CFG       | AXI feature configure                      |
| 0x8~0xB           | ADDR_MIN      | Minimum address for monitoring.            |
| 0xC~0xF           | ADDR_MAX      | Maximum address for monitoring.            |
| 0x10~0x13         | DATA_MIN_L32  | Minimum data for monitoring, low 32bit     |
| 0x14~0x17         | DATA_MAX_L32  | Maximum data for monitoring. Low 32bit     |
| 0x18~0x1b         | DATA_MASK_L32 | Data mask for monitoring. Low 32bit        |
| 0x1C~0x1F         | MATCH_ADDR    | Matched address which triggered interrupt. |
| 0x20~0x27         | MATCH_DATA    | Matched data which triggered interrupt.    |
| 0x28~0x2B         | DATA_MIN_H32  | Minimum data for monitoring, high 32bit    |
| 0x2C~0x2F         | DATA_MAX_H32  | Maximum data for monitoring. high 32bit    |
| 0x30~0x33         | DATA_MASK_H32 | Data mask for monitoring. high 32bit       |

## 5.6.5.2 Register Descriptions

### 5.6.5.2.1 CHN\_INT



| 0x0000 |                                 |                                | . (Re       | set to     | 0x0000 | 0000 | )     |    |       |        |       |         | CHN_INT   |              |            |    |  |
|--------|---------------------------------|--------------------------------|-------------|------------|--------|------|-------|----|-------|--------|-------|---------|-----------|--------------|------------|----|--|
| Bit    | 31                              | 30                             | 29          | 28         | 27     | 26   | 25    | 24 | 23    | 22     | 21    | 20      | 19        | 18           | 17         | 16 |  |
| Name   | INT_<br>MAS<br>K_S<br>TAT<br>US | INT_<br>RA<br>W_S<br>TAT<br>US | INT_<br>CLR | INT_<br>EN |        | Rese | rved. |    | Match | n_size | Match | n_burst | Match_len |              |            |    |  |
| Туре   | RO                              | RO                             | wo          | RW         | 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   |                                 |                                |             | Match      | n_strb |      |       |    |       | Mato   | ch_id |         |           | rese<br>rved | CHN<br>_EN |    |  |
| Type   |                                 |                                |             |            |        |      | R     | .0 |       |        |       |         |           |              | RO         | RW |  |
| Reset  | 0                               | 0                              | 0           | 0          | 0      | 0    | 0     | 0  | 0     | 0      | 0     | 0       | 0         | 0            | 0          | 0  |  |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                                                     |
|-----------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------|
| INT_MASK_STATUS | [31]    | RO   | ʻb0            | Interrupt Mask status and should be cleared by asserting INT_CLR; Only would be active when INT_EN active high. |
| INT_RAW_STATUS  | [30]    | RO   | 'b0            | Interrupt raw status and should be cleared by asserting INT_CLR;                                                |
| INT_CLR         | [29]    | WO   | 'b0            | Writing "1" to this bit will clear the interrupt raw status;                                                    |
| INT_EN          | [28]    | RW   | ,p0            | 0 : By default, disable busmon interrupt; 1 : Enable busmon interrupt;                                          |
| Reserved        | [27:24] | RO   | 'b0            | Reserved.                                                                                                       |
| MATCH_SIZE      | [23:22] | RO   | 'b0            | AXI size of the matched transaction                                                                             |
| MATCH_BURST     | [21:20] | RO   | 'b0            | AXI Burst type of the matched transaction                                                                       |
| MATCH_LEN       | [19:16] | RO   | 'b0            | AXI Burst length of the matched transaction                                                                     |
| MATCH_STRB      | [15:8]  | RO   | 'b0            | AXI Write strobe of the matched transaction                                                                     |
| MATCH_ID        | [7:2]   | RO   | 'b0            | AXI transaction ID of the matched transaction                                                                   |
| Reserved.       | [1]     | RO   | 'b0            | Reserved.                                                                                                       |
| CHN_EN          | [0]     | RW   | ʻb0            | Channel enable: 0: by default, disable bus monitor; 1: Enable bus monitor;                                      |

# 5.6.5.2.2 CHN\_CFG



| 0x0004 |    |       | . (Re | set to    | 0x0000 | 0000     | )  |                   |    |         |    |             |                  |       | CHN               | CFG              |
|--------|----|-------|-------|-----------|--------|----------|----|-------------------|----|---------|----|-------------|------------------|-------|-------------------|------------------|
| Bit    | 31 | 30    | 29    | 28        | 27     | 26       | 25 | 24                | 23 | 22      | 21 | 20          | 19               | 18    | 17                | 16               |
| Name   |    |       |       | Reserved. |        |          |    |                   |    |         |    | ВІ          | BUR<br>ST_<br>EN |       |                   |                  |
| Туре   |    |       |       | RO        |        |          |    |                   |    |         |    |             | 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   |    | MASTE | R_CFG |           | F      | Reserved | l. | MAS<br>TER<br>_EN | S  | SIZE_CF | G  | SIZE<br>_EN | Rese             | erved | WRI<br>TE_<br>CFG | WRI<br>TE_<br>EN |
| Type   |    | R'    | W     |           |        | RO       |    | RW                |    | RW      |    | RW          | R                | W     | RW                | RW               |
| Reset  | 0  | 0     | 0     | 0         | 0      | 0        | 0  | 0                 | 0  | 0       | 0  | 0           | 0                | 0     | 0                 | 0                |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                               |
|------------|---------|------|----------------|-------------------------------------------------------------------------------------------|
| WSTRB_CFG  | [31:24] | RW   | 'b0            | AXI WSTRB monitoring                                                                      |
| LEN_CFG    | [23:20] | RW   | 'b0            | AXI burst length monitoring                                                               |
| LEN_EN     | [19]    | RW   | ʻb0            | AXI burst length monitoring enable 0: Disable ALEN monitoring 0: Enable ALEN monitoring   |
| BURST_CFG  | [18:17] | RW   | 'b0            | AXI BURST monitoring: 2'b00 : Fixed 2'b01 : INCR; 2'b10 : WRAP; 2;b11 : Reserved          |
| BURST_EN   | [16]    | RW   | ʻb0            | HBURST type monitoring enable: 0 : Disable BURST monitoring; 1 : Enable BURST monitoring; |
| ID_CFG     | [15:10] | RW   | 'b0            | AXI ID monitoring                                                                         |
| ID_EN      | [9]     | RW   | 'b0            | AXI ID monitoring enable                                                                  |
| STRB_EN    | [8]     | RW   | 'b0            | AXI WSTRB monitoring enable                                                               |
| SIZE_CFG   | [7:5]   | RW   | 'b0            | AHB HSIZE monitoring: 000: Byte; 001: Half-word; 010: Word; Others: reserved.             |
| SIZE_EN    | [4]     | RW   | 'b0            | HSIZE type monitoring enable; 0: Disable HSIZE monitoring; 1: Enable HSIZE monitoring;    |



| Reserved  | [3:2] | RW | 'b0 | Reserved                                                                                        |
|-----------|-------|----|-----|-------------------------------------------------------------------------------------------------|
| WRITE_CFG | [1]   | RW | 'b0 | HWRITE for monitoring: 0: HWRITE = 1'b0, read transaction; 1: HWRITE = 1'b1, write transaction; |
| WRITE_EN  | [0]   | RW | 'b0 | HWRITE type monitoring enable; 0 : Dis-able HWRITE monitoring; 1 : Enable HWRITE monitoring;    |

## 5.6.5.2.3 ADDR\_MIN

## Description:

| 0x0008 |    |    | . (Re | set to | 0x0000 | _0000 | )  |      |       |    |    |    |    |    | ADDR | _MIN |
|--------|----|----|-------|--------|--------|-------|----|------|-------|----|----|----|----|----|------|------|
| Bit    | 31 | 30 | 29    | 28     | 27     | 26    | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    |    |       |        |        |       |    | ADDF | R_MIN |    |    |    |    |    |      |      |
| Туре   |    |    |       |        |        |       |    | R    | W     |    |    |    |    |    |      |      |
| 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   |    |    |       |        |        |       |    | ADDF | R_MIN |    |    |    |    |    |      |      |
| Туре   |    |    | RW    |        |        |       |    |      |       |    |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0     | 0      | 0      | 0     | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0    | 0    |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                             |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------|
| ADDR_MIN   | [31: 0] | RW   | 'b0            | AHB minimal address for monitoring; Any access between Max and Min address space may trigger interrupt; |

## 5.6.5.2.4 ADDR\_MAX

| 0x000C |    |    | . (Re | set to | 0x0000 | 0000 | )  |      |      |    |    |    |    | -  | ADDR_MAX |    |  |
|--------|----|----|-------|--------|--------|------|----|------|------|----|----|----|----|----|----------|----|--|
| Bit    | 31 | 30 | 29    | 28     | 27     | 26   | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17       | 16 |  |
| Name   |    |    |       |        |        |      |    | ADDR | _MAX |    |    |    |    |    |          |    |  |
| Туре   |    |    |       |        |        |      |    | R    | W    |    |    |    |    |    |          |    |  |
| 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   |    |    |       |        |        |      |    | ADDR | _MAX |    |    |    |    |    |          |    |  |
| Туре   |    |    | RW    |        |        |      |    |      |      |    |    |    |    |    |          |    |  |
| Reset  | 0  | 0  | 0     | 0      | 0      | 0    | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0        | 0  |  |

| Field Name | Bit | Туре | Reset<br>Value | Description |
|------------|-----|------|----------------|-------------|
|            |     |      | value          |             |



| ADDR_MAX | [31: 0] | RW | 'b0 | AHB maxium address for monitoring;                                  |
|----------|---------|----|-----|---------------------------------------------------------------------|
|          |         |    |     | Any access between Max and Min address space may trigger interrupt; |

## 5.6.5.2.5 DATA\_MIN\_L32

## Description:

| 0x0010 |    |    | . (Re | set to | 0x0000 | _0000 | )  |      |      |    |    |    |    |    | DATA | _MIN |
|--------|----|----|-------|--------|--------|-------|----|------|------|----|----|----|----|----|------|------|
| Bit    | 31 | 30 | 29    | 28     | 27     | 26    | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    |    |       |        |        |       |    | DATA | _MIN |    |    |    |    |    |      |      |
| Туре   |    |    |       |        |        |       |    | R    | W    |    |    |    |    |    |      |      |
| 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   |    |    |       |        |        |       |    | DATA | _MIN |    |    |    |    |    |      |      |
| Туре   |    |    | RW    |        |        |       |    |      |      |    |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0     | 0      | 0      | 0     | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0    | 0    |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                                                                        |
|--------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------|
| DATA_MIN_L32 | [31: 0] | RW   | 'b0            | AHB minimal DATA for monitoring, low 32 bit<br>Any access between Max and Min data space<br>may trigger interrupt; |

### 5.6.5.2.6 DATA\_MAX\_L32

| 0x0014 |    |    | . (Re | set to | 0x0000 | 0000 | )  |      |      |    |    |    |    |    | DATA_ | MAX |
|--------|----|----|-------|--------|--------|------|----|------|------|----|----|----|----|----|-------|-----|
| Bit    | 31 | 30 | 29    | 28     | 27     | 26   | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17    | 16  |
| Name   |    |    |       |        |        |      |    | DATA | _MAX |    |    |    |    |    |       |     |
| Туре   |    |    |       |        |        |      |    | R    | W    |    |    |    |    |    |       |     |
| 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   |    |    |       |        |        |      |    | DATA | _MAX |    |    |    |    |    |       |     |
| Туре   |    |    | RW    |        |        |      |    |      |      |    |    |    |    |    |       |     |
| Reset  | 0  | 0  | 0     | 0      | 0      | 0    | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0     | 0   |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                                                                 |
|--------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------|
| DATA_MAX_L32 | [31: 0] | RW   | ʻb0            | AHB maxium Data for monitoring, low 32 bit Any access between Max and Min Data space may trigger interrupt; |



## 5.6.5.2.7 DATA\_MASK\_L32

## Description:

| 0x0018 |    |    | . (Re | set to | 0x0000 | 0000 | )  |       |      |    |    |    |    | D. | ATA_N | //ASK |
|--------|----|----|-------|--------|--------|------|----|-------|------|----|----|----|----|----|-------|-------|
| Bit    | 31 | 30 | 29    | 28     | 27     | 26   | 25 | 24    | 23   | 22 | 21 | 20 | 19 | 18 | 17    | 16    |
| Name   |    |    |       |        |        |      |    | DATA_ | MASK |    |    |    |    |    |       | X     |
| Туре   |    |    |       |        |        |      |    | R     | W    |    |    |    |    |    |       |       |
| 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   |    |    |       |        |        |      |    | DATA_ | MASK |    |    |    |    | 37 |       |       |
| Туре   |    | RW |       |        |        |      |    |       |      |    |    |    |    |    |       |       |
| Reset  | 0  | 0  | 0     | 0      | 0      | 0    | 0  | 0     | 0    | 0  | 0  | 0  | 0  | 0  | 0     | 0     |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                            |
|---------------|---------|------|----------------|------------------------------------------------------------------------------------------------------------------------|
| DATA_MASK_L32 | [31: 0] | RW   | 'b0            | Data_mask, active high makes the data of corresponding bits to be masked, and ignored during comparation. , low 32 bit |

### 5.6.5.2.8 **MATCH\_ADDR**

## Description:

| 0x001C |    |    | . (Re                     | set to     | 0x0000 | 0000 | )  | ~     |       |    |    |    |    | MA | TCH_A | ADDR |
|--------|----|----|---------------------------|------------|--------|------|----|-------|-------|----|----|----|----|----|-------|------|
| Bit    | 31 | 30 | 29                        | 28         | 27     | 26   | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
| Name   |    |    |                           | MATCH_ADDR |        |      |    |       |       |    |    |    |    |    |       |      |
| Туре   |    |    |                           | 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   |    |    |                           |            |        |      |    | MATCH | _ADDR |    |    |    |    |    |       |      |
| Туре   |    |    | RO                        |            |        |      |    |       |       |    |    |    |    |    |       |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |            |        |      |    |       |       |    |    |    |    |    |       |      |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                  |
|------------|---------|------|----------------|----------------------------------------------|
| MATCH_ADDR | [31: 0] | RO   | 'b0            | Captured Address, which triggered interrupt; |

## 5.6.5.2.9 MATCH\_DATA\_L32



| 0x0020 |    |    | . (Re                       | set to     | 0x0000 | 0000_ | )  |       |        |    |    |    |    | MA | TCH_[ | DATA |
|--------|----|----|-----------------------------|------------|--------|-------|----|-------|--------|----|----|----|----|----|-------|------|
| Bit    | 31 | 30 | 29                          | 28         | 27     | 26    | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
| Name   |    |    |                             | MATCH_DATA |        |       |    |       |        |    |    |    |    |    |       |      |
| Туре   |    |    |                             | 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   |    |    |                             |            |        |       |    | MATCH | I_DATA |    |    |    |    |    |       |      |
| Туре   |    |    | RO                          |            |        |       |    |       |        |    |    |    |    |    |       |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |            |        |       |    |       |        |    |    |    |    |    |       |      |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                          |
|----------------|---------|------|----------------|------------------------------------------------------|
| MATCH_DATA_L32 | [31: 0] | RO   | 'b0            | Captured Data, which triggered interrupt; low 32 bit |

### 5.6.5.2.10 MATCH\_DATA\_H32

Description:

| 0x0024 |    |                             | . (Re | set to | 0x0000 | 0000 | )  |       | 1      |    |    |    |    | BUS | SMON | CNT |
|--------|----|-----------------------------|-------|--------|--------|------|----|-------|--------|----|----|----|----|-----|------|-----|
| Bit    | 31 | 30                          | 29    | 28     | 27     | 26   | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18  | 17   | 16  |
| Name   |    |                             |       |        |        |      |    | MATCH | LDATA  |    |    |    |    |     |      |     |
| Туре   |    | 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   |    |                             |       |        |        |      |    | MATCH | I_DATA |    |    |    |    |     |      |     |
| Туре   | RO |                             |       |        |        |      |    |       |        |    |    |    |    |     |      |     |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |       |        |        |      |    |       |        |    |    |    |    |     |      |     |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                           |
|----------------|---------|------|----------------|-------------------------------------------------------|
| MATCH_DATA_H32 | [31: 0] | RO   | 'b0            | Captured Data, which triggered interrupt; high 32 bit |

# 5.6.5.2.11 DATA\_MIN\_H32



| 0x0010 |    |    | . (Re                     | set to | 0x0000 | 0000 | )  |      |      |    |    |    |    |    | DATA | _MIN |
|--------|----|----|---------------------------|--------|--------|------|----|------|------|----|----|----|----|----|------|------|
| Bit    | 31 | 30 | 29                        | 28     | 27     | 26   | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    |    |                           |        |        |      |    | DATA | _MIN |    |    |    |    |    |      |      |
| Туре   |    |    |                           | 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   |    |    |                           |        |        |      |    | DATA | _MIN |    |    |    |    |    |      |      |
| Туре   |    |    | RW                        |        |        |      |    |      |      |    |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |        |        |      |    |      |      |    |    |    |    |    |      |      |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                      |
|--------------|---------|------|----------------|------------------------------------------------------------------|
| DATA_MIN_H32 | [31: 0] | RW   | 'b0            | AHB minimal DATA for monitoring, high 32 bit                     |
|              |         |      |                | Any access between Max and Min data space may trigger interrupt; |

### 5.6.5.2.12 DATA\_MAX\_H32

## Description:

| 0x0014 |    |                               | . (Res | set to | 0x0000 |    | DATA_MA |      |      |    |    |    |    |    |    |    |
|--------|----|-------------------------------|--------|--------|--------|----|---------|------|------|----|----|----|----|----|----|----|
| Bit    | 31 | 30                            | 29     | 28     | 27     | 26 | 25      | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |    |                               |        |        |        |    |         | DATA | _MAX |    |    |    |    |    |    |    |
| Туре   |    | 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   |    |                               |        | 7      |        |    |         | DATA | _MAX |    |    |    |    |    |    |    |
| Туре   | RW |                               |        |        |        |    |         |      |      |    |    |    |    |    |    |    |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0   |        |        |        |    |         |      |      |    |    |    |    |    |    |    |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                                                                  |
|--------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------|
| DATA_MAX_H32 | [31: 0] | RW   | 'b0            | AHB maxium Data for monitoring, high 32 bit Any access between Max and Min Data space may trigger interrupt; |

# 5.6.5.2.13 DATA\_MASK\_H32



| 0x0018 |    |    | . (Re                           | set to    | 0x0000 | _0000 | )  |       |      |    |    |    |    | D  | ATA_N | MASK |
|--------|----|----|---------------------------------|-----------|--------|-------|----|-------|------|----|----|----|----|----|-------|------|
| Bit    | 31 | 30 | 29                              | 28        | 27     | 26    | 25 | 24    | 23   | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
| Name   |    |    |                                 | DATA_MASK |        |       |    |       |      |    |    |    |    |    |       |      |
| Туре   |    |    |                                 | 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   |    |    |                                 |           |        |       |    | DATA_ | MASK |    |    |    |    |    |       |      |
| Туре   |    |    | RW                              |           |        |       |    |       |      |    |    |    |    |    |       |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |           |        |       |    |       |      |    |    |    |    |    |       |      |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                            |
|---------------|---------|------|----------------|------------------------------------------------------------------------------------------------------------------------|
| DATA_MASK_H32 | [31: 0] | RW   | 'b0            | Data_mask, active high makes the data of corresponding bits to be masked, and ignored during comparation. ,high 32 bit |

#### 5.6.6 Application Note

SW programming is almost the same as AHB bus monitor. The most important difference is that the bus monitor do not support dynamically on/off because AXI address and data is in separate channel and multiple outstanding is enabled. So the bus monitor should always be on if we want to monitor AXI transaction. The other thing is that we can set register axibusmon\_sel(0x2090\_020C, bit11) to select one of them to monitor. (1: select GPU, 0:select CPU).

## 5.7 AHB Bus Monitor

#### 5.7.1 Overview

SC6820 contains multi-layer AHB bus, and each layer contains AHB masters and slaves. Bus monitors could monitor the bus access and provide the interrupts when a target data reading from or writing to a target address. Only CHN\_INT register(0x00) could be cleared after reset, other registers would not be effected by reset.

Besides, bus monitors provide the bus usage to analyze system performance.

#### 5.7.2 Features

SC6820 bus monitor supports the following features:

- I Support AMBA AHB bus Read and Write monitoring;
- I Support AHB byte/half-word/word access monitoring;
- I Support AHB 32-bit data bus monitoring, by 32-bit data mask;
- I Support AHB 32-bit address space monitoring, for any address between minimal and maximum setting;
- I Support interrupt raw/mask status and interrupt enable;
- I Support triggered HADDR/HDATA/HSIZE/HBURST status.



## **5.7.3 Bus Monitor Assignment**

SC6820 contains 7 AHB masters and 2 ARM side bus monitors, that is, only 2 AHB masters can be monitored at a given time. The bus monitors assignment is illustrated below.

Table 5-4 Bus Monitor Assignment

| Busmon Num   | Busmon0/1_sel = 0                         | Busmon0/1/_sel = 1                  |
|--------------|-------------------------------------------|-------------------------------------|
| Bus Monitor0 | A5 AHB master                             | Empty                               |
| Bus Monitor1 | DMAR/DMAW/SDIO/USB/CEVAX access to others | DMAR/DMAW/SDIO/USB/CEVAacess to EMC |

# 5.7.4 Control Registers

### 5.7.4.1 Memory Map

ARM base address: 0x2040\_0000 + 0x0000\_1000 \* N (N= 0, 1, Busmon Num)

| Offset<br>Address | Register Name | Register Description                       |
|-------------------|---------------|--------------------------------------------|
| 0x0000            | CHN_INT       | Channel interrupt configure.               |
| 0x0004            | CHN_CFG       | AHB feature configure.                     |
| 0x0008            | ADDR_MIN      | Minimum address for monitoring.            |
| 0x000C            | ADDR_MAX      | Maximum address for monitoring.            |
| 0x0010            | DATA_MIN      | Minimum data for monitoring.               |
| 0x0014            | DATA_MAX      | Maximum data for monitoring.               |
| 0x0018            | DATA_MASK     | Data mask for monitoring.                  |
| 0x001C            | MATCH_ADDR    | Matched address which triggered interrupt. |
| 0x0020            | MATCH_DATA    | Matched data which triggered interrupt.    |
| 0x0024            | BUSMON_CNT    | Performance counter.                       |

### 5.7.4.2 Register Descriptions

#### 5.7.4.2.1 CHN\_INT



| 0x0000 |                                 |                                | . (Re       | set to     | 0x0000 | 0000                                                                                                             | ) |   |   |   |     |      |                 |                  | CHI        | N_INT      |
|--------|---------------------------------|--------------------------------|-------------|------------|--------|------------------------------------------------------------------------------------------------------------------|---|---|---|---|-----|------|-----------------|------------------|------------|------------|
| Bit    | 31                              | 30                             | 29          | 28         | 27     | 27         26         25         24         23         22         21         20         19         18         17 |   |   |   |   |     |      |                 |                  | 16         |            |
| Name   | INT_<br>MAS<br>K_S<br>TAT<br>US | INT_<br>RA<br>W_S<br>TAT<br>US | INT_<br>CLR | INT_<br>EN |        | Reserved.                                                                                                        |   |   |   |   |     |      |                 |                  |            |            |
| Туре   | RO                              | RO                             | WO          | RW         |        | 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   |                                 |                                |             |            | Rese   | erved.                                                                                                           |   |   |   |   | CNT | _SEL | CNT<br>_CL<br>R | CNT<br>_HO<br>LD | CNT<br>_EN | CHN<br>_EN |
| Туре   |                                 |                                |             |            | R      | 0                                                                                                                |   |   |   |   | R   | W    | wo              | RW               | RW         | RW         |
| Reset  | 0                               | 0                              | 0           | 0          | 0      | 0                                                                                                                | 0 | 0 | 0 | 0 | 0   | 0    | 0               | 0                | 0          | 0          |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                                                                                                                    |
|-----------------|--------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------|
| INT_MASK_STATUS | [31]   | RO   | 'b0            | Interrupt Mask status and should be cleared by asserting INT_CLR; Only would be active when INT_EN active high.                |
| INT_RAW_STATUS  | [30]   | RO   | 'b0            | Interrupt raw status and should be cleared by asserting INT_CLR;                                                               |
| INT_CLR         | [29]   | WO   | 'b0            | Writing "1" to this bit will clear the interrupt raw status;                                                                   |
| INT_EN          | [28]   | RW   | 'b0            | 0 : By default, disable busmon interrupt; 1 : Enable busmon interrupt;                                                         |
|                 | [27:6] | RO   | ,p0            | Reserved.                                                                                                                      |
| CNT_SEL         | [5:4]  | RW   | 'b0            | Counter type as following: 2'b00: Busmon Enable; 2'b01: AHB Transcation; 2'b10: AHB Transcation with HREADY; 2'b11: Data Size; |
| CNT_CLR         | [3]    | RW   | 'b0            | Busmon Cnt clear, writing "1" to this bit will clear busmon cnt to zero;                                                       |
| CNT_HOLD        | [2]    | RW   | 'b0            | Transaction Counter hold, active HIGH will hold the counter;                                                                   |
| CNT_EN          | [1]    | RW   | ʻb0            | Transaction Counter Enable; 0 : Disable counter; 1 : Enable counter;                                                           |
| CHN_EN          | [0]    | RW   | ʻb0            | Channel enable: 0: by default, disable bus monitor; 1: Enable bus monitor;                                                     |

## 5.7.4.2.2 CHN\_CFG



| 0x0004 |    |           | . (Re | set to                              | 0x0000 | _0000    | )  |                   |   |         |   |             |                  |       | CHN               | _CFG             |
|--------|----|-----------|-------|-------------------------------------|--------|----------|----|-------------------|---|---------|---|-------------|------------------|-------|-------------------|------------------|
| Bit    | 31 | 30        | 29    | 29 28 27 26 25 24 23 22 21 20 19 18 |        |          |    |                   |   |         |   |             | 17               | 16    |                   |                  |
| Name   |    | Reserved. |       |                                     |        |          |    |                   |   |         |   | ВІ          | BUR<br>ST_<br>EN |       |                   |                  |
| Туре   |    |           |       |                                     |        | R        | 0  |                   |   |         |   |             |                  |       | RW                |                  |
| 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   |    | MASTE     | R_CFG |                                     | F      | Reserved | l. | MAS<br>TER<br>_EN | S | SIZE_CF | G | SIZE<br>_EN | Rese             | erved | WRI<br>TE_<br>CFG | WRI<br>TE_<br>EN |
| Туре   |    | R         | W     |                                     |        | RO       |    |                   |   | RW      |   | RW          | R                | W     | RW                | RW               |
| Reset  | 0  | 0         | 0     | 0                                   | 0      | 0        | 0  | 0                 | 0 | 0       | 0 | 0           | 0                | 0     | 0                 | 0                |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                             |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:20] | RO   | 'b0            | Reserved.                                                                                                                                               |
| BURST_CFG  | [19:17] | RW   | 'b0            | AHB HBURST definition: 3'b000 : Single; 3'b001 : INCR; 3'b010 : WRAP4; 3;b011 : INCR4; 3'b100 : WRAP8; 3'b101 : INCR8; 3'b101 : INCR8; 3'b111 : INCR16; |
| BURST_EN   | [16]    | RW   | 'b0            | HBURST type monitoring enable: 0 : Disable HBURST monitoring; 1 : Enable HBURST monitoring;                                                             |
| MASTER_CFG | [15:12] | RW   | 'b0            | HMASTER.                                                                                                                                                |
|            | [11:9]  | RO   | 'b0            | Reserved.                                                                                                                                               |
| MASTER_EN  | [8]     | RW   | 'b0            | AHB Hmaster enable, Must be set as default 0.                                                                                                           |
| SIZE_CFG   | [7:5]   | RW   | 'b0            | AHB HSIZE monitoring: 000: Byte; 001: Half-word; 010: Word; Others: reserved.                                                                           |
| SIZE_EN    | [4]     | RW   | 'b0            | HSIZE type monitoring enable; 0: Disable HSIZE monitoring; 1: Enable HSIZE monitoring;                                                                  |
|            | [3:2]   | RW   | 'b0            | Reserved                                                                                                                                                |
| WRITE_CFG  | [1]     | RW   | 'b0            | HWRITE for monitoring:                                                                                                                                  |



|          |     |    |     | 0 : HWRITE = 1'b0, read transaction;<br>1: HWRITE = 1'b1, write transaction;               |
|----------|-----|----|-----|--------------------------------------------------------------------------------------------|
| WRITE_EN | [0] | RW | 'b0 | HWRITE type monitoring enable; 0: Dis-able HWRITE monitoring; 1: Enable HWRITE monitoring; |

### 5.7.4.2.3 ADDR\_MIN

## Description:

| 0x0008 |    |          | . (Re | set to | 0x0000 | 0000 | )  |      |       |    |    |    |    |    | ADDR | _MIN |
|--------|----|----------|-------|--------|--------|------|----|------|-------|----|----|----|----|----|------|------|
| Bit    | 31 | 30       | 29    | 28     | 27     | 26   | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    | ADDR_MIN |       |        |        |      |    |      |       |    |    |    |    |    |      |      |
| Туре   |    | 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   |    |          |       |        |        |      |    | ADDF | R_MIN |    | 4  |    |    |    |      |      |
| Туре   |    |          | RW    |        |        |      |    |      |       |    |    |    |    |    |      |      |
| Reset  | 0  | 0        | 0     | 0      | 0      | 0    | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0    | 0    |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                             |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------|
| ADDR_MIN   | [31: 0] | RW   | ʻb0            | AHB minimal address for monitoring; Any access between Max and Min address space may trigger interrupt; |

# 5.7.4.2.4 ADDR\_MAX

| 0x000C |    |    | . (Re | set to                                   | 0x0000 | 0000 | ) |   |   |   |   |   | ADDR_MAX |    |   |   |
|--------|----|----|-------|------------------------------------------|--------|------|---|---|---|---|---|---|----------|----|---|---|
| Bit    | 31 | 30 | 29    | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |      |   |   |   |   |   |   |          | 16 |   |   |
| Name   |    |    |       | ADDR_MAX                                 |        |      |   |   |   |   |   |   |          |    |   |   |
| Туре   |    | U  |       | 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   |    |    |       | ADDR_MAX                                 |        |      |   |   |   |   |   |   |          |    |   |   |
| Type   |    |    | RW    |                                          |        |      |   |   |   |   |   |   |          |    |   |   |
| Reset  | 0  | 0  | 0     | 0                                        | 0      | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0        | 0  | 0 | 0 |

| Field Name | Bit     | Туре | Reset<br>Value | Description                        |
|------------|---------|------|----------------|------------------------------------|
| ADDR_MAX   | [31: 0] | RW   | 'b0            | AHB maxium address for monitoring; |



|  |  | Any access between Max and Min address |
|--|--|----------------------------------------|
|  |  | space may trigger interrupt;           |

### 5.7.4.2.5 DATA\_MIN

## Description:

| 0x0010 |    |    | . (Re | set to | 0x0000 | _0000 | )  |      |      |    |    |    |    |    | DATA     | _MIN |
|--------|----|----|-------|--------|--------|-------|----|------|------|----|----|----|----|----|----------|------|
| Bit    | 31 | 30 | 29    | 28     | 27     | 26    | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17       | 16   |
| Name   |    |    |       |        |        |       |    | DATA | _MIN |    |    |    |    |    | <b>\</b> |      |
| Туре   |    |    |       | 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   |    |    |       |        |        |       |    | DATA | _MIN |    |    |    |    |    |          |      |
| Туре   |    |    | RW    |        |        |       |    |      |      |    |    |    |    |    |          |      |
| Reset  | 0  | 0  | 0     | 0      | 0      | 0     | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0        | 0    |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                       |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------|
| DATA_MIN   | [31: 0] | RW   | 'b0            | AHB minimal DATA for monitoring; Any access between Max and Min data space may trigger interrupt; |

### 5.7.4.2.6 DATA\_MAX

| 0x0014 |               |    | . (Re | set to                    | 0x0000 | 0000 | )  |      |      |    |    |    |    | I  | DATA_ | MAX |
|--------|---------------|----|-------|---------------------------|--------|------|----|------|------|----|----|----|----|----|-------|-----|
| Bit    | 31            | 30 | 29    | 28                        | 27     | 26   | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17    | 16  |
| Name   |               |    | X     |                           |        |      |    | DATA | _MAX |    |    |    |    |    |       |     |
| Туре   |               |    |       | RW                        |        |      |    |      |      |    |    |    |    |    |       |     |
| 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>&gt;</b> . |    |       |                           |        |      |    | DATA | _MAX |    |    |    |    |    |       |     |
| Туре   |               |    | RW    |                           |        |      |    |      |      |    |    |    |    |    |       |     |
| Reset  | 0             | 0  | 0     | 0                         | 0      | 0    | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0     | 0   |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                      |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------------|
| DATA_MAX   | [31: 0] | RW   | 'b0            | AHB maxium Data for monitoring; Any access between Max and Min Data space may trigger interrupt; |



### 5.7.4.2.7 **DATA\_MASK**

## Description:

| 0x0018 |    |    | . (Re | set to | 0x0000 | 0000 | )  |       |      |    |    |    |    | D. | ATA_N | MASK |
|--------|----|----|-------|--------|--------|------|----|-------|------|----|----|----|----|----|-------|------|
| Bit    | 31 | 30 | 29    | 28     | 27     | 26   | 25 | 24    | 23   | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
| Name   |    |    |       |        |        |      |    | DATA_ | MASK |    |    |    |    |    |       |      |
| Туре   |    |    |       | 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   |    |    |       |        |        |      |    | DATA_ | MASK |    |    |    |    |    |       |      |
| Туре   |    |    |       | RW     |        |      |    |       |      |    |    |    |    |    |       |      |
| Reset  | 0  | 0  | 0     | 0      | 0      | 0    | 0  | 0     | 0    | 0  | 0  | 0  | 0  | 0  | 0     | 0    |

| Field Name | Bit     | Туре | Reset<br>Value | Description |
|------------|---------|------|----------------|-------------|
| DATA_MASK  | [31: 0] | RW   | 'b0            | Data_mask   |

### 5.7.4.2.8 **MATCH\_ADDR**

## Description:

| 0x001C |                               |    | . (Re      | set to | 0x0000 | 0000_ | )  |       |       |    |    |    |    | MA | TCH_A | ADDR |
|--------|-------------------------------|----|------------|--------|--------|-------|----|-------|-------|----|----|----|----|----|-------|------|
| Bit    | 31                            | 30 | 29         | 28     | 27     | 26    | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
| Name   |                               |    | MATCH_ADDR |        |        |       |    |       |       |    |    |    |    |    |       |      |
| Туре   |                               | 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   |                               |    |            |        |        |       |    | MATCH | _ADDR |    |    |    |    |    |       |      |
| Туре   |                               | RO |            |        |        |       |    |       |       |    |    |    |    |    |       |      |
| Reset  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |            |        |        |       |    |       |       |    |    |    |    |    |       |      |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                  |
|------------|---------|------|----------------|----------------------------------------------|
| MATCH_ADDR | [31: 0] | RO   | 'b0            | Captured Address, which triggered interrupt; |

## 5.7.4.2.9 MATCH\_DATA



| 0x0020 |    |    | . (Re | set to     | 0x0000 | 0000_ | )  |       |        |    |    |    |    | MA | TCH_[ | DATA |
|--------|----|----|-------|------------|--------|-------|----|-------|--------|----|----|----|----|----|-------|------|
| Bit    | 31 | 30 | 29    | 28         | 27     | 26    | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
| Name   |    |    |       | MATCH_DATA |        |       |    |       |        |    |    |    |    |    |       |      |
| Туре   |    |    |       | 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   |    |    |       |            |        |       |    | MATCH | I_DATA |    |    |    |    |    |       |      |
| Туре   |    |    | RO    |            |        |       |    |       |        |    |    |    |    |    |       |      |
| Reset  | 0  | 0  |       |            |        |       |    |       |        |    |    |    | 0  |    |       |      |

| Field Name | Bit     | Туре | Reset<br>Value | Description                               |
|------------|---------|------|----------------|-------------------------------------------|
| MATCH_DATA | [31: 0] | RO   | 'b0            | Captured Data, which triggered interrupt; |

## 5.7.4.2.10 BUSMON\_CNT

### Description:

| 0x0024 |    |    | . (Re | set to ( | 0x0000 | 0000 | )  |       |       |    |    |    |    | BUS | SMON | CNT |
|--------|----|----|-------|----------|--------|------|----|-------|-------|----|----|----|----|-----|------|-----|
| Bit    | 31 | 30 | 29    | 28       | 27     | 26   | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18  | 17   | 16  |
| Name   |    |    |       |          |        |      |    | BUSMC | N_CNT |    |    |    |    |     |      |     |
| Туре   |    | 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   |    |    |       |          |        |      |    | BUSMC | N_CNT |    |    |    |    |     |      |     |
| Туре   |    | RO |       |          |        |      |    |       |       |    |    |    |    |     |      |     |
| Reset  | 0  | 0  | 0     | 0        | 0      | 0    | 0  | 0     | 0     | 0  | 0  | 0  | 0  | 0   | 0    | 0   |

| Field Name | Bit     | Туре | Reset<br>Value | Description          |
|------------|---------|------|----------------|----------------------|
| BUSMON_CNT | [31: 0] | RO   | 'b0            | Transaction counter; |

# 5.8 RTC Timer

## 5.8.1 Overview

SC6820 provides an always-powered-on region to count second, minute, hour and day, and to perform alarm functions.

### 5.8.2 Features

Main feature list:

Second counter: 0 – 59Minute counter: 0 – 59



Hour counter: 0 – 23
 Day counter: 0 – 65535

- I Second, minute, hour and day numbers can be changed by software
- I Provide second interrupt, minute interrupt, hour interrupt and day interrupt
- I Provide configurable alarm function
- I All interrupts can be used to wakeup system from deep sleep
- I Alarm interrupt can be used to power up system from power-down status
- RTCVDD is the power supply for second counter, minute counter, hour counter, day counter, and alarm function. And this power is always on.

#### 5.8.3 Signal Description

#### **5.8.4 Function Description**

SC6820 provides a very small always-powered-on region supplied by RTCVDD. Second counter, minute counter, hour counter, day counter, and alarm function are put in this region, so these functions always work even if the base band chip enters power-down mode.

Second counter, minute counter, hour counter and day counter are used to count second, minute, hour and day values, and to issue second, minute, hour and day interrupts. The value of these four counters can be changed by software, but the changing time is very long, about 125 ms. In order to improve software efficiency, SC6820 provides four interrupts to inform software changing completion. The changes to four counters are independent, and it does not need waiting for first changing to complete before changing next one.

Alarm function is used to generate alarm interrupt to inform software, to wake up system, or to power up system. Alarm second, minute, hour and day values are stored in the RTCVDD power domain, and these four registers can be changed by software. It also takes long time to change these registers, and another set of four interrupts are provided for changing completion. Same as the above, the changes to the four registers are independent, and it does not need waiting for first changing to complete before changing next one.

Because RTC timers are in RTC clock domain, all interrupts can be used to wakeup system from deep sleep. Another important function is alarm interrupt can power up base band from power-down mode.

#### 5.8.5 Control Registers

#### 5.8.5.1 **Memory map**

ARM base address: 0x8200\_0080

| Address<br>Offset | Register Name    | Default Value |
|-------------------|------------------|---------------|
| 0x0000            | RTC_SEC_CNT      | -             |
| 0x0004            | RTC_MIN_CNT      | -             |
| 0x0008            | RTC_HOUR_CNT     | -             |
| 0x000C            | RTC_DAY_CNT      | -             |
| 0x0010            | RTC_SEC_CNT_UPD  | 32'h00000000  |
| 0x0014            | RTC_MIN_ CNT_UPD | 32'h00000000  |



| 0x0018 | RTC_HOUR_<br>CNT_UPD | 32'h00000000 |
|--------|----------------------|--------------|
| 0x001C | RTC_DAY_ CNT_UPD     | 32'h00000000 |
| 0x0020 | RTC_SEC_ALM_UPD      | 32'h00000000 |
| 0x0024 | RTC_MIN_ALM_UPD      | 32'h00000000 |
| 0x0028 | RTC_HOUR_ALM_UPD     | 32'h00000000 |
| 0x002C | RTC_DAY_ALM_UPD      | 32'h00000000 |
| 0x0030 | RTC_INT_EN           | 32'h00000000 |
| 0x0034 | RTC_INT_RAW_STS      | 32'h00000000 |
| 0x0038 | RTC_INT_CLR          | 32'h00000000 |
| 0x003C | RTC_INT_MASK_STS     | 32'h00000000 |
| 0x0040 | RTC_SEC_ALM_CNT      | -            |
| 0x0044 | RTC_MIN_ALM_CNT      |              |
| 0x0048 | RTC_HRS_ALM_CNT      | -            |
| 0x004C | RTC_DAY_ALM_CNT      | -            |
| 0x0050 | RTC_SPG_CNT          | -            |
| 0x0054 | RTC_SPG_CNT_UPD      | 32'h0000000  |

## 5.8.5.2 Register Descriptions

## 5.8.5.2.1 RTC\_SEC\_CNT

Description: Current second counter value

| 0x0000 |    |          | RTC | Secon | d Cou | nter  |    |    |    |    |    |    |        | RTC   | SEC | CNT |
|--------|----|----------|-----|-------|-------|-------|----|----|----|----|----|----|--------|-------|-----|-----|
| Bit    | 31 | 30       | 29  | 28    | 27    | 26    | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18    | 17  | 16  |
| Name   |    | Reserved |     |       |       |       |    |    |    |    |    |    |        |       |     |     |
| Туре   |    |          |     |       |       |       |    | R  | 0  |    |    |    |        |       |     |     |
| 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   |    |          |     |       | Rese  | erved |    |    |    |    |    |    | RTC_SI | C_CNT |     |     |
| Туре   |    | RO RO    |     |       |       |       |    |    |    |    |    |    |        |       |     |     |
| Reset  | 0  | 0        | 0   | 0     | 0     | 0     | 0  | 0  | 0  | 0  | -  | -  | -      | -     | -   | -   |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                  |
|-------------|--------|------|----------------|------------------------------|
|             | [31:6] | RO   | 26'h0          | Reserved                     |
| RTC_SEC_CNT | [5:0]  | RO   | -              | Current second counter value |

## 5.8.5.2.2 RTC\_MIN\_CNT

Description: Current minute counter value



| 0x0004 |    |          | RTC | Minute | e Cour | iter  |    |    |    |    |    |    | RTC_MIN_CNT |        |    |    |
|--------|----|----------|-----|--------|--------|-------|----|----|----|----|----|----|-------------|--------|----|----|
| Bit    | 31 | 30       | 29  | 28     | 27     | 26    | 25 | 24 | 23 | 22 | 21 | 20 | 19          | 18     | 17 | 16 |
| Name   |    | Reserved |     |        |        |       |    |    |    |    |    |    |             |        |    |    |
| Туре   |    | 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   |    |          |     |        | Rese   | erved |    |    |    |    |    |    | RTC_M       | IN_CNT |    |    |
| Туре   |    |          |     |        | R      | 0     |    |    |    |    |    |    | R           | .0     |    |    |
| Reset  | 0  | 0        | 0   | 0      | 0      | 0     | 0  | 0  | 0  | 0  | -  | -  | -           | -      | -  | -  |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                  |
|-------------|--------|------|----------------|------------------------------|
|             | [31:6] | RO   | 26'h0          | Reserved                     |
| RTC_MIN_CNT | [5:0]  | RO   | -              | Current minute counter value |

## 5.8.5.2.3 RTC\_HRS\_CNT

Description: Current hour counter value

| 0x0008 | 8 RTC Hour Counter |          |    |    |    |          |    |    |    |    |    |    |     | RTC     | _HRS | CNT |
|--------|--------------------|----------|----|----|----|----------|----|----|----|----|----|----|-----|---------|------|-----|
| Bit    | 31                 | 30       | 29 | 28 | 27 | 26       | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18      | 17   | 16  |
| Name   |                    | Reserved |    |    |    |          |    |    |    |    |    |    |     |         |      |     |
| Туре   |                    | 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   |                    |          |    |    |    | Reserved | ł  |    |    |    |    |    | RTO | C_HRS_0 | CNT  |     |
| Туре   |                    | RO RO    |    |    |    |          |    |    |    |    |    |    |     |         |      |     |
| Reset  | 0                  | 0        | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | -  | •   | -       | -    | -   |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                |
|-------------|--------|------|----------------|----------------------------|
|             | [31:5] | RO   | 27'h0          | Reserved                   |
| RTC_HRS_CNT | [4:0]  | RO   | -              | Current hour counter value |

### 5.8.5.2.4 RTC\_DAY\_CNT

Description: Current day counter value



| 0x000C |    |          | RTC Day Counter |    |    |    |    |       |        |    |    |    | RTC_D |    |    | CNT |
|--------|----|----------|-----------------|----|----|----|----|-------|--------|----|----|----|-------|----|----|-----|
| Bit    | 31 | 30       | 29              | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19    | 18 | 17 | 16  |
| Name   |    | Reserved |                 |    |    |    |    |       |        |    |    |    |       |    |    |     |
| Туре   |    | 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   |    |          |                 |    |    |    |    | RTC_D | AY_CNT |    |    |    |       |    |    |     |
| Туре   | RO |          |                 |    |    |    |    |       |        |    |    |    |       |    |    |     |
| Reset  | 1  | -        | -               | 1  | -  | -  | -  | -     | -      | -  | -  | -  | -     | -  | -  | -   |

| Field Name  | Bit     | Туре | Reset<br>Value | Description               |
|-------------|---------|------|----------------|---------------------------|
|             | [31:16] | RO   | 16'h0          | Reserved                  |
| RTC_DAY_CNT | [15:0]  | RO   | -              | Current day counter value |

## 5.8.5.2.5 RTC\_SEC\_CNT\_UPD

Description: Current second counter update

| 0x0010 | RTC Second Counter Update (reset 0x0000_0000) |          |    |    |      |       |    |    |    |    |    |    | RTC_SEC_CNT_UPD |         |    |    |  |
|--------|-----------------------------------------------|----------|----|----|------|-------|----|----|----|----|----|----|-----------------|---------|----|----|--|
| Bit    | 31                                            | 30       | 29 | 28 | 27   | 26    | 25 | 24 | 23 | 22 | 21 | 20 | 19              | 18      | 17 | 16 |  |
| Name   |                                               | Reserved |    |    |      |       |    |    |    |    |    |    |                 |         |    |    |  |
| Туре   |                                               | 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   |                                               |          |    |    | Rese | erved |    |    |    |    |    | R1 | C_SEC           | _CNT_UI | PD |    |  |
| Туре   |                                               |          |    |    | R    | 0     |    |    |    |    |    |    | R               | W       |    |    |  |
| Reset  | 0                                             | 0        | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0       | 0  | 0  |  |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                                                                                              |
|-----------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------|
|                 | [31:6] | RO   | 26'h0          | Reserved                                                                                                 |
| RTC_SEC_CNT_UPD | [5:0]  | R/W  | 6'h0           | Current second counter update                                                                            |
|                 |        |      |                | Write new counter value to this register to start an second counter updating operation in RTCVDD domain. |
|                 |        |      |                | Reading this register can get recent updating value                                                      |

## 5.8.5.2.6 RTC\_MIN\_CNT\_UPD

Description: Current minute counter update



| 0x0014 |    |                          | RTC                             | Minute                    | e Cour | ter Up | date ( | reset ( | x0000 | _0000 | ) |    | RT | RTC_MIN_CNT_UPD |    |    |  |
|--------|----|--------------------------|---------------------------------|---------------------------|--------|--------|--------|---------|-------|-------|---|----|----|-----------------|----|----|--|
| Bit    | 31 | 30                       | 0 29 28 27 26 25 24 23 22 21 20 |                           |        |        |        |         |       |       |   | 20 | 19 | 18              | 17 | 16 |  |
| Name   |    | Reserved                 |                                 |                           |        |        |        |         |       |       |   |    |    |                 |    |    |  |
| Туре   |    |                          | RO                              |                           |        |        |        |         |       |       |   |    |    |                 |    |    |  |
| 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   |    | Reserved RTC_MIN_CNT_UPD |                                 |                           |        |        |        |         |       |       |   |    |    |                 |    |    |  |
| Туре   |    |                          | RO R/W                          |                           |        |        |        |         |       |       |   |    |    |                 |    |    |  |
| Reset  | 0  | 0                        | 0                               | 0                         | 0      | 0      | 0      | 0       | 0     | 0     | 0 | 0  | 0  | 0               | 0  | 0  |  |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                |
|-----------------|--------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | [31:6] | RO   | 26'h0          | Reserved                                                                                                                                                                                   |
| RTC_MIN_CNT_UPD | [5:0]  | R/W  | 6'h0           | Current minute counter update Write new counter value to this register to start an minute counter updating operation in RTCVDD domain. Reading this register can get recent updating value |

## 5.8.5.2.7 RTC\_HRS\_CNT\_UPD

Description: Current hour counter update

| 0x0018 |    |                                                | RTC | Hour ( | Counte | r Upda   | ate (re | set 0x | 0000_0 | 0000) |   |    | RTO   | C_HRS  | _CNT  | _UPD |
|--------|----|------------------------------------------------|-----|--------|--------|----------|---------|--------|--------|-------|---|----|-------|--------|-------|------|
| Bit    | 31 | 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |     |        |        |          |         |        |        |       |   | 16 |       |        |       |      |
| Name   |    | Reserved                                       |     |        |        |          |         |        |        |       |   |    |       |        |       |      |
| Туре   |    | RO                                             |     |        |        |          |         |        |        |       |   |    |       |        |       |      |
| 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   |    |                                                |     |        | ſ      | Reserved | i       |        |        |       |   |    | RTC_H | IRS_CN | T_UPD |      |
| Туре   |    | RO R/W                                         |     |        |        |          |         |        |        |       |   |    |       |        |       |      |
| Reset  | 0  | 0                                              | 0   | 0      | 0      | 0        | 0       | 0      | 0      | 0     | 0 | 0  | 0     | 0      | 0     | 0    |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                              |
|-----------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | [31:5] | RO   | 27'h0          | Reserved                                                                                                                                                                                 |
| RTC_MIN_CNT_UPD | [4:0]  | R/W  | 5'h0           | Current hour counter update  Write new counter value to this register to start an hour counter updating operation in RTCVDD domain.  Reading this register can get recent updating value |



## 5.8.5.2.8 RTC\_DAY\_CNT\_UPD

Description: Current day counter update

| 0x001C |    |    | RTC      | Day C                                     | ounter | Upda | te (res | et 0x0 | 000_00 | 000) |   |   | RTO | C_DAY | _CNT | UPD |
|--------|----|----|----------|-------------------------------------------|--------|------|---------|--------|--------|------|---|---|-----|-------|------|-----|
| Bit    | 31 | 30 | 29       | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |      |         |        |        |      |   |   |     | 16    |      |     |
| Name   |    |    | Reserved |                                           |        |      |         |        |        |      |   |   |     |       |      |     |
| Туре   |    |    |          | 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   |    |    |          | RTC_DAY_CNT_UPD                           |        |      |         |        |        |      |   |   |     |       |      |     |
| Туре   |    |    | R/W      |                                           |        |      |         |        |        |      |   |   |     |       |      |     |
| Reset  | 0  | 0  | 0        | 0                                         | 0      | 0    | 0       | 0      | 0      | 0    | 0 | 0 | 0   | 0     | 0    | 0   |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                           |
|-----------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | [31:16] | RO   | 16'h0          | Reserved                                                                                                                                                                              |
| RTC_MIN_CNT_UPD | [15:0]  | R/W  | 16'h0          | Current hour counter update Write new counter value to this register to start an day counter updating operation in RTCVDD domain. Reading this register can get recent updating value |

## 5.8.5.2.9 RTC\_SEC\_ALM\_UPD

Description: Current second alarm update

| 0x0020 |    |                          | RTC    | Secon                     | d Alar | m Upd | late (re | eset 0x | 0000_ | 0000) |    |    | RTO | C_SEC | _ALM | UPD |
|--------|----|--------------------------|--------|---------------------------|--------|-------|----------|---------|-------|-------|----|----|-----|-------|------|-----|
| Bit    | 31 | 30 <                     | 29     | 28                        | 27     | 26    | 25       | 24      | 23    | 22    | 21 | 20 | 19  | 18    | 17   | 16  |
| Name   |    |                          |        |                           |        |       |          | Rese    | erved |       |    |    |     |       |      |     |
| Туре   |    |                          |        |                           |        |       |          | R       | 0     |       |    |    |     |       |      |     |
| 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   |    | Reserved RTC_SEC_ALM_UPD |        |                           |        |       |          |         |       |       |    |    |     |       |      |     |
| Туре   |    |                          | RO R/W |                           |        |       |          |         |       |       |    |    |     |       |      |     |
| Reset  | 0  | 0                        | 0      | 0                         | 0      | 0     | 0        | 0       | 0     | 0     | 0  | 0  | 0   | 0     | 0    | 0   |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                 |
|-----------------|--------|------|----------------|-----------------------------|
|                 | [31:6] | RO   | 26'h0          | Reserved                    |
| RTC_SEC_ALM_UPD | [5:0]  | R/W  | 6'h0           | Current second alarm update |



|  | Write new counter value to this register to start an second alarm updating operation in RTCVDD domain. |
|--|--------------------------------------------------------------------------------------------------------|
|  | Reading this register can get recent updating value                                                    |

### 5.8.5.2.10 RTC\_MIN\_ALM\_UPD

Description: Current minute alarm update

| 0x0024 |    |                                                                          | RTC    | Minute                  | Alarn | n Upda | ate (re | set 0x( | 0000_0 | 000) |   |    | RT     | C_MIN  | _ALM | _UPD |
|--------|----|--------------------------------------------------------------------------|--------|-------------------------|-------|--------|---------|---------|--------|------|---|----|--------|--------|------|------|
| Bit    | 31 | 30   29   28   27   26   25   24   23   22   21   20   19   18   17   16 |        |                         |       |        |         |         |        |      |   | 16 |        |        |      |      |
| Name   |    | Reserved                                                                 |        |                         |       |        |         |         |        |      |   |    |        |        |      |      |
| Туре   |    |                                                                          | 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   |    |                                                                          |        |                         | Rese  | erved  |         |         |        |      |   | R  | C_MIN_ | _ALM_U | PD   |      |
| Туре   |    |                                                                          | RO R/W |                         |       |        |         |         |        |      |   |    |        |        |      |      |
| Reset  | 0  | 0                                                                        | 0      | 0                       | 0     | 0      | 0       | 0       | 0      | 0    | 0 | 0  | 0      | 0      | 0    | 0    |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                            |
|-----------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | [31:6] | RO   | 26'h0          | Reserved                                                                                                                                                                               |
| RTC_MIN_ALM_UPD | [5:0]  | R/W  | 6'h0           | Current minute alarm update Write new counter value to this register to start an minute alarm updating operation in RTCVDD domain. Reading this register can get recent updating value |

## 5.8.5.2.11 RTC\_HRS\_ALM\_UPD

Description: Current hour alarm update

| 0x00 | )28  |    |        | RTC | Hour / | Alarm ( | Update   | e (rese | t 0x00 | 00_000 | 00) |    |    | RTC_HRS_ALM_UPD |         |        |    |
|------|------|----|--------|-----|--------|---------|----------|---------|--------|--------|-----|----|----|-----------------|---------|--------|----|
| Bit  | t    | 31 | 30     | 29  | 28     | 27      | 26       | 25      | 24     | 23     | 22  | 21 | 20 | 19              | 18      | 17     | 16 |
| Nam  | пе   |    |        |     |        |         |          |         | Rese   | erved  |     |    |    |                 |         |        |    |
| Туре | е    |    |        |     |        |         |          |         | R      | 0      |     |    |    |                 |         |        |    |
| Res  | et   | 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  |
| Nam  | ne l |    |        |     |        | í       | Reserved | i       |        |        |     |    |    | RTC_H           | HRS_ALN | //_UPD |    |
| Тур  | е    |    | RO R/W |     |        |         |          |         |        |        |     |    |    |                 |         |        |    |
| Rese | et   | 0  | 0      | 0   | 0      | 0       | 0        | 0       | 0      | 0      | 0   | 0  | 0  | 0               | 0       | 0      | 0  |

| Field Name | Bit | Туре | Reset<br>Value | Description |
|------------|-----|------|----------------|-------------|
|            |     |      | value          |             |



|                 | [31:5] | RO  | 27'h0 | Reserved                                                                                            |
|-----------------|--------|-----|-------|-----------------------------------------------------------------------------------------------------|
| RTC_MIN_ALM_UPD | [4:0]  | R/W | 5'h0  | Current hour alarm update  Write new counter value to this register to start an                     |
|                 |        |     |       | hour alarm updating operation in RTCVDD domain. Reading this register can get recent updating value |

### 5.8.5.2.12 RTC\_DAY\_ALM\_UPD

Description: Current day alarm update

| 0x002C |    |          | RTC | Day A | larm U | pdate | (reset | 0x000  | 0_000   | 0) |          |    | RTC | _DAY | _ALM | UPD |
|--------|----|----------|-----|-------|--------|-------|--------|--------|---------|----|----------|----|-----|------|------|-----|
| Bit    | 31 | 30       | 29  | 28    | 27     | 26    | 25     | 24     | 23      | 22 | 21       | 20 | 19  | 18   | 17   | 16  |
| Name   |    | Reserved |     |       |        |       |        |        |         |    |          |    |     |      |      |     |
| Туре   |    |          |     |       |        |       |        | R      | 0       |    |          |    |     |      |      |     |
| 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   |    |          |     |       |        |       | RT     | C_DAY_ | _ALM_UI | PD | <b>1</b> |    |     |      |      |     |
| Туре   |    |          |     |       |        |       |        | R      | W       |    |          |    |     |      |      |     |
| Reset  | 0  | 0        | 0   | 0     | 0      | 0     | 0      | 0      | 0       | 0  | 0        | 0  | 0   | 0    | 0    | 0   |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                      |
|-----------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | [31:16] | RO   | 16'h0          | Reserved                                                                                                                                                                         |
| RTC_MIN_ALM_UPD | [15:0]  | R/W  | 16'h0          | Current day alarm update Write new counter value to this register to start an day alarm updating operation in RTCVDD domain. Reading this register can get recent updating value |

## 5.8.5.2.13 RTC\_INT\_EN

Description: Interrupt enable and hour format control



| 0x0030 |                                                |                                                     | RTC                                            | Day C                                          | ounter                                         | •                                                   |                                                |                                                |                                                |                  |                                             |                                |                                | RTC                             | _DAY_                   | CNT                           |
|--------|------------------------------------------------|-----------------------------------------------------|------------------------------------------------|------------------------------------------------|------------------------------------------------|-----------------------------------------------------|------------------------------------------------|------------------------------------------------|------------------------------------------------|------------------|---------------------------------------------|--------------------------------|--------------------------------|---------------------------------|-------------------------|-------------------------------|
| Bit    | 31                                             | 30                                                  | 29                                             | 28                                             | 27                                             | 26                                                  | 25                                             | 24                                             | 23                                             | 22               | 21                                          | 20                             | 19                             | 18                              | 17                      | 16                            |
| Name   |                                                |                                                     |                                                |                                                |                                                |                                                     |                                                | Rese                                           | erved                                          |                  |                                             |                                |                                |                                 |                         |                               |
| Туре   |                                                | 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   | RTC<br>_DA<br>Y_A<br>LM_<br>UPD<br>_INT<br>_EN | RTC<br>_HO<br>UR_<br>ALM<br>_UP<br>D_I<br>NT_<br>EN | RTC<br>_MI<br>N_A<br>LM_<br>UPD<br>_INT<br>_EN | RTC<br>_SE<br>C_A<br>LM_<br>UPD<br>_INT<br>_EN | RTC<br>_DA<br>Y_C<br>NT_<br>UPD<br>_INT<br>_EN | RTC<br>_HO<br>UR_<br>CNT<br>_UP<br>D_I<br>NT_<br>EN | RTC<br>_MI<br>N_C<br>NT_<br>UPD<br>_INT<br>_EN | RTC<br>_SE<br>C_C<br>NT_<br>UPD<br>_INT<br>_EN | RTC<br>_SP<br>G_C<br>NT_<br>UPD<br>_INT<br>_EN | Res<br>erve<br>d | RTC<br>_HO<br>UR_<br>FOR<br>MAT<br>_SE<br>L | RTC<br>_AL<br>M_I<br>NT_<br>EN | RTC<br>_DA<br>Y_IN<br>T_E<br>N | RTC<br>_HO<br>UR_<br>INT_<br>EN | RTC<br>_MI<br>NT_<br>EN | RTC<br>SE<br>C_I<br>NT_<br>EN |
| Туре   | R/W                                            | R/W                                                 | R/W                                            | R/W                                            | R/W                                            | R/W                                                 | R/W                                            | R/W                                            | R/W                                            | RO               | R/W                                         | R/W                            | 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                             |

| Field Name              | Bit     | Туре | Reset<br>Value | Description                                                                                              |
|-------------------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------|
|                         | [31:16] | RO   | 16'h0          | Reserved                                                                                                 |
| RTC_DAY_ALM_UPD_INT_EN  | [15]    | RW   | 1'h0           | Day alarm updating complete interrupt enable 0: disabled 1: enabled                                      |
| RTC_HOUR_ALM_UPD_INT_EN | [14]    | RW   | 1'h0           | Hour alarm updating complete interrupt enable                                                            |
| RTC_MIN_ALM_UPD_INT_EN  | [13]    | RW   | 1'h0           | Minute alarm updating complete interrupt enable                                                          |
| RTC_SEC_ALM_UPD_INT_EN  | [12]    | RW   | 1'h0           | Second alarm updating complete interrupt enable                                                          |
| RTC_DAY_CNT_UPD_INT_EN  | [11]    | RW   | 1'h0           | Day counter updating complete interrupt enable                                                           |
| RTC_HOUR_CNT_UPD_INT_EN | [10]    | RW   | 1'h0           | Hour counter updating complete interrupt enable                                                          |
| RTC_MIN_CNT_UPD_INT_EN  | [9]     | RW   | 1'h0           | Minute counter updating complete interrupt enable                                                        |
| RTC_SEC_CNT_UPD_INT_EN  | [8]     | RW   | 1'h0           | Second counter updating complete interrupt enable                                                        |
| RTC_SPG_CNT_UPD_INT_EN  | [7]     | RW   | 1'h0           | Spg counter updating complete interrupt enable                                                           |
|                         | [6]     | RO   | 1'h0           | Reserved                                                                                                 |
|                         | [5]     | RW   | 1'h0           | Hour format select                                                                                       |
|                         |         |      |                | 0: The read back hour count is formatted as 0 to 23.                                                     |
|                         |         |      |                | 1: The read back hour count is formatted as 0 to 11, and bit 4 represent AM or PM – AM is 0 and PM is 1. |



| RTC_ALM_INT_EN  | [4] | RW | 1'h0 | alarm interrupt enable  |
|-----------------|-----|----|------|-------------------------|
| RTC_DAY_INT_EN  | [3] | RW | 1'h0 | day interrupt enable    |
| RTC_HOUR_INT_EN | [2] | RW | 1'h0 | hour interrupt enable   |
| RTC_MIN_INT_EN  | [1] | RW | 1'h0 | minute interrupt enable |
| RTC_SEC_INT_EN  | [0] | RW | 1'h0 | Second interrupt enable |

## **5.8.5.2.14 RTC\_INT\_RAW\_STS**

Description: Interrupt raw status

| 0x0034 |                                                             |                                                            | RTC                                                         | Day C                                                       | ounter                                                   | •                                       |                                                             |                                 |                           |                  |                                              |                                             |                                         | RTC                                          | _DAY                                        | CNT                                        |
|--------|-------------------------------------------------------------|------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------|-------------------------------------------------------------|---------------------------------|---------------------------|------------------|----------------------------------------------|---------------------------------------------|-----------------------------------------|----------------------------------------------|---------------------------------------------|--------------------------------------------|
| Bit    | 31                                                          | 30                                                         | 29                                                          | 28                                                          | 27                                                       | 26                                      | 25                                                          | 24                              | 23                        | 22               | 21                                           | 20                                          | 19                                      | 18                                           | 17                                          | 16                                         |
| Name   |                                                             |                                                            |                                                             |                                                             |                                                          |                                         |                                                             | Rese                            | erved                     |                  |                                              |                                             |                                         |                                              |                                             |                                            |
| Туре   |                                                             | 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   | RTC<br>_DA<br>Y_A<br>LM_<br>UPD<br>_INT<br>_RA<br>W_S<br>TS | RTC<br>HO<br>UR<br>ALM<br>UP<br>DI<br>NT<br>RA<br>WS<br>TS | RTC<br>_MI<br>N_A<br>LM_<br>UPD<br>_INT<br>_RA<br>W_S<br>TS | RTC<br>_SE<br>C_A<br>LM_<br>UPD<br>_INT<br>_RA<br>W_S<br>TS | RTC<br>DA<br>Y_C<br>NT_<br>UPD<br>INT<br>RA<br>W_S<br>TS | RTC<br>HO<br>UR T<br>UP DI NT A S<br>TS | RTC<br>_MI<br>N_C<br>NT_<br>UPD<br>_INT<br>_RA<br>W_S<br>TS | RTC SE C_C NT UPD INT RA W S TS | RT SP C NT I D ST RA S TS | Res<br>erve<br>d | RTC<br>_AL<br>M_I<br>NTO<br>_RA<br>W_S<br>TS | RTC<br>_AL<br>M_I<br>NT_<br>RA<br>W_S<br>TS | RTC<br>_DA<br>Y_IN<br>T_R<br>AW_<br>STS | RTC<br>_HO<br>UR_<br>INT_<br>RA<br>W_S<br>TS | RTC<br>_MI<br>N_I<br>NT_<br>RA<br>W_S<br>TS | RTC<br>SE<br>C_I<br>NT_<br>RA<br>W_S<br>TS |
| Туре   | RO                                                          | RO                                                         | RO                                                          | RO                                                          | RO                                                       | RO                                      | RO                                                          | RO                              | RO                        | RO               | RO                                           | RO                                          | RO                                      | RO                                           | RO                                          | RO                                         |
| Reset  | 0                                                           | 0                                                          | 0                                                           | 0                                                           | 0                                                        | 0                                       | 0                                                           | 0                               | 0                         | 0                | 0                                            | 0                                           | 0                                       | 0                                            | 0                                           | 0                                          |

| Field Name                   | Bit     | Туре | Reset<br>Value | Description                                           |
|------------------------------|---------|------|----------------|-------------------------------------------------------|
|                              | [31:16] | RO   | 16'h0          | Reserved                                              |
| RTC_DAY_ALM_UPD_INT_RAW_STS  | [15]    | RO   | 1'h0           | Day alarm updating complete interrupt raw status      |
| RTC_HOUR_ALM_UPD_INT_RAW_STS | [14]    | RO   | 1'h0           | Hour alarm updating complete interrupt raw status     |
| RTC_MIN_ALM_UPD_INT_RAW_STS  | [13]    | RO   | 1'h0           | Minute alarm updating complete interrupt raw status   |
| RTC_SEC_ALM_UPD_INT_RAW_STS  | [12]    | RO   | 1'h0           | Second alarm updating complete interrupt raw status   |
| RTC_DAY_CNT_UPD_INT_RAW_STS  | [11]    | RO   | 1'h0           | Day counter updating complete interrupt raw status    |
| RTC_HOUR_CNT_UPD_INT_RAW_STS | [10]    | RO   | 1'h0           | Hour counter updating complete interrupt raw status   |
| RTC_MIN_CNT_UPD_INT_RAW_STS  | [9]     | RO   | 1'h0           | Minute counter updating complete interrupt raw status |
| RTC_SEC_CNT_UPD_INT_RAW_STS  | [8]     | RO   | 1'h0           | Second counter updating                               |



|                             |     |    |      | complete interrupt raw status                      |
|-----------------------------|-----|----|------|----------------------------------------------------|
| RTC_SPG_CNT_UPD_INT_RAW_STS | [7] | RO | 1'h0 | Spg counter updating complete interrupt raw status |
|                             | [6] | RO | 1'h0 | Reserved                                           |
| RTC_ALM_INT0_RAW_STS        | [5] | RO | 1'h0 | alarm interrupt0 raw status                        |
| RTC_ALM_INT_RAW_STS         | [4] | RO | 1'h0 | alarm interrupt raw status                         |
| RTC_DAY_INT_RAW_STS         | [3] | RO | 1'h0 | day interrupt raw status                           |
| RTC_HOUR_INT_RAW_STS        | [2] | RO | 1'h0 | hour interrupt raw status                          |
| RTC_MIN_INT_RAW_STS         | [1] | RO | 1'h0 | minute interrupt raw status                        |
| RTC_SEC_INT_RAW_STS         | [0] | RO | 1'h0 | Second interrupt raw status                        |

## 5.8.5.2.15 RTC\_INT\_CLR

Description: Interrupt clear

| 0x0038 |                             |                                                      | RTC                                                 | Day C                                               | ounter                                              |                                                      |                                                     |                                                     |                        |      |       |                                 |                                 | RTC                              | _DAY                            | CNT                            |
|--------|-----------------------------|------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|------------------------|------|-------|---------------------------------|---------------------------------|----------------------------------|---------------------------------|--------------------------------|
| Bit    | 31                          | 30                                                   | 29                                                  | 28                                                  | 27                                                  | 26                                                   | 25                                                  | 24                                                  | 23                     | 22   | 21    | 20                              | 19                              | 18                               | 17                              | 16                             |
| Name   |                             |                                                      |                                                     |                                                     |                                                     |                                                      |                                                     | Rese                                                | erved                  |      |       |                                 |                                 |                                  |                                 |                                |
| Туре   |                             | 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   | RTC _DA Y_A LM_ UPD _I CL R | RTC<br>_HO<br>UR_<br>ALM<br>_UP<br>D_I<br>NT_<br>CLR | RTC<br>_MI<br>N_A<br>LM_<br>UPD<br>_INT<br>_CL<br>R | RTC<br>_SE<br>C_A<br>LM_<br>UPD<br>_INT<br>_CL<br>R | RTC<br>_DA<br>Y_C<br>NT_<br>UPD<br>_INT<br>_CL<br>R | RTC<br>_HO<br>UR_<br>CNT<br>_UP<br>D_I<br>NT_<br>CLR | RTC<br>_MI<br>N_C<br>NT_<br>UPD<br>_INT<br>_CL<br>R | RTC<br>_SE<br>C_C<br>NT_<br>UPD<br>_INT<br>_CL<br>R | RTC P C NT I D ST CL R | Rese | erved | RTC<br>_AL<br>M_I<br>NT_<br>CLR | RTC<br>_DA<br>Y_IN<br>T_C<br>LR | RTC<br>_HO<br>UR_<br>INT_<br>CLR | RTC<br>_MI<br>N_I<br>NT_<br>CLR | RTC<br>SE<br>C_I<br>NT_<br>CLR |
| Туре   | WO                          | WO W             |                                                     |                                                     |                                                     |                                                      |                                                     |                                                     |                        |      |       |                                 |                                 |                                  |                                 |                                |
| Reset  | 0                           | 0                                                    | 0                                                   | 0                                                   | 0                                                   | 0                                                    | 0                                                   | 0                                                   | 0                      | 0    | 0     | 0                               | 0                               | 0                                | 0                               | 0                              |

| Field Name               | Bit     | Туре | Reset<br>Value | Description                                                                                      |
|--------------------------|---------|------|----------------|--------------------------------------------------------------------------------------------------|
|                          | [31:16] | RO   | 16'h0          | Reserved                                                                                         |
| RTC_DAY_ALM_UPD_INT_CLR  | [15]    | WO   | 1'h0           | Day alarm updating complete interrupt clear Write 1 to this bit to clear corresponding interrupt |
| RTC_HOUR_ALM_UPD_INT_CLR | [14]    | WO   | 1'h0           | Hour alarm updating complete interrupt clear                                                     |
| RTC_MIN_ALM_UPD_INT_CLR  | [13]    | WO   | 1'h0           | Minute alarm updating complete interrupt clear                                                   |
| RTC_SEC_ALM_UPD_INT_CLR  | [12]    | WO   | 1'h0           | Second alarm updating complete interrupt clear                                                   |
| RTC_DAY_CNT_UPD_INT_CLR  | [11]    | WO   | 1'h0           | Day counter updating complete                                                                    |



|                          |       |    |      | interrupt clear                                  |
|--------------------------|-------|----|------|--------------------------------------------------|
| RTC_HOUR_CNT_UPD_INT_CLR | [10]  | WO | 1'h0 | Hour counter updating complete interrupt clear   |
| RTC_MIN_CNT_UPD_INT_CLR  | [9]   | WO | 1'h0 | Minute counter updating complete interrupt clear |
| RTC_SEC_CNT_UPD_INT_CLR  | [8]   | WO | 1'h0 | Second counter updating complete interrupt clear |
| RTC_SPG_CNT_UPD_INT_CLR  | [7]   | WO | 1'h0 | Spg counter updating complete interrupt clear    |
|                          | [6:5] | RO | 2'h0 | Reserved                                         |
| RTC_ALM_INT_CLR          | [4]   | WO | 1'h0 | alarm interrupt clear                            |
| RTC_DAY_INT_CLR          | [3]   | WO | 1'h0 | day interrupt clear                              |
| RTC_HOUR_INT_CLR         | [2]   | WO | 1'h0 | hour interrupt clear                             |
| RTC_MIN_INT_CLR          | [1]   | WO | 1'h0 | minute interrupt clear                           |
| RTC_SEC_INT_CLR          | [0]   | WO | 1'h0 | Second interrupt clear                           |

# 5.8.5.2.16 RTC\_INT\_MASK\_STS

Description: Interrupt masked status

| 0x003C |                                      |                                        | RTC                                                          | Day C                                                      | ounter                    |                               |                                                              |                                                             | 1                               |      |       |                                              |                                              | RTC                                           | _DAY                                         | CNT                                         |
|--------|--------------------------------------|----------------------------------------|--------------------------------------------------------------|------------------------------------------------------------|---------------------------|-------------------------------|--------------------------------------------------------------|-------------------------------------------------------------|---------------------------------|------|-------|----------------------------------------------|----------------------------------------------|-----------------------------------------------|----------------------------------------------|---------------------------------------------|
| Bit    | 31                                   | 30                                     | 29                                                           | 28                                                         | 27                        | 26                            | 25                                                           | 24                                                          | 23                              | 22   | 21    | 20                                           | 19                                           | 18                                            | 17                                           | 16                                          |
| Name   |                                      |                                        |                                                              |                                                            |                           |                               |                                                              | Rese                                                        | erved                           |      |       |                                              |                                              |                                               |                                              |                                             |
| Туре   |                                      | RO                                     |                                                              |                                                            |                           |                               |                                                              |                                                             |                                 |      |       |                                              |                                              |                                               |                                              |                                             |
| 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   | RTC _DA Y_A LM_ UPD _INT _MA SK_ STS | RTC _HO UR_ ALM _UP D_I NT_ MAS K_S TS | RTC<br>_MI<br>N_A<br>LM_<br>UPD<br>_INT<br>_MA<br>SK_<br>STS | RTC<br>SE<br>C_A<br>LM_<br>UPD<br>INT<br>_MA<br>SK_<br>STS | RTC DA C NT DD INT MA STS | RTC HO UR TO UP DI NT MAS K S | RTC<br>_MI<br>N_C<br>NT_<br>UPD<br>_INT<br>_MA<br>SK_<br>STS | RTC<br>SE<br>C_C<br>NT_<br>UPD<br>_INT<br>_MA<br>SK_<br>STS | RTC SP G_C NT_UPD INT MA SK_STS | Rese | erved | RTC<br>_AL<br>M_I<br>NT_<br>MAS<br>K_S<br>TS | RTC<br>_DA<br>Y_IN<br>T_M<br>ASK<br>_ST<br>S | RTC<br>_HO<br>UR_<br>INT_<br>MAS<br>K_S<br>TS | RTC<br>_MI<br>N_I<br>NT_<br>MAS<br>K_S<br>TS | RTC<br>SE<br>C_I<br>NT_<br>MAS<br>K_S<br>TS |
| Туре   | R/W                                  | R/W                                    | R/W                                                          | R/W                                                        | R/W                       | R/W                           | R/W                                                          | R/W                                                         | R/W                             | R    | 0     | R/W                                          | 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                                           |

| Field Name                    | Bit     | Туре | Reset<br>Value | Description                                                                                                      |
|-------------------------------|---------|------|----------------|------------------------------------------------------------------------------------------------------------------|
|                               | [31:16] | RO   | 16'h0          | Reserved                                                                                                         |
| RTC_DAY_ALM_UPD_INT_MASK_STS  | [15]    | RW   | 1'h0           | Day alarm updating complete interrupt masked status Write 1 to this bit to masked status corresponding interrupt |
| RTC_HOUR_ALM_UPD_INT_MASK_STS | [14]    | RW   | 1'h0           | Hour alarm updating complete                                                                                     |



|                               |       |    |      | interrupt masked status                                  |
|-------------------------------|-------|----|------|----------------------------------------------------------|
| RTC_MIN_ALM_UPD_INT_MASK_STS  | [13]  | RW | 1'h0 | Minute alarm updating complete interrupt masked status   |
| RTC_SEC_ALM_UPD_INT_MASK_STS  | [12]  | RW | 1'h0 | Second alarm updating complete interrupt masked status   |
| RTC_DAY_CNT_UPD_INT_MASK_STS  | [11]  | RW | 1'h0 | Day counter updating complete interrupt masked status    |
| RTC_HOUR_CNT_UPD_INT_MASK_STS | [10]  | RW | 1'h0 | Hour counter updating complete interrupt masked status   |
| RTC_MIN_CNT_UPD_INT_MASK_STS  | [9]   | RW | 1'h0 | Minute counter updating complete interrupt masked status |
| RTC_SEC_CNT_UPD_INT_MASK_STS  | [8]   | RW | 1'h0 | Second counter updating complete interrupt masked status |
| RTC_SPG_CNT_UPD_INT_MASK_STS  | [7]   | RW | 1'h0 | Spg counter updating complete interrupt masked status    |
|                               | [6:5] | RO | 2'h0 | Reserved                                                 |
| RTC_ALM_INT_MASK_STS          | [4]   | RW | 1'h0 | alarm interrupt masked status                            |
| RTC_DAY_INT_MASK_STS          | [3]   | RW | 1'h0 | day interrupt masked status                              |
| RTC_HOUR_INT_MASK_STS         | [2]   | RW | 1'h0 | hour interrupt masked status                             |
| RTC_MIN_INT_MASK_STS          | [1]   | RW | 1'h0 | minute interrupt masked status                           |
| RTC_SEC_INT_MASK_STS          | [0]   | RW | 1'h0 | Second interrupt masked status                           |

## 5.8.5.2.17 RTC\_SEC\_ALM\_CNT

Description: Current second alarm value

| 0x0040 |    |                                                 | RTC | Secon | d aları | m     |   |      |       |   |   | RTC Second alarm |       |        |    |   |  |  |  |  |  |  |  |
|--------|----|-------------------------------------------------|-----|-------|---------|-------|---|------|-------|---|---|------------------|-------|--------|----|---|--|--|--|--|--|--|--|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |     |       |         |       |   |      |       |   |   |                  |       | 16     |    |   |  |  |  |  |  |  |  |
| Name   |    |                                                 |     |       |         |       |   | Rese | erved |   |   |                  |       |        |    |   |  |  |  |  |  |  |  |
| Туре   |    |                                                 |     |       |         |       |   | R    | 0     |   |   |                  |       |        |    |   |  |  |  |  |  |  |  |
| 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   |    |                                                 |     |       | Rese    | erved |   |      |       |   |   | RT               | C_SEC | _ALM_C | NT |   |  |  |  |  |  |  |  |
| Туре   |    | RO RO                                           |     |       |         |       |   |      |       |   |   |                  |       |        |    |   |  |  |  |  |  |  |  |
| Reset  | 0  | 0                                               | 0   | 0     | 0       | 0     | 0 | 0    | 0     | 0 | - | -                | -     | -      | -  | - |  |  |  |  |  |  |  |

| Field Name | Bit | Туре | Reset<br>Value | Description |
|------------|-----|------|----------------|-------------|
|            |     |      |                |             |



|                 | [31:6] | RO | 26'h0 | Reserved                   |
|-----------------|--------|----|-------|----------------------------|
| RTC_SEC_ALM_CNT | [5:0]  | RO | -     | Current second alarm value |

## 5.8.5.2.18 RTC\_MIN\_ALM\_CNT

Description: Current minute alarm value

| 0x0044 |    |       | RTC | Minute | e alarm | 1     |    |      |       |    |    |    | RT     | C_MIN   | _ALM | CNT |
|--------|----|-------|-----|--------|---------|-------|----|------|-------|----|----|----|--------|---------|------|-----|
| Bit    | 31 | 30    | 29  | 28     | 27      | 26    | 25 | 24   | 23    | 22 | 21 | 20 | 19     | 18      | 17   | 16  |
| Name   |    |       |     |        |         |       |    | Rese | erved |    |    |    |        |         |      |     |
| Туре   |    |       |     |        |         |       |    | R    | 0     |    |    |    |        |         |      |     |
| 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   |    |       |     |        | Rese    | erved |    |      |       |    |    | R  | C_MIN_ | _ALM_CI | NT   |     |
| Туре   |    | RO RO |     |        |         |       |    |      |       |    |    |    |        |         |      |     |
| Reset  | 0  | 0     | 0   | 0      | 0       | 0     | 0  | 0    | 0     | 0  | -  |    |        | -       |      | -   |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                |
|-----------------|--------|------|----------------|----------------------------|
|                 | [31:6] | RO   | 26'h0          | Reserved                   |
| RTC_MIN_ALM_CNT | [5:0]  | RO   | -              | Current minute alarm value |

## 5.8.5.2.19 RTC\_HRS\_ALM\_CNT

Description: Current hour alarm value

| 0x0048 |    |       | RTC | Hour /   | Alarm |          |    |    |    |    |    |    | RTO   | _HRS    | _ALM  | CNT |
|--------|----|-------|-----|----------|-------|----------|----|----|----|----|----|----|-------|---------|-------|-----|
| Bit    | 31 | 30    | 29  | 28       | 27    | 26       | 25 | 24 | 23 | 22 | 21 | 20 | 19    | 18      | 17    | 16  |
| Name   |    |       |     | Reserved |       |          |    |    |    |    |    |    |       |         |       |     |
| Туре   |    |       |     |          |       |          |    | R  | 0  |    |    |    |       |         |       |     |
| 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   |    |       |     |          |       | Reserved | ı  |    |    |    |    |    | RTC_H | HRS_ALM | /_CNT |     |
| Туре   |    | RO RO |     |          |       |          |    |    |    |    |    |    |       |         |       |     |
| Reset  | 0  | 0     | 0   | 0        | 0     | 0        | 0  | 0  | 0  | 0  | 0  | -  | -     | -       | -     | -   |

| Field Name      | Bit    | Туре | Reset<br>Value | Description              |
|-----------------|--------|------|----------------|--------------------------|
|                 | [31:5] | RO   | 27'h0          | Reserved                 |
| RTC_HRS_ALM_CNT | [4:0]  | RO   | -              | Current hour alarm value |



### 5.8.5.2.20 RTC\_DAY\_ALM\_CNT

Description: Current day alarm value

| 0x004C |    |    | RTC | Day A | larm |    |    |       |        |    |    |    | RTC | C_DAY | _ALM | CNT |
|--------|----|----|-----|-------|------|----|----|-------|--------|----|----|----|-----|-------|------|-----|
| Bit    | 31 | 30 | 29  | 28    | 27   | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19  | 18    | 17   | 16  |
| Name   |    |    |     |       |      |    |    | Rese  | erved  |    |    |    |     |       |      |     |
| Туре   |    |    |     |       |      |    |    | R     | .0     |    |    |    |     |       |      |     |
| 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   |    |    |     |       |      |    |    | RTC_D | AY_CNT |    |    |    |     |       | 4    |     |
| Туре   |    | RO |     |       |      |    |    |       |        |    |    |    |     |       |      |     |
| Reset  | -  |    |     |       |      |    |    |       |        |    |    |    |     |       |      |     |

| Field Name      | Bit     | Туре | Reset<br>Value | Description             |
|-----------------|---------|------|----------------|-------------------------|
|                 | [31:16] | RO   | 16'h0          | Reserved                |
| RTC_DAY_ALM_CNT | [15:0]  | RO   | -              | Current day alarm value |

## 5.8.5.2.21 RTC\_SPG\_CNT

Description: Current spg counter value

| 0x0050 |    | RTC SPG Counter Value RTC_SPG_CNT |    |      |       |    |    |    |             |    | CNT |    |    |    |    |    |
|--------|----|-----------------------------------|----|------|-------|----|----|----|-------------|----|-----|----|----|----|----|----|
| Bit    | 31 | 30                                | 29 | 28   | 27    | 26 | 25 | 24 | 23          | 22 | 21  | 20 | 19 | 18 | 17 | 16 |
| Name   |    | Reserved                          |    |      |       |    |    |    |             |    |     |    |    |    |    |    |
| Туре   |    | RO                                |    |      |       |    |    |    |             |    |     |    |    |    |    |    |
| 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   |    |                                   |    | Rese | erved |    |    |    | RTC_SPG_CNT |    |     |    |    |    |    |    |
| Туре   | RO |                                   |    |      |       |    |    | RO |             |    |     |    |    |    |    |    |
| Reset  | 0  | 0                                 | 0  | 0    | 0     | 0  | 0  | 0  | -           | -  | -   | -  | -  | -  | -  | -  |

| Field Name  | Bit    | Туре | Reset<br>Value | Description               |
|-------------|--------|------|----------------|---------------------------|
|             | [31:8] | RO   | 24'h0          | Reserved                  |
| RTC_SPG_CNT | [7:0]  | RO   | -              | Current spg counter value |

## 5.8.5.2.22 RTC\_SPG\_CNT\_UPD

Description: Current spg counter update



| 0x0054 |          | RTC SPG Counter Update (reset 0x0000_0000) RTC_SPG_CNT_ |    |      |       |    |    |    |                 | UPD |    |    |    |    |    |    |
|--------|----------|---------------------------------------------------------|----|------|-------|----|----|----|-----------------|-----|----|----|----|----|----|----|
| Bit    | 31       | 30                                                      | 29 | 28   | 27    | 26 | 25 | 24 | 23              | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | Reserved |                                                         |    |      |       |    |    |    |                 |     |    |    |    |    |    |    |
| Туре   |          | 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   |          |                                                         |    | Rese | erved |    |    |    | RTC_SPG_CNT_UPD |     |    |    |    |    |    |    |
| Туре   | RO       |                                                         |    |      |       |    |    | R  |                 |     |    | w  |    |    |    |    |
| Reset  | 0        | 0                                                       | 0  | 0    | 0     | 0  | 0  | 0  | 0               | 0   | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                           |
|-----------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | [31:8] | RO   | 24'h0          | Reserved                                                                                                                                                                              |
| RTC_SPG_CNT_UPD | [7:0]  | R/W  | 8'h0           | Current spg counter update Write new counter value to this register to start an spgd counter updating operation in RTCVDD domain. Reading this register can get recent updating value |

## 5.8.6 Application Notes

Second counter, minute counter, hour counter and day counter always run in RTCVDD domain. However, if software wants to access or control these functions, it should set rtc\_eb and rtc\_rtc\_eb first.

After setting rtc\_eb and rtc\_rtc\_eb, software can get second, minute, hour and day counter values by reading rtc\_sec\_cnt, rtc\_min\_cnt, rtc\_hour\_cnt and rtc\_day\_cnt. Double-reading method is still recommended, like the system timer reading.

RTC timers provide second interrupt, minute interrupt, hour interrupt and day interrupt. Software can enable these interrupts by setting 1 to rtc\_sec\_int\_en, rtc\_min\_int\_en, rtc\_sec\_hour\_en and rtc\_day\_int\_en, check status by reading rtc\_sec\_int\_mask\_sts, rtc\_min\_int\_mask\_sts, rtc\_hour\_int\_mask\_sts and rtc\_day\_int\_mask\_sts, and clear these interrupts by writing 1 to rtc\_sec\_int\_clr, rtc\_min\_int\_clr, rtc\_hour\_int\_clr and rtc\_day\_int\_clr.

Software can update the four counter values by writing new value to rtc\_sec\_cnt\_upd, rtc\_min\_cnt\_upd, rtc\_hour\_cnt\_upd or rtc\_day\_cnt\_upd. However, the changing time is very long, about 125 ms. In order to improve software efficiency, RTC timer provides four interrupts to inform software changing completion. Software can enable these interrupts by setting rtc\_sec\_cnt\_upd\_int\_en, rtc\_min\_cnt\_upd\_int\_en, rtc\_hour\_cnt\_upd\_int\_en and rtc\_day\_cnt\_upd\_int\_en, check status by reading rtc\_sec\_cnt\_upd\_int\_mask\_sts, rtc\_min\_cnt\_upd\_int\_mask\_sts, rtc\_hour\_cnt\_upd\_int\_mask\_sts and rtc\_day\_cnt\_upd\_int\_mask\_sts, and clear these interrupts by writing 1 to rtc\_sec\_cnt\_upd\_int\_clr, rtc\_min\_cnt\_upd\_int\_clr, rtc\_nupd\_hour\_int\_clr and rtc\_day\_cnt\_upd\_int\_clr. The changes to four counters are independent, and it does not need waiting for first changing to complete before changing next one.

RTC timer provides an alarm function. If an alarm occurs, alarm interrupt is issued. Software can enable this interrupt by setting rtc\_alm\_int\_en, check status by reading rtc\_alm\_int\_mask\_sts, and clear these interrupts by writing 1 to rtc\_alm\_int\_clr.



Alarm value can be configured by writing expected value to rtc\_sec\_alm\_upd, rtc\_min\_alm\_upd, rtc\_hour\_alm\_upd and rtc\_day\_alm\_upd. However, the changing time is very long, about 125 ms. In order to improve software efficiency, RTC timer provides four interrupts to inform software changing completion. Software can enable these interrupts by setting rtc\_sec\_alm\_upd\_int\_en, rtc\_min\_alm\_upd\_int\_en, rtc\_hour\_alm\_upd\_int\_en and rtc\_day\_alm\_upd\_int\_en, check status by reading rtc\_sec\_alm\_upd\_int\_mask\_sts, rtc\_min\_alm\_upd\_int\_mask\_sts, rtc\_hour\_alm\_upd\_int\_mask\_sts and rtc\_day\_alm\_upd\_int\_mask\_sts, and clear these interrupts by writing 1 to rtc\_sec\_alm\_upd\_int\_clr, rtc\_min\_alm\_upd\_int\_clr, rtc\_alm\_upd\_hour\_int\_clr and rtc\_day\_alm\_upd\_int\_clr. The changes to the four counters are independent, and it does not need waiting for first changing to complete before changing next one.

Because RTC timers are in RTC clock domain, all interrupts can be used to wakeup system from deep sleep. Another important function is alarm interrupt can power up base band chip from power-down mode.

## **5.9 General Purpose Timer**

#### 5.9.1 Overview

The module includes three general-purpose timers, two RTC-clock trigged asynchronous timers, and one PCLK trigged synchronous timer.

### 5.9.2 Features

RTC clock trigged timers:

- I Two independent RTC clock trigged timers
- I 32-bit decreasing counter
- Support one-time mode and period mode
- I Support configurable counting value
- I Can be used as wakeup source during deep sleep

#### PCLK clock trigged timer:

- I One PCLK clock trigged timer
- 32-bit decreasing counter
- Support one-time mode and period mode
- Support configurable counting value
- Cannot be used as wakeup source during deep sleep

### 5.9.3 Signal Description

Null

### 5.9.4 Function Description

The MCU sub-system provides three general-purpose timers. Timer 0 and Timer 1 are trigged by RTC clock, which is 32.768KHz, and Timer 2 is trigged by PCLK, which is 26MHz. These three timers can be controlled independently.



### 5.9.4.1 RTC Clock Trigged Timers

Timer 0 and Timer 1 are trigged by RTC clock, which is 32.768KHz. So the counting step is about 30.5us.

Each timer has a 32-bit decreasing counter. This kind of timer provides two operating modes: one-time mode and period mode.

If the timer is configured in one-time mode, counter decreases from setting value to 0 When counter gets to 0, an interrupt is issued. The counter stays at 0 until software load it again.

If the timer is configured in period mode, counter decreases from setting value to 0. When counter gets to 0, an interrupt is issued, and counter is reloaded by setting value, and then counter continues to decrease from setting value.

Because trigging clock is RTC clock, these two timers can be used to wake up system during deep sleep.

### 5.9.4.2 PCLK Trigged Timers

Timer 2 is trigged by PCLK, which is 26MHz. So the counting step is about 38.5ns.

This timer has a 32-bit decreasing counter. This timer provides two operating modes: one-time mode and period mode.

If the timer is configured in one-time mode, counter decreases from setting value to 0. When counter gets to 0, an interrupt is issued. The counter stays at 0 until software load it again.

If the timer is configured in period mode, counter decreases from setting value to 0. When counter gets to 0, an interrupt is issued, and counter is reloaded by setting value, and then counter continues to decrease from setting value.

Because trigging clock is PCLK, this timer cannot be used to wake up system during deep sleep.

## 5.9.5 Control Registers

### **5.9.5.1 Memory map**

ARM base address: 0x8100 0000

#### Timer0:

| Offset<br>Address | Name         | Description              |
|-------------------|--------------|--------------------------|
| 0x0000            | TIMER0_LOAD  | Timer0 load value        |
| 0x0004            | TIMER0_VALUE | Timer0 counter value     |
| 0x0008            | TIMER0_CTL   | Timer0 control registers |



| Offset<br>Address | Name       | Description      |
|-------------------|------------|------------------|
| 0x000C            | TIMER0_INT | Timer0 interrupt |

### Timer1:

| Offset<br>Address | Name         | Description              |
|-------------------|--------------|--------------------------|
| 0x0020            | TIMER1_LOAD  | Timer1 load value        |
| 0x0024            | TIMER1_VALUE | Timer1 counter value     |
| 0x0028            | TIMER1_CTL   | Timer1 control registers |
| 0x002C            | TIMER1_INT   | Timer1 interrupt         |

## Timer2:

| Offset<br>Address | Name         | Description              |
|-------------------|--------------|--------------------------|
| 0x0040            | TIMER2_LOAD  | Timer2 load value        |
| 0x0044            | TIMER2_VALUE | Timer2 counter value     |
| 0x0048            | TIMER2_CTL   | Timer2 control registers |
| 0x004C            | TIMER2_INT   | Timer2 interrupt         |

## 5.9.5.2 Register Descriptions

## 5.9.5.2.1 TIMER0\_LOAD

Description: Timer0 load value

| 0x0000 |    | Timer0 load value (Reset 0x0000_0000) |    |    |    |    |    |       |        |    | TIMER0_LOAD |    |    |    |    |    |
|--------|----|---------------------------------------|----|----|----|----|----|-------|--------|----|-------------|----|----|----|----|----|
| Bit    | 31 | 30                                    | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21          | 20 | 19 | 18 | 17 | 16 |
| Name   |    | timer0_load                           |    |    |    |    |    |       |        |    |             |    |    |    |    |    |
| Туре   |    | 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   |    |                                       |    |    |    |    |    | timer | )_load |    |             |    |    |    |    |    |
| Туре   |    | RW                                    |    |    |    |    |    |       |        |    |             |    |    |    |    |    |
| Reset  | 0  | 0                                     | 0  | 0  | 0  | 0  | 0  | 0     | 0      | 0  | 0           | 0  | 0  | 0  | 0  | 0  |

| Field Name  | Bit    | R/W | Reset Value | Description                                                      |
|-------------|--------|-----|-------------|------------------------------------------------------------------|
| timer0_load | [31:0] | RW  | 32'h0       | Timer0 load value                                                |
|             |        |     |             | Write to this register will reload the timer with the new value. |
|             |        |     |             | In one-time mode, this value is                                  |



| Field Name | Bit | R/W | Reset Value | Description                                                 |
|------------|-----|-----|-------------|-------------------------------------------------------------|
|            |     |     |             | the first counting start number.                            |
|            |     |     |             | In periodic mode, this value is each counting start number. |

## **5.9.5.2.2 TIMERO\_VALUE**

Description: Timer0 counter value

| 0x0004 |    |                               | Time         | Timer0 counter value (Reset 0x0000_0000) TIMER0_VALUE |    |    |    |        |        |    |    |    |    |    |    |    |
|--------|----|-------------------------------|--------------|-------------------------------------------------------|----|----|----|--------|--------|----|----|----|----|----|----|----|
| Bit    | 31 | 30                            | 29           | 28                                                    | 27 | 26 | 25 | 24     | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |    |                               | timer0_value |                                                       |    |    |    |        |        |    |    |    |    |    |    |    |
| Туре   |    |                               | 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   |    |                               |              |                                                       |    |    |    | timer0 | _value |    |    |    |    |    |    |    |
| Туре   |    | RO                            |              |                                                       |    |    |    |        |        |    |    |    |    |    |    |    |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |              |                                                       |    |    |    |        |        |    |    |    |    |    |    |    |

| Field Name   | Bit    | R/W | Reset Value | Description                                                                                                                                |
|--------------|--------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| timer0_value | [31:0] | RO  | 32'h0       | Timer0 counter value This read-only register indicates current counter value.                                                              |
|              |        |     |             | It's not recommended to read this register in normal usage.                                                                                |
|              | 7/1    |     |             | Because the counter is in different clock domain with APB, software needs use double-reading method to read this value, like system timer. |

## 5.9.5.2.3 TIMER0\_CTL

Description: Timer0 control registers



| 0x0008 |    |    | Time                | r0 con | trol re | gister | (Rese | t 0x000 | 000_000            | 0)                  |    |    |     | Т     | IMER0 | _CTL |
|--------|----|----|---------------------|--------|---------|--------|-------|---------|--------------------|---------------------|----|----|-----|-------|-------|------|
| Bit    | 31 | 30 | 29                  | 28     | 27      | 26     | 25    | 24      | 23                 | 22                  | 21 | 20 | 19  | 18    | 17    | 16   |
| Name   |    |    |                     |        |         |        |       | Rese    | erved              |                     |    |    |     |       |       |      |
| Туре   |    | RO |                     |        |         |        |       |         |                    |                     |    |    |     |       |       |      |
| 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   |    |    |                     | Rese   | erved   |        |       |         | timer<br>0_ru<br>n | timer<br>0_m<br>ode |    |    | Res | erved |       |      |
| Type   |    |    |                     | R      | 0       |        |       |         | RW                 | RW                  |    |    | R   | .0    |       |      |
| Reset  | 0  | 0  | 0                   | 0      | 0       | 0      | 0     | 0       | 0                  | 0                   | 0  | 0  | 0   | 0     | 0     | 0    |

| Field Name  | Bit    | R/W | Default Value | Description                                        |
|-------------|--------|-----|---------------|----------------------------------------------------|
|             | [31:8] | RO  | 24'h0         | Reserved                                           |
| timer0_run  | [7]    | RW  | 1'h0          | Timer0 open bit 0: timer stops 1: timer runs       |
| timer0_mode | [6]    | RW  | 1'h0          | Timer0 mode select 0: one-time mode 1: period mode |
|             | [5:0]  | RO  | 6'h0          | Reserved                                           |

## 5.9.5.2.4 TIMER0\_INT

Description: Timer0 interrupt

| 0x000C |    |                         | Time | r0 inte | rrupt ( | Reset    | 0x000 | 0_000 | 0)    |    |    |                            |                        | Т                                   | IMER                           | _INT                  |
|--------|----|-------------------------|------|---------|---------|----------|-------|-------|-------|----|----|----------------------------|------------------------|-------------------------------------|--------------------------------|-----------------------|
| Bit    | 31 | 30                      | 29   | 28      | 27      | 26       | 25    | 24    | 23    | 22 | 21 | 20                         | 19                     | 18                                  | 17                             | 16                    |
| Name   |    |                         |      |         |         |          |       | Rese  | erved |    |    |                            |                        |                                     |                                |                       |
| Туре   |    | RO                      |      |         |         |          |       |       |       |    |    |                            |                        |                                     |                                |                       |
| Reset  | 0  |                         |      |         |         |          |       |       |       |    |    |                            |                        |                                     |                                |                       |
| Bit    | 15 | 14                      | 13   | 12      | 11      | 10       | 9     | 8     | 7     | 6  | 5  | 4                          | 3                      | 2                                   | 1                              | 0                     |
| Name   |    |                         |      |         | ı       | Reserved | i     |       |       |    |    | timer<br>0_ld<br>_bus<br>y | timer<br>0_int<br>_clr | timer<br>0_int<br>_ma<br>sk_s<br>ts | timer<br>0_int<br>_raw<br>_sts | timer<br>0_int<br>_en |
| Type   |    | RO RO RO RO RW          |      |         |         |          |       |       |       |    |    |                            |                        |                                     |                                |                       |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 |      |         |         |          |       |       |       |    |    |                            |                        | 0                                   | 0                              | 0                     |

| Field Name     | Bit    | R/W | Default Value | Description             |
|----------------|--------|-----|---------------|-------------------------|
|                | [31:5] | RO  | 27'h0         | Reserved                |
| timer0_ld_busy | [4]    | RO  | 1'h0          | Timer0 load busy status |



| Field Name              | Bit | R/W | Default Value | Description                                                                                                         |
|-------------------------|-----|-----|---------------|---------------------------------------------------------------------------------------------------------------------|
|                         |     |     |               | 0: Timer is ready for new loading                                                                                   |
|                         |     |     |               | 1: Last loading is not completed                                                                                    |
|                         |     |     |               | Software must not load new value when this bit is busy, that is, this bit should be checked before any new loading. |
|                         |     |     |               | This bit is set after a new loading, and lasts two or three RTC clock cycles, about 60us - 92us.                    |
| timer0_int_clr          | [3] | WO  | 1'h0          | Timer0 Interrupt clear<br>Write 1 to this bit to clear<br>interrupt                                                 |
| timer0_int_mas<br>k_sts | [2] | RO  | 1'h0          | Timer0 interrupt masked status                                                                                      |
| timer0_int_raw<br>_sts  | [1] | RO  | 1'h0          | Timer0 interrupt raw status                                                                                         |
| timer0_int_en           | [0] | RW  | 1'h0          | Timer0 interrupt enable                                                                                             |

## 5.9.5.2.5 TIMER1\_LOAD

Description: Timer1 load value

|        |    | Timer1 load value (Reset 0x0000_0000) TIMER1_LOAD |             |                           |         |       |         |        |       |    |    |    |    |     |       |      |
|--------|----|---------------------------------------------------|-------------|---------------------------|---------|-------|---------|--------|-------|----|----|----|----|-----|-------|------|
| 0x0020 |    |                                                   | Time        | r1 load                   | d value | (Rese | et 0x00 | 00_00  | 00)   |    |    |    |    | TIM | ER1_L | .OAD |
| Bit    | 31 | 30                                                | 29          | 28                        | 27      | 26    | 25      | 24     | 23    | 22 | 21 | 20 | 19 | 18  | 17    | 16   |
| Name   |    |                                                   | timer1_load |                           |         |       |         |        |       |    |    |    |    |     |       |      |
| Туре   |    |                                                   | RW          |                           |         |       |         |        |       |    |    |    |    |     |       |      |
| 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   |    |                                                   |             |                           |         |       |         | timer1 | _load |    |    |    |    |     |       |      |
| Туре   |    | RW                                                |             |                           |         |       |         |        |       |    |    |    |    |     |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |             |                           |         |       |         |        |       |    |    |    |    |     |       |      |

| Field Name  | Bit    | R/W | Reset Value | Description                                                      |
|-------------|--------|-----|-------------|------------------------------------------------------------------|
| timer1_load | [31:0] | RW  | 32'h0       | Timer1 load value                                                |
|             |        |     |             | Write to this register will reload the timer with the new value. |
|             |        |     |             | In one-time mode, this value is the first counting start number. |
|             |        |     |             | In period mode, this value is each counting start number.        |



## **5.9.5.2.6 TIMER1\_VALUE**

Description: Timer1 counter value

| 0x0024 |    |    | Time | r1 cou                  | inter v | alue (F | Reset 0 | )x0000 | _0000) | )  |    |    |    | TIME | R1_V | ALUE |
|--------|----|----|------|-------------------------|---------|---------|---------|--------|--------|----|----|----|----|------|------|------|
| Bit    | 31 | 30 | 29   | 28                      | 27      | 26      | 25      | 24     | 23     | 22 | 21 | 20 | 19 | 18   | 17   | 16   |
| Name   |    |    |      |                         |         |         |         | timer1 | _value |    |    |    |    |      |      |      |
| Туре   |    |    |      | RO                      |         |         |         |        |        |    |    |    |    |      |      |      |
| 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   |    |    |      |                         |         |         |         | timer1 | _value |    |    |    |    |      |      |      |
| Туре   |    |    | RO   |                         |         |         |         |        |        |    |    |    |    |      |      |      |
| Reset  | 0  | 0  | 0    | 0                       | 0       | 0       | 0       | 0      | 0      | 0  | 0  | 0  | 0  | 0    | 0    | 0    |

| Field Name   | Bit    | R/W | Reset Value | Description                                                                                                                                |
|--------------|--------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| timer1_value | [31:0] | RO  | 32'h0       | Timer1 counter value This read-only register indicates current counter value.                                                              |
|              |        |     |             | It's not recommended to read this register in normal usage.                                                                                |
|              |        |     |             | Because the counter is in different clock domain with APB, software needs use double-reading method to read this value, like system timer. |

## 5.9.5.2.7 TIMER1\_CTL

Description: Timer1 control registers

| 0x0028 |    |    | Time | r1 con | trol re | gister | (Reset | 0x000 | 000_000            | 0)                  | TIMER1 |    |       |       | _CTL |    |  |  |
|--------|----|----|------|--------|---------|--------|--------|-------|--------------------|---------------------|--------|----|-------|-------|------|----|--|--|
| Bit    | 31 | 30 | 29   | 28     | 27      | 26     | 25     | 24    | 23                 | 22                  | 21     | 20 | 19    | 18    | 17   | 16 |  |  |
| Name   |    |    |      |        |         |        |        | Rese  | erved              |                     |        |    |       |       |      |    |  |  |
| Туре   |    | 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 |       |      |    |  |  |
| Name   |    |    |      | Rese   | erved   |        |        |       | timer<br>1_ru<br>n | timer<br>1_m<br>ode |        |    | Rese  | erved |      |    |  |  |
| Type   |    |    |      | R      | 0       |        |        |       | RW                 | RW                  |        |    | R     | .0    |      |    |  |  |
| Reset  | 0  | 0  | 0    | 0      | 0       | 0      | 0      | 0     | 0                  | 0                   | 0      | 0  | 0     | 0     | 0    | 0  |  |  |



| Field Name  | Bit    | R/W | Default Value | Description                                        |
|-------------|--------|-----|---------------|----------------------------------------------------|
|             | [31:8] | RO  | 24'h0         | Reserved                                           |
| timer1_run  | [7]    | RW  | 1'h0          | Timer1 open bit 0: timer stops 1: timer runs       |
| timer1_mode | [6]    | RW  | 1'h0          | Timer1 mode select 0: one-time mode 1: period mode |
|             | [5:0]  | RO  | 6'h0          | Reserved                                           |

## 5.9.5.2.8 TIMER1\_INT

Description: Timer1 interrupt

| 0x002C |    |                               | Time     | r1 inte | rrupt ( | Reset    | 0x000 | 0_000 | 0) |    |    |                            |                        | Т                                   | IMER <sup>2</sup>              | I_INT                 |
|--------|----|-------------------------------|----------|---------|---------|----------|-------|-------|----|----|----|----------------------------|------------------------|-------------------------------------|--------------------------------|-----------------------|
| Bit    | 31 | 30                            | 29       | 28      | 27      | 26       | 25    | 24    | 23 | 22 | 21 | 20                         | 19                     | 18                                  | 17                             | 16                    |
| Name   |    |                               | Reserved |         |         |          |       |       |    |    |    |                            |                        |                                     |                                |                       |
| Туре   |    | 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   |    |                               |          |         |         | Reserved | i     |       |    |    |    | timer<br>1_ld<br>_bus<br>y | timer<br>1_int<br>_clr | timer<br>1_int<br>_ma<br>sk_s<br>ts | timer<br>1_int<br>_raw<br>_sts | timer<br>1_int<br>_en |
| Туре   |    | RO                            |          |         |         |          |       |       |    |    |    |                            | WO                     | RO                                  | RO                             | RW                    |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0           |          |         |         |          |       |       |    |    |    | 0                          | 0                      | 0                                   | 0                              | 0                     |

| Field Name     | Bit    | R/W | Default Value | Description                                                                                                                                                                                                                                                                                                      |
|----------------|--------|-----|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [31:5] | RO  | 27'h0         | Reserved                                                                                                                                                                                                                                                                                                         |
| timer1_ld_busy | [4]    | RO  | 1'h0          | Timer1 load busy status 0: Timer is ready for new loading 1: Last loading is not completed  Software must not load new value when this bit is busy, that is, this bit should be checked before any new loading. This bit is set after a new loading, and lasts two or three RTC clock cycles, about 60us - 92us. |
| timer1_int_clr | [3]    | WO  | 1'h0          | Timer1 Interrupt clear Write 1 to this bit to clear                                                                                                                                                                                                                                                              |



| Field Name              | Bit | R/W | Default Value | Description                    |
|-------------------------|-----|-----|---------------|--------------------------------|
|                         |     |     |               | interrupt                      |
| timer1_int_mas<br>k_sts | [2] | RO  | 1'h0          | Timer1 interrupt masked status |
| timer1_int_raw<br>_sts  | [1] | RO  | 1'h0          | Timer1 interrupt raw status    |
| timer1_int_en           | [0] | RW  | 1'h0          | Timer1 interrupt enable        |

## 5.9.5.2.9 TIMER2\_LOAD

Description: Timer2 load value

|        |                       |                                       | '  |    |    |    |   |        |        |   |   |   |   |             |    |    |
|--------|-----------------------|---------------------------------------|----|----|----|----|---|--------|--------|---|---|---|---|-------------|----|----|
| 0x0040 |                       | Timer2 load value (Reset 0x0000_0000) |    |    |    |    |   |        |        |   |   |   |   | TIMER2_LOAD |    |    |
| Bit    | 31                    | 1 30 29 28 27 26 25 24 23 22 21 20 19 |    |    |    |    |   |        |        |   |   |   |   | 18          | 17 | 16 |
| Name   |                       | timer2_load                           |    |    |    |    |   |        |        |   |   |   |   |             |    |    |
| Туре   |                       | 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   |                       |                                       |    |    |    |    |   | timer2 | 2_load |   |   |   |   |             |    |    |
| Туре   |                       |                                       |    |    |    |    |   | N      | 10     |   |   |   |   |             |    |    |
| Reset  | 0 0 0 0 0 0 0 0 0 0 0 |                                       |    |    |    |    |   |        |        | 0 | 0 | 0 | 0 | 0           |    |    |

| Field Name  | Bit    | R/W | Reset Value | Description                                                                                                                                                                                                   |
|-------------|--------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| timer2_load | [31:0] | WO  | 32'h0       | Timer2 load value Write to this register will reload the timer with the new value. In one-time mode, this value is the first counting start number. In period mode, this value is each counting start number. |

## 5.9.5.2.10 TIMER2\_VALUE

Description: Timer2 counter value



| 0x0044 |    |                                 | Time                                  | Timer2 counter value (Reset 0x0000_0000) |    |    |   |        |        |   |   |   |   |   | TIMER2_VALUE |    |  |  |
|--------|----|---------------------------------|---------------------------------------|------------------------------------------|----|----|---|--------|--------|---|---|---|---|---|--------------|----|--|--|
| Bit    | 31 | 30                              | 0 29 28 27 26 25 24 23 22 21 20 19 18 |                                          |    |    |   |        |        |   |   |   |   |   | 17           | 16 |  |  |
| Name   |    |                                 | timer2_value                          |                                          |    |    |   |        |        |   |   |   |   |   |              |    |  |  |
| Туре   |    |                                 |                                       |                                          |    |    |   | R      | .0     |   |   |   |   |   |              |    |  |  |
| 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   |    |                                 |                                       |                                          |    |    |   | timer2 | _value |   |   |   |   |   |              |    |  |  |
| Туре   |    |                                 |                                       |                                          |    |    |   | R      | 0      |   |   |   |   |   |              |    |  |  |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                       |                                          |    |    |   |        |        |   |   | 0 |   |   |              |    |  |  |

| Field Name   | Bit    | R/W | Reset Value | Description                                                                   |
|--------------|--------|-----|-------------|-------------------------------------------------------------------------------|
| timer2_value | [31:0] | RO  | 32'h0       | Timer2 counter value This read-only register indicates current counter value. |

## 5.9.5.2.11 TIMER2\_CTL

Description: Timer2 control registers

| 0x0048 |    |                             | Time | r2 con | trol re | gister | (Rese | t 0x000 | 000_00             | 0)                      |    |    |      | Т     | IMER2 | _CTL |
|--------|----|-----------------------------|------|--------|---------|--------|-------|---------|--------------------|-------------------------|----|----|------|-------|-------|------|
| Bit    | 31 | 30                          | 29   | 28     | 27      | 26     | 25    | 24      | 23                 | 22                      | 21 | 20 | 19   | 18    | 17    | 16   |
| Name   |    | Reserved                    |      |        |         |        |       |         |                    |                         |    |    |      |       |       |      |
| Туре   |    | 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   |    |                             |      | Rese   | erved   |        |       |         | timer<br>2_ru<br>n | Tim<br>er2<br>_m<br>ode |    |    | Rese | erved |       |      |
| Type   |    |                             |      | R      | 0       |        |       |         | RW                 | RW                      | RO |    |      |       |       |      |
| Reset  | 0  | 0                           | 0    | 0      | 0       | 0      | 0     | 0       | 0                  | 0                       | 0  | 0  | 0    | 0     | 0     | 0    |

| Field Name  | Bit    | R/W | Default Value | Description                                        |
|-------------|--------|-----|---------------|----------------------------------------------------|
|             | [31:8] | RO  | 24'h0         | Reserved                                           |
| timer2_run  | [7]    | RW  | 1'h0          | Timer2 open bit 0: timer stops 1: timer runs       |
| Timer2_mode | [6]    | RW  | 1'h0          | Timer2 mode select 0: one-time mode 1: period mode |
|             | [5:0]  | RO  | 6'h0          | Reserved                                           |



### 5.9.5.2.12 TIMER2 INT

| Description: | Timer2 interrupt |
|--------------|------------------|
|--------------|------------------|

| 0x004C |    |                             | Time | r2 inte | rrupt ( | Reset | 0x000 | 0_000 | 0) |    |    |    |                        | Т                                   | IMER2                          | 2_INT                 |
|--------|----|-----------------------------|------|---------|---------|-------|-------|-------|----|----|----|----|------------------------|-------------------------------------|--------------------------------|-----------------------|
| Bit    | 31 | 30                          | 29   | 28      | 27      | 26    | 25    | 24    | 23 | 22 | 21 | 20 | 19                     | 18                                  | 17                             | 16                    |
| Name   |    | Reserved                    |      |         |         |       |       |       |    |    |    |    |                        |                                     |                                |                       |
| Туре   |    | 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   |    |                             |      |         |         | Rese  | erved |       |    |    |    |    | timer<br>2_int<br>_clr | timer<br>2_int<br>_ma<br>sk_s<br>ts | timer<br>2_int<br>_raw<br>_sts | timer<br>2_int<br>_en |
| Туре   |    | RO                          |      |         |         |       |       |       |    |    |    |    | wo                     | RO                                  | RO                             | RW                    |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0       |      |         |         |       |       |       |    |    |    | 0  | 0                      | 0                                   | 0                              | 0                     |

| Field Name              | Bit    | R/W | Default Value | Description                                                   |
|-------------------------|--------|-----|---------------|---------------------------------------------------------------|
|                         | [31:4] | RO  | 28'h0         | Reserved                                                      |
| timer2_int_clr          | [3]    | wo  | 1'h0          | Timer2 Interrupt clear Write 1 to this bit to clear interrupt |
| timer2_int_mas<br>k_sts | [2]    | RO  | 1'h0          | Timer2 interrupt masked status                                |
| timer2_int_raw<br>_sts  | [1]    | RO  | 1'h0          | Timer2 interrupt raw status                                   |
| timer2_int_en           | [0]    | RW  | 1'h0          | Timer2 interrupt enable                                       |

## 5.9.6 Application Notes

### 5.9.6.1 RTC Clock Trigged Timers

When software uses RTC clock trigged timer, it should set tmr\_eb bit and tmr\_rtc\_eb bit in global control register.

Before opening timer0\_run or timer1\_run, software should configure all control registers – timer0\_load or timer1\_load, timer0\_mode or timer1\_mode, timer0\_int\_en or timer1\_int\_en.

Then timer0\_run or timer1\_run is set to 1 to open corresponding timer.

After receiving interrupt issued by a timer, software can check interrupt status by reading timer0\_int\_mask\_sts or timer1\_int\_mask\_sts, and can clear interrupt by writing 1 to timer0\_int\_clr or timer1\_int\_clr.

When software completes using RTC clock trigged timer, it should disable timer0\_run or timer1\_run firstly, then it disable tmr\_rtc\_eb and tmr\_eb in global control registers.



It's IMPORTANT that there are 2-3 RTC clock cycles delay from setting timer0\_load or timer1\_load to counter setting success because of different clock domains, that is, if N is configured in timer0\_load or timer1\_load, real counting number is N+2 or N+3.

And during this 2-3 RTC clock cycles loading time, any new loading operation is forbidden. Each Timer provides a bit, timer0\_ld\_busy or timer1\_ld\_busy, for software to indicate if timer is busy in last loading. And software should check this bit before any new loading.

It's not recommended to read counter value in normal usage. Because the counter is binary-code counter, not gray-code, and is in different clock domain with APB, software needs use double-reading method to read this value, like system timer.

If the timer is configured in one-time mode, counter decreases from setting value to 0. When counter gets to 0, an interrupt is issued. The counter stays at 0 until software load it again.

If the timer is configured in period mode, counter decreases from setting value to 0. When counter gets to 0, an interrupt is issued, and counter is reloaded by setting value, and then counter continues to decrease from setting value.

### 5.9.6.2 PCLK Trigged Timers

When software uses PCLK trigged timer, it should set tmr\_eb bit in global control register.

Before opening timer2\_run, software should configure all control registers – timer2\_load, timer2\_mode, timer2\_int\_en.

Then timer2\_run is set to 1 to open the timer.

After receiving interrupt issued by a timer, software can check interrupt status by reading timer2\_int\_mask\_sts, and can clear interrupt by writing 1 to timer2\_int\_clr.

When software completes using PCLK trigged timer, it should disable timer2\_run firstly, and then it disable tmr\_eb in global control registers.

If the timer is configured in one-time mode, counter decreases from setting value to 0. When counter gets to 0, an interrupt is issued. The counter stays at 0 until software load it again.

If the timer is configured in period mode, counter decreases from setting value to 0. When counter gets to 0, an interrupt is issued, and counter is reloaded by setting value, and then counter continues to decrease from setting value.

# 5.10 Watchdog Timer

### 5.10.1 Overview

Watchdog timer is a 32-bit decreasing timer with RTC-clock trigged, and this timer can be used to issue system reset.



#### 5.10.2 Features

- I RTC-clock trigged
- I 32-bit decreasing timer
- I Support 32-bit timer value loading
- I Support reset mode for watchdog function
- I Support interrupt mode for debug function and timer function

## 5.10.3 Signal Description

Null

### 5.10.4 Function Description

After hardware reset, watchdog timer is 32'hFFFF FFFF.

And after enabled, watchdog timer decreases from the reset value or from software-loading value.

The counting step is one RTC clock cycle.

For reset mode, whenever watchdog timer gets to 0, system reset is issued. Then system reboots, and watchdog timer comes back to 32'hFFFF\_FFFF, and all controlled registers and status also come back to reset value, except interrupt raw status. Interrupt raw status can be used to judge if or not system rebooting comes from watchdog reset.

For interrupt mode, watchdog timer runs as a periodic generic timer. If watchdog timer gets to 0, an interrupt is issued, and then the timer is reloaded automatically.

After enabled, watchdog timer can be loaded at any time, and software should quarantee the timer is loaded before it decreases to 0.

Reset mode is used as normal watchdog function. And interrupt mode is used as debug mode or as a generic periodic timer.

### 5.10.5 Control Registers



## 5.10.5.1 Memory map

ARM base address: 0x8200\_0040

| Offset<br>Address | Name          | Description                          |
|-------------------|---------------|--------------------------------------|
| 0x0000            | WDG_LOAD_LOW  | Low 16 bit of watchdog load value    |
| 0x0004            | WDG_LOAD_HIGH | High16 bit of watchdog load value    |
| 0x0008            | WDG_CTRL      | Watchdog control                     |
| 0x000C            | WDG_INT_CLR   | Watchdog interrupt clear             |
| 0x0010            | WDG_INT_RAW   | Watchdog interrupt raw status        |
| 0x0014            | WDG_INT_MASK  | Watchdog interrupt masked status     |
| 0x0018            | WDG_CNT_LOW   | Low 16 bit of watchdog counter value |
| 0x001C            | WDG_CNT_HIGH  | High16 bit of watchdog counter value |
| 0x0020            | WDG_LOCK      | Watchdog lock                        |

## 5.10.5.2 Register Descriptions

## 5.10.5.2.1 WDG\_LOAD\_LOW

Description: Low 16 bit of watchdog load value

| 0x0000 |                               |          | Low | 16 bit | of wat | chdog | load v | alue (l | Reset ( | 0x0000 | _FFFF | =) | V  | NDG_L | .OAD_ | LOW |
|--------|-------------------------------|----------|-----|--------|--------|-------|--------|---------|---------|--------|-------|----|----|-------|-------|-----|
| Bit    | 31                            | 30       | 29  | 28     | 27     | 26    | 25     | 24      | 23      | 22     | 21    | 20 | 19 | 18    | 17    | 16  |
| Name   |                               | Reserved |     |        |        |       |        |         |         |        |       |    |    |       |       |     |
| Туре   |                               |          |     |        |        |       |        | R       | 0       |        |       |    |    |       |       |     |
| 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   |                               |          |     |        | >      |       |        | wdg_lo  | ad_low  |        |       |    |    |       |       |     |
| Туре   |                               | RW       |     |        |        |       |        |         |         |        |       |    |    |       |       |     |
| Reset  | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |          |     |        |        |       |        |         |         |        |       |    |    |       |       |     |

| Field Name   | Bit     | R/W | Reset Value | Description                                                                                                |
|--------------|---------|-----|-------------|------------------------------------------------------------------------------------------------------------|
|              | [31:16] | RO  | 16'h0       | Reserved                                                                                                   |
| wdg_load_low | [15:0]  | RW  | 16'hFFFF    | wdg_load_low: low 16 bit of watchdog timer load value.                                                     |
|              |         |     |             | Wdg_load_high: high 16 bit of watchdog timer load value. wdg_load_low and wdg_load_high are used together. |
|              |         |     |             | Software should write                                                                                      |



| Field Name | Bit | R/W | Reset Value | Description                                                                                                                                                                                                                                                                               |
|------------|-----|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |     |     |             | wdg_load_high firstly, and then write wdg_load_low, because writing wdg_load_low can trig loading both wdg_load_low and wdg_load_high to watchdog counter, and writing wdg_load_high cannot trig this event. So software must guarantee wdg_load_high is ready when writing wdg_load_low. |
|            |     |     |             | In reset mode, software should load new value before timer decrease to 0. In interrupt mode, this value is counting start number. The default value is about 8 seconds.                                                                                                                   |

## 5.10.5.2.2 WDG\_LOAD\_HIGH

Description: High 16 bit of watchdog load value

| 0x0004 |    |    | High | 16 bit | of wat | chdog | load | value ( | Reset   | 0x000 | 0_0003 | 3) | ٧  | VDG_L | OAD_ | HIGH |
|--------|----|----|------|--------|--------|-------|------|---------|---------|-------|--------|----|----|-------|------|------|
| Bit    | 31 | 30 | 29   | 28     | 27     | 26    | 25   | 24      | 23      | 22    | 21     | 20 | 19 | 18    | 17   | 16   |
| Name   |    |    |      |        |        |       |      | Rese    | erved   |       |        |    |    |       |      |      |
| Туре   |    |    |      |        |        |       |      | R       | 0       |       |        |    |    |       |      |      |
| 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   |    |    |      |        |        |       |      | wdg_lo  | ad_high |       |        |    |    |       |      |      |
| Type   |    | RW |      |        |        |       |      |         |         |       |        |    |    |       |      |      |
| Reset  | 0  | 0  | 0    | 0      | 0      | 0     | 0    | 0       | 0       | 0     | 0      | 0  | 0  | 0     | 1    | 1    |

| Field Name    | Bit     | R/W | Reset Value | Description                  |
|---------------|---------|-----|-------------|------------------------------|
|               | [31:16] | RO  | 16'h0       | Reserved                     |
| wdg_load_high | [15:0]  | RW  | 16'h0003    | See wdg_load_low description |

## 5.10.5.2.3 WDG\_CTRL

Description: Watchdog control



| 0x0008 |    |    | Watc                                                                                                                        | hdog     | contro | l (Rese | et 0x00 | 000_00 | 00) |   |   |   |   | 1 | WDG_CTRL    |                  |
|--------|----|----|-----------------------------------------------------------------------------------------------------------------------------|----------|--------|---------|---------|--------|-----|---|---|---|---|---|-------------|------------------|
| Bit    | 31 | 30 | 29         28         27         26         25         24         23         22         21         20         19         18 |          |        |         |         |        |     |   |   |   |   |   | 17          | 16               |
| Name   |    |    |                                                                                                                             | Reserved |        |         |         |        |     |   |   |   |   |   |             |                  |
| Туре   |    |    |                                                                                                                             |          |        |         |         | R      | 0   |   |   |   |   |   |             |                  |
| 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   |    |    |                                                                                                                             |          |        |         | Rese    | erved  |     |   |   |   |   |   | wdg<br>_run | wdg<br>_mo<br>de |
| Туре   |    |    | RO                                                                                                                          |          |        |         |         |        |     |   |   |   |   |   | RW          | RW               |
| Reset  | 0  | 0  | 0                                                                                                                           | 0        | 0      | 0       | 0       | 0      | 0   | 0 | 0 | 0 | 0 | 0 | 0           | 0                |

| Field Name | Bit    | R/W | Default Value | Description                                               |
|------------|--------|-----|---------------|-----------------------------------------------------------|
|            | [31:2] | RO  | 30'h0         | Reserved                                                  |
| wdg_run    | [1]    | RW  | 1'h0          | Watchdog counter open: 0: counter stops. 1: counter runs. |
| wdg_mode   | [0]    | RW  | 1'h0          | Watchdog mode 0: reset mode 1: interrupt mode             |

## 5.10.5.2.4 WDG\_INT\_CLR

Description: Watchdog interrupt clear

| 0x000C |    |                                                                                                                                                   | Watc                      | hdog | interru | pt clea | r (Res | set 0x0  | 000_0 | 000) |   |   |   | WD | G_INT | CLR                 |
|--------|----|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------|---------|---------|--------|----------|-------|------|---|---|---|----|-------|---------------------|
| Bit    | 31 | 30         29         28         27         26         25         24         23         22         21         20         19         18         17 |                           |      |         |         |        |          |       |      |   |   |   | 16 |       |                     |
| Name   |    |                                                                                                                                                   | Reserved                  |      |         |         |        |          |       |      |   |   |   |    |       |                     |
| Туре   |    | 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   |    |                                                                                                                                                   |                           |      |         |         |        | Reserved | d     |      |   |   |   |    |       | wdg<br>_int_<br>clr |
| Туре   |    | RO                                                                                                                                                |                           |      |         |         |        |          |       |      |   |   |   | WO |       |                     |
| Reset  | 0  | 0                                                                                                                                                 | 0                         | 0    | 0       | 0       | 0      | 0        | 0     | 0    | 0 | 0 | 0 | 0  | 0     | 0                   |

| Field Name  | Bit    | R/W | Default Value | Description                                                     |
|-------------|--------|-----|---------------|-----------------------------------------------------------------|
|             | [31:1] | RO  | 31'h0         | Reserved                                                        |
| wdg_int_clr | [0]    | WO  | 1'h0          | Watchdog interrupt clear Write 1 to this bit to clear interrupt |



## 5.10.5.2.5 WDG\_INT\_RAW

Description: Watchdog interrupt raw status

| 0x0010 |    |    | Watc                                                                                                                                   | hdog | interru | pt raw   | status | s (Res | et 0x0( | 000_00 | 000) |                    |   | WDG      | WDG_INT_RAW |                     |  |
|--------|----|----|----------------------------------------------------------------------------------------------------------------------------------------|------|---------|----------|--------|--------|---------|--------|------|--------------------|---|----------|-------------|---------------------|--|
| Bit    | 31 | 30 | 29         28         27         26         25         24         23         22         21         20         19         18         17 |      |         |          |        |        |         |        |      |                    |   | 16       |             |                     |  |
| Name   |    |    |                                                                                                                                        |      |         |          |        | Rese   | erved   |        |      |                    |   |          |             |                     |  |
| Туре   |    | 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   |    |    |                                                                                                                                        |      | ı       | Reserved | i      |        |         |        |      | wdg<br>_ld_<br>bus |   | Reserved | 1           | wdg<br>_int_<br>raw |  |
| Туре   |    | RO |                                                                                                                                        |      |         |          |        |        |         |        |      |                    |   | RO       |             | RO                  |  |
| Reset  | 0  | 0  | 0                                                                                                                                      | 0    | 0       | 0        | 0      | 0      | 0       | 0      | 0    | 0                  | 0 | 0        | 0           | 0                   |  |

| Field Name  | Bit    | R/W | Default Value | Description                                                                                                         |
|-------------|--------|-----|---------------|---------------------------------------------------------------------------------------------------------------------|
|             | [31:5] | RO  | 27'h0         | Reserved                                                                                                            |
| wdg_ld_busy | [4]    | RO  | 1'h0          | Watchdog load busy status  0: Watchdog is ready for new loading  1: Last loading is not completed                   |
|             |        |     |               | Software must not load new value when this bit is busy, that is, this bit should be checked before any new loading. |
|             |        |     |               | This bit is set after a new loading, and lasts two or three RTC clock cycles, about 60us - 92us.                    |
|             | [3:1]  | RO  | 3'h0          | Reserved                                                                                                            |
| wdg_int_raw | [0]    | RO  | 1'h0          | Watchdog interrupt raw status                                                                                       |

# 5.10.5.2.6 WDG\_INT\_MASK

Description: Watchdog interrupt mask status



| 0x0014 |    |                           | Watc | hdog     | interru | pt mas | sk stat | us (Re   | set 0x | 0000_ | 0000) |    |    | WDG | _INT_N | //ASK                    |
|--------|----|---------------------------|------|----------|---------|--------|---------|----------|--------|-------|-------|----|----|-----|--------|--------------------------|
| Bit    | 31 | 30                        | 29   | 28       | 27      | 26     | 25      | 24       | 23     | 22    | 21    | 20 | 19 | 18  | 17     | 16                       |
| Name   |    |                           |      | Reserved |         |        |         |          |        |       |       |    |    |     |        |                          |
| Type   |    |                           |      |          |         |        |         | R        | 0      |       |       |    |    |     |        |                          |
| 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   |    |                           |      |          |         |        | ı       | Reserved | i      |       |       |    |    |     |        | wdg<br>_int_<br>mas<br>k |
| Туре   |    |                           |      | RO       |         |        |         |          |        |       |       |    |    |     | RO     |                          |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |      |          |         |        |         |          |        |       |       | 0  |    |     |        |                          |

| Field Name   | Bit    | R/W | Default Value | Description                      |
|--------------|--------|-----|---------------|----------------------------------|
|              | [31:1] | RO  | 31'h0         | Reserved                         |
| wdg_int_mask | [0]    | RO  | 1'h0          | Watchdog interrupt masked status |

## 5.10.5.2.7 WDG\_CNT\_LOW

Description: Low 16 bit of watchdog counter value

| 0x0018 |                           |                                                 | Low | 16 bit | of wat | chdog | count | er valu | ıe (Res | set 0x0 | 000_F | FFF) |   | WDG | _CNT_ | LOW |
|--------|---------------------------|-------------------------------------------------|-----|--------|--------|-------|-------|---------|---------|---------|-------|------|---|-----|-------|-----|
| Bit    | 31                        | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |     |        |        |       |       |         |         |         |       |      |   | 16  |       |     |
| Name   |                           |                                                 |     |        |        |       |       | Rese    | erved   |         |       |      |   |     |       |     |
| Туре   |                           |                                                 |     |        |        |       |       | R       | 0       |         |       |      |   |     |       |     |
| 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   |                           |                                                 |     |        |        |       |       | wdg_c   | nt_low  |         |       |      |   |     |       |     |
| Туре   |                           | RO                                              |     |        |        |       |       |         |         |         |       |      |   |     |       |     |
| Reset  | 1 1 1 1 1 1 1 1 1 1 1 1 1 |                                                 |     |        |        |       |       |         |         |         |       | 1    |   |     |       |     |

| Field Name  | Bit     | R/W | Reset Value | Description                                                                                                                                                                                                                   |
|-------------|---------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | [31:16] | RO  | 16'h0       | Reserved                                                                                                                                                                                                                      |
| wdg_cnt_low | [15:0]  | RO  | 16'hFFFF    | wdg_cnt_low: Low 16 bit of watchdog timer counter value. wdg_cnt_high: High 16 bit of watchdog timer counter value. wdg_cnt_low and wdg_cnt_high are used together.  This read-only register indicates current counter value. |



| Field Name | Bit | R/W | Reset Value | Description                                                                                                                                |
|------------|-----|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
|            |     |     |             | It's not recommended to read this register in normal usage.                                                                                |
|            |     |     |             | Because the counter is in different clock domain with APB, software needs use double-reading method to read this value, like system timer. |

## 5.10.5.2.8 WDG\_CNT\_HIGH

Description: High 16 bit of watchdog counter value

| 0x001C |    |                           | High                                         | 16bit | of wate | chdog | count | er valu | e (Res  | set 0x0 | 000_F | FFF) |   | WDG | CNT_ | HIGH |
|--------|----|---------------------------|----------------------------------------------|-------|---------|-------|-------|---------|---------|---------|-------|------|---|-----|------|------|
| Bit    | 31 | 30                        | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |       |         |       |       |         |         |         |       |      |   |     |      | 16   |
| Name   |    |                           | Reserved                                     |       |         |       |       |         |         |         |       |      |   |     |      |      |
| Туре   |    |                           |                                              |       |         |       |       | R       | 0       |         |       |      |   |     |      |      |
| 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   |    |                           |                                              |       |         |       |       | wdg_c   | nt_high |         |       |      |   |     |      |      |
| Туре   |    |                           | RO                                           |       |         |       |       |         |         |         |       |      |   |     |      |      |
| Reset  | 1  | 1 1 1 1 1 1 1 1 1 1 1 1 1 |                                              |       |         |       |       |         |         |         |       |      |   |     |      |      |

| Field Name   | Bit     | R/W | Reset Value | Description                  |  |  |  |
|--------------|---------|-----|-------------|------------------------------|--|--|--|
|              | [31:16] | RO  | 16'h0       | Reserved                     |  |  |  |
| wdg_cnt_high | [15:0]  | RO  | 16'hFFFF    | See wdg_cnt_low description. |  |  |  |

## 5.10.5.2.9 WDG\_LOCK

Description: Watchdog lock control

| 0x0020 |    |                             | Watc | hdog | lock co | ontrol | (Reset | 0x000 | 000_0 | 0) |    |    |    | ٧  | VDG_L | оск |
|--------|----|-----------------------------|------|------|---------|--------|--------|-------|-------|----|----|----|----|----|-------|-----|
| Bit    | 31 | 30                          | 29   | 28   | 27      | 26     | 25     | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17    | 16  |
| Name   |    |                             |      |      |         |        |        | Rese  | erved |    |    |    |    |    |       |     |
| Туре   |    |                             |      |      |         |        |        | R     | .0    |    |    |    |    |    |       |     |
| 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   |    |                             |      |      |         |        |        | wdg.  | _lock |    |    |    |    |    |       |     |
| Туре   |    | RW                          |      |      |         |        |        |       |       |    |    |    |    |    |       |     |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |      |      |         |        |        |       |       |    |    |    |    |    |       |     |



| Field Name | Bit     | R/W | Reset Value | Description                                                                                                                                                                                                |
|------------|---------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:16] | RO  | 16'h0       | Reserved                                                                                                                                                                                                   |
| wdg_lock   | [15:0]  | RW  | 16'h0       | Watchdog lock control Write 16'hE551 to this register to unlock watchdog. Write other value to this register to lock watchdog If reading this register, bit-0 is lock status, and other bits are reserved. |
|            |         |     |             | If watchdog is locked, all control registers cannot be written by software.                                                                                                                                |

## 5.10.6 Application Notes

When software uses watchdog, it should set wdg\_eb bit and wdg\_rtc\_eb bit in global control register, and also should guarantee arch\_rtc\_eb is set.

Before configuring watchdog, software should write 16'hE551 to wdg\_lock to unlock watchdog.

Then Software configures all control registers – wdg\_load\_low, wdg\_load\_high and wdg\_mode.

IMPORTANT: wdg\_load\_high should always be configured before writing wdg\_load\_low.

Then wdg\_run is set to 1 to open counter.

Reset mode is used as normal watchdog function. After enabled, watchdog timer can be loaded at any time, and software should guarantee the timer is reloaded before it decreases to 0.

Whenever watchdog timer gets to 0, system reset is issued. Then system reboots, and watchdog timer comes back to 32'hFFFF\_FFFF, and all controlled registers and status also come back to reset value, except interrupt raw status. Interrupt raw status can be used to judge if or not system rebooting comes from watchdog reset.

For interrupt mode, watchdog timer runs as a periodic generic timer. If watchdog timer gets to 0, an interrupt is issued, and then the timer is reloaded automatically.

After receiving interrupt, software can check interrupt status by reading wdg\_int\_mask, and can clear interrupt by writing 1 to wdg\_int\_clr.

Interrupt mode is used as debug mode or as a generic periodic timer.

When software completes using watchdog, it should disable wdg\_run firstly, then it disable wdg\_rtc\_eb and wdg\_eb in global control registers.

It's IMPORTANT that only writing wdg\_load\_high cannot reload watchdog. Both wdg\_load\_low and wdg\_load\_high should be written if watchdog need reloaded. And software must write wdg\_load\_high firstly, then write wdg\_load\_low.



Another IMPORTANT thing is that there are 2-3 RTC clock cycles delay from setting wdg\_load\_low to counter setting success because of different clock domains, that is, if N is configured in {wdg\_load\_high,wdg\_load\_low}, real counting number is N+2 or N+3.

And during this 2-3 RTC clock cycles loading time, any new loading operation is forbidden. Watchdog provides a bit, wdg\_ld\_busy, for software to indicate if counter is busy in last loading. And software should check this bit before any new loading.

It's not recommended to read counter value in normal usage. Because the counter is binary-code counter, not gray-code, and is in different clock domain with APB, software needs use double-reading method to read this value, like system timer.

## 5.11 System Timer

### 5.11.1 Overview

System timer is a 32-bit free-running increasing timer with 1ms step.

#### 5.11.2 Features

- I RTC-clock trigged
- I 32-bit free-running increasing timer
- I 1ms step
- I Support one configurable alarm, and support alarm interrupt generating
- I Alarm interrupt can be used as wakeup source during deep sleep

## 5.11.3 Signal Description

Null

### 5.11.4 Function Description

After hardware reset, system timer is 0. And after enabled, system timer runs from 0 to the maximum, 2^32-1. if system timer gets to the maximum, it return to 0 again and then continue increasing. If no new hardware reset occurs and system timer is kept enabled, nothing can stop system timer.

The counting step is 1ms, that is, the timer increases by 1 per 1ms.



The timer value can be read by software. But double-reading method must be used because of different clock domains.

Based on system timer free running, it provides an alarm function. When system timer value is equal to alarm value, an interrupt is issued, and this interrupt can be used for system wakeup source during deep sleep.

## 5.11.5 Control Registers

### 5.11.5.1 Memory map

ARM base address: 0x8700 3000

| Offset<br>Address | Name       | Description            |
|-------------------|------------|------------------------|
| 0x0000            | SYST_ALARM | System timer alarm     |
| 0x0004            | SYST_VALUE | System timer value     |
| 0x0008            | SYST_INT   | System timer interrupt |
|                   |            |                        |

## 5.11.5.2 Register Descriptions

### 5.11.5.2.1 SYST\_ALARM

Description: System timer alarm

| 0x0000 |    |                             | Syste | em tim                                    | er alaı | m (Re | set 0x | 0000_I | FFF)  |   |   |   | SYST_ALAF |   |   | .ARM |
|--------|----|-----------------------------|-------|-------------------------------------------|---------|-------|--------|--------|-------|---|---|---|-----------|---|---|------|
| Bit    | 31 | 30                          | 29    | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |       |        |        |       |   |   |   |           |   |   | 16   |
| Name   |    |                             | -     |                                           |         |       |        | syst_  | alarm |   |   |   |           |   |   |      |
| Туре   |    | U                           |       |                                           |         |       |        | R      | W     |   |   |   |           |   |   |      |
| 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   |    |                             |       |                                           |         |       |        | syst_  | alarm |   |   |   |           |   |   |      |
| Туре   |    | RW                          |       |                                           |         |       |        |        |       |   |   |   |           |   |   |      |
| Reset  | 1  | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |       |                                           |         |       |        |        |       |   |   |   |           |   |   |      |

| Field Name | Bit    | R/W | Reset Value  | Description                 |
|------------|--------|-----|--------------|-----------------------------|
| syst_alarm | [31:0] | RW  | 32'h0000FFFF | System timer alarm value:   |
|            |        |     |              | If system timer is equal to |



| Field Name | Bit | R/W | Reset Value | Description                            |
|------------|-----|-----|-------------|----------------------------------------|
|            |     |     |             | system alarm, one interrupt is issued. |

## 5.11.5.2.2 **SYST\_VALUE**

Description: System timer value

| 0x0004 |    |            | Syste | System timer value (Reset 0x0000_0000) |    |    |    |       |       |    |    |    | SYST_VALUE |    |    |    |
|--------|----|------------|-------|----------------------------------------|----|----|----|-------|-------|----|----|----|------------|----|----|----|
| Bit    | 31 | 30         | 29    | 28                                     | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19         | 18 | 17 | 16 |
| Name   |    | syst_value |       |                                        |    |    |    |       |       |    |    |    |            |    |    |    |
| Туре   |    |            |       | 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   |    |            |       |                                        |    |    |    | syst_ | value |    |    |    |            |    |    |    |
| Туре   |    | RO         |       |                                        |    |    |    |       |       |    |    |    |            |    |    |    |
| Reset  | 0  | 0          | 0     | 0                                      | 0  | 0  | 0  | 0     | 0     | 0  | 0  | 0  | 0          | 0  | 0  | 0  |

| Field Name | Bit    | R/W | Reset Value | Description                                                                   |
|------------|--------|-----|-------------|-------------------------------------------------------------------------------|
| syst_value | [31:0] | RO  | 32'h0       | System timer value  Double-reading method MUST be used to read this register. |

## 5.11.5.2.3 SYST\_INT

Description: System timer interrupt

|        |          |          |                       | _                             | •       |         |       |       |       |                              |                      |                                   |                              |                     |      |      |
|--------|----------|----------|-----------------------|-------------------------------|---------|---------|-------|-------|-------|------------------------------|----------------------|-----------------------------------|------------------------------|---------------------|------|------|
| 0x000C | x000C    |          |                       | em tim                        | er inte | rrupt ( | Reset | 0x000 | 0_000 | 0)                           |                      |                                   |                              |                     | SYST | _INT |
| Bit    | 31       | 30       | 29                    | 29 28 27 26 25 24 23 22 21 20 |         |         |       |       |       |                              |                      |                                   | 19                           | 18                  | 17   | 16   |
| Name   |          | Reserved |                       |                               |         |         |       |       |       |                              |                      |                                   |                              |                     |      |      |
| Туре   |          | RO       |                       |                               |         |         |       |       |       |                              |                      |                                   |                              |                     |      |      |
| Reset  | 0        | 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   | Reserved |          |                       |                               |         |         |       |       |       | syst<br>_int_<br>pls_<br>sts | syst<br>_int_<br>clr | syst<br>_int_<br>mas<br>k_st<br>s | syst<br>_int_<br>raw_<br>sts | syst<br>_int_<br>en |      |      |
| Туре   |          | RO RO    |                       |                               |         |         |       |       |       |                              |                      | RO                                | WO                           | RO                  | RO   | RW   |
| Reset  | 0        | 0        | 0                     | 0                             | 0       | 0       | 0     | 0     | 0     | 0                            | 0                    | 0                                 | 0                            | 0                   | 0    | 0    |

| Field Name    | Bit | R/W    | Default Value | Description |
|---------------|-----|--------|---------------|-------------|
| i leid Naille | Dit | 17/ 44 | Delault Value | Description |



| Field Name            | Bit    | R/W | Default Value | Description                                                               |
|-----------------------|--------|-----|---------------|---------------------------------------------------------------------------|
|                       | [31:5] | RO  | 27'h0         | Reserved                                                                  |
| syst_int_pls_sts      | [4]    | RO  | 1'h0          | System timer interrupt pulse status This bit is used only for debugging.  |
| syst_int_clr          | [3]    | WO  | 1'h0          | System timer Interrupt clear<br>Write 1 to this bit to clear<br>interrupt |
| syst_int_mask_<br>sts | [2]    | RO  | 1'h0          | System timer interrupt masked status                                      |
| syst_int_raw_st<br>s  | [1]    | RO  | 1'h0          | System timer interrupt raw status                                         |
| syst_int_en           | [0]    | RW  | 1'h0          | System timer interrupt enable                                             |

## 5.11.6 Application Notes

When software begins to use system timer, it should set sys\_eb bit and sys\_rtc\_eb bit in global control register.

When software completes using system timer, it should disable sys\_eb bit and sys\_rtc\_eb bit in global control registers.

When software uses alarm function, it should configure sys\_alarm and sys\_int\_en. After receiving interrupt issued by a system timer, software can check interrupt status by reading sys\_int\_mask\_sts, and can clear interrupt by writing 1 to sys\_int\_clr.

### IMPORTANT:

System timer is in RTC clock domain, and there is no shadow register for reading. So double-reading method MUST be used to read this register. When software wants to get system timer value, software needs read twice, and if twice numbers are the same, this value is correct, otherwise, software should repeat above operating – next twice reading and comparison.

### 5.12 MCU JTAG Interface

The MCU JTAG interface consists of the following pins.

- MTDO, test data output
- MTDI, test data input
- · MTCK, test clock
- MTMS, test mode
- MTRST\_N, test reset, active low

For JTAG timing parameters please see "JTAG Timing".



## 5.12.1 JTAG Timing



Figure 5-11 JTAG Interface Timing

Table 5-5 JTAG Interface Timing

|                    | Parameter             | Min | Typical | Мах     | Units |
|--------------------|-----------------------|-----|---------|---------|-------|
| Symbol             |                       |     |         |         |       |
| t <sub>TCKCY</sub> | TCK period            | 100 | 200     | 1000000 | ns    |
| t <sub>TCKH</sub>  | TCK pulse width high  | 50  | 100     | 500000  | ns    |
| t <sub>TCKL</sub>  | TCK pulse width low   | 50  | 100     | 500000  | ns    |
| t <sub>SUTMS</sub> | TMS Input Set-up Time | 44  | _       | -       | ns    |
| t <sub>HTMS</sub>  | TMS Input Hold Time   | 6   | _       | _       | ns    |
| t <sub>SUTDI</sub> | TDI Input Set-up Time | 44  | _       | -       | ns    |
| t <sub>HTDI</sub>  | TDI Input Hold Time   | 15  | -       | _       | ns    |
| t <sub>DO</sub>    | TDO Data Output Delay | 6   | _       | ?       | ns    |



# **6 Micro-Controller Unit Peripherals**

### 6.1 USB Device Interface

### 6.1.1 Overview

The USB interface is a USB device-only controller, fully compliant with the USB 2.0 Specification. The USB 2.0 configurations support high-speed(HS, 480-Mbps), full-speed(FS,12-Mbps), and low-speed(LS, 1.5-Mps) transfers. USB core connects to the industry-standard AMBA High-Performance Bus (AHB) to communicate with the application and system memory, and is fully compliant with AMBA specification, Revision 2.0.

### 6.1.2 Features

### 6.1.2.1 General Features

- I Supports different clocks for AHB and the PHY interfaces for ease of integration
- Uses the coreConsultant utility to configure the core to user requirements
- I Includes USB power management features
- I Supports packet-based, Dynamic FIFO memory allocation for endpoints for small FIFOs and flexible, efficient use of RAM
- Uses single-port RAM instead of dual-port RAM for smaller area and lower power.
- I Provides support to change an endpoint's FIFO memory size
- Supports endpoint FIFO sizes that are not powers of 2, to allow the use of contiguous memory locations
- I Supports the Keep-alive in Low-Speed mode and SOFs in High/Full-Speed modes
- I Power-optimized design

#### 6.1.2.2 Application Features

- I Interfaces for the application via the AHB:
  - n AHB Slave interface for accessing Control and Status Registers(CSRs),the Data FIFO, and queues
  - n Optional AHB Master interface for Data FIFO access when Internal DMA is
- Supports only 32-bits data on the AHB
- I Supports Little or Big Endian mode(selectable by pin, In our case, the pin is tied to 1'b1 for Big Endian)
- Supports all AHB burst types in AHB Slave interface
- Supports Split, Retry, and Error AHB responses on the AHB Master interface; these are not generated on the AHB Slave interface(That means core itself will not generate split response, but as a master, it can handle split response as retry response. In our case, the AHB bus does not support split transfer, so there won't be any split response occurred.)
- I Software-selectable AHB burst type on AHB Master interface
  - n If INCR4 is chosen, core only uses INCR4.
  - **n** If INCR8 is chosen, core normally uses INCR8, but at the beginning and at the end of a transfer, it can use INCR4, depending on the size of the transfer.
  - n If INCR8 is chosen, core normally uses INCR8, but at the beginning and at the end of a transfer, it can use INCR4, depending on the size of the transfer.
  - n If INCR16 is chosen, core normally uses INCR16, but at the beginning and at the end of a transfer, it can use INCR4/INCR8, depending on the size of the transfer.



- I Handles the fixed burst address alignment. For example, INCR16 is used only when lower addresses [5:0] are all 0.
- I Generates AHB Busy cycles on the AHB Master interface
- I Takes care of the 1KB boundary breakup.
- I Includes optional interface to an external DMA controller; data is transferred through the AHB Slave interface.

#### 6.1.2.3 USB 2.0 Supported Features

- Complies with the On-The-Go Supplement to the USB 2.0 Specification (Revision 1.0a)
- I Operates in High-Speed (HS, 480-Mbps), Full-Speed (FS, 12-Mbps) and Low-Speed (LS, 1.5-Mbps) modes
- Supports the UTMI+ Level 3 interface (Revision 1.0, February 25th, 2004). 8-, 16-, and 8/16-bit data buses are supported.
- Supports ULPI interface (Revision 1.1rc, September 1st, 2004) 8-bit SDR, 4-bit DDR, 6-pin Serial, 3- pin Serial
- I Includes automatic ping capabilities

## 6.1.2.4 Power Optimization Features

- I AHB clock gating support during USB Suspend and Session-Off modes
- I Data FIFO RAM chip-select deasserted when not active
- I Data FIFO RAM clock-gating support

## 6.1.3 Signal Description

### Table 6-1 USB interface pins

| Ball<br>No | Signal<br>Name | Pin Name | Туре | Power  | Value<br>During<br>Reset | Value<br>After<br>Reset | Description             |
|------------|----------------|----------|------|--------|--------------------------|-------------------------|-------------------------|
|            |                | DP       | AIO  | VDDUSB | NA                       | NA                      | USB data line, positive |
|            |                | DM       | AIO  | VDDUSB | NA                       | NA                      | USB data line, negative |
|            | tx_enable      | LCD_D9   | 0    | VDDUSB | NA                       | NA                      | TLL mode tx enable      |
|            | tx_dat         | LCD_D10  | 0    | VDDUSB | NA                       | NA                      | TLL mode tx data 1      |
|            | tx_se0         | LCD_D11  | 0    | VDDUSB | NA                       | NA                      | TLL mode tx data 0      |
|            | suspend_out    | LCD_D8   | 0    | VDDUSB | NA                       | NA                      | TLL mode suspend signal |
|            | rx_rcv         | LCD_D15  | I    | VDDUSB | NA                       | NA                      | TLL mode rx receive     |
|            | rx_dm          | LCD_D14  | 1    | VDDUSB | NA                       | NA                      | TLL mode rx data 0      |
|            | rx_dp          | LCD_D13  | I    | VDDUSB | NA                       | NA                      | TLL mode rx data 1      |
|            | int            | LCD_D12  | I    | VDDUSB | NA                       | NA                      | TLL mode interrupt      |





Figure 6-1 TLL mode connection

## 6.1.4 Function Description

The following figure shows the DWC\_otg controller in a typical system. The core interfaces are summarized in the following subsections.





### Figure 6-2 System-Level Block Diagram

## 6.1.5 Control Registers

By reading from and writing to the Control and Status Registers (CSRs) through the AHB Slave interface, your application controls the DWC\_otg core. These registers are 32 bits wide, and the addresses are 32-bit block aligned.

Only the Core Global, Power and Clock Gating, Data FIFO Access, and Host Port registers can be accessed in both Host and Device modes. When the DWC\_otg core is operating in one mode, either Device or Host, the application must not access registers from the other mode. If an illegal access occurs, a Mode Mismatch interrupt is generated and reflected in the Core Interrupt register (GINTSTS.ModeMis).

The CSR address map is fixed and does not depend on the core's configuration (for example, how many endpoints are implemented). Host and Device mode registers occupy different addresses. All registers are implemented in the AHB Clock domain.

### **6.1.5.1** Memory map

ARM base address: 0x2030 0000

| Offset Address  | Name       | Description                      |
|-----------------|------------|----------------------------------|
| 0x0008          | GAHBCFG    | Global AHB Configure             |
| 0x000C          | GUSBCFG    | Global USB Configure             |
| 0x0010          | GRSTCTL    | Global Reset Contrl              |
| 0x0018          | GINTMSK    | Global Interrupt Mask            |
| 0x001C          | GRXSTSR    | Global RX Status Register        |
| 0x0020          | GRXSTSP    | Global RX Status POP             |
| 0x0024          | GRXFSIZ    | Global RX FIFO Size              |
| 0x0028          | GNPTXFSIZ  | Global NON-Periodic TX FIFO Size |
| 0x002C          | GNPTXSTS   | Global NON-Periodic TX Status    |
| 0x0040          | GSNPSID    | Global Synopsys ID               |
| 0x0044          | GHWCFG1    | Global Hardware Configuration 1  |
| 0x0048          | GHWCFG2    | Global Hardware Configuration 2  |
| 0x004C          | GHWCFG3    | Global Hardware Configuration 3  |
| 0x0050          | GHWCFG4    | Global Hardware Configuration 4  |
| 0x0104+(n-1)*04 | DPTXFSIZn  | IN Endpoint Tx FIFO Size n       |
| 0x0800          | DCFG       | Device Configure                 |
| 0x0804          | DCTL       | Device Contrl                    |
| 0x0808          | DSTS       | Device Status                    |
| 0x0810          | DIEPMSK    | Device In Endpoint Mask          |
| 0x0814          | DOEPMSK    | Device Out Endpoint Mask         |
| 0x0818          | DAINT      | Device All Interrupt             |
| 0x081C          | DAINTMSK   | Device All Interrupt Mask        |
| 0x0834          | DIEPEMPMSK | Device In Endpoint Empty Mask    |
| 0x0900          | DIEPCTL0   | Device In Endpoint Control 0     |



| Offset Address          | Name      | Description                         |
|-------------------------|-----------|-------------------------------------|
| 0x0B00                  | DOEPCTL0  | Device Out Endpoint Control 0       |
| IN EP:<br>0x900+(n*20)  | DIEPCTLn  | Device In Endpoint Control n        |
| OUT EP:<br>0xB00+(n*20) | DOEPCTLn  | Device Out Endpoint Control n       |
| IN EP:<br>0x908+(n*20)  | DIEPINTn  | Device In Endpoint Int n            |
| OUT EP:<br>0xB08+(n*20) | DOEPINTn  | Device Out Endpoint Int n           |
| 0x0910                  | DIEPTSIZ0 | Device In Endpoint Transfer Size 0  |
| 0x0B10                  | DOEPTSIZ0 | Device Out Endpoint Transfer Size 0 |
| IN EP:<br>0x910+(n*20)  | DIEPTSIZn | Device In Endpoint Transfer Size n  |
| OUT EP:<br>0xB10+(n*20) | DOEPTSIZn | Device Out Endpoint Transfer Size n |
| IN EP:<br>0x914+(n*20)  | DIEPDMAn  | Device In Endpoint DMA n            |
| OUT EP:<br>0xB14+(n*20) | DOEPDMAn  | Device Out Endpoint DMA n           |
| 0x918h+(n*20h)          | DTXFSTSn  | Device TX FIFO Status n             |
| 0x0E00                  | PCGCCTL   | Power and Clock Gating Control      |

## 6.1.5.2 Register Descriptions

## 6.1.5.2.1 GAHBCFG

Description: (Global AHB Configure)

| 0x0008 |    | •        | Glob | al AHE            | 3 Conf | igure(r | reset 0 | x0000 | _0000) |    | •             | GAHBCI  |    |    |    | BCFG                    |
|--------|----|----------|------|-------------------|--------|---------|---------|-------|--------|----|---------------|---------|----|----|----|-------------------------|
| Bit    | 31 | 30       | 29   | 28                | 27     | 26      | 25      | 24    | 23     | 22 | 21            | 20      | 19 | 18 | 17 | 16                      |
| Name   |    | Reserved |      |                   |        |         |         |       |        |    |               |         |    |    |    |                         |
| Туре   |    | RO       |      |                   |        |         |         |       |        |    |               |         |    |    |    |                         |
| 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   |    | Reserved |      |                   |        |         |         |       |        |    | DM<br>A<br>EN | HBSTLEN |    |    |    | GLB<br>LINT<br>RMS<br>K |
| Туре   |    | RO RW    |      |                   |        |         |         |       |        |    |               | RW F    |    |    | RW |                         |
| Reset  | 0  | 0        | 0    | 0                 | 0      | 0       | 0       | 0     | 0      | 0  | 0             |         | 4' | b0 |    | 0                       |

| Field Name | Bit | Туре | Reset<br>Value | Description |
|------------|-----|------|----------------|-------------|
|------------|-----|------|----------------|-------------|



| DMAEN       | [5]   | RO  | 1'b0 | 1'b0: Core operates in Slave mode     1'b1: Core operates in a DMA mode  This bit is always 0 when Slave-Only mode has been                                                                                                                                                                               |
|-------------|-------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |       |     |      | selected for the Architecture in coreConsultant (parameter OTG_ARCHITECTURE = 0).                                                                                                                                                                                                                         |
| HBSTLEN     | [4:1] | R/W | 1'b0 | Internal DMA Mode—AHB Master burst type:  • 4'b0000 Single  • 4'b0001 INCR  • 4'b0011 INCR4  • 4'b0101 INCR8  • 4'b0111 INCR16  • Others: Reserved                                                                                                                                                        |
| GLBLINTRMSK | [0]   | R/W | 1'b0 | The application uses this bit to mask or unmask the interrupt line assertion to itself. Irrespective of this bit's setting, the interrupt status registers are updated by the core.  • 1'b0: Mask the interrupt assertion to the application.  • 1'b1: Unmask the interrupt assertion to the application. |

## 6.1.5.2.2 GUSBCFG

Description: (Global USB Configure)

| 0x000C |                                     |                          | Glob             | Global USB Configure (reset 0x0000_1400) |               |        |                  |    |            |                            |                           |           | GUSBCFG                 |                         |                  |                  |
|--------|-------------------------------------|--------------------------|------------------|------------------------------------------|---------------|--------|------------------|----|------------|----------------------------|---------------------------|-----------|-------------------------|-------------------------|------------------|------------------|
| Bit    | 31                                  | 30                       | 29               | 28                                       | 27 26 25 24 2 |        |                  |    |            | 22                         | 21                        | 20        | 19                      | 18                      | 17               | 16               |
| Name   | CO<br>RRU<br>PT<br>TX<br>PAC<br>KET | FOR<br>CED<br>EVM<br>ODE | Res<br>erve<br>d | TXE<br>NDD<br>ELA<br>Y                   | Reserved      |        |                  |    |            | Ter<br>msel<br>dlpul<br>se | Reserved                  |           | ULPI<br>CLK<br>SUS<br>M | ULP<br>IAU<br>TOR<br>ES | ULPI<br>FSL<br>S | Res<br>erve<br>d |
| Туре   | RW                                  | RW                       |                  | RW                                       |               |        |                  |    |            | RW                         |                           |           | RW                      | RW                      | RW               |                  |
| Reset  | 0                                   | 0                        | 0                | 0                                        | 5'b0          |        |                  |    |            | 0                          | 2'b0                      |           | 0                       | 0                       | 0                | 0                |
| Bit    | 15                                  | 14                       | 13               | 12                                       | 11 10 9 8     |        |                  |    | 7          | 6                          | 5                         | 4         | 3                       | 2                       | 1                | 0                |
| Name   | PHY<br>LPW<br>RCL<br>KSE<br>L       | Res<br>erve<br>d         |                  | Usbtrdtim                                |               |        | Reserved DDR SEL |    | PHY<br>SEL | FSI<br>NTF                 | ULPI<br>_UT<br>MI_<br>SEL | PHY<br>IF | TOUTCAL                 |                         | L                |                  |
| Туре   | RW                                  |                          | RW               |                                          |               | RW     |                  | RW | RW         | RW                         | RW                        | RW        | RW                      |                         |                  |                  |
| Reset  | 0                                   | 0                        | 4'h5             |                                          |               | 2'b0 0 |                  | 0  | 0          | 0                          | 0                         | 0         | 3'b00                   |                         |                  |                  |

| Field Name           | Bit  | Туре | Reset<br>Value | Description                                                                                             |
|----------------------|------|------|----------------|---------------------------------------------------------------------------------------------------------|
| CORRUPT TX<br>PACKET | [31] | R/W  | 1'b0           | This bit is for debug purposes only. Never set this bit to 1.                                           |
| FORCEDEVMODE         | [30] | R/W  | 1'b0           | Writing a 1 to this bit forces the core to device mode irrespective of utmiotg_iddig input pin. • 1'b0: |



|                |         |     |       | Normal Mode • 1'b1: Force Device Mode After setting the force bit, the application must wait at least 25 ms before the change to take effect. When the simulation is in scale down mode, waiting for 500 us is sufficient.                                                                                                                                                                                                                                                                                          |
|----------------|---------|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [29]    | RO  | 1'b0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| TXENDDELAY     | [28]    | R/W | 1'b0  | Writing a 1 to this bit enables the TxEndDelay timers in the core as per the section 4.1.5 on Opmode of the USB 2.0 Transceiver Macrocell Interface (UTMI) version 1.05.  • 1'b0: Normal mode  • 1'b1: Introduce Tx end delay timers                                                                                                                                                                                                                                                                                |
|                | [27:23] | RO  | 5'b0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| TERMSELDLPULSE | [22]    | R/W | 1'b0  | This bit selects utmi_termselect to drive data line pulse during SRP.  • 1'b0: Data line pulsing using utmi_txvalid (default).  • 1'b1: Data line pulsing using utmi_termsel.                                                                                                                                                                                                                                                                                                                                       |
|                | [21:20] | RO  | 2'b00 | Host only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ULPICLKSUSM    | [19]    | R/W | 1'b0  | This bit sets the ClockSuspendM bit in the Interface Control register on the ULPI PHY. This bit applies only in serial modes.  1'b0: PHY powers down internal clock during suspend.  1'b1: PHY does not power down internal clock.                                                                                                                                                                                                                                                                                  |
| ULPIAUTORES    | [18]    | R/W | 1'b0  | This bit sets the AutoResume bit in the Interface Control register on the ULPI PHY.  1'b0: PHY does not use AutoResume feature.  1'b1: PHY uses AutoResume feature.                                                                                                                                                                                                                                                                                                                                                 |
| ULPIFSLS       | [17]    | R/W | 1'b0  | The application uses this bit to select the FS/LS serial interface for the ULPI PHY. This bit is valid only when the FS serial transceiver is selected on the ULPI PHY.  • 1'b0: ULPI interface  • 1'b1: ULPI FS/LS serial interface                                                                                                                                                                                                                                                                                |
|                | [16]    | RO  | 1'b0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PHYLPWRCLKSEL  | [15]    | R/W | 1'b0  | Selects either 480-MHz or 48-MHz (low-power) PHY mode. In FS and LS modes, the PHY can usually operate on a 48-MHz clock to save power.  • 1'b0: 480-MHz Internal PLL clock  • 1'b1: 48-MHz External Clock In 480 MHz mode, the UTMI interface operates at either 60 or 30-MHz, depending upon whether 8- or 16-bit data width is selected. In 48-MHz mode, the UTMI interface operates at 48 MHz in FS and LS modes. This bit drives the utmi_fsls_low_power core output signal, and is valid only for UTMI+ PHYs. |
|                | [14]    | RO  | 1'b0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| USBTRDTIM      | [13:10] | R/W | 4'h5  | Sets the turnaround time in PHY clocks. Specifies the response time for a MAC request to                                                                                                                                                                                                                                                                                                                                                                                                                            |



|               |       |     |      | the Packet FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               |       |     |      | Controller (PFC) to fetch data from the DFIFO (SPRAM).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|               |       |     |      | This must be programmed to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               |       |     |      | • 4'h5: When the MAC interface is 16-bit UTMI+.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|               |       |     |      | 4'h9: When the MAC interface is 8-bit UTMI+.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | [9:8] | RO  | 2'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DDRSEL        | [7]   | R/W | 1'b0 | The application uses this bit to select a Single Data Rate (SDR) or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|               |       |     |      | Double Data Rate (DDR) or ULPI interface.  • 1'b0: Single Data Rate ULPI Interface, with 8-bit-wide data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               |       |     |      | 1'b1: Double Data Rate ULPI Interface, with 4-bit-wide data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| PHYSEL        | [6]   | R/W | 1'b0 | The application uses this bit to select either a high-speed UTMI+ or ULPI PHY, or a full-speed transceiver.  • 1'b0: USB 2.0 high-speed UTMI+ or ULPI PHY  • 1'b1: USB 1.1 full-speed serial transceiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| FSINTF        | [5]   | R/W | 1'b0 | The application uses this bit to select either a unidirectional or bidirectional USB 1.1 full-speed serial transceiver interface.  • 1'b0: 6-pin unidirectional full-speed serial interface  • 1'b1: 3-pin bidirectional full-speed serial interface                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ULPI_UTMI_SEL | [4]   | R/W | 1'b0 | The application uses this bit to select either a UTMI+ interface or ULPI Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|               |       |     |      | 1'b0: UTMI+ Interface     1'b1: ULPI Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| PHYIF         | [3]   | R/W | 1'b0 | The application uses this bit to configure the core to support a UTMI+ PHY with an 8- or 16-bit interface. When a ULPI PHY is chosen, this must be set to 8-bit mode.  • 1'b0: 8 bits • 1'b1: 16 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| TOUTCAL       | [2:0] | R/W | 3'b0 | The number of PHY clocks that the application programs in this field is added to the high-speed/full-speed interpacket timeout duration in the core to account for any additional delays introduced by the PHY. This can be required, because the delay introduced by the PHY in generating the line state condition can vary from one PHY to another.  The USB standard timeout value for high-speed operation is 736 to 816 (inclusive) bit times. The USB standard timeout value for full-speed operation is 16 to 18 (inclusive) bit times. The application must program this field based on the speed of enumeration. The number of bit times added per PHY clock are: High-speed operation: |
|               |       |     |      | One 30-MHz PHY clock = 16 bit times                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |



|  | One 60-MHz PHY clock = 8 bit times      |
|--|-----------------------------------------|
|  | Full-speed operation:                   |
|  | • One 30-MHz PHY clock = 0.4 bit times  |
|  | • One 60-MHz PHY clock = 0.2 bit times  |
|  | • One 48-MHz PHY clock = 0.25 bit times |

## 6.1.5.2.3 GRSTCTL

Description: (Global USB Configure)

| 0x0010 |                 |                | Glob     | Global Reset Contrl(reset 0x8000_0000) GRSTCTL |    |    |        |      |   |    |                 |                 | TCTL                   |                  |                 |                 |
|--------|-----------------|----------------|----------|------------------------------------------------|----|----|--------|------|---|----|-----------------|-----------------|------------------------|------------------|-----------------|-----------------|
| Bit    | 31              | 30             | 29       | 29 28 27 26 25 24 23 22 21 20 19 18 17 10      |    |    |        |      |   |    |                 | 16              |                        |                  |                 |                 |
| Name   | AHB<br>IDL<br>E | DM<br>ARE<br>Q |          | Reserved                                       |    |    |        |      |   |    |                 |                 |                        |                  |                 |                 |
| Туре   | RO              | RO             |          |                                                |    |    |        |      | R | .0 |                 |                 |                        |                  |                 |                 |
| Reset  | 1               | 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   |                 | 1              | Reserved | i                                              |    |    | TXFNUM |      |   |    | TXF<br>FLS<br>H | RXF<br>FLS<br>H | INT<br>KNQ<br>FLS<br>H | Res<br>erve<br>d | HSF<br>TRS<br>T | CSF<br>TRS<br>T |
| Туре   |                 | RO             |          |                                                |    | RW |        |      |   |    | R_<br>WS_<br>SC | R_W<br>S_S<br>C | R_W<br>S_S<br>C        | R0               | R_<br>WS_<br>SC | R_W<br>S_S<br>C |
| Reset  | 0               | 0              | 0        | 0                                              | 0  |    |        | 5'b0 |   |    | 0               | 0               | 0                      | 0                | 0               | 0               |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                     |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AHBIDLE    | [31]    | RO   | 1'b0           | Indicates that the AHB Master State Machine is in the IDLE condition.                                                                                                                                                                                                                                                                                                           |
| DMAREQ     | [30]    | RO   | 1'b0           | Indicates that the DMA request is in progress. Used for debug.                                                                                                                                                                                                                                                                                                                  |
|            | [29:11] | RO   | 19'b0          | Reserved                                                                                                                                                                                                                                                                                                                                                                        |
| TXFNUM     | [10:6]  | R/W  | 5'b0           | This is the FIFO number that must be flushed using the TxFIFO Flush bit. This field must not be changed until the core clears the TxFIFO Flush bit.  • 5'h0:  - Tx FIFO 0 flush in device mode when in dedicated FIFO mode  • 5'h1:  - TXFIFO 1 flush in device mode when in dedicated FIFO mode  • 5'h2:  - TXFIFO 2 flush in device mode when in dedicated FIFO mode  • 5'h5: |



|            |     |         |      | - TXFIFO 15 flush in device mode when in dedicated FIFO mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-----|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |     |         |      | • 5'h10: Flush all the transmit FIFOs in device or host mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TXFFLSH    | [5] | R_WS_SC | 5'b0 | This bit selectively flushes a single or all transmit FIFOs, but cannot do so if the core is in the midst of a transaction. The application must write this bit only after checking that the core is neither writing to the TxFIFO nor reading from the TxFIFO. Verify using these registers:  • Read—NAK Effective Interrupt ensures the core is not reading from the FIFO  • Write—GRSTCTL.AHBIdle ensures the core is not writing anything to the FIFO. Flushing is normally recommended when FIFOs are reconfigured or when switching between Shared FIFO and Dedicated Transmit FIFO operation. FIFO flushing is also recommended during device endpoint disable. The application must wait until the core clears this bit before performing any operations. This bit takes eight clocks to clear, using the slower clock of phy_clk or hclk. |
| RXFFLSH    | [4] | R_WS_SC | 1'b0 | The application can flush the entire RxFIFO using this bit, but must first ensure that the core is not in the middle of a transaction. The application must only write to this bit after checking that the core is neither reading from the RxFIFO nor writing to the RxFIFO. The application must wait until the bit is cleared before performing any other operations. This bit requires 8 clocks (slowest of PHY or AHB clock) to clear.                                                                                                                                                                                                                                                                                                                                                                                                        |
| INTKNQFLSH | [3] | R_WS_SC | 1'b0 | The application writes this bit to flush the IN Token Sequence Learning Queue.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|            | [2] | R/W     | 1'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| HSFTRST    | [1] | R_WS_SC | 1'b0 | The application uses this bit to flush the control logic in the AHB Clock domain. Only AHB Clock Domain pipelines are reset.  • FIFOs are not flushed with this bit.  • All state machines in the AHB clock domain are reset to the Idle state after terminating the transactions on the AHB, following the protocol.  • CSR control bits used by the AHB clock domain state machines are cleared.  • To clear this interrupt, status mask bits that control the interrupt status and are generated by the AHB clock domain state machine are cleared.  • Because interrupt status bits are not cleared, the application can get the status of any core events that occurred after it set this bit. This is a self-clearing bit that the core clears after all                                                                                     |



|         |     |         |      | take several clocks, depending on the core's current state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-----|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CSFTRST | [0] | R_WS_SC | 1'b0 | Resets the hclk and phy_clock domains as follows: • Clears the interrupts and all the CSR registers except the following register bits:  - PCGCCTL.RstPdwnModule  - PCGCCTL.GateHclk  - PCGCCTL.PwrCImp  -PCGCCTL.StopPPhyLPwrClkSelclk - GUSBCFG.PhyLPwrClkSel  - GUSBCFG.DDRSel  - GUSBCFG.DDRSel  - GUSBCFG.ULPI_UTMI_Sel  - GUSBCFG.HYIf  - HCFG.FSLSPclkSel  - DCFG.DevSpd  - GGPIO  • All module state machines (except the AHB Slave Unit) are reset to the IDLE state, and all the transmit FIFOs and the receive FIFO are flushed.  • Any transactions on the AHB Master are terminated as soon as possible, after gracefully completing the last data phase of an AHB transfer. Any transactions on the USB are terminated immediately.  The application can write to this bit any time it wants to reset the core. This is a self-clearing bit and the core clears this bit after all the necessary logic is reset in the core, which can take several clocks, depending on the current state of the core. Once this bit is cleared software must wait at least 3 PHY clocks before doing any access to the PHY domain (synchronization delay). Software must also must check that bit 31 of this register is 1 (AHB Master is IDLE) before starting any operation.  Typically software reset is used during software development and also when you dynamically change the PHY, the corresponding clock for the PHY is selected and used in the PHY domain. Once a new clock is selected, the PHY domain has to be reset for proper operation. |

## 6.1.5.2.4 GINTSTS

Description: (Global Interrupt Status)



| 0x0014 |                 |                        | Glob             | lobal Interrupt Status(reset 0x0000_0020) |                 |                  |    |                        |                   |                  |                              |                         |                 |                 | GIN             | TSTS             |
|--------|-----------------|------------------------|------------------|-------------------------------------------|-----------------|------------------|----|------------------------|-------------------|------------------|------------------------------|-------------------------|-----------------|-----------------|-----------------|------------------|
| Bit    | 31              | 30                     | 29               | 28                                        | 27              | 26               | 25 | 24                     | 23                | 22               | 21                           | 20                      | 19              | 18              | 17              | 16               |
| Name   | WK<br>UPI<br>NT | SES<br>SRE<br>QIN<br>T | Res<br>erve<br>d | CON<br>IDST<br>SCH<br>NG                  |                 | Reserved         |    |                        | RES<br>ETD<br>ET  | FET<br>SUS<br>P  | INC<br>OM<br>PIS<br>OO<br>UT | INC<br>OM<br>PIS<br>OIN | OEP<br>INT      | IEPI<br>NT      | EPM<br>IS       | Res<br>erve<br>d |
| Туре   | R_S<br>S_W<br>C | R_S<br>S_W<br>C        |                  | R_S<br>S_W<br>C                           |                 |                  |    |                        |                   | R_S<br>S_W<br>C  | R_S<br>S_W<br>C              | R_S<br>S_W<br>C         | RO              | RO              | RO              |                  |
| Reset  | 0               | 0                      | 0                | 0                                         |                 | 4'l              | b0 |                        | 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   | EOP<br>F        | ISO<br>OUT<br>DR<br>OP | ENU<br>MD<br>ONE | USB<br>RST                                | USB<br>SUS<br>P | SUS CII Reserved |    | GO<br>UTN<br>AKE<br>FF | GIN<br>NAK<br>EFF | NPT<br>XFE<br>MP | RXF<br>LV                    | SOF                     | OTG<br>INT      | MO<br>DEM<br>IS | CUR<br>MO<br>D  |                  |
| Туре   | R_S<br>S_W<br>C | R_S<br>S_W<br>C        | R_S<br>S_W<br>C  | R_S<br>S_W<br>C                           | R_S<br>S_W<br>C | S_W S_W          |    |                        | RO                | RO               | RO                           | RO                      | R_S<br>S_W<br>C | R_S<br>S_W<br>C | R_S<br>S_W<br>C | RO               |
| Reset  | 0               | 0                      | 0                | 0                                         | 0               | 0                | 2' | b0                     | 0                 | 0                | 1                            | 0                       | 0               | 0               | 0               | 0                |

| Field Name   | Bit     | Туре    | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|--------------|---------|---------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WKUPINT      | [31]    | R_SS_WC | 1'b0           | The Wakeup bit is same for both L1 and normal wakeup, except that Partial Power-Down cannot be used in L1. In L1, this interrupt is asserted when a host-initiated resume or a device-initiated remote wakeup is detected on the USB in Host and Device modes. In Device mode, this interrupt is asserted when a resume is detected on the USB for normal suspend. |
| SESSREQINT   | [30]    | R_SS_WC | 1'b0           | device. In Device mode, this interrupt is asserted when theutmiotg_bvalid signal goes high.                                                                                                                                                                                                                                                                        |
|              | [29]    |         | 1'b0           | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| CONIDSTSCHNG | [28]    | R_SS_WC | 1'b0           | The core sets this bit when there is a change in connector ID status.                                                                                                                                                                                                                                                                                              |
|              | [27:24] | RO      | 4'h3           | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| RESETDET     | [23]    | R/W     | 1'b0           | The core asserts this interrupt in Device mode when it detects a reset on the USB in Partial Power-Down mode when the device is in Suspend.  This interrupt is not asserted in Host mode.                                                                                                                                                                          |
| FETSUSP      | [22]    | R_SS_WC | 1'b0           | This interrupt is valid only in DMA mode. This interrupt indicates that the core has stopped fetching data for IN endpoints due to the unavailability of TxFIFO space or Request Queue space. This interrupt is used by the application for an endpoint mismatch algorithm. For example, after detecting an endpoint mismatch, the application:                    |



|              | 1    | 1       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |      |         |      | Sets a global non-periodic IN NAK handshake                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|              |      |         |      | Disables In endpoints                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|              |      |         |      | Flushes the FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              |      |         |      | Determines the token sequence from the IN<br>Token Sequence Learning Queue                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|              |      |         |      | Re-enables the endpoints                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              |      |         |      | Clears the global non-periodic IN NAK handshake                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|              |      |         |      | If the global non-periodic IN NAK is cleared, the core has not yet fetched data for the IN endpoint, and the IN token is received: the core generates an "IN token received when FIFO empty" interrupt. The OTG then sends the host a NAK response. To avoid this scenario, the application can check the GINTSTS.FetSusp interrupt, which ensures that the FIFO is full before clearing a global NAK handshake.  Alternatively, the application can mask the "IN token received when FIFO empty" interrupt when clearing a global IN NAK handshake. |
| INCOMPISOOUT | [21] | R_SS_WC | 1'b0 | The Device mode, the core sets this interrupt to indicate that there is at least one isochronous OUT endpoint on which the transfer is not completed in the current microframe. This interrupt is asserted along with the End of Periodic Frame Interrupt (EOPF) bit in this register.                                                                                                                                                                                                                                                               |
| INCOMPISOIN  | [20] | R_SS_WC | 1'b0 | The core sets this interrupt to indicate that there is at least one isochronous IN endpoint on which the transfer is not completed in the current microframe. This interrupt is asserted along with the End of Periodic Frame Interrupt (EOPF) bit in this register.                                                                                                                                                                                                                                                                                 |
| OEPINT       | [19] | RO      | 1'b0 | The core sets this bit to indicate that an interrupt is pending on one of the OUT endpoints of the core (in Device mode). The application must read the Device All Endpoints Interrupt (DAINT) register to determine the exact number of the OUT endpoint on which the interrupt occurred, and then read the corresponding Device OUT Endpoint-n Interrupt (DOEPINTn) register to determine the exact cause of the interrupt. The application must clear the appropriate status bit in the corresponding DOEPINTn register to clear this bit.        |
| IEPINT       | [18] | RO      | 1'b0 | The core sets this bit to indicate that an interrupt is pending on one of the IN endpoints of the core (in Device mode). The application must read the Device All Endpoints Interrupt (DAINT) register to determine the exact number of the IN endpoint on which the interrupt occurred, and then read the corresponding Device IN Endpoint-n Interrupt (DIEPINTn) register to determine the exact                                                                                                                                                   |



|            |         |         |      | cause of the interrupt. The application must clear the appropriate status bit in the corresponding DIEPINTn register to clear this bit.                                                                                                                                                                                                                                                                                                                                                                        |
|------------|---------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [17:16] | RO      | 2'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| EOPF       | [15]    | R_SS_WC | 1'b0 | Indicates that the period specified in the Periodic Frame Interval field of the Device Configuration register (DCFG.PerFrInt) has been reached in the current microframe.                                                                                                                                                                                                                                                                                                                                      |
| ISOOUTDROP | [14]    | R_SS_WC | 1'b0 | The core sets this bit when it fails to write an isochronous OUT packet into the RxFIFO because the RxFIFO does not have enough space to accommodate a maximum packet size packet for the isochronous OUT endpoint.                                                                                                                                                                                                                                                                                            |
| ENUMDONE   | [13]    | R_SS_WC | 1'b0 | The core sets this bit to indicate that speed enumeration is complete. The application must read the Device Status (DSTS) register to obtain the enumerated speed.                                                                                                                                                                                                                                                                                                                                             |
| USBRST     | [12]    | R_SS_WC | 1'b0 | The core sets this bit to indicate that a reset is detected on the USB.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| USBSUSP    | [11]    | R_SS_WC | 1'b0 | The core sets this bit to indicate that a suspend was detected on the USB. The core enters the Suspended state when there is no activity on the phy_line_state_i signal for an extended period of time.                                                                                                                                                                                                                                                                                                        |
| ERLYSUSP   | [10]    | R_SS_WC | 1'b0 | The core sets this bit to indicate that an Idle state has been detected on the USB for 3 ms                                                                                                                                                                                                                                                                                                                                                                                                                    |
|            | [9:8]   |         |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| GOUTNAKEFF | [7]     | RO      | 1'b0 | Indicates that the Set Global OUT NAK bit in the Device Control register (DCTL.SGOUTNak), set by the application, has taken effect in the core. This bit can be cleared by writing the Clear Global OUT NAK bit in the Device Control register (DCTL.CGOUTNak).                                                                                                                                                                                                                                                |
| GINNAKEFF  | [6]     | RO      | 1'b0 | Indicates that the Set Global Non-periodic IN NAK bit in the Device Control register (DCTL.SGNPInNak), set by the application, has taken effect in the core. That is, the core has sampled the Global IN NAK bit set by the application. This bit can be cleared by clearing the Clear Global Non-periodic IN NAK bit in the Device Control register (DCTL.CGNPInNak).  This interrupt does not necessarily mean that a NAK handshake is sent out on the USB. The STALL bit takes precedence over the NAK bit. |
| NPTXFEMP   | [5]     | RO      | 1'b1 | This interrupt is valid only when OTG_EN_DED_TX_FIFO = 0. This interrupt is asserted when the Non-periodic TxFIFO is either half or completely empty, and there is space for at least one entry to be written to the Non-periodic Transmit Request Queue. The half or completely empty status is determined by the Non-periodic TxFIFO Empty Level bit in                                                                                                                                                      |



|         |     |         |      | the Core AHB Configuration register (GAHBCFG.NPTxFEmpLvI).                                                                                                                                                                                                                                                                                                      |
|---------|-----|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RXFLVL  | [4] | RO      | 1'b0 | Indicates that there is at least one packet pending to be read from the RxFIFO.                                                                                                                                                                                                                                                                                 |
| SOF     | [3] | R_SS_WC | 2'b0 | In Device mode, in the core sets this bit to indicate that an SOF token has been received on the USB. The application can read the Device Status register to get the current (micro)frame number. This interrupt is seen only when the core is operating at either HS or FS.                                                                                    |
| OTGINT  | [2] | R_SS_WC | 1'b0 | The core sets this bit to indicate an OTG protocol event. The application must read the OTG Interrupt Status (GOTGINT) register to determine the exact event that caused this interrupt. The application must clear the appropriate status bit in the GOTGINT register to clear this bit.                                                                       |
| MODEMIS | [1] | R_SS_WC | 1'b0 | The core sets this bit when the application is trying to access:  • A Host mode register, when the core is operating in Device mode  • A Device mode register, when the core is operating in Host mode  The register access is completed on the AHB with an OKAY response, but is ignored by the core internally and does not affect the operation of the core. |
| CURMOD  | [0] | RO      | 1'b1 | Indicates the current mode.  • 1'b0: Device mode  • 1'b1: Host mode                                                                                                                                                                                                                                                                                             |

## 6.1.5.2.5 GINTMSK

Description: (Global Interrupt Mask)



| 0x0018 |                        |                               | Glob                    | al Inte                     | rrupt N                | /lask(re         | eset 0 | <0000_ | 0000)                         |                          |                                     |                                |                   |                   | GINT                   | MSK              |
|--------|------------------------|-------------------------------|-------------------------|-----------------------------|------------------------|------------------|--------|--------|-------------------------------|--------------------------|-------------------------------------|--------------------------------|-------------------|-------------------|------------------------|------------------|
| Bit    | 31                     | 30                            | 29                      | 28                          | 27                     | 26               | 25     | 24     | 23                            | 22                       | 21                                  | 20                             | 19                | 18                | 17                     | 16               |
| Name   | WK<br>UPI<br>NTM<br>SK | SES<br>SRE<br>QIN<br>TMS<br>K | Res<br>erve<br>d        | Coni<br>dsts<br>chng<br>msk |                        | Reserved         |        |        |                               | FET<br>SUS<br>PMS<br>K   | INC<br>OM<br>PIS<br>OO<br>UTM<br>SK | INC<br>OM<br>PIS<br>OIN<br>MSK | OEP<br>INT<br>MSK | IEPI<br>NTM<br>SK | EPM<br>ISM<br>SK       | Res<br>erve<br>d |
| Туре   | RW                     | RW                            |                         | RW                          |                        |                  |        |        |                               | RW                       | RW                                  | RW                             | RW                | RW                | RW                     |                  |
| Reset  | 0                      | 0                             | 0                       | 0                           |                        | 4'b0             |        |        |                               | 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   | EOP<br>FMS<br>K        | ISO<br>OUT<br>DR<br>OP<br>MSK | ENU<br>MD<br>ONE<br>MSK | USB<br>RST<br>MSK           | USB<br>SUS<br>PMS<br>K | SUS YSU Reserved |        |        | GO<br>UTN<br>AKE<br>FFM<br>SK | GIN<br>NAK<br>EFF<br>MSK | NPT<br>XFE<br>MP<br>MSK             | RXF<br>LVL<br>MSK              | SOF<br>MSK        | OTG<br>INT<br>MSK | MO<br>DEM<br>ISM<br>SK | Res<br>erve<br>d |
| Туре   | RW                     | RW                            | RW                      | RW                          | RW RW                  |                  |        | RW     | RW                            | RW                       | RW                                  | RW                             | RW                | RW                |                        |                  |
| Reset  | 0                      | 0                             | 0                       | 0                           | 0 0 2'b0               |                  |        | 0      | 0                             | 0                        | 0                                   | 0                              | 0                 | 0                 | 0                      |                  |

| Field Name      | Bit  | Туре | Reset<br>Value | Description                                    |
|-----------------|------|------|----------------|------------------------------------------------|
| WKUPINTMSK      | [31] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| SESSREQINTMSK   | [30] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| DISCONNINTMSK   | [29] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| CONIDSTSCHNGMSK | [28] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| LPM_INTMSK      | [27] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| PTXFEMPMSK      | [26] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| HCHINTMSK       | [25] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| PRTINTMSK       | [24] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| RESETDETMSK     | [23] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| FETSUSPMSK      | [22] | R/W  | 1'b0           | 1'b0: Mask Interrupt 1'b1: Unmask Interrupt    |
| INCOMPISOOUTMSK | [21] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| INCOMPISOINMSK  | [20] | R/W  | 1'b0           | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |



| OEPINTMSK     | [19] | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
|---------------|------|-----|------|------------------------------------------------|
| EPINTMSK      | [18] | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| EPMISMSK      | [17] | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
|               | [16] | RO  | 1'b0 | Reserved                                       |
| EOPFMSK       | [15] | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| ISOOUTDROPMSK | [14] | R/W |      | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| ENUMDONEMSK   | [13] | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| USBRSTMSK     | [12] | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| USBSUSPMSK    | [11] | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| ERLYSUSPMSK   | [10] | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| I2CINTMSK     | [9]  | R/W | 1'b0 | Reserved                                       |
| ULPICKINTMsk  | [8]  | R/W | 1'b0 | Reserved                                       |
| GOUTNAKEFFMSK | [7]  | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| GINNAKEFFMSK  | [6]  | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| NPTXFEMPMSK   | [5]  | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| RXFLVLMSK     | [4]  | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| SOFMSK        | [3]  | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| OTGINTMSK     | [2]  | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
| MODEMISMSK    | [1]  | R/W | 1'b0 | 1'b0: Mask Interrupt<br>1'b1: Unmask Interrupt |
|               | [0]  |     |      | Reserved                                       |

## 6.1.5.2.6 GRXSTSR

Description: (Global Receive Status Register)



| 0x001C |          |    |    | Glob     | al RX | Status | Regis | ster(re | set 0x0 | 0000_0 | 000) |    |      | STSR |    |          |
|--------|----------|----|----|----------|-------|--------|-------|---------|---------|--------|------|----|------|------|----|----------|
| Bit    | 31       | 30 | 29 | 28       | 27    | 26     | 25    | 24      | 23      | 22     | 21   | 20 | 19   | 18   | 17 | 16       |
| Name   |          |    | ı  | Reserved | d     |        |       |         | F       | N      |      |    | PKT  | STS  |    | DPI<br>D |
| Туре   |          |    |    |          |       |        |       |         | R       | 0      |      |    | R    |      | RO |          |
| Reset  |          |    |    | 7'b0     |       |        |       |         | 4'l     | n0     |      |    | 4'   | 2'b0 |    |          |
| Bit    | 15       | 14 | 13 | 12       | 11    | 10     | 9     | 8       | 7       | 6      | 5    | 4  | 3    | 2    | 1  | 0        |
| Name   | DPI<br>D |    |    |          |       |        | BCNT  |         |         |        |      |    |      |      |    |          |
| Туре   | RO       |    |    |          |       |        | RO    |         |         |        |      |    |      |      |    |          |
| Reset  | 2'b0     |    |    |          |       |        | 11'b0 |         |         |        |      |    | 3'b0 |      |    |          |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                               |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FN         | [24:21] | RO   | 4'b0           | This is the least significant 4 bits of the (micro)frame number in which the packet is received on the USB. This field is supported only when isochronous OUT endpoints are supported.                                                                                                                                    |
| PKTSTS     | [20:17] | RO   | 4'b0           | Indicates the status of the received packet  • 4'b0001: Global OUT NAK (triggers an interrupt)  • 4'b0010: OUT data packet received  • 4'b0011: OUT transfer completed (triggers an interrupt)  • 4'b0100: SETUP transaction completed (triggers an interrupt)  • 4'b0110: SETUP data packet received  • Others: Reserved |
| DPID       | [16:15] | RO   | 2'b0           | Indicates the Data PID of the received OUT data packet • 2'b00: DATA0 • 2'b10: DATA1 • 2'b01: DATA2 • 2'b11: MDATA                                                                                                                                                                                                        |
| BCNT       | [14:4]  | RO   | 11'b0          | Indicates the byte count of the received data packet.                                                                                                                                                                                                                                                                     |
| EPNUM      | [3:0]   | RO   | 4'b0           | Indicates the endpoint number to which the current received packet belongs.                                                                                                                                                                                                                                               |

# 6.1.5.2.7 GRXSTSP

Description: (Global Receive Status Pop)



| 0x001C |          |    |    | Glob     | al RX | Status | Regis | ster(re | set 0x0 | 0000_0 | 000) |    |       | STSR |    |          |
|--------|----------|----|----|----------|-------|--------|-------|---------|---------|--------|------|----|-------|------|----|----------|
| Bit    | 31       | 30 | 29 | 28       | 27    | 26     | 25    | 24      | 23      | 22     | 21   | 20 | 19    | 18   | 17 | 16       |
| Name   |          |    |    | Reserved | d     |        |       |         | F       | N      |      |    | PKT   | STS  |    | DPI<br>D |
| Туре   |          |    |    |          |       |        |       |         | R       | 0      |      |    | R     | 0    |    | RO       |
| Reset  |          |    |    | 7'b0     |       |        |       |         | 4'l     | ո0     |      |    | 4'l   | 2'b0 |    |          |
| Bit    | 15       | 14 | 13 | 12       | 11    | 10     | 9     | 8       | 7       | 6      | 5    | 4  | 3     | 2    | 1  | 0        |
| Name   | DPI<br>D |    |    |          |       |        | BCNT  |         |         |        |      |    | EPNUM |      |    |          |
| Туре   | RO       |    |    |          |       |        | RO    |         |         |        |      |    |       |      |    |          |
| Reset  | 2'b0     |    |    |          |       |        | 11'b0 |         |         |        |      |    | 3'b0  |      |    |          |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                               |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FN         | [24:21] | RO   | 4'b0           | This is the least significant 4 bits of the (micro)frame number in which the packet is received on the USB. This field is supported only when isochronous OUT endpoints are supported.                                                                                                                                    |
| PKTSTS     | [20:17] | RO   | 4'b0           | Indicates the status of the received packet  • 4'b0001: Global OUT NAK (triggers an interrupt)  • 4'b0010: OUT data packet received  • 4'b0011: OUT transfer completed (triggers an interrupt)  • 4'b0100: SETUP transaction completed (triggers an interrupt)  • 4'b0110: SETUP data packet received  • Others: Reserved |
| DPID       | [16:15] | RO   | 2'b0           | Indicates the Data PID of the received OUT data packet • 2'b00: DATA0 • 2'b10: DATA1 • 2'b01: DATA2 • 2'b11: MDATA                                                                                                                                                                                                        |
| BCNT       | [14:4]  | RO   | 11'b0          | Indicates the byte count of the received data packet.                                                                                                                                                                                                                                                                     |
| EPNUM      | [3:0]   | RO   | 4'b0           | Indicates the endpoint number to which the current received packet belongs.                                                                                                                                                                                                                                               |

# 6.1.5.2.8 GRXFSIZ

Description: (Global Receive FIFO Size)



| 0x0024 |    |                    |    | G  | lobal | RX FIF | O Size | e(reset | 0x000 | 0_021 | 5) |    |    |    | GR | KFSIZ |
|--------|----|--------------------|----|----|-------|--------|--------|---------|-------|-------|----|----|----|----|----|-------|
| Bit    | 31 | 30                 | 29 | 28 | 27    | 26     | 25     | 24      | 23    | 22    | 21 | 20 | 19 | 18 | 17 | 16    |
| Name   |    |                    |    |    |       |        |        | Res     | erved |       |    |    |    |    |    |       |
| Туре   |    |                    |    |    |       |        |        |         |       |       |    |    |    |    |    |       |
| Reset  |    | 15 <sup>5</sup> b0 |    |    |       |        |        |         |       |       |    |    |    |    |    |       |
| Bit    | 15 | 14                 | 13 | 12 | 11    | 10     | 9      | 8       | 7     | 6     | 5  | 4  | 3  | 2  | 1  | 0     |
| Name   |    |                    |    |    |       |        |        | RxFIF(  | Depth |       |    |    |    |    |    |       |
| Туре   |    | RW                 |    |    |       |        |        |         |       |       |    |    |    |    |    |       |
| Reset  |    |                    |    |    |       |        |        | 16'0    | 1533  |       |    |    |    |    |    |       |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:16] | RO   | 0              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RXFDEP     | [15:0]  | RO   | 15'b215        | This value is in terms of 32-bit words.  • Minimum value is 16  • Maximum value is 32,768  The power-on reset value of this register is specified as the Largest Rx Data FIFO Depth (parameter OTG_RX_DFIFO_DEPTH) during coreConsultant configuration.  If Enable Dynamic FIFO Sizing? was selected in coreConsultant (parameter OTG_DFIFO_DYNAMIC = 1), you can write a new value in this field. You can write a new value in this field. Programmed values must not exceed the power-on value set in coreConsultant. |

## 6.1.5.2.9 GNPTXFSIZ

Description: (Global Non-Periodic Transmit FIFO Size)

| 0x0028 |    |    | GI      | obal N | ION-Pe | eriodic | TX FII | FO Siz | e(rese | t 0x01 | 00_010 | 0) |    | (  | GNPT | (FSIZ |
|--------|----|----|---------|--------|--------|---------|--------|--------|--------|--------|--------|----|----|----|------|-------|
| Bit    | 31 | 30 | 29      | 28     | 27     | 26      | 25     | 24     | 23     | 22     | 21     | 20 | 19 | 18 | 17   | 16    |
| Name   |    |    |         |        |        |         |        | NPTX   | FDEP   |        |        |    |    |    |      |       |
| Туре   |    |    |         | RW     |        |         |        |        |        |        |        |    |    |    |      |       |
| Reset  |    |    | 16'h100 |        |        |         |        |        |        |        |        |    |    |    |      |       |
| Bit    | 15 | 14 | 13      | 12     | 11     | 10      | 9      | 8      | 7      | 6      | 5      | 4  | 3  | 2  | 1    | 0     |
| Name   |    |    |         |        |        |         | ١      | NPTXF  | STADE  | DR     |        |    |    |    |      |       |
| Туре   |    | RW |         |        |        |         |        |        |        |        |        |    |    |    |      |       |
| Reset  | ·  |    |         |        |        |         |        | 16'c   | 1100   |        |        |    |    |    |      |       |



| Field Name  | Bit     | Туре      | Reset<br>Value | Description                                                                                                                                                                                                                               |
|-------------|---------|-----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NPTXFDEP    | [31:16] | RW        | 16'h100        | INEPTxF0Dep)This field is valid only for Device mode and when OTG_EN_DED_TX_FIFO = 1 This value is in terms of 32-bit words.                                                                                                              |
|             |         |           |                | Minimum value is 16                                                                                                                                                                                                                       |
|             |         |           |                | Maximum value is 32,768 This field is determined during coreConsultant configuration by Enable Dynamic FIFO Sizing?  (OTG_TX_DINEP_DFIFO_DEPTH_0):  OTG_DFIFO_DYNAMIC = 0—These flops are optimized, and reads return the power-on value. |
|             |         |           |                | OTG_DFIFO_DYNAMIC =  —Programmed values must not exceed the power-on value set in coreConsultant.                                                                                                                                         |
|             |         |           |                | The power-on reset value of this field is specified during coreConsultant configuration as Largest IN Endpoint FIFO 0 Depth (parameter OTG_TX_DINEP_DFIFO_DEPTH_0).                                                                       |
| NPTXFSTADDR | [15:0]  | RW        | 16'h100        | For Device mode, this field is valid only when OTG_EN_DED_TX_FIFO = 0                                                                                                                                                                     |
|             |         |           |                | This field contains the memory start address for IN Endpoint Transmit FIFO# 0. OTG_RX_DFIFO_DEPTH                                                                                                                                         |
|             |         |           |                | This field is determined during coreConsultant configuration by Enable Dynamic FIFO Sizing? (OTG_DFIFO_DYNAMIC):                                                                                                                          |
|             | . (1    | <i>),</i> |                | • OTG_DFIFO_DYNAMIC = 0 —These flops are optimized, and reads return the power-on value.                                                                                                                                                  |
|             |         |           |                | OTG_DFIFO_DYNAMIC = 1—The application can write a new value in this field. Programmed values must not exceed the power-on value set in coreConsultant.                                                                                    |
| .00         |         |           |                | The power-on reset value of this register is specified during coreConsultant configuration as the Largest Rx Data FIFO Depth (parameter OTG_RX_DFIFO_DEPTH).                                                                              |

## 6.1.5.2.10 GNPTXSTS

Description: (Global Non-Periodic Transmit FIFO Status)



| 0x002C |                  |    |              |       | Glo    | bal NO | ON-Pe | riodic <sup>·</sup> | ΓX Sta      | tus |    |        |         |    | GNPT | XSTS |
|--------|------------------|----|--------------|-------|--------|--------|-------|---------------------|-------------|-----|----|--------|---------|----|------|------|
| Bit    | 31               | 30 | 29           | 28    | 27     | 26     | 25    | 24                  | 23          | 22  | 21 | 20     | 19      | 18 | 17   | 16   |
| Name   | Res<br>erve<br>d |    |              | N     | PTXQTO | )P     |       |                     |             |     |    | NPTXQS | SPCAVA  | I  |      |      |
| Туре   |                  |    |              | RO RO |        |        |       |                     |             |     |    |        |         |    |      |      |
| Reset  | 0                |    |              |       | 7'h0   |        |       |                     |             |     |    | Config | jurable |    |      |      |
| Bit    | 15               | 14 | 13           | 12    | 11     | 10     | 9     | 8                   | 7 6 5 4 3 2 |     |    |        |         |    | 1    | 0    |
| Name   |                  |    |              |       |        |        |       | NPTXFS              | PCAVAI      | L   |    |        |         |    |      |      |
| Туре   |                  |    | RO           |       |        |        |       |                     |             |     |    |        |         |    |      |      |
| Reset  |                  |    | Configurable |       |        |        |       |                     |             |     |    |        |         |    |      |      |

| Field-Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                       |
|---------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [31]    | RO   | 1'b0           | Reserved                                                                                                                                                                                                                                                                                                                                                          |
| NPTXQTOP      | [30:24] | RO   | 7'h0           | Entry in the Non-periodic Tx Request Queue that is currently being processed by the MAC.  • Bits [30:27]: Channel/endpoint number  • Bits [26:25]:  • 2'b00: IN/OUT token  - 2'b01: Zero-length transmit packet (device IN/host OUT)  - 2'b10: PING/CSPLIT token  - 2'b11: Channel halt command  • Bit [24]: Terminate (last entry for selected channel/endpoint) |
| NPTXQSPCAVAIL | [23:16] | RO   | 0              | Indicates the amount of free space available in the Non-periodic Transmit Request Queue. Device mode has only IN requests.  • 8'h0: Non-periodic Transmit Request Queue is full  • 8'h1: 1 location available  • 8'h2: 2 locations available  • n: n locations available (0 <n <8)="" others:="" reserved<="" td="" •=""></n>                                     |
| NPTXFSPCAVAIL | [15:0]  | RO   | 0              | Indicates the amount of free space available in the Non-periodic TxFIFO. Values are in terms of 32-bit words.  • 16'h0: Non-periodic TxFIFO is full  • 16'h1: 1 word available  • 16'h2: 2 words available  • 16'hn: n words available (where 0 ≤ n ≤ 32,768)  • 16'h8000: 32,768 words available  • Others: Reserved                                             |



### 6.1.5.2.11 GSNPSID

Description: (Global Synopsys ID)

| 0x0040 |    |    |    | (                                      | lobal | Synop | sys ID | (reset | Global Synopsys ID(reset 0x0000_4F54) GSNPSID |   |   |   |   |   |   |   |  |  |  |
|--------|----|----|----|----------------------------------------|-------|-------|--------|--------|-----------------------------------------------|---|---|---|---|---|---|---|--|--|--|
| Bit    | 31 | 30 | 29 | 28 27 26 25 24 23 22 21 20 19 18 17 16 |       |       |        |        |                                               |   |   |   |   |   |   |   |  |  |  |
| Name   |    |    |    | SYNOPSYSID                             |       |       |        |        |                                               |   |   |   |   |   |   |   |  |  |  |
| Туре   |    |    |    | RO                                     |       |       |        |        |                                               |   |   |   |   |   |   |   |  |  |  |
| Reset  |    |    |    | 32'h4F54                               |       |       |        |        |                                               |   |   |   |   |   |   |   |  |  |  |
| Bit    | 15 | 14 | 13 | 12                                     | 11    | 10    | 9      | 8      | 7                                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name   |    |    |    | SYNOPSYSID                             |       |       |        |        |                                               |   |   |   |   |   |   |   |  |  |  |
| Туре   |    |    |    | RO                                     |       |       |        |        |                                               |   |   |   |   |   |   |   |  |  |  |
| Reset  |    |    |    | 32'h4F54                               |       |       |        |        |                                               |   |   |   |   |   |   |   |  |  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                       |
|------------|--------|------|----------------|-------------------------------------------------------------------|
| SYNOPSYSID | [31:0] | RO   | 32'h4F54       | Release number of the DWC_otg core being used, currently OT2.91a. |

# 6.1.5.2.12 GHWCFG1

Description: (Global Hardware Configuration 1)

| 0x0044 |    |    |    |                                          | Glo | bal Ha | rdwar | e Conf | igurati | on 1 |   |   |   |   | GHW | CFG1 |
|--------|----|----|----|------------------------------------------|-----|--------|-------|--------|---------|------|---|---|---|---|-----|------|
| Bit    | 31 | 30 | 29 | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |     |        |       |        |         |      |   |   |   |   |     |      |
| Name   |    |    |    | epdir                                    |     |        |       |        |         |      |   |   |   |   |     |      |
| Туре   |    |    |    | RO                                       |     |        |       |        |         |      |   |   |   |   |     |      |
| Reset  |    |    |    | 32'b0                                    |     |        |       |        |         |      |   |   |   |   |     |      |
| Bit    | 15 | 14 | 13 | 12                                       | 11  | 10     | 9     | 8      | 7       | 6    | 5 | 4 | 3 | 2 | 1   | 0    |
| Name   |    |    |    | epdir                                    |     |        |       |        |         |      |   |   |   |   |     |      |
| Туре   |    |    |    | RO                                       |     |        |       |        |         |      |   |   |   |   |     |      |
| Reset  |    |    |    |                                          |     |        |       | 32     | ?'b0    |      |   |   |   |   |     |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                |
|------------|--------|------|----------------|--------------------------------------------------------------------------------------------|
| EPDIR      | [31:0] | RO   | 0              | This 32-bit field uses two bits per endpoint to determine the endpoint direction. Endpoint |
|            |        |      |                | Bits [31:30]: Endpoint 15 direction                                                        |



| Bits [29:28]: Endpoint 14 direction                         |
|-------------------------------------------------------------|
| Bits [3:2]: Endpoint 1 direction                            |
| Bits[1:0]: Endpoint 0 direction (always<br>BIDIR) Direction |
| • 2'b00: BIDIR (IN and OUT) endpoint                        |
| • 2'b01: IN endpoint                                        |
| • 2'b10: OUT endpoint                                       |
| • 2'b11: Reserved                                           |

### 6.1.5.2.13 GHWCFG2

Description: (Global Hardware Configuration 2)

| 0x0048 |                  |       |    |           | Glo | bal Ha | rdware   | Conf      | igurati        | on 2             |                             |                 |                               |        | GHW      | CFG2 |   |
|--------|------------------|-------|----|-----------|-----|--------|----------|-----------|----------------|------------------|-----------------------------|-----------------|-------------------------------|--------|----------|------|---|
| Bit    | 31               | 30    | 29 | 28        | 27  | 26     | 25       | 24        | 23             | 22               | 21                          | 20              | 19                            | 18     | 17       | 16   |   |
| Name   | Res<br>erve<br>d |       | TK | (NQDEP    | ТН  |        | Reserved |           | NPTXQDEP<br>TH |                  | Res erve d MUL TIPR OCI NTR |                 | DYN<br>FIF<br>OSI<br>ZIN<br>G |        | Reserved |      |   |
| Туре   |                  |       | RO |           |     |        |          |           | RO             |                  | RO                          | RO              |                               |        |          |      |   |
| Reset  | 0                |       |    | 5'h8      |     |        | 2'b0     |           | 2'b            | 10               | 0                           | 1'b0            | 1'b1                          |        | 3'b0     |      |   |
| Bit    | 15               | 14    | 13 | 12        | 11  | 10     | 9        | 8         | 7              | 6                | 5                           | 4               | 3                             | 2      | 1        | 0    |   |
| Name   | Rese             | erved |    | NUMDEVEPS |     |        | FSPHY    | FSPHYTYPE |                | HYTYPE HSPHYTYPE |                             | SIN<br>GPN<br>T | OTG                           | ARCH   | OTGMODE  |      | E |
| Type   |                  |       |    | RO        |     | RO     |          | RO        |                | RO               | R                           | 0               | RO                            |        | ·        |      |   |
| Reset  | 2'l              | 00    |    | 4'h7      |     |        | 2'b11    |           | 2'b11 2'b11    |                  | 1'b1                        | 2't             | 10                            | 3'b100 |          |      |   |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                  |
|-----------------|---------|------|----------------|--------------------------------------------------------------|
|                 | [31]    | RO   | 0              |                                                              |
| TKNQDEPTH       | [30:26] | RO   | 5'h8           | Range:0-30                                                   |
|                 | [25:24] | RO   | 0              |                                                              |
| NPTXQDEPTH      | [23:22] | RO   | 2'b10          | • 2'b00: 2<br>• 2'b01: 4<br>• 2'b10: 8<br>• Others: Reserved |
|                 | [21]    | RO   | 1'b0           | Reserved                                                     |
| MULTIPROCINTRPT | [20]    | RO   | 1'b0           | • 1'b0: No<br>• 1'b1: Yes                                    |
| DYNFIFOSIZING   | [19]    | RO   | 1'b1           | • 1'b0: No<br>• 1'b1: Yes                                    |



|           | [18:14] | RO     | 5'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                   |
|-----------|---------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NUMDEVEPS | [13:10] | 4'h7   | RO   | Indicates the number of device endpoints supported by the core in Device mode in addition to control endpoint 0. The range of this field is 1–15.                                                                                                                                                                                                          |
| FSPHYTYPE | [9:8]   | 2'b11  | RO   | <ul> <li>2'b00: Full-speed interface not supported</li> <li>2'b01: Dedicated full-speed interface</li> <li>2'b10: FS pins shared with UTMI+ pins</li> <li>2'b11: FS pins shared with ULPI pins</li> </ul>                                                                                                                                                  |
| HSPHYTYPE | [7:6]   | 2'b11  | RO   | <ul> <li>2'b00: High-Speed interface not supported</li> <li>2'b01: UTMI+</li> <li>2'b10: ULPI</li> <li>2'b11: UTMI+ and ULPI</li> </ul>                                                                                                                                                                                                                    |
| SINGPNT   | [5]     | 1'b1   | RO   | <ul><li>1'b0: Multi-point application</li><li>1'b1: Single-point application</li></ul>                                                                                                                                                                                                                                                                     |
| OTGARCH   | [4:3]   | 2'b10  | RO   | <ul><li>2'b00: Slave-Only</li><li>2'b01: External DMA</li><li>2'b10: Internal DMA</li><li>Others: Reserved</li></ul>                                                                                                                                                                                                                                       |
| OTGMODE   | [2:0]   | 3'b100 | RO   | <ul> <li>3'b000: HNP- and SRP-Capable OTG (Host and Device)</li> <li>3'b001: SRP-Capable OTG (Host and Device)</li> <li>3'b010: Non-HNP and Non-SRP Capable OTG (Host and Device)</li> <li>3'b011: SRP-Capable Device</li> <li>3'b100: Non-OTG Device</li> <li>3'b101: SRP-Capable Host</li> <li>3'b110: Non-OTG Host</li> <li>Others: Reserved</li> </ul> |

## 6.1.5.2.14 GHWCFG3

Description: (Global Hardware Configuration 3)



| 0x004C |                                |                  |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Glo | bal Ha | rdware | e Confi | gurati | on 3    |        |    |    |             | GHW  | CFG3 |
|--------|--------------------------------|------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------|--------|---------|--------|---------|--------|----|----|-------------|------|------|
| Bit    | 31                             | 30               | 29                              | 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 27  | 26     | 25     | 24      | 23     | 22      | 21     | 20 | 19 | 18          | 17   | 16   |
| Name   |                                | DfifoDepth       |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |        |        |         |        |         |        |    |    |             |      |      |
| Туре   |                                |                  |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |        |        | R       | .0     |         |        |    |    |             |      |      |
| Reset  |                                |                  | 16'h1188                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |        |        |         |        |         |        |    |    |             |      |      |
| Bit    | 15                             | 14               | 13                              | 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |        |        |         |        |         |        |    |    |             |      |      |
| Name   | OTG<br>_EN<br>ABL<br>E_L<br>PM | Res<br>erve<br>d | OTG<br>_EN<br>ABL<br>E_H<br>SIC | EN ABL TYP FEA CTL NTS EN CTL NTS EN CTC TYP EL TYP EL TYP FEL TYP EL TY |     |        |        |         |        |         |        | 1  |    |             |      |      |
| Туре   | RO                             |                  | RO                              | RO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO  | RO     | RO     | RO      | RO     | D RO RO |        |    |    |             |      |      |
| Reset  | 0                              | 0                | 0                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | 1'b1   | 0      | 0       | 0      |         | 3'b110 |    |    | <b>4</b> "b | 1000 |      |

| Field Name            | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                    |
|-----------------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DFIFODEPTH            | [31:16] | RO   | 16'h1188       | This value is in terms of 32-bit words.  • Minimum value is 32  • Maximum value is 32,768                                                                                                                                      |
| OTG_ENABLE_LPM        | [15]    | RO   | 1'b0           | 1'b0:No                                                                                                                                                                                                                        |
|                       | [14]    | RO   | 0              |                                                                                                                                                                                                                                |
| OTG_ENABLE_HSIC       | [13]    | RO   | 1'b0           | Non-HSIC-capable                                                                                                                                                                                                               |
| OTG_ENABLE<br>_IC_USB | [12]    | RO   | 1'b0           | 1'b0:No                                                                                                                                                                                                                        |
| RSTTYPE               | [11]    | RO   | 1'b0           | • 1'b0: Asynchronous reset is used in the core                                                                                                                                                                                 |
|                       |         |      |                | • 1'b1: Synchronous reset is used in the core                                                                                                                                                                                  |
| OPTFEATURE            | [10]    | RO   | 1'b1           | Indicates whether the User ID register, GPIO interface ports, and SOF toggle and counter ports were removed for gate count optimization by enabling Remove Optional Features? during coreConsultant configuration.  • 1'b0: No |
|                       |         |      |                | • 1 bu: No<br>• 1'b1: Yes                                                                                                                                                                                                      |
| VNDCTLSUPT            | [9]     | RO   | 1'b0           | <ul> <li>1'b0: Vendor Control Interface is not available on the core.</li> <li>1'b1: Vendor Control Interface is available.</li> </ul>                                                                                         |
| I2CINTSEL             | [8]     | RO   | 1'b0           | <ul> <li>1'b0: I2C Interface is not available on the core.</li> <li>1'b1: I2C Interface is available on the core.</li> </ul>                                                                                                   |
| OTGEN                 | [7]     | RO   | 1'b0           | The application uses this bit to indicate the DWC_otg core's OTG capabilities.  • 1'b0: Not OTG capable                                                                                                                        |



|               |       |         |    | • 1'b1: OTG Capable                                                                                                                                                                              |
|---------------|-------|---------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PKTSIZEWIDTH  | [6:4] | 3'b110  | RO | Width of Packet Size Counters (PktSizeWidth)  • 3'b000: 4 bits  • 3'b001: 5 bits  • 3'b010: 6 bits  • 3'b011: 7 bits  • 3'b100: 8 bits  • 3'b101: 9 bits  • 3'b110: 10 bits  • Others: Reserved) |
| XFERSIZEWIDTH | [3:0] | 4'b1000 | RO | • 4'b0000: 11 bits • 4'b0001: 12 bits • 4'b1000: 19 bits • Others: Reserved                                                                                                                      |

## 6.1.5.2.15 GHWCFG4

Description: (Global Hardware Configuration 4)

| 0x0050 |                                           |                                                                         |    |                              | Glo | bal Ha | rdware | e Conf                   | igurati | on 4 |                           |                  |           |    | GHW | CFG4 |
|--------|-------------------------------------------|-------------------------------------------------------------------------|----|------------------------------|-----|--------|--------|--------------------------|---------|------|---------------------------|------------------|-----------|----|-----|------|
| Bit    | 31                                        | 30                                                                      | 29 | 28                           | 27  | 26     | 25     | 24                       | 23      | 22   | 21                        | 20               | 19        | 18 | 17  | 16   |
| Name   | SCA<br>TTE<br>R/G<br>ATH<br>ER<br>DM<br>A | SCA<br>TTE<br>R/G<br>ATH<br>ER<br>DM<br>A CO<br>NFI<br>GU<br>RAT<br>ION |    | INEPS                        |     |        |        | DED SES SEN DFL LIDF LTR |         |      | VBU<br>SVA<br>LIDF<br>LTR | IDD<br>GFL<br>TR | NUMCTLEPS |    |     |      |
| Туре   | RO                                        | RO                                                                      |    | R                            | 0   |        | RO     | RO                       | RO      | RO   | RO                        | RO               |           | RO |     |      |
| Reset  | 0                                         | 0                                                                       |    | 4'h7 0 0 0 0 0               |     |        |        | 0                        | 0       |      | 4'                        | b0               |           |    |     |      |
| Bit    | 15                                        | 14                                                                      | 13 | 12                           | 11  | 10     | 9      | 8                        | 7       | 6    | 5                         | 4                | 3         | 2  | 1   | 0    |
| Name   | PHYD                                      |                                                                         |    | Reserved  AHB FRE PW Q ROP T |     |        |        |                          |         |      |                           |                  | PERIOEF   | PS |     |      |
| Туре   | R                                         | O                                                                       |    | RO RO RO                     |     |        |        |                          |         |      |                           |                  |           |    |     |      |
| Reset  | 2'b                                       | 10                                                                      |    |                              |     | (      | )      |                          |         |      | 1'b0                      | 0                |           | 4' | h1  |      |

| Field Name            | Bit  | Туре | Reset<br>Value | Description                                                     |
|-----------------------|------|------|----------------|-----------------------------------------------------------------|
| SCATTER/GATHER<br>DMA | [31] | RO   | 1'b0           | 1'b0: Non Dynamic configuration     1'b1: Dynamic configuration |



| SCATTER/GATHER<br>DMA<br>CONFIGURATION | [30]    | RO | 1'b0  | 1'b0: Non-Scatter/Gather DMA configuration     1'b1: Scatter/Gather DMA configuration                                                                             |
|----------------------------------------|---------|----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INEPS                                  | [29:26] | RO | 1'b0  | <ul><li>0:1 IN Endpoint</li><li>1:2 IN Endpoints</li><li></li><li>15:16 IN Endpoints</li></ul>                                                                    |
| DEDFIFOMODE                            | [25]    | RO | 1'b0  | <ul> <li>1'b0: Dedicated Transmit FIFO Operation not enabled.</li> <li>1'b1: Dedicated Transmit FIFO Operation enabled.</li> </ul>                                |
| SESSENDFLTR                            | [24]    | RO | 1'b0  | 1'b0: No filter     1'b1: Filter                                                                                                                                  |
| BVALIDFLTR                             | [23]    | RO | 1'b0  | 1'b0: No filter     1'b1: Filter                                                                                                                                  |
| AVALIDFLTR                             | [22]    | RO | 1'b0  | 1'b0: No filter     1'b1: Filter                                                                                                                                  |
| VBUSVALIDFLTR                          | [21]    | RO | 1'b0  | • 1'b0: No filter<br>• 1'b1: Filter                                                                                                                               |
| IDDGFLTR                               | [20]    | RO | 1'b0  | • 1'b0: No filter<br>• 1'b1: Filter                                                                                                                               |
| NUMCTLEPS                              | [19:16] | RO | 4'b0  | Range:0-15                                                                                                                                                        |
| PHYDATAWIDTH                           | [15:14] | RO | 2'b10 | When a ULPI PHY is used, an internal wrapper converts ULPI to UTMI+ . • 2'b00: 8 bits • 2'b01: 16 bits • 2'b10: 8/16 bits, software selectable • Others: Reserved |
|                                        | [13:6]  |    |       | Reserved                                                                                                                                                          |
| AHBFREQ                                | [5]     | RO | 1'b0  | • 1'b0: No<br>• 1'b1: Yes                                                                                                                                         |
| ENABLEPWROPT                           | [4]     | RO | 1'b0  | • 1'b0: No<br>• 1'b1: Yes                                                                                                                                         |
| NUMDEVPERIOEPS                         | [3:0]   | RO | 4'h1  | Range:0-15                                                                                                                                                        |

# 6.1.5.2.16 DPTXFSIZn

Description: (Device Periodic TX FIFO Size n)



| 0x0104l<br>h | h+(n-1 | )*04    |    | IN Endpoint Tx FIFO Size n DPTXFS |    |    |   |        |         |   |   |   |   |   | FSIZn |   |
|--------------|--------|---------|----|-----------------------------------|----|----|---|--------|---------|---|---|---|---|---|-------|---|
| Bit          | 31     | 30      | 30 |                                   |    |    |   |        |         |   |   |   |   |   |       |   |
| Name         |        |         |    | INEPnTxFDep                       |    |    |   |        |         |   |   |   |   |   |       |   |
| Туре         |        |         |    | RW                                |    |    |   |        |         |   |   |   |   |   |       |   |
| Reset        |        |         |    |                                   |    |    |   | 16'h   | 100     |   |   |   |   |   |       |   |
| Bit          | 15     | 14      | 13 | 12                                | 11 | 10 | 9 | 8      | 7       | 6 | 5 | 4 | 3 | 2 | 1     | 0 |
| Name         |        |         |    |                                   |    |    |   | INEPnT | kFStAdd | , |   |   |   |   |       |   |
| Туре         |        |         | RW |                                   |    |    |   |        |         |   |   |   |   |   |       |   |
| Reset        |        | 16'h215 |    |                                   |    |    |   |        |         |   |   |   |   |   |       |   |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INEPnTxFDep    | [31:16] | R/W  | 16'h100        | This value is in terms of 32-bit words.  Minimum value is 16 Maximum value is 32,768 The power-on reset value of this register is specified as the Largest IN Endpoint FIFO number Depth (parameter OTG_TX_DINEP_DFIFO_DEPTH_n) during coreConsultant configuration (0 < n <= 15).  • If Enable Dynamic FIFO Sizing? was deselected in coreConsultant (parameter OTG_DFIFO_DYNAMIC = 0), these flops are optimized, and reads return the power-on value.  • If Enable Dynamic FIFO Sizing? was selected in coreConsultant (parameter OTG_DFIFO_DYNAMIC = 1), you can write a new value in this field. Programmed values must not exceed the power-on value set in coreConsultant. |
| INEPNTXFSTADDR | [15:0]  | R/W  | 16'h215        | This field contains the memory start address for IN endpoint Transmit FIFOn (0 < n <= 15). The power-on reset value of this register is specified as the Largest Rx Data FIFO Depth (parameter OTG_RX_DFIFO_DEPTH) during coreConsultant configuration.  OTG_RX_DFIFO_DEPTH + SUM 0 to n - 1 (OTG_DINEP_TXFIFO_DEPTH_n) For example start address of IN endpoint FIFO 1 is OTG_RX_DFIFO_DEPTH_0 The start address of IN endpoint FIFO 2 is OTG_RX_DFIFO_DEPTH_0 The start address of IN endpoint FIFO 2 is OTG_RX_DFIFO_DEPTH_1  • If Enable Dynamic FIFO Sizing? was deselected in coreConsultant (parameter OTG_DFIFO_DYNAMIC = 0), these flops                                 |



|  | are optimized, and reads return the power-on value.  • If Enable Dynamic FIFO Sizing? was selected in coreConsultant (parameter OTG_DFIFO_DYNAMIC = 1), and you have programmed a new value for RxFIFO depth, you can write that value in this field. Programmed values must not exceed the power-on value set in coreConsultant. |
|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | power-on value set in coreconsultant.                                                                                                                                                                                                                                                                                             |

## 6.1.5.2.17 DCFG

Description: (Device Configure)

| 0x0800 | h  |          |    |          | Device | e Conf     | igure(r                      | eset 0 | x0000 | _0000 | )  |    |    |      |    | OCFG |
|--------|----|----------|----|----------|--------|------------|------------------------------|--------|-------|-------|----|----|----|------|----|------|
| Bit    | 31 | 30       | 29 | 28       | 27     | 26         | 25                           | 24     | 23    | 22    | 21 | 20 | 19 | 18   | 17 | 16   |
| Name   |    |          |    | Reserved |        |            |                              |        |       |       |    |    |    |      |    |      |
| Туре   |    |          |    |          |        |            |                              |        |       |       |    |    |    |      |    |      |
| Reset  |    |          |    | 0        |        |            |                              |        |       |       |    |    |    |      |    |      |
| Bit    | 15 | 14       | 13 | 12       | 11     | 10         | 9                            | 8      | 7     | 6     | 5  | 4  | 3  | 2    | 1  | 0    |
| Name   | ı  | Reserved | d  | PERF     | RINT   |            | DEVADDR Res erve d UTH d SHK |        |       |       |    |    |    | /SPD |    |      |
| Туре   |    |          |    | R        | :W     | RW RW RW   |                              |        |       |       |    |    | :W |      |    |      |
| Reset  |    | 0        |    | 2'       | h0     | 7'h0 0 0 0 |                              |        |       |       |    | 0  |    |      |    |      |

| Field Name   | Bit              | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                     |
|--------------|------------------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | [31:13]          | RO   | 0              | Reserved                                                                                                                                                                                                                                                                                                        |
| PERFRINT     | [12:11] R/W 2'h0 |      | 2'h0           | Indicates the time within a (micro)frame at which the application must be notified using the End Of Periodic Frame Interrupt. This can be used to determine if all the isochronous traffic for that (micro)frame is complete.  • 2'b00: 80% of the (micro)frame interval • 2'b01: 85% • 2'b10: 90% • 2'b11: 95% |
| DEVADDR      | [10:4]           | R/W  | 7'h0           | The application must program this field after every SetAddress control command.                                                                                                                                                                                                                                 |
|              | [3]              | RO   | 0              | Reserved                                                                                                                                                                                                                                                                                                        |
| NZSTSOUTHSHK | [2]              | R/W  | 1'b0           | The application can use this field to select the handshake the core sends on receiving a nonzero-length data packet during the                                                                                                                                                                                  |



|        |       |     |      | OUT transaction of a control transfer's Status stage.  • 1'b1: Send a STALL handshake on a nonzero-length status OUT transaction and do not send the received OUT packet to the application.  • 1'b0: Send the received OUT packet to the application (zero-length or nonzerolength) and send a handshake based on the NAK and STALL bits for the endpoint in the Device Endpoint Control register.                                                                                                                                                           |
|--------|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DEVSPD | [1:0] | R/W | 2'b0 | Indicates the speed at which the application requires the core to enumerate, or the maximum speed the application can support. However, the actual bus speed is determined only after the chirp sequence is completed, and is based on the speed of the USB host to which the core is connected. See "Device Initialization" on page 295 for details.  • 2'b00: High speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)  • 2'b01: Full speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)  • 2'b10: Reserved  • 2'b11: Full speed (USB 1.1 transceiver clock is 48 MHz) |

## 6.1.5.2.18 DCTL

Description: (Device Control)

| 0x0804 | h                      | Device Control DC                                          |    |    |    |    |    |      |    |                    |      | DCTL |                   |    |    |    |
|--------|------------------------|------------------------------------------------------------|----|----|----|----|----|------|----|--------------------|------|------|-------------------|----|----|----|
| Bit    | 31                     | 30                                                         | 29 | 28 | 27 | 26 | 25 | 24   | 23 | 22                 | 21   | 20   | 19                | 18 | 17 | 16 |
| Name   |                        | Reserved                                                   |    |    |    |    |    |      |    |                    |      |      | NAK<br>ONB<br>BLE |    |    |    |
| Туре   |                        | RW                                                         |    |    |    |    |    |      |    |                    |      | RW   |                   |    |    |    |
| Reset  |                        | 0 0                                                        |    |    |    |    |    |      |    |                    |      | 0    |                   |    |    |    |
| Bit    | 15                     | 14                                                         | 13 | 12 | 11 | 10 | 9  | 8    | 7  | 6                  | 5    | 4    | 3                 | 2  | 1  | 0  |
| Name   | IGN<br>RFR<br>MNU<br>M | RFR GMC erve PRG TNA NAK AK d TSTCT TNA INN DIS KST AKS CO |    |    |    |    |    |      |    | RMT<br>WKU<br>PSIG |      |      |                   |    |    |    |
| Туре   | RW                     | RW RO RW WO WO RW RO RO RW                                 |    |    |    |    |    | RW   | RW |                    |      |      |                   |    |    |    |
| Reset  | 0                      |                                                            | 0  | 0  | 0  | 0  | 0  | 1'b0 | 0  |                    | 3'b0 |      | 0                 | 0  | 0  | 0  |

| Field Name | Bit | Туре | Reset | Description |
|------------|-----|------|-------|-------------|
|            |     |      | Value |             |



|              | [31:17] | RO  | 0    | Reserved                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|---------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAKONBBLE    | [16]    | R/W | 1'h0 | The core sets NAK automatically for the endpoint on which babble is received.                                                                                                                                                                                                                                                                                                                    |
| IGNRFRMNUM   | [15]    | R/W | 1'h0 | Ignore frame number for isochronous endpoints in case of Scatter/Gather DMA (IgnrFrmNum) Do NOT program IgnrFrmNum bit to 1'b1 when the core is operating in Threshold mode. Note:  • When Scatter/Gather DMA mode is disabled, this field is used by the application to enable periodic transfer interrupt. The application can program periodic endpoint transfers for multiple (micro)frames. |
|              |         |     |      | O: Periodic transfer interrupt feature is<br>disabled; the application must program<br>transfers for periodic endpoints every<br>(micro)frame                                                                                                                                                                                                                                                    |
|              |         |     |      | - 1: Periodic transfer interrupt feature is enabled; the application can program transfers for multiple (micro)frames for periodic endpoints.                                                                                                                                                                                                                                                    |
|              |         |     |      | In non-Scatter/Gather DMA mode, the application receives transfer complete interrupt after transfers for multiple (micro)frames are completed.                                                                                                                                                                                                                                                   |
| GMC          | [14:13] | RO  | 0    | GMC must be programmed only once after initialization.                                                                                                                                                                                                                                                                                                                                           |
|              |         |     |      | Applicable only for Scatter/Gather DMA mode.                                                                                                                                                                                                                                                                                                                                                     |
|              |         |     |      | When Scatter/Gather DMA mode is disabled, this field is reserved. and reads 2'b00.                                                                                                                                                                                                                                                                                                               |
|              | [12]    | R/W | 1'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| PWRONPRGDONE | [11]    | R/W | 1'b0 | The application uses this bit to indicate that register programming is completed after a wake-up from Power Down mode.                                                                                                                                                                                                                                                                           |
| CGOUTNAK     | [10]    | WO  | 1'b0 | A write to this field clears the Global OUT NAK.                                                                                                                                                                                                                                                                                                                                                 |
| SGOUTNAK     | [9]     | WO  | 1'b0 | A write to this field sets the Global OUT NAK.                                                                                                                                                                                                                                                                                                                                                   |
|              |         |     |      | The application uses this bit to send a NAK handshake on all OUT endpoints.                                                                                                                                                                                                                                                                                                                      |
|              |         |     |      | The application must set the this bit only after making sure that the Global OUT NAK Effective bit in the Core Interrupt Register (GINTSTS.GOUTNakEff) is cleared.                                                                                                                                                                                                                               |
| CGNPINNAK    | [8]     | WO  | 1'b0 | A write to this field clears the Global<br>Non-periodic IN NAK.                                                                                                                                                                                                                                                                                                                                  |
|              | [7]     | RO  | 1'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| TSTCTL       | [6:4]   | R/W | 3'b0 | • 3'b000: Test mode disabled • 3'b001: Test_J mode                                                                                                                                                                                                                                                                                                                                               |



|             |     |     |      | • 3'b010: Test_K mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|-----|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|             |     |     |      | • 3'b011: Test_SE0_NAK mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             |     |     |      | 3'b100: Test_Packet mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|             |     |     |      | • 3'b101: Test_Force_Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             |     |     |      | Others: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| GOUTNAKSTS  | [3] | RO  | 1'b0 | <ul> <li>1'b0: A handshake is sent based on the FIFO Status and the NAK and STALL bit settings.</li> <li>1'b1: No data is written to the RxFIFO, irrespective of space availability. Sends a NAK handshake on all packets, except on SETUP transactions. All isochronous OUT</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|             |     |     |      | packets are dropped.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| GNPINNAKSTS | [2] | RO  | 1'b0 | <ul> <li>1'b0: A handshake is sent out based on the data availability in the transmit FIFO.</li> <li>1'b1: A NAK handshake is sent out on all non-periodic IN endpoints, irrespective of the data availability in the transmit FIFO.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SFTDISCON   | [1] | R/W | 1'b0 | The application uses this bit to signal the DWC_otg core to do a soft disconnect. As long as this bit is set, the host does not see that the device is connected, and the device does not receive signals on the USB. The core stays in the disconnected state until the application clears this bit.  The minimum duration for which the core must keep this bit set is specified in Table 5.4.  • 1'b0: Normal operation. When this bit is cleared after a soft disconnect, the core drives the phy_opmode_o signal on the UTMI+ to 2'b00, which generates a device connect event to the USB host. When the device is reconnected, the USB host restarts device enumeration.  • 1'b1: The core drives the phy_opmode_o signal on the UTMI+ to 2'b01, which |
|             |     |     |      | generates a device disconnect event to the USB host.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RMTWKUPSIG  | [0] | R/W | 1'b0 | When the application sets this bit, the core initiates remote signaling to wake the USB host. The application must set this bit to instruct the core to exit the Suspend state. As specified in the USB 2.0 specification, the application must clear this bit 1–15 ms after setting it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## 6.1.5.2.19 DSTS

Description: (Device Status)



| 0x0808 | h        |       |                                          |    | Devi | ice Sta | tus(re | set 0x( | 0000_0     | 002) |                               |    |   |     |     | DSTS            |  |
|--------|----------|-------|------------------------------------------|----|------|---------|--------|---------|------------|------|-------------------------------|----|---|-----|-----|-----------------|--|
| Bit    | 31       | 30    | 29 28 27 26 25 24 23 22 21 20 19 18 17 1 |    |      |         |        |         |            |      |                               | 16 |   |     |     |                 |  |
| Name   | Reserved |       |                                          |    |      |         |        |         |            |      | SOFFN                         |    |   |     |     |                 |  |
| Туре   |          |       |                                          |    |      |         |        |         |            |      |                               |    | R | 0   |     |                 |  |
| Reset  |          | 0     |                                          |    |      |         |        |         |            |      | 0                             |    |   |     |     | 7               |  |
| Bit    | 15       | 14    | 13                                       | 12 | 11   | 10      | 9      | 8       | 7          | 6    | 5                             | 4  | 3 | 2   | 1   | 0               |  |
| Name   |          | SOFFN |                                          |    |      |         |        |         |            |      | Reserved ERR TICE ENUMSPER RR |    |   |     |     | SUS<br>PST<br>S |  |
| Туре   | RO       |       |                                          |    |      |         |        |         | 3'b0 RO RO |      |                               |    |   | 0   | RO  |                 |  |
| Reset  |          | 0     |                                          |    |      |         |        |         |            |      | 0                             |    | 0 | 2'b | 001 | 0               |  |

| Field-Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:22] | RO   | 0              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| SOFFN      | [21:8]  | RO   | 14'h0          | When the core is operating at high speed, this field contains a microframe number. When the core is operating at full or low speed, this field contains a frame number.                                                                                                                                                                                                                                                                                                                   |
| ERRTICERR  | [3]     | RO   | 1'h0           | The core sets this bit to report any erratic errors (phy_rxvalid_i/phy_rxvldh_i or phy_rxactive_i is asserted for at least 2 ms, due to PHY error) seen on the UTMI+.  Due to erratic errors, the DWC_otg core goes into Suspended state and an interrupt is generated to the application with Early Suspend bit of the Core Interrupt register (GINTSTS.ErlySusp). If the early suspend is asserted due to an erratic error, the application can only perform a soft disconnect recover. |
| ENUMSPD    | [2:1]   | RO   | 0              | Indicates the speed at which the DWC_otg core has come up after speed detection through a chirp sequence.  2'b00: High speed (PHY clock is running at 30 or 60 MHz)  • 2'b01: Full speed (PHY clock is running at 30 or 60 MHz)  • 2'b10: Low speed (PHY clock is running at 48 MHz, internal phy_clk at 6 MHz)  • 2'b11: Full speed (PHY clock is running at 48 MHz)  Low speed is not supported for devices using a UTMI+ PHY.                                                          |
| SUSPSTS    | [0]     | RO   | 1'b0           | In Device mode, this bit is set as long as a Suspend condition is detected on the USB. The core enters the Suspended state when                                                                                                                                                                                                                                                                                                                                                           |



| there is no activity on the phy_line_state_i signal for an extended period of time. The core comes out of the suspend:                       |
|----------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>When there is any activity on the<br/>phy_line_state_i signal</li> </ul>                                                            |
| <ul> <li>When the application writes to the Remote<br/>Wakeup Signaling bit in the Device Control<br/>register (DCTL.RmtWkUpSig).</li> </ul> |

## 6.1.5.2.20 DIEPMSK

Description: (Device In Endpoint Mask)

| 0x0810 | h    |          |            | Dev                                       | ice In   | Endpo | oint Ma | sk(res                         | et 0x0           | 000_0                         | 000)                      |                                |                        |                   | DIEF                    | PMSK                     |
|--------|------|----------|------------|-------------------------------------------|----------|-------|---------|--------------------------------|------------------|-------------------------------|---------------------------|--------------------------------|------------------------|-------------------|-------------------------|--------------------------|
| Bit    | 31   | 30       | 29         | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |          |       |         |                                |                  |                               |                           |                                |                        |                   |                         |                          |
| Name   |      | Reserved |            |                                           |          |       |         |                                |                  |                               |                           |                                |                        |                   |                         |                          |
| Туре   |      |          |            |                                           |          |       |         | R                              | 10               |                               |                           |                                |                        |                   |                         |                          |
| Reset  |      | 0        |            |                                           |          |       |         |                                |                  |                               |                           |                                |                        |                   |                         |                          |
| Bit    | 15   | 14       | 13         | 12                                        | 11       | 10    | 9       | 8                              | 7                | 6                             | 5                         | 4                              | 3                      | 2                 | 1                       | 0                        |
| Name   | Rese | erved    | NAK<br>MSK | F                                         | Reserved |       |         | TXFI<br>FOU<br>NDR<br>NMS<br>K | Res<br>erve<br>d | INE<br>PNA<br>KEF<br>FMS<br>K | INTK<br>NEP<br>MIS<br>MSK | INTK<br>NTX<br>FEM<br>PMS<br>K | TIM<br>EOU<br>TMS<br>K | AHB<br>ERR<br>MSK | EPD<br>ISBL<br>DMS<br>K | XFE<br>RCO<br>MPL<br>MSK |
| Туре   |      |          | RW         |                                           |          |       |         | RW                             |                  | RW                            | RW                        | RW                             | RW                     | RW                | RW                      | RW                       |
| Reset  |      |          | 0          |                                           | 0        |       | 0       | 0                              | 0                | 0                             | 0                         | 0                              | 0                      | 0                 | 0                       | 0                        |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                    |
|----------------|---------|------|----------------|------------------------------------------------|
|                | [31:14] | RO   | 23'h0          | Reserved                                       |
| NAKMSK         | [13]    | R/W  | 1'h0           | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
|                | [12:10] | RO   | 3'h0           |                                                |
| BNAININTRMSK   | [9]     | R/W  | 1'b0           | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
| TXFIFOUNDRNMSK | [8]     | R/W  | 1'b0           | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
|                | [7]     | 1'b0 |                | Reserved                                       |
| INEPNAKEFFMSK  | [6]     | R/W  | 1'b0           | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
| INTKNEPMISMSK  | [5]     | R/W  | 1'b0           | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
| INTKNTXFEMPMSK | [4]     | R/W  | 1'b0           | 1'b0: Mask interrupt                           |



|              |     |     |      | 1'b1: Unmask interrupt                         |
|--------------|-----|-----|------|------------------------------------------------|
| TIMEOUTMSK   | [3] | R/W | 1'b0 | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
| AHBERRMSK    | [2] | R/W | 1'b0 | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
| EPDISBLDMSK  | [1] | R/W | 1'b0 | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
| XFERCOMPLMSK | [0] | R/W | 1'b0 | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |

## 6.1.5.2.21 DOEPMSK

Description: (Device Out Endpoint Mask)

| 0x0814 | h                |                 |            | Devi                                   | ice Ou | t Endp   | oint M | ask(re                   | set 0x           | 0000_0                         | 0000)            | X                              |                  |                   | DOEF                    | PMSK                     |
|--------|------------------|-----------------|------------|----------------------------------------|--------|----------|--------|--------------------------|------------------|--------------------------------|------------------|--------------------------------|------------------|-------------------|-------------------------|--------------------------|
| Bit    | 31               | 30              | 29         | 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |          |        |                          |                  |                                |                  |                                |                  | 16                |                         |                          |
| Name   |                  | Reserved        |            |                                        |        |          |        |                          |                  |                                |                  |                                |                  |                   |                         |                          |
| Туре   |                  |                 |            |                                        |        |          |        |                          |                  |                                |                  |                                |                  |                   |                         |                          |
| Reset  |                  | 0               |            |                                        |        |          |        |                          |                  |                                |                  |                                |                  |                   |                         |                          |
| Bit    | 15               | 14              | 13         | 12                                     | 11     | 10       | 9      | 8                        | 7                | 6                              | 5                | 4                              | 3                | 2                 | 1                       | 0                        |
| Name   | Res<br>erve<br>d | NYE<br>TMS<br>K | NAK<br>MSK | BBL<br>EER<br>RM<br>SK                 | Rese   | Reserved |        | OUT<br>PKT<br>ERR<br>MSK | Res<br>erve<br>d | BAC<br>K2B<br>ACK<br>SET<br>UP | Res<br>erve<br>d | OUT<br>TKN<br>EPD<br>ISM<br>SK | SET<br>UPM<br>SK | AHB<br>ERR<br>MSK | EPD<br>ISBL<br>DMS<br>K | XFE<br>RCO<br>MPL<br>MSK |
| Туре   |                  | RW              | RW         | RW                                     |        |          | RW     | RW                       |                  | RW                             |                  | RW                             | RW               | RW                | RW                      | RW                       |
| Reset  | 0                | 0               | 0          | 0                                      | C      | )        | 0      | 0                        | 0                | 0                              | 0                | 0                              | 0                | 0                 | 0                       | 0                        |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                    |
|---------------|---------|------|----------------|------------------------------------------------|
|               | [31:15] | RO   | 17'h0          | Reserved                                       |
| NYETMSK       | [14]    | R/W  | 1'b0           | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
| NAKMSK        | [13]    | R/W  | 1'h0           | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
| BBLEERRMSK    | [12]    | RO   | 1'b0           | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
|               | [11:10] | RO   | 3'h0           | Reserved                                       |
| BNAOUTINTRMSK | [9]     | R/W  | 1'b0           | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt |
| OUTPKTERRMSK  | [8]     | R/W  | 1'b0           | 1'b0: Mask interrupt                           |



|                |     |      |      | 1'b1: Unmask interrupt                                                         |
|----------------|-----|------|------|--------------------------------------------------------------------------------|
|                | [7] | 1'b0 |      | Reserved                                                                       |
| BACK2BACKSETUP | [6] | R/W  | 1'b0 | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt                                 |
|                | [5] | R/W  | 1'b0 | Reserved                                                                       |
| OUTTKNEPDISMSK | [4] | R/W  | 1'b0 | Applies to control endpoints only. 1'b0: Mask interrupt 1'b1: Unmask interrupt |
| SETUPMSK       | [3] | R/W  | 1'b0 | Applies to control endpoints only. 1'b0: Mask interrupt 1'b1: Unmask interrupt |
| AHBERRMSK      | [2] | R/W  | 1'b0 | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt                                 |
| EPDISBLDMSK    | [1] | R/W  | 1'b0 | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt                                 |
| XFERCOMPLMSK   | [0] | R/W  | 1'b0 | 1'b0: Mask interrupt<br>1'b1: Unmask interrupt                                 |

### 6.1.5.2.22 DAINT

Description: (Device All Interrupt)

| 0x0818 | h  |          |         | [                                         | Device | All Int | errupt | (reset | 0x000 | 0_0000 | 0) |   |   |    | D | AINT |
|--------|----|----------|---------|-------------------------------------------|--------|---------|--------|--------|-------|--------|----|---|---|----|---|------|
| Bit    | 31 | 30       | 29      | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |         |        |        |       |        |    |   |   | 16 |   |      |
| Name   |    | OUTEPINT |         |                                           |        |         |        |        |       |        |    |   |   |    |   |      |
| Туре   |    |          | RO      |                                           |        |         |        |        |       |        |    |   |   |    |   |      |
| Reset  |    |          |         | 0                                         |        |         |        |        |       |        |    |   |   |    |   |      |
| Bit    | 15 | 14       | 13      | 12                                        | 11     | 10      | 9      | 8      | 7     | 6      | 5  | 4 | 3 | 2  | 1 | 0    |
| Name   |    |          | INEPINT |                                           |        |         |        |        |       |        |    |   |   |    |   |      |
| Туре   |    | RO       |         |                                           |        |         |        |        |       |        |    |   |   |    |   |      |
| Reset  |    |          |         |                                           |        |         |        |        | 0     |        |    |   |   |    |   | ·    |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                     |
|------------|---------|------|----------------|---------------------------------------------------------------------------------|
| OUTEPINT   | [31:16] | RO   | 16'h0          | One bit per OUT endpoint: Bit 16 for OUT endpoint 0, bit 31 for OUT endpoint 15 |
| INEPINT    | [15:0]  | RO   | 16'b0          | One bit per IN Endpoint:<br>Bit 0 for IN endpoint 0, bit 15 for endpoint 15     |



### 6.1.5.2.23 DAINTMSK

Description: (Device All Interrupt)

| 0x081C | h  |    |    | Device All Interrupt Mask(reset 0x0000_0000) DAINTMSK |    |    |   |   |   |   |   |   |   | rmsk |   |   |
|--------|----|----|----|-------------------------------------------------------|----|----|---|---|---|---|---|---|---|------|---|---|
| Bit    | 31 | 30 | 29 | 29 28 27 26 25 24 23 22 21 20 19 18 17 16             |    |    |   |   |   |   |   |   |   |      |   |   |
| Name   |    |    |    | OUTEPMSK                                              |    |    |   |   |   |   |   |   |   |      |   |   |
| Туре   |    |    |    | RW                                                    |    |    |   |   |   |   |   |   |   |      |   |   |
| Reset  |    |    |    | 0                                                     |    |    |   |   |   |   |   |   |   |      |   |   |
| Bit    | 15 | 14 | 13 | 12                                                    | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1 | 0 |
| Name   |    |    |    | INEPMSK                                               |    |    |   |   |   |   |   |   |   |      |   |   |
| Туре   |    |    |    | RW                                                    |    |    |   |   |   |   |   |   |   |      |   |   |
| Reset  |    |    | 0  |                                                       |    |    |   |   |   |   |   |   |   |      |   |   |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                 |
|------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------|
| OUTEPMSK   | [31:16] | R/W  | 16'h0          | One per OUT Endpoint: Bit 16 for OUT EP 0, bit 31 for OUT EP 15 1'b0: Mask interrupt 1'b1: Unmask interrupt |
| INEPMSK    | [15:0]  | R/W  | 16'b0          | One bit per IN Endpoint: Bit 0 for IN EP 0, bit 15 for IN EP 15 1'b0: Mask interrupt 1'b1: Unmask interrupt |

## 6.1.5.2.24 DIEPEMPMSK

Description: (Device IN Endpoint Empty Mask)

| 0x08 | 334h |    |    | Devi          | Device In Endpoint Empty Mask DIEPEMPMSK |    |    |   |   |   |   |   |   |   | PMSK |   |   |
|------|------|----|----|---------------|------------------------------------------|----|----|---|---|---|---|---|---|---|------|---|---|
| Bit  |      | 31 | 30 | 29            | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |    |   |   |   |   |   |   |   |      |   |   |
| Nam  | ie   |    |    |               | Reserved                                 |    |    |   |   |   |   |   |   |   |      |   |   |
| Туре | e    |    |    |               |                                          |    |    |   |   |   |   |   |   |   |      |   |   |
| Rese | et   |    |    |               | 0                                        |    |    |   |   |   |   |   |   |   |      |   |   |
| Bit  | :    | 15 | 14 | 13            | 12                                       | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1 | 0 |
| Nam  | ne   |    |    | INEPTXFEMPMSK |                                          |    |    |   |   |   |   |   |   |   |      |   |   |
| Тур  | е    |    | RW |               |                                          |    |    |   |   |   |   |   |   |   |      |   |   |
| Rese | et   |    | 0  |               |                                          |    |    |   |   |   |   |   |   |   |      |   |   |



| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                                                 |
|---------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------|
|               | [31:16] | R/W  | 16'h0          | reserved                                                                                                                                    |
| INEPTXFEMPMSK | [15:0]  | R/W  | 16'b0          | These bits acts as mask bits for DIEPINTn.  TxFEmp interrupt One bit per IN Endpoint:  • Bit 0 for IN endpoint 0   • Bit 15 for endpoint 15 |

#### 6.1.5.2.25 DIEPCTL0

Description: (Device IN Endpoint Control 0)

| 0x0900 | h                |                 | Devi     | ce In E | ndpoi    | nt Con   | trol 0(ı            | reset ( | )x0000 | _0000 | )         |              |        |    | DIEP       | CTL0         |
|--------|------------------|-----------------|----------|---------|----------|----------|---------------------|---------|--------|-------|-----------|--------------|--------|----|------------|--------------|
| Bit    | 31               | 30              | 29       | 28      | 27       | 26       | 25 24 23 22 21 20 1 |         |        |       | 19        | 18           | 17     | 16 |            |              |
| Name   | EPE<br>NA        | EPD<br>IS       | Rese     | erved   | SNA<br>K | CNA<br>K | TXFNUM              |         |        |       | STA<br>LL | Rese<br>rved | EPTYPE |    | NAK<br>STS | Rese<br>rved |
| Туре   | R_<br>WS<br>_SC  | R_<br>WS<br>_SC |          |         | wo       | WO       | VO RW RS_SC RO      |         |        |       |           |              |        | RO |            |              |
| Reset  | 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   | USB<br>ACT<br>EP |                 | Reserved |         |          |          |                     |         |        |       | М         | PS           |        |    |            |              |
| Туре   | RO               |                 |          |         |          |          |                     |         |        |       |           |              | R      | W  |            |              |
| Reset  | 1                |                 |          |         |          |          |                     | 0       |        |       |           |              |        |    | (          | )            |

| Field Name | Bit  | Туре    | Reset<br>Value | Description                                                                                                                                                                                                                                    |
|------------|------|---------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EPENA      | [31] | R_WS_SC | 1'h0           | When Scatter/Gather DMA mode is disabled—such as in buffer-pointer based DMA mode—this bit indicates that data is ready to be transmitted on the endpoint.  The core clears this bit before setting the following interrupts on this endpoint: |
|            |      |         |                | Endpoint Disabled                                                                                                                                                                                                                              |
|            |      |         |                | Transfer Completed                                                                                                                                                                                                                             |
| EPDIS      | [30] | R_WS_SC | 1'b0           | The application sets this bit to stop transmitting data on an endpoint, even before the transfer for that endpoint is complete. The application must wait for the Endpoint                                                                     |
|            |      |         |                | Disabled interrupt before treating the endpoint as disabled. The core clears this bit before setting the Endpoint Disabled                                                                                                                     |



|          |         |         |       | Interrupt. The application must set this bit only if Endpoint Enable is already set for this endpoint.                                                                                                                                                                                                                                                                                                                               |
|----------|---------|---------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | [29:28] | RO      | 2'b0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |
| SNAK     | [27]    | WO      | 1'b0  | A write to this bit sets the NAK bit for the endpoint.  Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set this bit for an endpoint after a SETUP packet is received on that endpoint.                                                                                                                                                                             |
| CNAK     | [26]    | WO      | 1'b0  | A write to this bit clears the NAK bit for the endpoint.                                                                                                                                                                                                                                                                                                                                                                             |
| TXFNUM   | [25:22] | R/W     | 4'h0  | • For Dedicated FIFO operation, this value is set to the FIFO number that is assigned to IN Endpoint 0.                                                                                                                                                                                                                                                                                                                              |
| STALL    | [21]    | R_WS_SC | 1'b0  | The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit, Global Non-periodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority.                                                                                                                                                                                               |
|          | [20]    | RO      | 1'b0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |
| EPTYPE   | [19:18] | RO      | 2'b0  | Hardcoded to 00 for control.                                                                                                                                                                                                                                                                                                                                                                                                         |
| NAKSTS   | [17]    | RO      | 1'b0  | Indicates the following:                                                                                                                                                                                                                                                                                                                                                                                                             |
|          |         |         |       | <ul> <li>1'b0: The core is transmitting non-NAK handshakes based on the FIFO status</li> <li>1'b1: The core is transmitting NAK handshakes on this endpoint.</li> <li>When this bit is set, either by the application or core, the core stops transmitting data, even if there is data available in the TxFIFO. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.</li> </ul> |
|          | [16]    | RO      | 1'b0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |
| USBACTEP | [15]    | RO      | 1'b0  | This bit is always set to 1, indicating that control endpoint 0 is always active in all configurations and interfaces.                                                                                                                                                                                                                                                                                                               |
|          | [14:2]  |         | 13'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |
| MPS      | [1:0]   | R/W     | 2'b0  | Applies to IN and OUT endpoints.  The application must program this field with the maximum packet size for the current logical endpoint.  • 2'b00: 64 bytes  • 2'b01: 32 bytes  • 2'b10: 16 bytes  • 2'b11: 8 bytes                                                                                                                                                                                                                  |



## 6.1.5.2.26 DOEPCTL0

Description: (Device OUT Endpoint Control 0)

| 0x0B00 | )h               |                 | Devi | ce Out   | Endpo    | oint Co                                              | ntrol (          | O(reset | 0x000 | 0_100 | 0) |    |        |    | DOEP       | CTL0         |
|--------|------------------|-----------------|------|----------|----------|------------------------------------------------------|------------------|---------|-------|-------|----|----|--------|----|------------|--------------|
| Bit    | 31               | 30              | 29   | 28       | 27       | 26                                                   | 25               | 24      | 23    | 22    | 21 | 20 | 19     | 18 | 17         | 16           |
| Name   | EPE<br>na        | EPD<br>is       | Rese | erved    | SNA<br>K | CNA<br>K                                             | TxFNum Stall Snp |         |       |       |    |    | EPType |    | NAK<br>Sts | Rese<br>rved |
| Туре   | R_<br>WS<br>_SC  | R_<br>WS<br>_SC |      |          | WO       | WO         RW         R WS_ SC         RW         RO |                  |         |       |       |    |    | 0      | RO |            |              |
| Reset  | 0                | 0               | (    | )        | 0        | 0                                                    | 0 0 0            |         |       |       |    |    | C      |    | 0          | 0            |
| Bit    | 15               | 14              | 13   | 12       | 11       | 10                                                   | 9                | 8       | 7     | 6     | 5  | 4  | 3      | 2  | 1          | 0            |
| Name   | USB<br>Act<br>EP |                 |      | Reserved |          |                                                      |                  |         |       |       |    | МІ | PS     |    |            |              |
| Туре   | RO               |                 |      |          |          |                                                      |                  |         |       |       |    | R' | W      |    |            |              |
| Reset  | 1                |                 |      |          |          |                                                      |                  | 0       |       |       |    |    |        |    | (          | )            |

| Field Name | Bit     | Туре    | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|---------|---------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EPENA      | [31]    | R_WS_SC | 1'h0           | When Scatter/Gather DMA mode is disabled—(such as for buffer-pointer based DMA mode)—this bit indicates that the application has allocated the memory to start receiving data from the USB.  The core clears this bit before setting any of the following interrupts on this endpoint:     SETUP Phase Done     Endpoint Disabled     Transfer Completed     Note: In DMA mode, this bit must be set for the core to transfer SETUP data packets into memory. |
| EPDIS      | [30]    | R_WS_SC | 1'b0           | The application cannot disable control OUT endpoint 0.                                                                                                                                                                                                                                                                                                                                                                                                        |
|            | [29:28] | RO      | 2'b0           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| SNAK       | [27]    | WO      | 1'b0           | A write to this bit sets the NAK bit for the endpoint.  Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set bit on a Transfer Completed interrupt, or after a SETUP is received on the endpoint.                                                                                                                                                                                             |
| CNAK       | [26]    | WO      | 1'b0           | A write to this bit clears the NAK bit for the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                      |
|            | [25:22] | RO      | 4'h0           | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



| STALL    | [21]    | R_WS_SC | 1'b0  | The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit or Global OUT NAK is set along with this bit, the STALL bit takes priority. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.                                                                                                                                   |
|----------|---------|---------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SNP      | [20]    | R/W     | 1'b0  | This bit configures the endpoint to Snoop mode. In Snoop mode, the core does not check the correctness of OUT packets before transferring them to application memory.                                                                                                                                                                                                                                                                                 |
| EPTYPE   | [19:18] | RO      | 2'b0  | Hardcoded to 00 for control.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| NAKSTS   | [17]    | RO      | 1'b0  | Indicates the following:  • 1'b0: The core is transmitting non-NAK handshakes based on the FIFO status.  • 1'b1: The core is transmitting NAK handshakes on this endpoint.  When either the application or the core sets this bit, the core stops receiving data, even if there is space in the RxFIFO to accommodate the incoming packet.  Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake. |
|          | [16]    | RO      | 1'b0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| USBACTEP | [15]    | RO      | 1'b0  | This bit is always set to 1, indicating that a control endpoint 0 is always active in all configurations and interfaces.                                                                                                                                                                                                                                                                                                                              |
|          | [14:2]  |         | 13'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| MPS      | [1:0]   | R/W     | 2'b0  | The maximum packet size for control OUT endpoint 0 is the same as what is programmed in control IN Endpoint 0. • 2'b00: 64 bytes • 2'b01: 32 bytes • 2'b10: 16 bytes • 2'b11: 8 bytes                                                                                                                                                                                                                                                                 |

## 6.1.5.2.27 DIEPCTLn/DOEPCTLn

Description: (Device IN Endpoint Control n/ Device OUT Endpoint Control n)



| h)<br>OUT | Ox900h+(n*20 Device In Endpoint Control n Device Out Endpoint Control n |                 |                  |                  |          |          |                    |    |    |    |                |    |     | CTLn<br>CTLn |            |      |
|-----------|-------------------------------------------------------------------------|-----------------|------------------|------------------|----------|----------|--------------------|----|----|----|----------------|----|-----|--------------|------------|------|
| Bit       | 31                                                                      | 30              | 29               | 28               | 27       | 26       | 25                 | 24 | 23 | 22 | 21             | 20 | 19  | 18           | 17         | 16   |
| Name      | EPE<br>NA                                                               | EPD<br>IS       | SET<br>D1P<br>ID | SET<br>D0PI<br>D | SNA<br>K | CNA<br>K | TXFNUM STA SN LL P |    |    |    |                |    | EPT | YPE          | NAK<br>STS | DPID |
| Туре      | R_<br>WS<br>_SC                                                         | R_<br>WS<br>_SC | WO               | WO               | wo       | WO       | RW R_ WS_ RW SC    |    |    |    |                |    | R   | 0            | RO         |      |
| Reset     | 0                                                                       | 0               | 0                | 0                | 0        | 0        |                    | (  | 0  |    | WS_<br>SC<br>0 | 0  |     |              | 0          | 0    |
| Bit       | 15                                                                      | 14              | 13               | 12               | 11       | 10       | 9                  | 8  | 7  | 6  | 5              | 4  | 3   | 2            | 1          | 0    |
| Name      | USB<br>ACT<br>EP                                                        |                 | Res              | erved            |          | MPS      |                    |    |    |    |                |    |     |              |            |      |
| Туре      | RO                                                                      |                 |                  |                  |          |          | RW                 |    |    |    |                |    |     |              |            |      |
| Reset     | 1                                                                       |                 |                  | 0                |          | 0        |                    |    |    |    |                |    |     |              |            |      |

| Field-Name | Bit  | Туре    | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|------|---------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EPENA      | [31] | R_WS_SC | 1'h0           | Applies to IN and OUT endpoints.  • When Scatter/Gather DMA mode is enabled—such as for buffer-pointer based DMA mode: - For IN endpoints, this bit indicates that data is ready to be transmitted on the endpoint.  - For OUT endpoints, this bit indicates that the application has allocated the memory to start receiving data from the USB.  - The core clears this bit before setting any of the following interrupts on this endpoint:  • SETUP Phase Done  • Endpoint Disabled  • Transfer Completed |
| 1 (S)      |      |         |                | Note: For control endpoints in DMA mode, this bit must be set to be able to transfer SETUP data packets in memory.                                                                                                                                                                                                                                                                                                                                                                                           |
| EPDIS      | [30] | R_WS_SC | 1'b0           | Applies to IN and OUT endpoints.  The application sets this bit to stop transmitting/receiving data on an endpoint, even before the transfer for that endpoint is complete. The application must wait for the Endpoint Disabled interrupt before treating the endpoint as disabled. The core clears this bit before setting the Endpoint Disabled interrupt. The application must set this bit only if Endpoint Enable is already set for                                                                    |



|          |         |     |      | this endpoint.                                                                                                                                                                                                                                                                                                                                                                    |
|----------|---------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SETD1PID | [29]    | WO  | 1'b0 | Applies to interrupt/bulk IN and OUT endpoints only.                                                                                                                                                                                                                                                                                                                              |
|          |         |     |      | Writing to this field sets the Endpoint Data PID (DPID) field in this register to DATA1.                                                                                                                                                                                                                                                                                          |
|          |         |     |      | This field is applicable both for Scatter/Gather DMA mode and non-Scatter/Gather DMA mode.                                                                                                                                                                                                                                                                                        |
|          |         |     |      | Set Odd (micro)frame (SetOddFr) Applies to isochronous IN and OUT endpoints only. Writing to this field sets the Even/Odd (micro)frame (EO_FrNum) field to odd (micro)frame. This field is not applicable for Scatter/Gather DMA mode.                                                                                                                                            |
| SETD0PID | [28]    | WO  | 1'b0 | Applies to interrupt/bulk IN and OUT endpoints only.  Writing to this field sets the Endpoint Data PID (DPID) field in this register to DATA0.  This field is applicable both for Scatter/Gather DMA mode and non-Scatter/Gather DMA mode.                                                                                                                                        |
|          |         |     |      | In non-Scatter/Gather DMA mode: Set Even (micro)frame (SetEvenFr)  Applies to isochronous IN and OUT endpoints only.  Writing to this field sets the Even/Odd (micro)frame (EO_FrNum) field to even (micro) frame.  When Scatter/Gather DMA mode is enabled, this field is reserved. The frame number in which to send data is in the transmit descriptor structure. The frame in |
|          |         |     |      | which to receive data is updated in receive descriptor structure.                                                                                                                                                                                                                                                                                                                 |
| SNAK     | [27]    | WO  | 1'b0 | Applies to IN and OUT endpoints.  A write to this bit sets the NAK bit for the endpoint.  Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set this bit for OUT endpoints on a Transfer Completed interrupt, or after a SETUP is received on the endpoint.                                                        |
| CNAK     | [26]    | WO  | 1'b0 | Applies to IN and OUT endpoints.  A write to this bit clears the NAK bit for the endpoint.                                                                                                                                                                                                                                                                                        |
| TXFNUM   | [25:22] | R/W | 4'h0 | Dedicated FIFO Operation—these bits specify the FIFO number associated with this endpoint. Each active IN endpoint must be programmed to a separate FIFO                                                                                                                                                                                                                          |



|        |         |         |      | number.                                                                                                                                                                                                                                                                                                                                          |
|--------|---------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         |         |      | This field is valid only for IN endpoints.                                                                                                                                                                                                                                                                                                       |
| STALL  | [21]    | R_WS_SC | 1'b0 | Applies to non-control, non-isochronous IN and OUT endpoints only.                                                                                                                                                                                                                                                                               |
|        |         |         |      | The application sets this bit to stall all tokens from the USB host to this endpoint. If a NAK bit, Global Non-periodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Only the application can clear this bit, never the core.                                                                             |
|        |         |         |      | Applies to control endpoints only.                                                                                                                                                                                                                                                                                                               |
|        |         |         |      | The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit, Global Non-periodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake. |
| SNP    | [20]    | R/W     | 1'b0 | Applies to OUT endpoints only.                                                                                                                                                                                                                                                                                                                   |
|        |         |         |      | This bit configures the endpoint to Snoop mode. In Snoop mode, the core does not check the correctness of OUT packets before transferring them to application memory.                                                                                                                                                                            |
| EPTYPE | [19:18] | RO      | 2'b0 | Applies to IN and OUT endpoints.                                                                                                                                                                                                                                                                                                                 |
|        |         |         |      | This is the transfer type supported by this logical endpoint.  • 2'b00: Control  • 2'b01: Isochronous  • 2'b10: Bulk  • 2'b11: Interrupt                                                                                                                                                                                                         |
| NAKSTS | [17]    | RO      | 1'b0 | Applies to IN and OUT endpoints. Indicates the following:                                                                                                                                                                                                                                                                                        |
|        |         |         |      | 1'b0: The core is transmitting non-NAK handshakes based on the FIFO status.                                                                                                                                                                                                                                                                      |
|        |         |         |      | 1'b1: The core is transmitting NAK handshakes on this endpoint. When either the application or the core sets this bit:                                                                                                                                                                                                                           |
|        |         |         |      | • The core stops receiving any data on an OUT endpoint, even if there is space in the RxFIFO to accommodate the incoming packet.                                                                                                                                                                                                                 |
|        |         |         |      | • For non-isochronous IN endpoints: The core stops transmitting any data on an IN endpoint, even if there data is available in the TxFIFO.                                                                                                                                                                                                       |
|        |         |         |      | For isochronous IN endpoints: The core sends out a zero-length data packet, even if there data is available in the TxFIFO. Irrespective of this bit's setting, the core always responds to SETUP data packets                                                                                                                                    |



|          |         |        |      | with an ACK handshake.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|---------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DPID     | [16]    | RO     | 1'b0 | Applies to interrupt/bulk IN and OUT endpoints only.  Contains the PID of the packet to be received or transmitted on this endpoint. The application must program the PID of the first packet to be received or transmitted on this endpoint, after the endpoint is activated. The applications use the SetD1PID and SetD0PID fields of this register to program either DATA0 or DATA1 PID.  1'b0: DATA0  1'b1: DATA1  This field is applicable both for Scatter/Gather DMA mode and non-Scatter/Gather DMA mode.                                                                                                                                                                                                               |
|          |         |        |      | Even/Odd (Micro)Frame (EO_FrNum) In non-Scatter/Gather DMA mode: Applies to isochronous IN and OUT endpoints only. Indicates the (micro)frame number in which the core transmits/receives isochronous data for this endpoint. The application must program the even/odd (micro) frame number in which it intends to transmit/receive isochronous data for this endpoint using the SetEvnFr and SetOddFr fields in this register.  • 1'b0: Even (micro)frame  • 1'b1: Odd (micro)frame When Scatter/Gather DMA mode is enabled, this field is reserved. The frame number in which to send data is provided in the transmit descriptor structure. The frame in which data is received is updated in receive descriptor structure. |
| USBACTEP | [15]    | R_W_SC | 1'b0 | Applies to IN and OUT endpoints. Indicates whether this endpoint is active in the current configuration and interface. The core clears this bit for all endpoints (other than EP 0) after detecting a USB reset. After receiving the SetConfiguration and SetInterface commands, the application must program endpoint registers accordingly and set this bit.                                                                                                                                                                                                                                                                                                                                                                  |
|          | [14:11] | R/W    | 4'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| MPS      | [10:0]  | R/W    | 2'b0 | Applies to IN and OUT endpoints.  The application must program this field with the maximum packet size for the current logical endpoint. This value is in bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



## 6.1.5.2.28 DIEPINTn/DOEPINTn

Description: (Device IN Endpoint Interrupt n/ Device OUT Endpoint Interrupt n)

| h)<br>OUT | Device In Endpoint Int n Device Out Endpoint Int n 308h+(n*20                                    |                                         |    |    |    |    |   |   |   |   |   |                   |                              |                 |                  | PINTn<br>PINTn    |
|-----------|--------------------------------------------------------------------------------------------------|-----------------------------------------|----|----|----|----|---|---|---|---|---|-------------------|------------------------------|-----------------|------------------|-------------------|
| Bit       | 31 30 29 28 27 26 25 24 23 22 21 20                                                              |                                         |    |    |    |    |   |   |   |   |   |                   | 19                           | 18              | 17               | 16                |
| Name      | Reserved                                                                                         |                                         |    |    |    |    |   |   |   |   |   |                   |                              |                 |                  |                   |
| Туре      |                                                                                                  |                                         |    |    |    |    |   |   |   |   |   |                   |                              |                 |                  |                   |
| Reset     | 0                                                                                                |                                         |    |    |    |    |   |   |   |   |   |                   |                              |                 |                  |                   |
| Bit       | 15                                                                                               | 14                                      | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4                 | 3                            | 2               | 1                | 0                 |
| Name      | Res NYE NAK EER DRO Res BNA NDR TXFI FOU NDR TRP RPT TRP D D D C R R R R R R R R R R R R R R R R |                                         |    |    |    |    |   |   |   |   |   | OUT<br>TKN<br>EPD | TIM<br>EOU<br>T<br>SET<br>UP | AHB<br>ERR      | EPDI<br>SBL<br>D | XFE<br>RCO<br>MPL |
| Туре      |                                                                                                  | R_S |    |    |    |    |   |   |   |   |   |                   |                              | R_S<br>S_W<br>C | R_S<br>S_W<br>C  | R_S<br>S_W<br>C   |
| Reset     | 0                                                                                                | 0                                       | 0  | 0  | 0  | 0  | 0 | 0 | 1 | 0 | 0 | 0                 | 0                            | 0               | 0                | 0                 |

| Field Name    | Bit     | Туре    | Reset<br>Value | Description                                                                                                                                                                                                                                   |
|---------------|---------|---------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EPENA         | [31:15] | RO      | 16'h0          | Reserved                                                                                                                                                                                                                                      |
| NYETINTRPT    | [14]    | R_SS_WC | 1'b0           | The core generates this interrupt when a NYET response is transmitted for a non isochronous OUT endpoint.                                                                                                                                     |
| NAKINTRPT     | [13]    | R_SS_WC | 1'b0           | The core generates this interrupt when a NAK is transmitted or received by the device.                                                                                                                                                        |
|               |         |         |                | In case of isochronous IN endpoints the interrupt gets generated when a zero length packet is transmitted due to un-availability of data in the TXFifo.                                                                                       |
| BBLEERRINTRPT | [12]    | R_SS_WC | 1'b0           | The core generates this interrupt when babble is received for the endpoint.                                                                                                                                                                   |
| PKTDRPSTS     | [11]    | R_SS_WC | 1'b0           | This bit indicates to the application that an ISOC OUT packet has been dropped. This bit does not have an associated mask bit and does not generate an interrupt.  Dependency: This bit is valid in non Scatter/Gather DMA mode when periodic |



|                |        |         |      | transfer interrupt feature is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|--------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [10:9] | RO      | 1'b0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TXFIFOUNDRN    | [8]    | R_SS_WC | 1'b0 | Applies to IN endpoints Only The core generates this interrupt when it detects a transmit FIFO underrun condition for this endpoint.  Dependency: This interrupt is valid only when both of the following conditions are true:  • Parameter OTG_EN_DED_TX_FIFO==1                                                                                                                                                                                                                             |
| OUTPKTERR      | [8]    | R_SS_WC | 1'b0 | Thresholding is enabled  Applies to OUT endpoints Only This interrupt is asserted when the core detects an overflow or a CRC error for non-Isochronous OUT packet. Dependency: This interrupt is valid only when both of the following conditions are true:      Parameter OTG_EN_DED_TX_FIFO==1     Thresholding is enabled.                                                                                                                                                                 |
| TXFEMP         | [7]    | RO      | 1'b1 | This bit is valid only for IN Endpoints This interrupt is asserted when the TxFIFO for this endpoint is either half or completely empty. The half or completely empty status is determined by the TxFIFO Empty Level bit in the Core AHB Configuration register (GAHBCFG.NPTxFEmpLvI)).                                                                                                                                                                                                       |
| INEPNAKEFF     | [6]    | R_SS_WC | 1'b0 | Applies to periodic IN endpoints only.  This bit can be cleared when the application clears the IN endpoint NAK by writing to DIEPCTLn.CNAK.  This interrupt indicates that the core has sampled the NAK bit set (either by the application or by the core). The interrupt indicates that the IN endpoint NAK bit set by the application has taken effect in the core.  This interrupt does not guarantee that a NAK handshake is sent on the USB. A STALL bit takes priority over a NAK bit. |
| BACK2BACKSETUP | [6]    | R/W     | 1'b0 | Applies to Control OUT endpoints only. This bit indicates that the core has received more than three back-to-back SETUP packets for this particular endpoint. For information about handling this interrupt,                                                                                                                                                                                                                                                                                  |
| INTKNEPMIS     | [5]    | R_SS_WC | 1'b0 | Applies to non-periodic IN endpoints only. Indicates that the data in the top of the non-periodic TxFIFO belongs to an endpoint other than the one for which the IN token was received. This interrupt is asserted on the endpoint for which the IN token was received.                                                                                                                                                                                                                       |



|             | [5] | RO      | 1'b0 | Reserved                                                                                                                                                                                                                                                                        |
|-------------|-----|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INTKNTXFEMP | [4] | R_SS_WC | 1'b0 | Applies to non-periodic IN endpoints only. Indicates that an IN token was received when the associated TxFIFO (periodic/nonperiodic) was empty. This interrupt is asserted on the endpoint for which the IN token was received.                                                 |
| OUTTKNEPDIS | [4] | R_SS_WC | 1'b0 | Applies only to control OUT endpoints. Indicates that an OUT token was received when the endpoint was not yet enabled. This interrupt is asserted on the endpoint for which the OUT token was received.                                                                         |
| TIMEOUT     | [3] | R_SS_WC | 1'b0 | In dedicated FIFO mode, applies only to<br>Control IN endpoints.  Indicates that the core has detected a<br>timeout condition on the USB for the last IN<br>token on this endpoint.                                                                                             |
| SETUP       | [3] | R_SS_WC | 1'b0 | Applies to control OUT endpoints only. Indicates that the SETUP phase for the control endpoint is complete and no more back-to-back SETUP packets were received for the current control transfer. On this interrupt, the application can decode the received SETUP data packet. |
| AHBERR      | [2] | R_SS_WC | 1'b0 | Applies to IN and OUT endpoints.  This is generated only in Internal DMA mode when there is an AHB error during an AHB read/write. The application can read the corresponding endpoint DMA address register to get the error address.                                           |
| EPDISBLD    | [1] | R_SS_WC | 1'b0 | Applies to IN and OUT endpoints. This bit indicates that the endpoint is disabled per the application's request.                                                                                                                                                                |
| XFERCOMPL   | [0] | R_SS_WC | 1'b0 | Applies to IN and OUT endpoints.  • When Scatter/Gather DMA mode is disabled, this field indicates that the programmed transfer is complete on the AHB as well as on the USB, for this endpoint.                                                                                |

# 6.1.5.2.29 DIEPTSIZ0

Description: (Device IN Endpoint Transfer Size 0)



| 0x0910 | h  |          | Devi | ce In E | ndpoi   | nt Tran | sfer S | ize 0(r | eset 0 | x0000_   | _0000) |    |   |   | DIEP     | TSIZ0 |
|--------|----|----------|------|---------|---------|---------|--------|---------|--------|----------|--------|----|---|---|----------|-------|
| Bit    | 31 | 30       | 29   | 28      | 27      | 26      | 21     | 20      | 19     | 18       | 17     | 16 |   |   |          |       |
| Name   |    | Reserved |      |         |         |         |        |         |        |          |        |    |   |   | Reserved |       |
| Туре   |    |          |      |         |         |         |        |         |        |          |        |    | W |   |          |       |
| Reset  | 0  |          |      |         |         |         |        |         |        |          |        | (  | 0 | 0 |          |       |
| Bit    | 15 | 14       | 13   | 12      | 11      | 10      | 9      | 8       | 7      | 6        | 5      | 4  | 3 | 2 | 1        | 0     |
| Name   |    |          |      |         | Reserve | d       |        |         |        | XFERSIZE |        |    |   |   |          |       |
| Туре   |    |          |      |         |         |         |        |         |        |          | RW     |    |   |   |          |       |
| Reset  |    |          |      |         | 0       |         |        |         | 0      |          |        |    |   |   |          |       |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                         |
|------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:21] | RO   | 11'h0          | Reserved                                                                                                                                                                                                                                                                                                                                                                            |
| PKTCNT     | [20:19] | R/W  | 2'b0           | Indicates the total number of USB packets that constitute the Transfer Size amount of data for endpoint 0.  This field is decremented every time a packet (maximum size or short packet) is read from the TxFIFO.                                                                                                                                                                   |
|            | [18:7]  | RO   | 12'b0          | Reserved                                                                                                                                                                                                                                                                                                                                                                            |
| XFERSIZE   | [6:0]   | R/W  | 7'b0           | Indicates the transfer size in bytes for endpoint 0. The core interrupts the application only after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.  The core decrements this field every time a packet from the external memory is written to the TxFIFO. |

# 6.1.5.2.30 DOEPTSIZ0

Description: (Device OUT Endpoint Transfer Size 0)



| 0x0B10    | )h               |     | Devi | ce Out                           | Endpo       | oint Tr | ansfer | Size 0 | (reset | 0x000    | 0_000 | 0) |    |   | DOEP     | TSIZ0 |  |
|-----------|------------------|-----|------|----------------------------------|-------------|---------|--------|--------|--------|----------|-------|----|----|---|----------|-------|--|
| Bit       | 31               | 30  | 29   | 28 27 26 25 24 23 22 21 20 19 18 |             |         |        |        |        |          |       | 17 | 16 |   |          |       |  |
| Nam<br>e  | Res<br>erve<br>d | SUP | CNT  |                                  | Reserved PK |         |        |        |        |          |       |    |    |   | Reserved |       |  |
| Туре      |                  | R   | W    |                                  | RW          |         |        |        |        |          |       |    |    |   |          |       |  |
| Rese<br>t | 0                | (   | 0    |                                  | 0 0         |         |        |        |        |          |       |    |    | 0 |          |       |  |
| Bit       | 15               | 14  | 13   | 12                               | 11          | 10      | 9      | 8      | 7      | 6        | 5     | 4  | 3  | 2 | 1        | 0     |  |
| Nam<br>e  |                  |     |      |                                  | Reserve     | d       |        |        |        | XFERSIZE |       |    |    |   |          |       |  |
| Туре      |                  |     |      |                                  |             |         |        |        |        |          | RW    |    |    |   |          |       |  |
| Rese<br>t |                  |     |      |                                  | 0           |         |        |        | 0      |          |       |    |    |   |          |       |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31]    | RO   | 11'h0          | Reserved                                                                                                                                                                                                                                                                                                                                                                                     |
| SUPCNT     | [30:29] | R/W  | 2'h0           | This field specifies the number of back-to-back SETUP data packets the endpoint can receive.  • 2'b01: 1 packet  • 2'b10: 2 packets  • 2'b11: 3 packets                                                                                                                                                                                                                                      |
|            | [28:20] |      | 9'h0           | Reserved                                                                                                                                                                                                                                                                                                                                                                                     |
| PKTCNT     | [19]    | R/W  | 2'b0           | This field is decremented to zero after a packet is written into the RxFIFO.                                                                                                                                                                                                                                                                                                                 |
|            | [18:7]  | RO   | 12'b0          | Reserved                                                                                                                                                                                                                                                                                                                                                                                     |
| XFERSIZE   | [6:0]   | R/W  | 7'b0           | Indicates the transfer size in bytes for endpoint 0. The core interrupts the application only after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.  The core decrements this field every time a packet is read from the RxFIFO and written to the external memory. |

# 6.1.5.2.31 DIEPTSIZn/DOEPTSIZn

Description: (Device IN/OUT Endpoint Transfer Size n)



| IN<br>EP:0x9<br>h)<br>OUT<br>EP:0xB<br>h) |                  |     |                   | evice In Endpoint Transfer Size n evice Out Endpoint Transfer Size n(reset 0x0000_0000) |    |    |    |     |     |    |    |    |    | DIEPTS<br>DOEPTS |         |    |  |
|-------------------------------------------|------------------|-----|-------------------|-----------------------------------------------------------------------------------------|----|----|----|-----|-----|----|----|----|----|------------------|---------|----|--|
| Bit                                       | 31               | 30  | 29                | 28                                                                                      | 27 | 26 | 25 | 24  | 23  | 22 | 21 | 20 | 19 | 18               | 17      | 16 |  |
| Nam<br>e                                  | Res<br>erve<br>d | RXD | C,<br>PID,<br>CNT |                                                                                         |    |    |    | PKT | CNT |    |    |    |    | )                | KFERSIZ | E  |  |
| Туре                                      | 0                | R'  | W                 |                                                                                         |    |    |    | R'  | W   |    |    |    |    |                  | RW      |    |  |
| Rese<br>t                                 |                  | (   | 0                 |                                                                                         |    |    |    | (   | )   |    |    |    |    |                  | 0       |    |  |
| Bit                                       | 15               | 14  | 13                | 12                                                                                      | 11 | 10 | 9  | 8   | 7   | 6  | 5  | 4  | 3  | 2                | 1       | 0  |  |
| Nam<br>e                                  |                  |     |                   | XFERSIZE                                                                                |    |    |    |     |     |    |    |    |    |                  |         |    |  |
| Туре                                      |                  |     |                   | RW                                                                                      |    |    |    |     |     |    |    |    |    |                  |         |    |  |
| Rese<br>t                                 |                  |     |                   | 0                                                                                       |    |    |    |     |     |    |    |    |    |                  |         |    |  |

| Field Name | Bit      | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                        |
|------------|----------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31]     | RO   | 11'h0          | Reserved                                                                                                                                                                                                                                                                                           |
| MC         | [30:29]  | R/W  | 2'h0           | Applies to IN endpoints only.  For periodic IN endpoints, this field indicates the number of packets that must be transmitted per microframe on the USB. The core uses this field to calculate the data PID for isochronous IN endpoints.  • 2'b01: 1 packet • 2'b10: 2 packets • 2'b11: 3 packets |
|            | <b>)</b> |      | RO             | For non-periodic IN endpoints, this field is valid only in Internal DMA mode. It specifies the number of packets the core must fetch for an IN endpoint before it switches to the endpoint pointed to by the Next Endpoint field of the Device Endpoint-n Control register (DIEPCTLn.NextEp).      |
| RXDPID     |          |      | RO             | Applies to isochronous OUT endpoints only. This is the data PID received in the last packet for this endpoint.  • 2'b00: DATA0  • 2'b01: DATA2  • 2'b10: DATA1  • 2'b11: MDATA                                                                                                                     |
| SUPCNT     |          |      | R/W            | Applies to control OUT Endpoints only. This field specifies the number of                                                                                                                                                                                                                          |



|          |         |     |       | back-to-back SETUP data packets the endpoint can receive. • 2'b01: 1 packet • 2'b10: 2 packets • 2'b11: 3 packets                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|---------|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PKTCNT   | [28:19] | R/W | 10'h0 | Indicates the total number of USB packets that constitute the Transfer Size amount of data for this endpoint. The power-on value is specified for Width of Packet Counters during coreConsultant configuration (parameter OTG_PACKET_COUNT_WIDTH)  • IN Endpoints: This field is decremented every time a packet (maximum size or short packet) is read from the TxFIFO.  • OUT Endpoints: This field is decremented every time a packet (maximum size or short packet) is written to the RxFIFO. |
| XFERSIZE | [18:0]  | R/W | 19'b0 | This field contains the transfer size in bytes for the current endpoint. The power-on value is specified for Width of Transfer Size Counters during coreConsultant configuration (parameter OTG_TRANS_COUNT_WIDTH). The core only interrupts the application after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.                                                       |

# 6.1.5.2.32 DIEPDMAn/DOEPDMAn

Description: (Device IN/OUT Endpoint DMA n)



| IN<br>EP:0x9<br>h)<br>OUT<br>EP:0xB<br>h) |    |         | Device In Endpoint DMA n Device Out Endpoint DMA n(reset 0x0000_0000) |    |    |    |    |    |    |    |    |    |    | DIEP<br>DOEP |    |    |  |
|-------------------------------------------|----|---------|-----------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|--------------|----|----|--|
| Bit                                       | 31 | 30      | 29                                                                    | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18           | 17 | 16 |  |
| Nam<br>e                                  |    | DMAADDR |                                                                       |    |    |    |    |    |    |    |    |    |    |              |    |    |  |
| Туре                                      |    | RW      |                                                                       |    |    |    |    |    |    |    |    |    |    |              |    |    |  |
| Rese<br>t                                 |    |         |                                                                       |    |    |    |    |    | 0  |    |    |    |    |              |    |    |  |
| Bit                                       | 15 | 14      | 13                                                                    | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2            | 1  | 0  |  |
| Nam<br>e                                  |    | DMAADDR |                                                                       |    |    |    |    |    |    |    |    |    |    |              |    |    |  |
| Туре                                      |    | RW      |                                                                       |    |    |    |    |    |    |    |    |    |    |              |    |    |  |
| Rese<br>t                                 |    |         | 0                                                                     |    |    |    |    |    |    |    |    |    |    |              |    |    |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|--------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMAADDR    | [31:0] | R/W  | 32'h0          | Holds the start address of the external memory for storing or fetching endpoint data.                                                                                                                                                                                                                                                                                                                                                                              |
|            |        |      |                | Note: For control endpoints, this field stores control OUT data packets as well as SETUP transaction data packets. When more than three SETUP packets are received back-to-back, the SETUP data packet in the memory is overwritten. This register is incremented on every AHB transaction. The application can give only a DWORD-aligned address.  • When Scatter/Gather DMA mode is not enabled, the application programs the start address value in this field. |

## 6.1.5.2.33 DTXFSTSn

 $\begin{tabular}{ll} Description: & (Device IN/OUT Endpoint DMA n) \\ \end{tabular}$ 



| 0x918h    | +(n*20 | Oh)          | Devi | ce TX I | FIFO S | tatus r | 1  |        |         |    |    |    | DTXF | STSn |    |    |
|-----------|--------|--------------|------|---------|--------|---------|----|--------|---------|----|----|----|------|------|----|----|
| Bit       | 31     | 30           | 29   | 28      | 27     | 26      | 25 | 24     | 23      | 22 | 21 | 20 | 19   | 18   | 17 | 16 |
| Nam<br>e  |        |              |      |         |        |         |    | Res    | erved   |    |    |    |      |      |    |    |
| Туре      |        | 0            |      |         |        |         |    |        |         |    |    |    |      |      |    |    |
| Rese<br>t |        |              |      |         |        |         |    |        |         |    |    |    |      |      |    |    |
| Bit       | 15     | 14           | 13   | 12      | 11     | 10      | 9  | 8      | 7       | 6  | 5  | 4  | 3    | 2    | 1  | 0  |
| Nam<br>e  |        |              |      |         |        |         |    | INEPTx | FSpcAva | i  |    |    |      |      |    |    |
| Туре      |        | RO           |      |         |        |         |    |        |         |    |    |    |      |      |    |    |
| Rese<br>t |        | Configurable |      |         |        |         |    |        |         |    |    |    |      |      |    |    |

| Field Name      | Bit     | Туре | Reset Value  | Description                                                                                                                                                                                        |
|-----------------|---------|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | [31:16] | RO   | 16'h0        | Reserved                                                                                                                                                                                           |
| INEPTXFSPCAVAIL | [15:0]  | RO   | Configurable | Indicates the amount of free space available in the Endpoint TxFIFO. Values are in terms of 32-bit words.  • 16'h0: Endpoint TxFIFO is full  • 16'h1: 1 word available  • 16'h2: 2 words available |
|                 |         |      |              | • 16'hn: n words available (where 0 ≤ n ≤ 32,768)                                                                                                                                                  |
|                 |         |      |              | <ul><li>16'h8000: 32,768 words available</li><li>Others: Reserved</li></ul>                                                                                                                        |

## 6.1.5.2.34 PCGCCTL

Description: (Power and Clock Gating Control )



| 0xE00h    | )  |          | Powe     | er and | Clock | Gating | g Cont | rol(res | et 0x0                | 000_0                | 000)                              |                                  |                                       |            | PCG         | CCTL                 |
|-----------|----|----------|----------|--------|-------|--------|--------|---------|-----------------------|----------------------|-----------------------------------|----------------------------------|---------------------------------------|------------|-------------|----------------------|
| Bit       | 31 | 30       | 29       | 28     | 27    | 26     | 25     | 24      | 23                    | 22                   | 21                                | 20                               | 19                                    | 18         | 17          | 16                   |
| Nam<br>e  |    | Reserved |          |        |       |        |        |         |                       |                      |                                   |                                  |                                       |            |             |                      |
| Туре      |    |          |          |        |       |        |        |         |                       |                      |                                   |                                  |                                       |            |             |                      |
| Rese<br>t |    | 0        |          |        |       |        |        |         |                       |                      |                                   |                                  |                                       |            |             |                      |
| Bit       | 15 | 14       | 13       | 12     | 11    | 10     | 9      | 8       | 7                     | 6                    | 5                                 | 4                                | 3                                     | 2          | 1           | 0                    |
| Nam<br>e  |    |          | Reserved |        |       |        |        |         | LUSP<br>SP<br>DD<br>D | PH<br>YS<br>LE<br>EP | EN<br>BL_<br>L1<br>GA<br>TIN<br>G | PH<br>YS<br>US<br>PE<br>ND<br>ED | RS<br>TP<br>DW<br>NM<br>OD<br>UL<br>E | PW RC LM P | GA TE HC LK | ST<br>OP<br>PC<br>LK |
| Туре      |    |          |          |        |       |        |        |         | RO                    | RO                   | RW                                | RO                               | RW                                    | RW         | RW          | RW                   |
| Rese<br>t |    | 0        |          |        |       |        |        | 0       | 0                     | 0                    | 0                                 | 0                                | 0                                     | 0          | 0           | 0                    |

| Field Name     | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|--------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [31:9] | RO   | 23'h0          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                           |
| RESETAFTERSUSP | [8]    | R/W  | 1'b0           | In partial power-down mode of operation, this bit needs to be set in host mode before clamp is removed if the host needs to issue reset after suspend. If this bit is not set, then the host issues resume after suspend. This bit is not applicable in device mode and non-partial power-down mode                                                                                                                |
| L1 SUSPENDED   | [7]    | RO   | 1'b0           | This bit indicates that the PHY is in deep sleep when in L1 state.                                                                                                                                                                                                                                                                                                                                                 |
| PHYSLEEP       | [6]    | RO   | 1'b0           | This bit indicates that the PHY is in the Sleep state.                                                                                                                                                                                                                                                                                                                                                             |
| ENBL_L1GATING  | [5]    | R/W  | 1'b0           | When this bit is set, core internal clock gating is enabled in Sleep state if the core cannot assert utmi_I1_suspend_n.  When this bit is not set, the PHY clock is not gated in Sleep state.                                                                                                                                                                                                                      |
| PHYSUSPENDED   | [4]    | RO   | 1'b0           | This bit indicates that the PHY has been suspended. After the application sets the Stop Pclk bit (Bit 0), this bit is updated when the PHY becomes suspended.  Because the UTMI+ PHY suspend is controlled through a port, the UTMI+ PHY is suspended immediately after the Stop Pclk bit is set. The ULPI PHY takes a few clocks to suspend, however, because the suspend information is conveyed to the ULPI PHY |



|               |     |     |      | through the ULPI protocol.                                                                                                                                                                                                                                                                             |
|---------------|-----|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RSTPDWNMODULE | [3] | R/W | 1'b0 | This bit is valid only in Partial Power-Down mode. The application sets this bit when the power is turned off. The application clears this bit after the power is turned on and the PHY clock is up.                                                                                                   |
| PWRCLMP       | [2] | R/W | 1'b0 | This bit is valid only in Partial Power-Down mode (OTG_EN_PWROPT = 1). The application sets this bit before the power is turned off to clamp the signals between the power-on modules and the power-off modules. The application clears the bit to disable the clamping before the power is turned on. |
| GATEHCLK      | [1] | R/W | 1'b0 | The application sets this bit to gate hclk to modules other than the AHB Slave and Master and wakeup logic when the USB is suspended or the session is not valid. The application clears this bit when the USB is resumed or a new session starts.                                                     |
| STOPPCLK      | [0] | R/W | 1'b0 | The application sets this bit to stop the PHY clock (phy_clk) when the USB is suspended, the session is not valid, or the device is disconnected. The application clears this bit when the USB is resumed or a new session starts.                                                                     |

## 6.1.6 Application Notes

#### 6.1.6.1 Data FIFO RAM Allocation

If Dynamic FIFO Sizing is enabled in the core, external RAM must be allocated among different FIFOs in the core before any transactions can start. The application must follow this procedure every time it changes core FIFO RAM allocation. The application must allocate data RAM per FIFO based on the AHB's operating frequency, the PHY Clock frequency, the available AHB bandwidth, and the performance required on the USB. Based on the above mentioned criteria, the application must provide a table as described below with RAM sizes for each FIFO in each mode.

USB core shares a single SPRAM between transmit FIFO(s) and receive FIFO.

In DMA mode--The SPRAM is also used for storing the some register information .

The Device mode Endpoint DMA address registers (DI/OEPDMAn) is stored in the SPRAM. In addition, the registers DIEPDMAn/DOEPDMAn are maintained in RAM.

#### 6.1.6.2 Memory Calculation

Considerations for allocating data RAM for some of the FIFOs in Device mode are listed here:

- Receive FIFO RAM allocation:
- RAM for SETUP Packets: 4 \* n + 6 locations must be Reserved in the receive FIFO to receive up to n SETUP packets on control endpoints, where n is the number of control endpoints the device core supports. The core does not use these locations, which are Reserved for SETUP packets, to write any other data.
- Ø One location for Global OUT NAK
- Status information is written to the FIFO along with each received packet. Therefore, a minimum space of (Largest Packet Size / 4) + 1 must be allotted to receive packets. If a high-bandwidth



endpoint is enabled, or multiple isochronous endpoints are enabled, then at least two (Largest Packet Size / 4) + 1 spaces must be allotted to receive back-to-back packets. Typically, two (Largest Packet Size / 4) + 1 spaces are recommended so that when the previous packet is being transferred to AHB, the USB can receive the subsequent packet. If AHB latency is high, you must allocate enough space to receive multiple packets. This is critical to prevent dropping any isochronous packets.

- Ø Along with each endpoint's last packet, transfer complete status information is also pushed to the FIFO. Typically, one location for each OUT endpoint is recommended.
- 2. Transmit FIFO RAM allocation:
- Ø The RAM size for the Periodic Transmit FIFO must equal the maximum amount of data that can be transmitted in a single microframe. The core does not use any data RAM allocated over this requirement, and when data RAM allocated is less than this requirement, the core can malfunction.
- Ø The minimum amount of RAM required for the Non-periodic Transmit FIFO is the largest maximum packet size among all supported non-periodic IN endpoints.
- More space allocated in the Transmit Non-periodic FIFO results in better performance on the USB and can hide AHB latencies. Typically, two Largest Packet Sizes' worth of space is recommended, so that when the current packet is under transfer to the USB, the AHB can get the next packet. If the AHB latency is large, then you must allocate enough space to buffer multiple packets.
- Ø It is assumed that i number of periodic FIFOs is implemented in Device mode.
- 3. Internal Register Storage Space Allocation:

When operating in Internal DMA mode, the core stores the Endpoint DMA address register (DI/OEPDMA) in the SPRAM. One location must be allocated for each endpoint. For example, if an endpoint is bidirectional, then two locations must be allocated. If an endpoint is IN or OUT, then only one location must be allocated.

#### 6.1.6.3 Calculating the Total FIFO Size for USB core

Total Mem Calculation conditions:

- Ø Minimum FIFO depth allocation
- Ø Support for no more than one Isochronous EndPoint in Device mode
- Ø The FIFO must equal at least one MaxPacketSize (MPS).
- Ø Support for high-bandwidth endpoints.

Total Data FIFO RAM Depth = RxFIFO + Non-periodic TxFIFO + device periodic TxFIFOs

Device RxFIFO = (4 \* number of control endpoints + 6) + ((largest USB packet used / 4) + 1) + (2 \* number of OUT endpoints) + 1

Non-Periodic TxFIFO =(largest non-periodic USB packet used / 4)

Device Periodic Endpoint-Specific TxFIFOs (a separate FIFO is allocated to each endpoint) = (largest periodic USB packet used for an endpoint / 4) \* maximum number of periodic data packets per microframe / frame

Our configuration is as following:

Using Dedicated FIFO mode. The MPS is 1023 bytes for a periodic USB packet and is 512 bytes for a non-periodic USB packet. There are three OUT endpoints, six IN endpoints (non-periodic), one control endpoint, and additional one isochronous (periodic) endpoint. The maximum number of periodic data packets per transfer for Endpoint is 2. With these information, The total data FIFO depth is calculated as follows:

Device RxFIFO = (4 \* 1 + 6) + ((1024 / 4) + 1) + 2 \* 4 + 1 = 276

Device IN Endpoint TxFIFO:

FIFO # 0 = (64/4) = 16(Assuming this is used for EP0)

FIFO # 1~4 = (512/4) = 128

FIFO #  $5 = 2^*$  (1024/4) = 512 (Assuming this is used for Isochonous)

Internal Register = 2 \* 8 = 16



Total Data FIFO RAM Depth = Max(276 + 128 \*3 + 512 + 16 + 16 = 1204, 276 + 128 \*6 + 16 + 16 = 1076) = 1204

Note: Because Dynamic FIFO Sizing is enabled, So FIFO RAM should be dynamically configured for different application:

For Isochronous Endpoint application: only 3 endpoint can be used, so FIFO depth configuration should be 276 + 128 \*3+ 512

For Normal application: Up to 6 endpoint can be used, so FIFO depth configuration should be 276 + 128\*6

Remember, the default value in register is the largest value, so these registers should be reprogrammed every time the core initiates.

### 6.2 UART and IrDA interface

### 6.2.1 Overview

UART is an asynchronous communication interface. SC6820 UART module includes a baud rate generator with software-programmable divider ratios for all common baud rates. Two 128-byte-deep FIFO buffers can minimize processor overhead. The module also includes a flexible interrupt with multiple maskable interrupt sources. Two hardware flow control lines are included (one for input, the other for output). This module also has a built-in IrDA controller and can be configured to connect to an IrDA transceiver. When being used as regular UART port, the IrDA controller is bypassed.

SC6820 provides 3 UART ports, UART0 and UART2 are dedicated for ARM, UART1 is controlled by ARM or DSP depending on global register; when this bit is set to "1", DSP controls UART1, else ARM controls UART1. UART0 ,UART1 and UART2 have 128-byte FIFO depth.

#### 6.2.2 Features

- I Full-duplex operation
- I Hardware flow control support
- I 128-byte-deep FIFOs minimizes processor overhead at high data rates
- Wide selection of UART word lengths, including 5, 6, 7 and 8 bits
- I Stop bit number can be 0, 1, 1.5 or 2 bits
- Support odd/even parity
- Auto detect for parity and framing error
- UART loop-back test mode
- Break character detection and generation
- support DMA operation
- I Single interrupt line for multiple maskable interrupt source events
- I Programmable interrupt trigger levels for FIFOs
- Baud rate generation based upon programmable divisors, operating from a flexible functional clock
- I Includes a built-in IrDA controller



# 6.2.3 Signal Description

UART0, UART1 and UART2 can be easily connected to the UART port of an external IC. UART0 supports hardware flow control.

Table 6-2 Uart singal description

| Signal    | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset |
|-----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Uart_tx   | 0   | Serial data output. Since the uart_tx is active high, the pin is set to low on reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1'h1  |
| Uart_rx   | I   | Serial data in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1'hx  |
| Uart_ctsn | I   | Clear to send  Active-low modem status signal. This signal is asserted (logic'0') by the DCE device to inform the UART module that transmission may begin. RTS and CTS are commonly used as handshaking signals to moderate the flow of data into the receiving UART device. The value of this signal is indicated by the UART STS0 bit9 after logical inverse. When the input signal CTSN changes value, either from 0 to 1 or from 1 to 0, an interrupt will be generated to the MCU. If hardware flow control is enabled and the signal CTSN is high, the UART immediately stops data transmission on the TXD output pin after it completes the current data byte transmission. Reading bit 9 of the UART status register checks the condition of uart_cts (inverse). | 1'hx  |
| Uart_rtsn | 0   | Request to send  When active (low), the module is ready to receive data. This assertion might mean enabling the transmit circuits of DTE device, or setting up the channel direction in half-duplex applications. When hardware flow control is not set, programming the UART CTL0 bit 6 directly controls the output of RTSN. This pin is the inverse of UART CTL0 bit 6. If receive hardware flow control is set by writing "1" to UART CTL1 bit 7, RTSN will be controlled by the RX FIFO level and Receive_Hardware_Flow_Control threshold. The threshold can be configured by writing UART CTL1[5:0].In this case, RTSN remains high as long as the number of data in the RX FIFO is greater than the configured threshold value.                                   | 1     |



Figure 6-3 UART0 with flow control application





Figure 6-4 UART1/UART2 without flow control application

# 6.2.4 Function Description

The UART and IRDA baud rate generator is based on the clk\_uart, the divisor coefficient is controlled by register UART\_CKD0. IRDA part clock period is the 1/16 of the UART part since the required timing of IRDA is 3/16 or 4/16 of bit width. The serial data rate can be changed by modify the clk\_uart or the UART divisor coefficient.





### Figure 6-5 Diagram of UART

#### 6.2.4.1 UART Mode Description

UARTs in SC6820 share the same design and each has an independent baud rate generator, which is used as a clock reference for data transmit and recovery. Each of them also has a 128-byte-deep RX FIFO and a 128-byte-deep TX FIFO to decrease processor interrupt load during the data receiving/transmitting.

### 6.2.4.1.1 FIFO Management

FIFOs are accessed by reading/writing UART\_RXD/UART\_TXD register. The number of data in TX/RX FIFO can be observed by reading UART\_STS1 [6:0]/UART\_STS1 [14:8]. Rx\_fifo\_full and Tx\_fifo\_empty status can be obtained by reading UART\_STS0 [1:0]. UART\_CTL2 register controls the FIFO trigger level, which enables the DMA request and interrupt generation.

TX FIFO size is 128 bytes. It uses a FIFO pointer to monitor the number of data in the TX FIFO that has not yet been transmitted. The MCU can read the UART STS1 [14:8] to access the pointer. The UART also provides a TXF empty interrupt threshold that can be configured by writing UART CTL2 [14:8].

RX FIFO size is 128 bytes. It uses a pointer to monitor the number of data in the RX FIFO that have not yet been read by the MCU. The MCU can access the pointer by reading the UART STS1 [6:0]. The UART also provides a RX FIFO full interrupt threshold that can be configured by writing to UART CTL2 [6:0]. In FIFO interrupt mode with flow control, the programmer must also ensure that the Receive\_Hardware\_Flow\_Control\_Threshold (UART\_CTL1 [6:0]) value is greater than or equal to the Receive\_Int\_WaterMark (UART\_CTL2 [6:0]). Otherwise, FIFO operation stalls.

In FIFO interrupt mode, the processor is informed of the status of the receiver and transmitter by an interrupt signal. The rx\_fifo\_full interrupt is set when the number of RX FIFO data bytes is larger than the RX interrupt watermark value. It is auto cleared when the condition disappears. The tx\_fifo\_empty interrupt is set when the number of TX FIFO data bytes is less than the TX interrupt watermark value. It is auto cleared when the condition disappears. The two interrupt sources can be masked by writing "0" to UART\_IEN register bit 0 and bit 1.The interrupt signal instructs the local hosts to write data to TX FIFO or read data from RX FIFO.

Note that in the cases of the UART flow control being enabled along with the interrupt capabilities, the user must ensure that the UART flow control FIFO threshold is greater than or equal to the receive FIFO watermark.

The TX and RX FIFO may be accessed by DMA. Writing to control register UART\_CTL1 bit 15 will enable DMA mode. In receive mode, a DMA request is generated as soon as the receive FIFO reached its threshold level defined in UART\_CTL2 [6:0]. This request is deserted when the number of bytes is less than the threshold level. In transmit mode, a DMA request is automatically asserted when the transmit FIFO is almost empty.

In this mode, when RX FIFO is almost full (the number of RX FIFO data bytes is larger than the RX interrupt watermark value), it will send the receive request to DMA controller, and when TX FIFO is almost empty, it will send the transmit request to DMA controller.

### 6.2.4.1.2 Hardware Flow Control

SC6820 UART supports both software flow control and hardware flow control. When UART\_CTL1 register bit 7 is set to "0", software will control the signal uart\_rtsn by writing UART\_CTL0 register bit 6; if "1", the signal uart\_rtsn will be controlled by hardware itself, called auto-RTS.



Hardware flow control is composed of auto-CTS and auto-RTS. Auto-CTS and auto-RTS can be enabled/disabled independently by programming UART\_CTL1 [8:7].

Auto-RTS data flow control originates in the receiver block. The receiver FIFO trigger levels used in auto-RTS are stored in the UART\_CTL1 [6:0]. RTS is active if the RX FIFO level is below the HALT trigger level. When the receiver FIFO HALT trigger level is reached, uart\_rtsn is deserted. The sending device (external UART device) may send an additional byte after the trigger level is reached because it may not recognize the desertion of RTSn until it has begun sending the additional byte. The assertion requests the sending device to resume transmission. In this case, uart\_rtsn is an active-low signal.

With auto-CTS, uart\_ctsn must be active before the module can transmit data. The transmitter circuitry checks uart\_ctsn before sending the next data byte. When uart\_ctsn is active, the transmitter sends the next byte. The auto-CTS function reduces interrupts to the host system. When auto-CTS flow control is enabled, the CTS state changes need not trigger host interrupts because the device automatically controls its own transmitter. Without auto-CTS, the transmitter sends any data present in the transmit FIFO and a receiver overrun error can result. In this case, uart\_ctsn is an active-low signal.

### 6.2.4.1.3 Interrupt sources

The UART also provides a TXF empty interrupt threshold that can be configured by writing UART CTL2 [14:8]. A tx\_fifo\_empty interrupt will be generated when the number of TX FIFO data bytes is less than the TX interrupt watermark value. It is auto cleared when the condition disappears.

UART also provides a RX FIFO full interrupt threshold that can be configured by writing to UART CTL2 [6:0]. An rx\_fifo\_full interrupt will be generated when the number of RX FIFO data bytes is larger than the RX interrupt watermark value. The interrupt will be auto cleared when the condition disappears.

An rx\_tout interrupt will be generated if the UART has not received data from the input line in a period of time. This period depends on the baudrate and the value of CTL1 [13:9]. If the value of CTL1 [13:9] is '0', the interrupt will never be generated. The interrupt can be cleared by writing "1" to UART\_ICLR bit 13.

When having received data, UART generate parity error/framing error if error condition occurs. Also, when having received FIFO overrun, an error interrupt will be generated. Writing to corresponding interrupt clear bit will clear these interrupts.

All interrupt sources in SC6820 UART can be disabled and masked by writing to corresponding registers.

When TX FIFO is empty and TX is idle, setting send break bit forces the TX data output to low.



Figure 6-6 UART timing parameter

#### 6.2.4.2 IRDA Mode Description

The IrDA can be used to communicate with other IrDA compatible device. IrDA mode is selected by writing "1" to UART CTL0 [15]. The default value of this bit is "0". IrDA mode is achieved by adding IrDA transmit block and IrDA receive block into UART module. The IrDA transmit block changes the UART transmit serial bits to the IrDA timing, and then sends to TXD port. On the other side, the receive module



detects the IrDA timing from the RXD port and changes back to UART bit stream to let the UART receive block to finish the data receiving.

Figure below shows the transmit IrDA timing. The polarity could be changed by UART CTL0 bit 9, and the pulse of a bit may be 3 or 4 high cycle controlled by the UART CTL0 bit 13. In the no polarity invert working mode, when sending "1", the output remains "0". And when sending "0", output follows the IrDA timing as demonstrated in the figure. On the receive data path, the polarity could be change by UART\_CTL0 bit 10. The transmission and receive operation could be controlled by the UART CTL0 bit 11 and bit 12.



Figure 6-7 IrDA transmit timing

# 6.2.5 Control Registers

### **6.2.5.1** Memory map

ARM base address: 0x8300\_0000 (UART0)

0x8400\_0000 (UART1) 0x8e00\_0000 (UART2)

| Offset<br>Address | Name       | Description                                                                   |
|-------------------|------------|-------------------------------------------------------------------------------|
| 0x0000            | UART_TXD   | Write data to this address initiates a character transmission through TX FIFO |
| 0x0004            | UART_RXD   | Read from this address retrieve data from RX FIFO                             |
| 0x0008            | UART_STS0  | IIS internal status                                                           |
| 0x000C            | UART_STS1  | The data number in TXF and RXF                                                |
| 0x0010            | UART_IEN   | UART interrupt enable register                                                |
| 0x0014            | UART_ICLR  | UART interrupt clear register                                                 |
| 0x0018            | UART_CTRL0 | UART control register                                                         |
| 0x001C            | UART_CTRL1 | UART control register                                                         |
| 0x0020            | UART_CTRL2 | UART control register                                                         |
| 0x0024            | UART_CKD0  | Divisor is (n+1)*2                                                            |



| Offset<br>Address | Name         | Description                |
|-------------------|--------------|----------------------------|
| 0x002C            | UART_STS2    | UART interrupt mask status |
| 0x0030            | UART_DSPWAIT | Control register           |

## 6.2.5.2 Register Descriptions

## 6.2.5.2.1 UART\_TXD

Description: Write data to this address initiates a character transmission through TX FIFO.

| 0x0000 |    |          | UAR | T TX re | egister | (0x000 | 000_000 | 0) |          |    |    |    | UART_TXD |    |    |    |  |
|--------|----|----------|-----|---------|---------|--------|---------|----|----------|----|----|----|----------|----|----|----|--|
| Bit    | 31 | 30       | 29  | 28      | 27      | 26     | 25      | 24 | 23       | 22 | 21 | 20 | 19       | 18 | 17 | 16 |  |
| Name   |    | Reserved |     |         |         |        |         |    |          |    |    |    |          |    |    |    |  |
| Туре   |    | 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   |    |          |     | Rese    | erved   |        |         |    | UART_TXD |    |    |    |          |    |    |    |  |
| Туре   |    |          |     | R       | 0       |        |         |    | wo       |    |    |    |          |    |    |    |  |
| Reset  | 0  | 0        | 0   | 0       | 0       | 0      | 0       | 0  | 0        | 0  | 0  | 0  | 0        | 0  | 0  | 0  |  |

| Field Name | Bit   | Туре | Reset<br>Value | Description                                                                   |
|------------|-------|------|----------------|-------------------------------------------------------------------------------|
| UART_TXD   | [7:0] | WO   | 8'h0           | Write data to this address initiates a character transmission through TX FIFO |

### 6.2.5.2.2 UART RXD

Description: Write data to this address initiates a character transmission through TX FIFO.

| 0x0004 |    |               | UAR | T RX r | egister | (0x000 | 00_000 | 00) |          |    |    |    | UART_RXD |    |    |    |  |
|--------|----|---------------|-----|--------|---------|--------|--------|-----|----------|----|----|----|----------|----|----|----|--|
| Bit    | 31 | 30            | 29  | 28     | 27      | 26     | 25     | 24  | 23       | 22 | 21 | 20 | 19       | 18 | 17 | 16 |  |
| Name   |    | Reserved      |     |        |         |        |        |     |          |    |    |    |          |    |    |    |  |
| 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   |    |               |     | Rese   | erved   |        |        |     | UART_RXD |    |    |    |          |    |    |    |  |
| Туре   |    | RO            |     |        |         |        |        |     |          |    | RO |    |          |    |    |    |  |
| Reset  | 0  | 0 0 0 0 0 0 0 |     |        |         |        |        |     |          | 0  | 0  | 0  | 0        | 0  | 0  | 0  |  |



| Field Name | Bit   | Туре | Reset<br>Value | Description                                                                                  |
|------------|-------|------|----------------|----------------------------------------------------------------------------------------------|
| UART_TXD   | [7:0] | RO   | 8'h0           | FIFO operation register Reading this register retrieves the next data byte from the Rx FIFO. |

# 6.2.5.2.3 UART\_STS0

Description: UART status register

| 0x0008 |                        |                             | Regi                                 | ster de | escript | ion (0x | 0000_ | 1802) |                                      |                                 |                                 |                                             |                                       | ι                                      | JART_                                 | STS0                                 |
|--------|------------------------|-----------------------------|--------------------------------------|---------|---------|---------|-------|-------|--------------------------------------|---------------------------------|---------------------------------|---------------------------------------------|---------------------------------------|----------------------------------------|---------------------------------------|--------------------------------------|
| Bit    | 31                     | 30                          | 29                                   | 28      | 27      | 26      | 25    | 24    | 23                                   | 22                              | 21                              | 20                                          | 19                                    | 18                                     | 17                                    | 16                                   |
| Name   |                        | Reserved                    |                                      |         |         |         |       |       |                                      |                                 |                                 |                                             |                                       |                                        |                                       |                                      |
| Туре   |                        | RO                          |                                      |         |         |         |       |       |                                      |                                 |                                 |                                             |                                       |                                        |                                       |                                      |
| 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   | TRA<br>NS_<br>OVE<br>R | RXF<br>_RE<br>ALF<br>ULL    | TIM<br>E_O<br>UT_<br>RA<br>W_S<br>TS | TXD     | RXD     | RTS     | CTS   | DSR   | BRK<br>_DT<br>CT_<br>RA<br>W_S<br>TS | CTS<br>_CH<br>G_R<br>AW_<br>STS | DSR<br>_CH<br>G_R<br>AW_<br>STS | RXF<br>_OV<br>ERR<br>UN_<br>RA<br>W_S<br>TS | FRA<br>ME_<br>ERR<br>_RA<br>W_S<br>TS | PAR<br>ITY_<br>ERR<br>_RA<br>W_S<br>TS | TXF<br>_EM<br>PTY<br>_RA<br>W_S<br>TS | RXF<br>_FU<br>LL_<br>RA<br>W_S<br>TS |
| Туре   | RO                     | RO                          | RO                                   | RO      | RO      | RO      | RO    | RO    | RO                                   | RO                              | RO                              | RO                                          | RO                                    | RO                                     | RO                                    | RO                                   |
| Reset  | 0                      | 0                           | 0                                    | 1       | 1       | 0       | 0     | 0     | 0                                    | 0                               | 0                               | 0                                           | 0                                     | 0                                      | 1                                     | 0                                    |

|                     |      |     |                | 1                                                                |  |  |  |
|---------------------|------|-----|----------------|------------------------------------------------------------------|--|--|--|
| Field Name          | Bit  | R/W | Reset<br>Value | Description                                                      |  |  |  |
| TRANS_OVER          | [15] | RO  | 1'h0           | Data transfer is really over                                     |  |  |  |
| RXF_REALFULL        | [14] | RO  | 1'h0           | RX FIFO is real full(not relates to register RXF_FULL_THLD)      |  |  |  |
| TIME_OUT_RAW_STS    | [13] | RO  | 1'h0           | RAW timeout interrupt, this bit is set when receive time is out. |  |  |  |
| TXD                 | [12] | RO  | 1'h1           | Transmit data                                                    |  |  |  |
| RXD                 | [11] | RO  | 1'h1           | Receive data                                                     |  |  |  |
| RTS                 | [10] | RO  | 1'h0           | Request to send                                                  |  |  |  |
| CTS                 | [9]  | RO  | 1'h0           | Clear to send                                                    |  |  |  |
| DSR                 | [8]  | RO  | 1'h0           | Data set ready(no used)                                          |  |  |  |
| BRK_DTCT_RAW_STS    | [7]  | RO  | 1'h0           | Raw break detect interrupt                                       |  |  |  |
| CTS_CHG_RAW_STS     | [6]  | RO  | 1'h0           | Raw CTS change interrupt                                         |  |  |  |
| DSR_CHG_RAW_STS     | [5]  | RO  | 1'h0           | Raw DSR change interrupt                                         |  |  |  |
| RXF_OVERRUN_RAW_STS | [4]  | RO  | 1'h0           | Raw RX FIFO overrun interrupt                                    |  |  |  |



| FRAME_ERR_RAW_STS  | [3] | RO | 1'h0 | Raw frame error interrupt   |
|--------------------|-----|----|------|-----------------------------|
| PARITY_ERR_RAW_STS | [2] | RO | 1'h0 | Raw parity error interrupt  |
| TXF_EMPTY_RAW_STS  | [1] | RO | 1'h1 | Raw TX FIFO empty interrupt |
| RXF_FULL_RAW_STS   | [0] | RO | 1'h0 | Raw RX FIFO full interrupt  |

## 6.2.5.2.4 UART\_STS1

Description: data number in the TXF and RXF

| 0x000C |                  |    | Regi     | ster de                   | script              | ion (0) | (0000_ | 0000) |                  |    |    |    | UART_STS1 |    |    |    |  |
|--------|------------------|----|----------|---------------------------|---------------------|---------|--------|-------|------------------|----|----|----|-----------|----|----|----|--|
| Bit    | 31               | 30 | 29       | 28                        | 27                  | 26      | 25     | 24    | 23               | 22 | 21 | 20 | 19        | 18 | 17 | 16 |  |
| Name   |                  |    | Reserved |                           |                     |         |        |       |                  |    |    |    |           |    |    |    |  |
| Туре   |                  | RO |          |                           |                     |         |        |       |                  |    |    |    |           |    |    |    |  |
| 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   | Res<br>erve<br>d |    |          | -                         | ΓXF_CN <sup>-</sup> | Т       |        |       | Res<br>erve<br>d |    |    | F  | RXF_CN    | Т  |    |    |  |
| Туре   | RO               | RO |          |                           |                     |         |        |       |                  | RO |    |    |           |    |    |    |  |
| Reset  | 0                | 0  | 0        | 0                         | 0                   | 0       | 0      | 0     | 0                | 0  | 0  | 0  | 0         | 0  | 0  | 0  |  |

| Field Name | Bit    | R/W | Reset Value | Description                                                                                                                                |
|------------|--------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| TXF_CNT    | [14:8] | RO  | 7'h0        | The number reserved in TX FIFO. The register will increase when writing data to the TX FIFO, while decrease when reading data from TX FIFO |
| Reserved   | [7]    | RO  | 1'h0        |                                                                                                                                            |
| RXF_CNT    | [6:0]  | RO  | 7'h0        | The number reserved in RX FIFO. The register will increase when writing data to the RX FIFO, while decrease when reading data from RX FIFO |

# 6.2.5.2.5 UART\_IEN

Description: UART interrupt enable register



| 0x0010 |      |       | Inter                           | upt er   | nable (   | 0x0000   | 0000 | 0) |                                 |                                |                                |                                        |                                  |                                   | UART                             | _IEN                            |
|--------|------|-------|---------------------------------|----------|-----------|----------|------|----|---------------------------------|--------------------------------|--------------------------------|----------------------------------------|----------------------------------|-----------------------------------|----------------------------------|---------------------------------|
| Bit    | 31   | 30    | 29                              | 28       | 27        | 26       | 25   | 24 | 23                              | 22                             | 21                             | 20                                     | 19                               | 18                                | 17                               | 16                              |
| Name   |      |       |                                 | Reserved |           |          |      |    |                                 |                                |                                |                                        |                                  |                                   |                                  |                                 |
| Туре   |      | 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   | Rese | erved | TIM<br>E_O<br>UT_I<br>NT_<br>EN |          |           | Reserved | i    |    | BRK<br>_DT<br>CT_I<br>NT_<br>EN | CTS<br>_CH<br>G_I<br>NT_<br>EN | DSR<br>_CH<br>G_I<br>NT_<br>EN | RXF<br>_OV<br>ERR<br>UN_<br>INT_<br>EN | FRA<br>ME_<br>ERR<br>_INT<br>_EN | PAR<br>ITY_<br>ERR<br>_INT<br>_EN | TXF<br>_EM<br>PTY<br>_INT<br>_EN | RXF<br>_FU<br>LL_I<br>NT_<br>EN |
| Туре   | R    | 0     | R/W                             |          | RO        |          |      |    | 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                              | 0                              | 0                                      | 0                                | 0                                 | 0                                | 0                               |

| Field Name         | Bit    | R/W | Reset<br>Value | Description                      |
|--------------------|--------|-----|----------------|----------------------------------|
| TIME_OUT_INT_EN    | [13]   | R/W | 1'h0           | Time out interrupt enable        |
| Reserved           | [12:8] | RO  | 5'h0           |                                  |
| BRK_DTCT_INT_EN    | [7]    | R/W | 1'h0           | Break detect interrupt enable    |
| CTS_CHG_INT_EN     | [6]    | R/W | 1'h0           | CTS change interrupt enable      |
| DSR_CHG_INT_EN     | [5]    | R/W | 1'h0           | DSR change interrupt enable      |
| RXF_OVERRUN_INT_EN | [4]    | R/W | 1'h0           | RX FIFO overrun interrupt enable |
| FRAME_ERR_INT_EN   | [3]    | R/W | 1'h0           | Frame error interrupt enable     |
| PARITY_ERR_INT_EN  | [2]    | R/W | 1'h0           | Parity error interrupt enable    |
| TXF_EMPTY_INT_EN   | [1]    | R/W | 1'h0           | TX FIFO empty interrupt enable   |
| RXF_FULL_INT_EN    | [0]    | R/W | 1'h0           | RX FIFO full interrupt enable    |

# 6.2.5.2.6 **UART\_ICLR**

Description: UART interrupt clear register



| 0x0014 |      |       | Inter                            | upt cl    | ear (0x | <0000_   | 0000) |     |                                  |                                 |                                 |                                         |                                       | Ţ                                      | JART_ | ICLR  |
|--------|------|-------|----------------------------------|-----------|---------|----------|-------|-----|----------------------------------|---------------------------------|---------------------------------|-----------------------------------------|---------------------------------------|----------------------------------------|-------|-------|
| Bit    | 31   | 30    | 29                               | 28        | 27      | 26       | 25    | 24  | 23                               | 22                              | 21                              | 20                                      | 19                                    | 18                                     | 17    | 16    |
| Name   |      |       |                                  |           |         |          |       | Res | erved                            |                                 |                                 |                                         |                                       |                                        |       |       |
| Туре   |      |       |                                  | 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   | Rese | erved | TIM<br>E_O<br>UT_I<br>NT_<br>CLR |           | ı       | Reserved | i     |     | BRK<br>_DT<br>CT_I<br>NT_<br>CLR | CTS<br>_CH<br>G_I<br>NT_<br>CLR | DSR<br>_CH<br>G_I<br>NT_<br>CLR | RXF<br>_OV<br>ERR<br>UN_<br>INT_<br>CLR | FRA<br>ME_<br>ERR<br>_INT<br>_CL<br>R | PAR<br>ITY_<br>ERR<br>_INT<br>_CL<br>R | Rese  | erved |
| Туре   | R    | 0     | wo                               |           | RO      |          |       |     |                                  | wo                              | wo                              | wo                                      | wo                                    | wo                                     | R     | 0     |
| Reset  | 0    | 0     | 0                                | 0 0 0 0 0 |         |          |       | 0   | 0                                | 0                               | 0                               | 0                                       | 0                                     | 0                                      | 0     | 0     |

| Field Name          | Bit    | R/W | Reset<br>Value | Description                            |
|---------------------|--------|-----|----------------|----------------------------------------|
| TIME_OUT_INT_CLR    | [13]   | WO  | 1'h0           | Write "1" Clear time out interrupt     |
| Reserved            | [12:8] | RO  | 5'h0           |                                        |
| BRK_DTCT_INT_CLR    | [7]    | WO  | 1'h0           | Write "1" Clear break_detect interrupt |
| CTS_CHG_INT_CLR     | [6]    | WO  | 1'h0           | Write "1" Clear cts_change interrupt   |
| DSR_CHG_INT_CLR     | [5]    | WO  | 1'h0           | Write "1" Clear dsr_change interrupt   |
| RXF_OVERRUN_INT_CLR | [4]    | WO  | 1'h0           | Write "1" Clear rxf_overrun interrupt  |
| FRAME_ERR_INT_CLR   | [3]    | WO  | 1'h0           | Write "1" Clear frame_error interrupt  |
| PARITY_ERR_INT_CLR  | [2]    | WO  | 1'h0           | Write "1" Clear parity_error interrupt |
| Reserved            | [1:0]  | RO  | 2'h0           |                                        |

6.2.5.2.7 UART\_CTRL0

Description: UART control register



| 0x0018 |                  |                  | Cont            | rol reg         | jister (         | 0x0000           | 0000         | ))              |                         |                  |            |             |      | UA   | ART_C             | TRL0                     |
|--------|------------------|------------------|-----------------|-----------------|------------------|------------------|--------------|-----------------|-------------------------|------------------|------------|-------------|------|------|-------------------|--------------------------|
| Bit    | 31               | 30               | 29              | 28              | 27               | 26               | 25           | 24              | 23                      | 22               | 21         | 20          | 19   | 18   | 17                | 16                       |
| Name   |                  |                  |                 |                 |                  |                  |              | Rese            | erved                   |                  |            |             |      |      |                   |                          |
| Туре   |                  |                  |                 |                 |                  |                  |              | R               | 0                       |                  |            |             |      |      |                   |                          |
| 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   | MO<br>DE_<br>SEL | Res<br>erve<br>d | IR_<br>WC<br>TL | IR_<br>DPL<br>X | IR_T<br>X_E<br>N | IR_<br>RX_I<br>V | IR_T<br>X_IV | DTR<br>_RE<br>G | SEN<br>D_B<br>RK_<br>EN | RTS<br>_RE<br>_G | STOP<br>NI | _BIT_<br>JM | BYTE | _LEN | PAR<br>ITY_<br>EN | ODD<br>_PA<br>_RIT<br>_Y |
| Туре   | R/W              | RO               | R/W             | 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                | 1          | 1           | 1    | 1    | 0                 | 0                        |

| Field Name   | Bit   | R/W | Reset Value | Description                                                                                                                                                                         |
|--------------|-------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MODE_SEL     | [15]  | R/W | 1'h0        | "0" : UART<br>"1" : IrDA                                                                                                                                                            |
| Reserved     | [14]  | RO  | 1'h0        |                                                                                                                                                                                     |
| IR_WCTL      | [13]  | R/W | 1'h0        | set "1", increase pulse width for one clock.                                                                                                                                        |
| IR_DPLX      | [12]  | R/W | 1'h0        | IRDA TX/RX enable                                                                                                                                                                   |
| IR_TX_EN     | [11]  | R/W | 1'h0        | IRDA TX enable                                                                                                                                                                      |
| IR_RX_IV     | [10]  | R/W | 1'h0        | IRDA RX polarity inverse                                                                                                                                                            |
| IR_TX_IV     | [9]   | R/W | 1'h0        | IRDA TX polarity inverse                                                                                                                                                            |
| DTR_REG      | [8]   | R/W | 1'h0        | This bit controls the dtrn output                                                                                                                                                   |
| SEND_BRK_EN  | [7]   | R/W | 1'h0        | When TX FIFO is empty and TX is idle, setting this bit forces the TX data output low.  Need to be cleared by MCU.                                                                   |
| RTS_REG      | [6]   | R/W | 1'h0        | When receive hardware flow control is not set, this bit controls the output of RTSN. When RCV_HW_FLOW_EN is set, the output of RTSN is controlled by the register RCV_HW_FLOW_THLD. |
| STOP_BIT_NUM | [5:4] | R/W | 2'h3        | 0: unused, 1: 1stop bit, 2: 1.5 stop bits, 3: 2 stop bits.                                                                                                                          |
| BYTE_LEN     | [3:2] | R/W | 2'h3        | data byte length. 0: 5 bits, 1: 6 bits, 2: 7 bits, 3: 8 bits.                                                                                                                       |
| PARITY_EN    | [1]   | R/W | 1'h0        | 0: parity disabled 1: parity enabled                                                                                                                                                |
| ODD_PARITY   | [0]   | R/W | 1'h0        | 0: even parity 1: odd parity                                                                                                                                                        |



# 6.2.5.2.8 UART\_CTRL1

Description: UART control register

| 0x001C |            |                   | Cont | rol reg                       | jister ( | 0x0000 | 0000 | ))                            |                                |                  |    |     |        | UA     | ART_C | TRL1 |
|--------|------------|-------------------|------|-------------------------------|----------|--------|------|-------------------------------|--------------------------------|------------------|----|-----|--------|--------|-------|------|
| Bit    | 31         | 30                | 29   | 28                            | 27       | 26     | 25   | 24                            | 23                             | 22               | 21 | 20  | 19     | 18     | 17    | 16   |
| Name   |            |                   |      |                               |          |        |      | Rese                          | erved                          |                  |    |     |        |        |       |      |
| Туре   |            |                   |      | RO                            |          |        |      |                               |                                |                  |    |     |        |        |       |      |
| Reset  | 0          | 0                 | 0    | 0 0 0 0 0 0 0 0 0 0 0 0 0     |          |        |      |                               |                                |                  |    |     | 0      |        |       |      |
| Bit    | 15         | 14                | 13   | 13 12 11 10 9 8 7 6 5 4 3 2 1 |          |        |      |                               |                                |                  |    |     | 1      | 0      |       |      |
| Name   | DMA<br>_EN | LOO<br>P_B<br>ACK |      | RX_                           | TOUT_T   | HLD    |      | TX_<br>HW_<br>FLO<br>W_E<br>N | RCV<br>_HW<br>_FL<br>OW<br>_EN | Res<br>erve<br>d |    | RC' | V_HW_F | LOW_TI | HLD   |      |
| Туре   | R/W        | R/W               |      |                               | R/W      |        |      | R/W                           | R/W                            | RO               |    |     | R/     | w      |       |      |
| Reset  | 0          | 0                 | 0    | 0                             | 0        | 0      | 0    | 0                             | 0                              | 0                | 0  | 0   | 0      | 0      | 0     | 0    |

| Field Name       | Bit    | R/W | Reset<br>Value | Description                                                                                                                                                                                                                            |
|------------------|--------|-----|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMA_EN           | [15]   | R/W | 1'h0           | "1" enable DMA access UART FIFOs                                                                                                                                                                                                       |
| LOOP_BACK        | [14]   | R/W | 1'h0           | Self test mode, TX input to RX                                                                                                                                                                                                         |
| RX_TOUT_THLD     | [13:9] | R/W | 5'h0           | Receive timeout threshold                                                                                                                                                                                                              |
| TX_HW_FLOW_EN    | [8]    | R/W | 1'h0           | Transmit_Hardware_Flow_Control_Enable "1" enable transmit hardware flow control "0" disable                                                                                                                                            |
| RCV_HW_FLOW_EN   | [7]    | R/W | 1'h0           | Receive_Hardware_Flow_Control_Enable "1" enable receive hardware flow control "0" disable                                                                                                                                              |
| Reserved         | [6]    | RO  |                |                                                                                                                                                                                                                                        |
| RCV_HW_FLOW_THLD | [5:0]  | R/W | 6'h0           | Receive_Hardware_Flow_Control_Threshold When RCV_HW_FLOW_EN is enabled, if the number of unread bytes in the RX FIFO is greater than the receive hardware flow control threshold value, the RTSN is set to high to stop the remote TX. |

## 6.2.5.2.9 UART\_CTRL2

Description: UART TX FIFO empty and RX FIFO full watermark register



| 0x0020 |                  |    | Cont | rol reg                 | jister ( | 0x0000 | 0008 | 3) |                  |    |    |      |                     | UA   | ART_C | TRL2 |
|--------|------------------|----|------|-------------------------|----------|--------|------|----|------------------|----|----|------|---------------------|------|-------|------|
| Bit    | 31               | 30 | 29   | 28                      | 27       | 26     | 25   | 24 | 23               | 22 | 21 | 20   | 19                  | 18   | 17    | 16   |
| Name   |                  |    |      | Reserved                |          |        |      |    |                  |    |    |      |                     |      |       |      |
| Туре   |                  |    |      | 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   | Res<br>erve<br>d |    |      | TXF_I                   | EMPTY_   | THLD   |      |    | Res<br>erve<br>d |    |    | RXF. | _FULL_ <sup>-</sup> | THLD |       |      |
| Туре   | RO               |    |      |                         | R/W      |        |      |    | RO               |    |    |      | R/W                 |      | A     |      |
| Reset  | 0                | 0  | 0    | 0                       | 0        | 0      | 0    | 0  | 0                | 0  | 0  | 0    | 1                   | 0    | 0     | 0    |

| Field Name     | Bit    | R/W | Reset Value | Description                  |
|----------------|--------|-----|-------------|------------------------------|
| TXF_EMPTY_THLD | [14:8] | R/W | 5'h0        | TX FIFO data empty threshold |
| Reserved       | [7]    | RO  | 1'h0        |                              |
| RXF_FULL_THLD  | [6:0]  | R/W | 5'h8        | RX FIFO data full threshold  |

# 6.2.5.2.10 UART\_CKD0

Description: This register is used to configure baud rate

| 0x0024 |     |    | Divis | or reg | ister (( | 0x0000 | _054A | 1)    |       |    |    |    |    |    | S  | CFG0 |
|--------|-----|----|-------|--------|----------|--------|-------|-------|-------|----|----|----|----|----|----|------|
| Bit    | 31  | 30 | 29    | 28     | 27       | 26     | 25    | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
| Name   |     |    |       |        |          |        |       | Rese  | erved |    |    |    |    |    |    |      |
| Туре   |     |    |       |        |          |        |       | R     | 0     |    |    |    |    |    |    |      |
| 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   |     |    |       | 1      |          |        |       | UART. | _CKD0 |    |    |    |    |    |    |      |
| Туре   | R/W |    |       |        |          |        |       |       |       |    |    |    |    |    |    |      |
| Reset  | 0   | 0  | 0     | 0      | 0        | 1      | 0     | 1     | 0     | 1  | 0  | 0  | 1  | 0  | 1  | 0    |

| Field Name | Bit    | R/W | Reset Value | Description               |
|------------|--------|-----|-------------|---------------------------|
| UART_CKD0  | [15:0] | R/W | 16'h54A     | Clock divisor bit 0 to 15 |

# 6.2.5.2.11 UART\_STS2

Description: UART interrupt mask status



| 0x002C |      |       | INT                                   | mask | status  | (0x00    | 00_00 | 00)  |                                       |                                       |                                       |                                              |                         | ι                                       | JART_                                  | STS2                                  |
|--------|------|-------|---------------------------------------|------|---------|----------|-------|------|---------------------------------------|---------------------------------------|---------------------------------------|----------------------------------------------|-------------------------|-----------------------------------------|----------------------------------------|---------------------------------------|
| Bit    | 31   | 30    | 29                                    | 28   | 27      | 26       | 25    | 24   | 23                                    | 22                                    | 21                                    | 20                                           | 19                      | 18                                      | 17                                     | 16                                    |
| Name   |      |       |                                       |      |         |          |       | Rese | erved                                 |                                       |                                       |                                              |                         |                                         |                                        |                                       |
| Туре   |      |       |                                       | 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   | Rese | erved | TIM<br>E_O<br>UT_<br>MAS<br>K_S<br>TS | _    |         | Reserved | I     |      | BRK<br>_DT<br>CT_<br>MAS<br>K_S<br>TS | CTS<br>_CH<br>G_M<br>ASK<br>_ST<br>_S | DSR<br>_CH<br>G_M<br>ASK<br>_ST<br>_S | RXF<br>_OV<br>ERR<br>UN_<br>MAS<br>K_S<br>TS | FRA ME_ ERR _MA SK_ STS | PAR<br>ITY_<br>ERR<br>_MA<br>SK_<br>STS | TXF<br>_EM<br>PTY<br>_MA<br>SK_<br>STS | RXF<br>_FU<br>LL_<br>MAS<br>K_S<br>TS |
| Туре   | R    | 0     | RO                                    |      | RO      |          |       |      | RO                                    | RO                                    | RO                                    | RO                                           | RO                      | RO                                      | RO                                     | RO                                    |
| Reset  | 0    | 0     | 0                                     | 0    | 0 0 0 0 |          |       |      | 0                                     | 0                                     | 0                                     | 0                                            | 0                       | 0                                       | 0                                      | 0                                     |

| Field Name           | Bit    | R/W | Reset<br>Value | Description                           |
|----------------------|--------|-----|----------------|---------------------------------------|
| TIME_OUT_MASK_STS    | [13]   | RO  | 1'h0           | Time out interrupt mask status        |
| Reserved             | [12:8] | RO  | 5'h0           | ~                                     |
| BRK_DTCT_MASK_STS    | [7]    | RO  | 1'h0           | Break detect interrupt mask status    |
| CTS_CHG_MASK_STS     | [6]    | RO  | 1'h0           | CTS change interrupt mask status      |
| DSR_CHG_MASK_STS     | [5]    | RO  | 1'h0           | DSR change interrupt mask status      |
| RXF_OVERRUN_MASK_STS | [4]    | RO  | 1'h0           | RX FIFO overrun interrupt mask status |
| FRAME_ERR_MASK_STS   | [3]    | RO  | 1'h0           | Frame error interrupt mask status     |
| PARITY_ERR_MASK_STS  | [2]    | RO  | 1'h0           | Parity error interrupt mask status    |
| TXF_EMPTY_MASK_STS   | [1]    | RO  | 1'h0           | TX FIFO empty interrupt enable        |
| RXF_FULL_MASK_STS    | [0]    | RO  | 1'h0           | RX FIFO full interrupt mask status    |

6.2.5.2.12 UART\_DSPWAIT

Description: UART control register



| 0x0030 |          |          | Control register (0x0000_0001) UART_DSPWAIT |    |    |    |    |                                |                                |              |    |    |         |    |    |    |
|--------|----------|----------|---------------------------------------------|----|----|----|----|--------------------------------|--------------------------------|--------------|----|----|---------|----|----|----|
| Bit    | 31       | 30       | 29                                          | 28 | 27 | 26 | 25 | 24                             | 23                             | 22           | 21 | 20 | 19      | 18 | 17 | 16 |
| Name   | Reserved |          |                                             |    |    |    |    |                                |                                |              |    |    |         |    |    |    |
| Туре   | 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   | Reserved |          |                                             |    |    |    |    | TX_<br>DMA<br>_MO<br>D_S<br>EL | RX_<br>DMA<br>_MO<br>D_S<br>EL | UART_DSPWAIT |    |    |         |    |    |    |
| Туре   |          | RO RW RW |                                             |    |    |    |    | R/W                            | R/W                            |              |    |    |         |    |    |    |
| Reset  | 0        | 0        | 0                                           | 0  | 0  | 0  | 0  | 0                              | 0                              | 0            | 0  | 0  | 0 0 0 1 |    |    |    |

| Field Name     | Bit   | R/W | Reset Value | Description                                                                                                    |
|----------------|-------|-----|-------------|----------------------------------------------------------------------------------------------------------------|
| TX_DMA_MOD_SEL | [5]   | R/W | 1'h0        | 0: tx_dma_req keep 1 until<br>receiving the rx_dma_ack<br>1: tx_dma_req is "1" when<br>rx_full is "1",else "0" |
| RX_DMA_MOD_SEL | [4]   | R/W | 1'h0        | 0: rx_dma_req keep 1 until<br>receiving the rx_dma_ack<br>1: rx_dma_req is "1" when<br>rx_full is "1",else "0" |
| UART_DSPWAIT   | [3:0] | R/W | 4'h1        | This register is used for DSP control                                                                          |

### 6.2.6 Application Notes

Including RAM input and output formats, special requirement, software control flow, description, etc.

Working in UART mode with hardware flow control (full duplex)

- 1. The initiator writes to the setup register (global register)
- 2. The initiator writes the UART\_CTL0 register bit 15 to "0" to enable UART mode.
- The initiator configures UART\_CKD0 registers to generate the suitable baud rate. For example, if clk\_uart is 26 MHz, UART\_CKD0 is set to 0xe1, then the UART baud rate is 115 k.
- 4. The initiator configures UART\_CTL0 to generate the suitable data format, such as parity enable and parity style, byte length, and stop bit number
- 5. Set UART\_CTL0 register bit 7 to "1" to enable receive hardware flow control
- 6. The initiator configures UART\_CTL1 register bit [5:0] to suitable value
- Set UART\_CTL0 register bit 8 to "1" to enable transmit hardware flow control
- 8. The initiator configures UART\_CTL2 to generate receive watermark and transmit watermark
- 9. The initiator writes UART\_CTL1 register to configure receive timeout value
- 10. Enable related interrupts by writing UART\_STS2 register



### 11. Writing data to UART\_TXD

Once the TX FIFO is not empty:

- 12. data in TX FIFO will appear on TX line in sequence
- 13. If data number in the TX FIFO is less than the data empty threshold value, a txf\_empty interrupt will be generated. After receiving this interrupt, MCU should clear the interrupt and write more data into the TX FIFO
- 14. If data number in the RX FIFO is more than the data full threshold value. An rxf\_full interrupt will be generated. After receiving this interrupt, MCU should clear the interrupt and read data from RX FIFO
- 15. If receiving RX TOUT interrupt, read all data in the RX FIFO

When the transmission is completed:

- If RX FIFO is not empty, read all data in the RX FIFO when receiving RX TOUT interrupt
- 17. Disable all interrupts, disable uart\_en in global register

## 6.3 SPI Interface

## 6.3.1 Overview

SPI is a serial synchronous communication interface. SPI block enables the device to interface with SPI peripherals (i.e. A/D converters, display drivers, EEPROMs etcs.) It consists of a serial shift register with serial data input, serial data output and serial shift clock. The shift clock can be selected from either an interval source or an external source. Operating the SPI with the internal clock source is called the Master mode of operation. Similarly, operating the SPI with an external shift clock is called the Slave mode of operation. SPI module support MICROWIRE/PLUS mode, sync mode, s8 mode and 3-wire mode. Only in MICROWIRE/PLUS mode, master and slave both be supported. This document defines function and configuration of SPI block.

SC6820 has 2 SPI controllers, SPI0 & SPI1.

## 6.3.2 Features

- Compliant with the SPI standard
- I Support MICRO/PLUS mode, SYNC mode, S8 mode and 3-wire mode
- Serial clock with programmable frequency, polarity
- I Wide selection of SPI word lengths ranging from 1 to 32 bits
- Two 32-word-deep FIFOs minimizes processor overhead at high data rates
- I Master / slave
- I MSB / LSB
- I Transmit only/ receive only / transmit and receive mode
- I Only receive mode , the length of words ready to receive form the slave can be programmed
- I The intervals of two SPI frames can be programmed
- I 2 DMA requests
- I Single interrupt line for multiple interrupt source events
- The polarity and position of the sync can be configured
- I As slave transmit phase adjustable



TX/RX FIFO address can be reset

# 6.3.3 Signal Description



Figure 6-8 SPI in Master Mode(FULL-Duplex)



Figure 6-9 SPI in Slave Mode(FULL-Duplex

## 6.3.4 Function Description

The SPI master mode supports communication with up to two independent SPI devices. SPI initiates a data transfer on the data lines (spi\_do and spi\_di) and generate clock (sck) and control signals(spi\_ncsi).

Write data to this Spi\_txd register initiates a character transmission through TX FIFO, the pointer txf\_wr\_address will increase. All data ready to send must be written into the TX FIFO first, thenoccurs in transmit line.



Data sampled from receive line is placed in RX FIFO first. When the data number in the RX FIFO is more than the receive data full threshold value, an rxf\_full interrupt is generated. MCU will read data from RX FIFO as soon as receiving the interrupt.



Figure 6-10 diagram of SPI

#### 6.3.4.1 MICROWIRE/PLUS work mode

MICROWIRE/PLUS is an enhancement of the MICROWIRE™ synchronous serial communications scheme, originally implemented by National Semiconductor's COP400 family microcontrollers. It has three wires, SI (serial input), SO (serial output), and SK (serial clock). The input data one the SI is shifted high order first into the chip; the output data is shifted out high order first from the Most Significant Bit (MSB) on SO. The SK clock is generated internally for the master mode. One burst has 8 data bits. The input data is captured on the rising edge of SK. Following is the timing diagram.





Figure 6-11 MICROWIRE/PLUS Timing (CPOL=0, CPHA=0)



Figure 6-12 Alternated Phase SK Clock Timing (CPOL=0, CPHA=1)



Figure 6-13 MICROWIRE/PLUS Timing (CPOL=1, CPHA=0)



Figure 6-14 MICROWIRE/PLUS Timing (CPOL=1, CPHA=1)

In the normal mode data is shifted in on the rising edge of the SCK clock and data is shifted out on the falling edge of the SCK clock. It is also allow an additional Alternate SCK Phase Operation. In the alternate SCK phase operation, data is shifted in on the falling edge of the SCK clock and data is shifted out on the rising edge of the SCK clock.

To configure SPI for this mode, just enable SPI clock in global control register, program  $spi\_ctl0$  control register, enable RX data shift in at SCK rising  $edge(spi\_ctl0[0] = 1)$ , and



enable TX data shift out at SCK falling edge(spi\_ctl0[1] = 0), set transmit data bit number to 8 . Also program spi\_clkd according to MCLK and SCK clock rate. Leaving other control register with default value. When put data into TX FIFO, the SPI will send and receive an N bit data at the same time.

The clock phase and TX/RX data timing is programmable to meet other requirements. For example, for:

N = 8, CS0, CPOL=0, CPHA =0 timing as Figure6-11, set spi\_ctl0 = 0x0e22

N = 8, CS0, CPOL=0, CPHA =1 timing as Figure6-12, set spi\_ctl0 = 0x0e21

N = 8, CS0, CPOL=1, CPHA =0 timing as Figure6-13, set spi\_ctl0 = 0x2e22

N = 8, CS0, CPOL=1, CPHA =1 timing as Figure6-14, set spi\_ctl0 = 0x2e21

CPOL=0 means SCK idle phase is low, maps to spi\_ctl0[13] = 0;

CPOL=1 means SCK idle phase is high, maps to spi\_ctl0[13]=1;

CPHA decides SPI working in normal mode or in the alternate SK phase operation. CPHA maps to ctl0\_reg[1:0],

"10" (CPHA=0) means output data at negedge of clk while receiving data at posedge of clk "01" (CPHA=1) means output data at posedge of clk while receiving data at negedge of clk

"00" and "11" are not available in this mode

### 6.3.4.2 Synchronous SPI

Besides SCK, SDI, SDO, Synchronous SPI provides the fourth pin as a synchronous signal. It generates single bit width pulse on one of the TX/RX bit position. On slave side, it tells when to latch the received byte and prepare the next data for transmit.

If enable sync mode by setting spi\_ctl0 register bit14, the sync pulse will appear on the last bit. If program spi\_ctl1 register bit 4~0 to N, the sync pulse will locates on top of bit N. The SYNC bit can be program output to one of the 4 chip select pins by setting spi\_ctl1[11:8].



Figure 6-15 Alternated Phase SK Clock Timing (CPOL=0, CPHA=1)

#### 6.3.4.3 4-wire Serial Interface(s8)

SC6820 SPI supports 4-wire serial interface, which required by LCD driver like ULTRACHIP UC1607. Only write operations are supported in this mode. Pin CS is used for chip select and bus cycle reset. Pin CD is used to determine the content of the data been transferred. On each write cycle, 8 bits of data, MSB first, are transmitted on falling SCK edges. If CD=0, the data byte will be decoded as command. If CD=1, this 8-bit will be treated as data. Pin CD is examined when SCK is pulled low for the LSB(D0) of each burst. The maximum SCK frequency required is 5MHZ.

To enable SPI working in this mode, all settings are same as program MICROWIRE except to enable TX data shifting out at SCK rising edge. Also need to set spi\_ctl1 control register bit7, enable s8 mode, and assign the CD signal output from one of the four CS pins by programming bit11~8. Please pay attention to not mapping CD to the same CS pin used for LCD chip select. For example using CS0 as chip select, using cs1 as CD, we



should program spi\_ctl0 register bit11~8 "1100" and programming spi\_ctl1 register bit11~8 "0010".



Figure 6-16 4-wire Serial Interface (s8) Timing

SW should write 9 bits data to TX FIFO while ctl0\_reg[6:2]] program to 8. Bit 8 is used to control CD signal, and bit[7:0] will be used to transmit to slave.

### 6.3.4.4 3-wire Serial interface

The 3-wire serial interface is required by Sound Generator Chips like OKIML2860. SDO works as an in/out pin because data has to be read/write through the same pin. SCK is the serial clock, output data from SDO change at clock falling edge, input data is sampled at falling edge. See Figure 8. There is also an alternate SCK phase operation, data output at clock rising edge and input data is sampled at rising edge. See Figure 12. One burst has 16 bits. 7 address bits sent first. Bit8 is command bit. "1" means writing 8 bits data to the slave. "0" means reading 8 bits data from the slave, the read data address in slave is the 7 bits address sent in the same burst.

Data Write Timing 1



Data Read Timing 1





Figure 6-17 3-wire Serial InterfaceTiming 1

Data Write Timing 2



Data Read Timing 2



Figure 6-18 3-wire Serial InterfaceTiming 2

To program SPI in this mode, set spi\_ctl0 control register to 0x0e43 ,means 16bits sent in one burst, TX at clock falling edge, RX sample at clock falling edge, CS maps to cs0. Set spi\_ctl1 to 0x3028 , means to enable 3-wire mode, command bit is bit8. Set spi\_ctl2 to 0x07 , the read data starts from bit7. Then put 16 bits data into TX FIFO, and receive 8 bit data from RX FIFO.

If set spi\_ctl1 bit6 to "1", signal CS will change to low before half cycle of the first edge of SCK, and go high after half cycle of the last edge of SCK.

To program alternate SCK phase timing as Figure 9, set spi\_ctl0 bit13 to "1", other setting are same as timing 1.

# 6.3.5 Control Registers

#### 6.3.5.1 **Memory map**

ARM base address: 0x8e00\_2000 SPI0

0x8e00\_3000 SPI1

| Offset<br>Address | Name     | Description                                                                                                                |
|-------------------|----------|----------------------------------------------------------------------------------------------------------------------------|
| 0x0000            | SPI_TXD  | Write data to this address initiates a character transmission through tx FIFO Read this address retrieve data from rx fifo |
| 0x0004            | SPI_CLKD | Clock divider bit 0 to 15. Divider is (n+1)*2                                                                              |



| Offset<br>Address | Name             | Description                   |
|-------------------|------------------|-------------------------------|
|                   |                  | Only used for slave mode      |
| 0x0008            | SPI_CTL0         | SPI control register          |
| 0x000C            | SPI_CTL1         | SPI control register          |
| 0x0010            | SPI_CTL2         | SPI control register          |
| 0x0014            | SPI_CTL3         | SPI control register          |
| 0x0018            | SPI_CTL4         | SPI control register          |
| 0x001C            | SPI_CTL5         | SPI control register          |
| 0x0020            | SPI_INT_EN       | SPI interrupt enable register |
| 0x0024            | SPI_INT_CLR      | SPI interrupt clear register  |
| 0x0028            | SPI_INT_RAW_STS  | SPI interrupt raw status      |
| 0x002C            | SPI_INT_MASK_STS | SPI interrupt mask status     |
| 0x0030            | SPI_STS1         | SPI status register           |
| 0x0034            | SPI_STS2         | SPI status register           |
| 0x0038            | DSP_WAIT         | Used for DSP control          |
| 0x003C            | SPI_STS3         | SPI status register           |
| 0x0040            | SPI_CTL6         | SPI control register          |
| 0x0044            | SPI_STS4         | SPI status reigster           |
| 0x0048            | SPI_FIFO_RST     | SPI RX/TX FIFO reset bit      |

# 6.3.5.2 Register Descriptions

# 6.3.5.2.1 SPI\_TXD

Description: Transmit word or Receive word

| 0x0000 |         |                               | RTX | registe | er (Res | r (Reset 0x0000_0000) |    |    |    |    |    |    |    |    | SPI_TXD |    |  |
|--------|---------|-------------------------------|-----|---------|---------|-----------------------|----|----|----|----|----|----|----|----|---------|----|--|
| Bit    | 31      | 30                            | 29  | 28      | 27      | 26                    | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17      | 16 |  |
| Name   | SPI_TXD |                               |     |         |         |                       |    |    |    |    |    |    |    |    |         |    |  |
| Туре   |         | R/W                           |     |         |         |                       |    |    |    |    |    |    |    |    |         |    |  |
| 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   |         | SPI_TXD                       |     |         |         |                       |    |    |    |    |    |    |    |    |         |    |  |
| Туре   |         | R/W                           |     |         |         |                       |    |    |    |    |    |    |    |    |         |    |  |
| Reset  | 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |     |         |         |                       |    |    |    |    |    |    |    |    |         |    |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                      |
|------------|--------|------|----------------|--------------------------------------------------|
| SPI_TXD    | [31:0] | R/W  | 32'h0          | Write data to this address initiates a character |



|  | transmission through TX FIFO                      |
|--|---------------------------------------------------|
|  | Read from this address retrieve data from RX FIFO |

### 6.3.5.2.2 SPI\_CLKD

Description: Clock divisor bit 0 to 15

| 0x0004 | 004 Clock divisor (Reset 0x0000_0003) |          |    |    |    |    |    |    |    |    | SPI_CLKD |    |    |    |    |    |
|--------|---------------------------------------|----------|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|
| Bit    | 31                                    | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21       | 20 | 19 | 18 | 17 | 16 |
| Name   |                                       | Reserved |    |    |    |    |    |    |    |    |          |    |    |    |    |    |
| Туре   |                                       | 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   |                                       | SPI_CLKD |    |    |    |    |    |    |    |    |          |    |    |    |    |    |
| Туре   |                                       | SPI_CLKD |    |    |    |    |    |    |    |    |          |    |    |    |    |    |
| Reset  | 0                                     | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 1  | 1  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                   |
|------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI_CLKD   | [15:0] | R/W  | 16'h3          | Specify the clock ratio between spi_sck and clk_spi.  If clk_spi runs at 48 MHz, and iis_sck runs at 12MHz,  SPI_CLKD should be 1,  spi_sck = clk_spi/2(n+1). |

### Note:

When work in the slave mode, the frequency of spi\_sck depends on the IIS master, so the register SPI\_CLKD is not used .

### 6.3.5.2.3 SPI\_CTL0

|   | 0x0008 |                  |                 | Conf            | igure r          | egiste | r (Res      | et 0x0 | 000_0F | F02)  |     |    |        |    |    | SPI_      | CTL0      |
|---|--------|------------------|-----------------|-----------------|------------------|--------|-------------|--------|--------|-------|-----|----|--------|----|----|-----------|-----------|
|   | Bit    | 31               | 30              | 29              | 28               | 27     | 26          | 25     | 24     | 23    | 22  | 21 | 20     | 19 | 18 | 17        | 16        |
| I | Name   |                  |                 |                 |                  |        |             |        | Rese   | erved |     |    |        |    |    |           |           |
|   | Type   |                  |                 |                 |                  |        |             |        | R      | 0     |     |    |        |    |    |           |           |
| I | 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   | SYN<br>C_P<br>OL | SYN<br>C_M<br>D | SCK<br>_RE<br>V | Res<br>erve<br>d |        | SPI_CSN_PRE |        |        | LSB   |     | С  | HNL_LE | N  |    | NG_<br>TX | NG_<br>RX |
|   | Туре   | R/W              | R/W             | R/W             | RO               | R/W    |             |        |        | R/W   | R/W |    |        |    |    | R/W       | R/W       |
|   | Reset  | 0                | 0               | 0               | 0                | 1      | 1           | 1      | 1      | 0     | 0   | 0  | 0      | 0  | 0  | 1         | 0         |

| Field Name Bit | R/W | Reset Value | Description |
|----------------|-----|-------------|-------------|
|----------------|-----|-------------|-------------|



| SYNC_POL    | [15]   | R/W | 1'h0 | Sync_polarity, positive or negative pulse for SPI or 3-wire mode ,read command polarity                                                                                                                                              |
|-------------|--------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SYNC_MD     | [14]   | R/W | 1'h0 | "1" : sync mode                                                                                                                                                                                                                      |
| SCK_REV     | [13]   | R/W | 1'h0 | "1" : spi_sck reverse                                                                                                                                                                                                                |
| Reserved    | [12]   | RO  | 1'h0 |                                                                                                                                                                                                                                      |
| SPI_CSN_PRE | [11:8] | R/W | 4'hf | 4 bit chip select. There are totally 4 chip selects for SPI "1110": cs0 is valid "1101": cs1 is valid                                                                                                                                |
| LSB         | [7]    | R/W | 1'h0 | In default, The input data is shifted high order first into the chip; the output data is shifted out high order first from the Most Significant Bit (MSB) on SO. When this bit is set, the data will be shift out or in from the LSB |
| CHNL_LEN    | [6:2]  | R/W | 1'h0 | Transmit data bit number. "0": 32 bits per word "1": 1 bits per word "31": 31 bits per word                                                                                                                                          |
| NG_TX       | [1]    | R/W | 1'h1 | "1" enable TX data shift out at clock neg-edge                                                                                                                                                                                       |
| NG_RX       | [0]    | R/W | 1'h0 | "1" enable RX data shift in at clock neg-edge                                                                                                                                                                                        |

# 6.3.5.2.4 SPI\_CTL1

| 0x000C |          |       | Conf | Configure register (Reset 0x0000_3000) |             |     |    |    |           |                 |            |    |     |       | SPI_CTL1 |    |  |  |
|--------|----------|-------|------|----------------------------------------|-------------|-----|----|----|-----------|-----------------|------------|----|-----|-------|----------|----|--|--|
| Bit    | 31       | 30    | 29   | 28                                     | 27          | 26  | 25 | 24 | 23        | 22              | 21         | 20 | 19  | 18    | 17       | 16 |  |  |
| Name   | Reserved |       |      |                                        |             |     |    |    |           |                 |            |    |     |       |          |    |  |  |
| Type   |          | RO    |      |                                        |             |     |    |    |           |                 |            |    |     |       |          |    |  |  |
| 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   | Rese     | erved | RTX  | _MD                                    | SYN_CSN_SEL |     |    |    | S8_<br>MD | CS_<br>H_M<br>D | S3W<br>_MD |    | S   | 3W_PO | S        |    |  |  |
| Type   | R        | 0     | R/   | W                                      |             | R/W |    |    |           | R/W             | R/W        |    | R/W |       |          |    |  |  |
| Reset  | 0        | 0     | 1    | 1                                      | 0           | 0   | 0  | 0  | 0         | 0               | 0          | 0  | 0   | 0     | 0        | 0  |  |  |

| Field Name | Bit     | R/W | Reset Value | Description |
|------------|---------|-----|-------------|-------------|
| Reserved   | [15:14] | RO  | 2'h0        |             |



| RTX_MD      | [13:12] | R/W | 2'h3 | "00": idle mode "01": receive mode "10": transmit mode "11": transmit and receive                             |
|-------------|---------|-----|------|---------------------------------------------------------------------------------------------------------------|
| SYN_CSN_SEL | [11:8]  | R/W | 4'h0 | S8 CD or SYNC signal maps to csn number "0x0001" selects csn0 as cd signal "0x0010" selects csn1 as cd signal |
| S8_MD       | [7]     | R/W | 1'h0 | "1" : enable S8 mode                                                                                          |
| CS_H_MD     | [6]     | R/W | 1'h0 | 3-wire Melody timing 1, csn high mode enable                                                                  |
| S3W_MD      | [5]     | R/W | 1'h0 | "1": enable 3-wire mode                                                                                       |
| S3W_POS     | [4:0]   | R/W | 5'h0 | 3-wire mode, w/r control position or the sync pulse position(the pulse will locates on top of bit N)          |

# 6.3.5.2.5 SPI\_CTL2

| 0x0010 |    |    | Conf                      | igure ı            | egiste | r (Res | et 0x0 | 000_00 | 000) |    |    |    |             |     | SPI_ | CTL2 |
|--------|----|----|---------------------------|--------------------|--------|--------|--------|--------|------|----|----|----|-------------|-----|------|------|
| Bit    | 31 | 30 | 29                        | 28                 | 27     | 26     | 25     | 24     | 23   | 22 | 21 | 20 | 19          | 18  | 17   | 16   |
| Name   |    |    | Reserved                  |                    |        |        |        |        |      |    |    |    |             |     |      |      |
| Туре   |    | RO |                           |                    |        |        |        |        |      |    |    |    |             |     |      |      |
| 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   |    |    | Rese                      | TX_                |        |        |        |        |      |    |    |    | S3W_RD_STRT |     |      |      |
| Туре   |    |    | R                         | RO R/W 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    |      |

| Field Name | Bit     | R/W | Reset Value | Description                                                                                                     |
|------------|---------|-----|-------------|-----------------------------------------------------------------------------------------------------------------|
| Reserved   | [15:10] | RO  | 6'h0        |                                                                                                                 |
| TX_DMA_SEL | [9]     | R/W | 1'h0        | 0: tx_dma_req keep 1 until<br>receiving the tx_dma_ack<br>1: rx_dma_req is "1" when<br>tx_empty is "1",else "0" |
| RX_DMA_SEL | [8]     | R/W | 1'h0        | 0: rx_dma_req keep 1 until<br>receiving the rx_dma_ack<br>1: rx_dma_req is "1" when<br>rx_full is "1",else "0"  |



| RX_ONLY_HLD | [7]   | R/W | 1'h0 | "0": working on only receive mode, when rxf_realfull is high, SPI will be held until rxf_realfull is low "1": no holding |
|-------------|-------|-----|------|--------------------------------------------------------------------------------------------------------------------------|
| DMA_EN      | [6]   | R/W | 1'h0 | "1" enable DMA mode                                                                                                      |
| IS_SLVD     | [5]   | R/W | 1'h0 | "0" : master "1" : slave, only support microplus mode                                                                    |
| S3W_RD_STRT | [4:0] | R/W | 5'h0 | Read data start bit ,used for 3-wire mode                                                                                |

# 6.3.5.2.6 SPI\_CTL3

Description: SPI RX FIFO FULL/EMPTY watermark

| 0x0014 |    |          | RXF | waterr | nark (F       | Reset ( | 0x0000 | _1010 | )  |         |    |    |      |       | SPI_CTL3 |    |
|--------|----|----------|-----|--------|---------------|---------|--------|-------|----|---------|----|----|------|-------|----------|----|
| Bit    | 31 | 30       | 29  | 28     | 27            | 26      | 25     | 24    | 23 | 22      | 21 | 20 | 19   | 18    | 17       | 16 |
| Name   |    | Reserved |     |        |               |         |        |       |    |         |    |    |      |       |          |    |
| Туре   |    | 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   | ı  | Reserved | ł   | I      | RXF_E         | MPTY.   | _THLC  | )     | ı  | Reserve | t  |    | RXF_ | FULL_ | THLD     |    |
| Туре   |    | RO       |     |        | R/W RO R/W    |         |        |       |    |         |    |    |      |       |          |    |
| Reset  | 0  | 0        | 0   | 1      | 1 0 0 0 0 0 0 |         |        |       |    |         | 0  | 1  | 0    | 0     | 0        | 0  |

| Field Name     | Bit    | R/W | Reset Value | Description                                                              |
|----------------|--------|-----|-------------|--------------------------------------------------------------------------|
| RXF_EMPTY_THLD | [12:8] | R/W | 5'h10       | Receive FIFO data empty threshold. Relative with rx_fifo_empty interrupt |
| Reserved       | [7:5]  | RO  | 3'h0        |                                                                          |
| RXF_FULL_THLD  | [4:0]  | R/W | 5'h10       | Receive FIFO data full threshold. Relative with rx_fifo_full interrupt   |

# 6.3.5.2.7 SPI\_CTL4



| 0x0018 |                        |            | Conf             | igure | registe                          | r (Res                    | et 0x0                     | 000_00            | 000)  |    |     |       |     |    | SPI_ | CTL4 |
|--------|------------------------|------------|------------------|-------|----------------------------------|---------------------------|----------------------------|-------------------|-------|----|-----|-------|-----|----|------|------|
| Bit    | 31                     | 30         | 29               | 28    | 27                               | 26                        | 25                         | 24                | 23    | 22 | 21  | 20    | 19  | 18 | 17   | 16   |
| Name   |                        |            |                  |       |                                  |                           |                            | Rese              | erved |    |     |       |     |    |      |      |
| Туре   |                        |            |                  |       |                                  |                           |                            | R                 | 0     |    |     |       |     |    |      |      |
| 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   | RX_<br>ONL<br>Y_D<br>O | IS_F<br>ST | PHS <sub>-</sub> | _DLY  | SY<br>NC<br>_C<br>LK<br>MA<br>SK | SY<br>NC<br>_H<br>AL<br>F | IS_<br>RX<br>_O<br>NL<br>Y |                   |       |    | BLO | DCK_N | IUM |    |      |      |
| Туре   | 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 0 0 0 0   |       |    |     |       |     | 0  |      |      |

| Field Name   | Bit     | R/W | Reset Value | Description                                                                              |
|--------------|---------|-----|-------------|------------------------------------------------------------------------------------------|
| RX_ONLY_DO   | [15]    | R/W | 1'h0        | working in only receive mode, "0": SPI send all 0 to slave                               |
|              |         |     |             | "1": SPI send all 1 to slave                                                             |
| IS_FST       | [14]    | R/W | 1'h0        | "0" : normal mode<br>"1" : fast mode                                                     |
|              |         |     |             | Only used for slave mode                                                                 |
| PHS_DLY      | [13:12] | R/W | 2'h0        | Phase delay. Relate to fast mode.                                                        |
|              |         |     |             | When in normal mode, this bit is not used . Only used for slave mode                     |
| SYNC_CLKMASK | [11]    | R/W | 1'h0        | "1" Mask out the first clock pulse in SPI mode                                           |
| SYNC_HALF    | [10]    | R/W | 1'h0        | Sync_half, sync width is half spi_sck cycle                                              |
| IS_RX_ONLY   | [9]     | R/W | 1'h0        | "1":receive data only. The bit should be written at last. Only used for master mode      |
| BLOCK_NUM    | [8:0]   | R/W | 9'h0        | Number of data words ready to receive in "receive only" mode. Only used for master mode. |

# 6.3.5.2.8 SPI\_CTL5



| 0x001C |    |    | Conf | igure ı  | egiste | r(Rese | t 0x00 | 00_00 | 00) |    |    |    |    | SPI_CTL |    |    |  |
|--------|----|----|------|----------|--------|--------|--------|-------|-----|----|----|----|----|---------|----|----|--|
| Bit    | 31 | 30 | 29   | 28       | 27     | 26     | 25     | 24    | 23  | 22 | 21 | 20 | 19 | 18      | 17 | 16 |  |
| Name   |    |    |      | Reserved |        |        |        |       |     |    |    |    |    |         |    |    |  |
| Туре   |    |    |      | 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   |    |    |      | ITVL_NUM |        |        |        |       |     |    |    |    |    |         |    |    |  |
| Туре   |    |    |      | R/W      |        |        |        |       |     |    |    |    |    |         |    |    |  |
| Reset  | 0  | 0  |      |          |        |        |        |       |     |    |    | 0  |    |         |    |    |  |

| Field Name | Bit    | R/W | Reset Value | Description                                                                                                                                                                                                                                                                                       |
|------------|--------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ITVL_NUM   | [15:0] | R/W | 16'h0       | For master, transmit data interval, programmable n from 0 to 65535, delay is (n*4+3) clock cycle(clk_spi).  For slave, max receive data interval. If the slave has not sampled the edge of spi_clk in the interval(n*4+3)(clk_spi), slave will stop the receive process and send timout interrupt |

# 6.3.5.2.9 SPI\_INT\_EN

Description: SPI interrupt enable register

| 0x0020 |    |                                       | Inter | rupt er                             | nable ( | Reset | 0x000 | 0_000 | 0)                               |               |               |     |                  | 5   | SPI_IN | Γ_ΕΝ             |
|--------|----|---------------------------------------|-------|-------------------------------------|---------|-------|-------|-------|----------------------------------|---------------|---------------|-----|------------------|-----|--------|------------------|
| Bit    | 31 | 30                                    | 29    | 29 28 27 26 25 24 23 22 21 20 19 18 |         |       |       |       |                                  |               |               |     |                  |     | 17     | 16               |
| Name   |    | Reserved                              |       |                                     |         |       |       |       |                                  |               |               |     |                  |     |        |                  |
| Туре   |    |                                       | RO    |                                     |         |       |       |       |                                  |               |               |     |                  |     |        |                  |
| Reset  | 0  | 0                                     | 0     | 0                                   | 0       | 0     | 0     | 0     | 0                                | 0             | 0             | 0   | 0                | 0   | 0      | 0                |
| Bit    | 15 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |       |                                     |         |       |       |       |                                  |               |               |     | 0                |     |        |                  |
| Name   |    |                                       |       | Rese                                | erved   |       |       |       | TXF<br>_EM<br>PTY<br>_INT<br>_EN | RX F_U_IT E_N | M E O T T E Z | X   | Res<br>erve<br>d | X   | X      | Res<br>erve<br>d |
| Туре   |    |                                       |       | R                                   | 0       |       |       |       | R/W                              | R/W           | R/W           | R/W | RO               | R/W | R/W    | RO               |
| Reset  | 0  | 0                                     | 0     | 0                                   | 0       | 0     | 0     | 0     | 0                                | 0             | 0             | 0   | 0                | 0   | 0      | 0                |

| Field Name | Bit | R/W | Reset | Description |
|------------|-----|-----|-------|-------------|
|            |     |     | Value |             |



| TXF_EMPTY_INT_EN | [7] | R/W | 1'h0 | txf_empty interrupt enable          |
|------------------|-----|-----|------|-------------------------------------|
| RXF_FULL_INT_EN  | [6] | R/W | 1'h0 | Rxf_full interrupt enable           |
| TIME_OUT_INT_EN  | [5] | R/W | 1'h0 | Slave mode timeout interrupt enable |
| RX_OVF_INT_EN    | [4] | R/W | 1'h0 | Rx_overrun_reg interrupt enable     |
| Reserved         | [3] | RO  | 1'h0 |                                     |
| TXF_FULL_INT_EN  | [2] | R/W | 1'h0 | Tx_fifo_full interrupt enable       |
| RXF_EMPTY_INT_EN | [1] | R/W | 1'h0 | Rx_fifo_empty interrupt enable      |
| Reserved         | [0] | RO  | 1'h0 |                                     |

# 6.3.5.2.10 SPI\_INT\_CLR

Description: SPI interrupt clear register

| 0x0024 |    |                                      | Interi                                       | rupt cl | ear (R | eset 0x | <0000_ | 0000) |    |   |                                  |                                |                  | SI                               | PI_INT                                | _CLR             |
|--------|----|--------------------------------------|----------------------------------------------|---------|--------|---------|--------|-------|----|---|----------------------------------|--------------------------------|------------------|----------------------------------|---------------------------------------|------------------|
| Bit    | 31 | 30                                   | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |        |         |        |       |    |   |                                  |                                |                  |                                  |                                       |                  |
| Name   |    | Reserved                             |                                              |         |        |         |        |       |    |   |                                  |                                |                  |                                  |                                       |                  |
| Туре   |    |                                      |                                              |         |        |         |        | R     | .0 |   |                                  |                                |                  |                                  |                                       |                  |
| Reset  | 0  | 0                                    | 0                                            | 0       | 0      | 0       | 0      | 0     | 0  | 0 | 0                                | 0                              | 0                | 0                                | 0                                     | 0                |
| Bit    | 15 | 5 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |                                              |         |        |         |        |       |    |   |                                  |                                |                  |                                  |                                       |                  |
| Name   |    |                                      |                                              |         | Rese   | erved   |        |       |    |   | TIM<br>E_O<br>UT_I<br>NT_<br>CLR | RX_<br>OVF<br>_INT<br>_CL<br>R | Res<br>erve<br>d | TXF<br>_FU<br>LL_I<br>NT_<br>CLR | RXF<br>_EM<br>PTY<br>_INT<br>_CL<br>R | Res<br>erve<br>d |
| Туре   |    | RO WO WO RO WO RO                    |                                              |         |        |         |        |       |    |   |                                  |                                |                  |                                  |                                       |                  |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0          |                                              |         |        |         |        |       |    |   |                                  |                                |                  |                                  |                                       |                  |

| Field Name        | Bit | R/W | Reset<br>Value | Description                                  |
|-------------------|-----|-----|----------------|----------------------------------------------|
| TIME_OUT_INT_CLR  | [5] | WO  | 1'h0           | Write "1" clear slave mode timeout interrupt |
| RX_OVF_INT_CLR    | [4] | WO  | 1'h0           | Write "1" clear<br>Rx_overrun_reg interrupt  |
| Reserved          | [3] | RO  | 1'h0           |                                              |
| TXF_FULL_INT_CLR  | [2] | WO  | 1'h0           | Write "1" clear Tx_fifo_full interrupt       |
| RXF_EMPTY_INT_CLR | [1] | WO  | 1'h0           | Write "1" clear<br>Rx_fifo_empty interrupt   |
| Reserved          | [3] | RO  | 1'h0           |                                              |

# 6.3.5.2.11 SPI\_INT\_RAW



Description: SPI interrupt raw status

| 0x0028 |    |                         | Raw | status | (Rese | t 0x00 | 00_00 | 8A) |                                       |                                      |                                      |                                | SI                              | PI_INT                               | _RAW                                  | _STS                           |
|--------|----|-------------------------|-----|--------|-------|--------|-------|-----|---------------------------------------|--------------------------------------|--------------------------------------|--------------------------------|---------------------------------|--------------------------------------|---------------------------------------|--------------------------------|
| Bit    | 31 | 30                      | 29  | 28     | 27    | 26     | 25    | 24  | 23                                    | 22                                   | 21                                   | 20                             | 19                              | 18                                   | 17                                    | 16                             |
| Name   |    | Reserved                |     |        |       |        |       |     |                                       |                                      |                                      |                                |                                 |                                      |                                       |                                |
| Туре   |    | Reserved                |     |        |       |        |       |     |                                       |                                      |                                      |                                |                                 |                                      |                                       |                                |
| 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   |    |                         |     | Rese   | erved |        |       |     | TXF<br>_EM<br>PTY<br>_RA<br>W_S<br>TS | RXF<br>_FU<br>LL_<br>RA<br>W_S<br>TS | TIM<br>E_O<br>UT_<br>RA<br>W_S<br>TS | RX_<br>OVF<br>_RA<br>W_S<br>TS | TX_<br>FIF<br>O_E<br>MPT<br>Y_W | TXF<br>_FU<br>LL_<br>RA<br>W_S<br>TS | RXF<br>_EM<br>PTY<br>_RA<br>W_S<br>TS | RX_<br>FIF<br>O_F<br>ULL<br>_R |
| Туре   |    | RO RO RO RO RO RO RO RO |     |        |       |        |       |     |                                       |                                      |                                      |                                |                                 |                                      |                                       |                                |
| Reset  | 0  | 0 0 0 0 0 0 0 1 0 0 1 0 |     |        |       |        |       |     |                                       |                                      |                                      |                                |                                 |                                      |                                       |                                |

| Field Name        | Bit | R/W | Reset<br>Value | Description                                                                                                                                                          |
|-------------------|-----|-----|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TXF_EMPTY_RAW_STS | [7] | RO  | 1'h1           | Raw txf_empty interrupt, This bit is set when the number of tx fifo data byte is less than the tx empty watermark value. Auto cleared when the condition disappears. |
| RXF_FULL_RAW_STS  | [6] | RO  | 1'h0           | Raw rxf_full interrupt. This bit is set when the number of rx fifo data byte is larger than the rx full watermark value. Auto cleared when the condition disappears. |
| TIME_OUT_RAW_STS  | [5] | RO  | 1'h0           | Raw slave mode time out interrupt                                                                                                                                    |
| RX_OVF_RAW_STS    | [4] | RO  | 1'h0           | Raw Rx_overrun_reg interrupt                                                                                                                                         |
| TX_FIFO_EMPTY_W   | [3] | RO  | 1'h1           | Txf_empty_w(for debug)                                                                                                                                               |
| TXF_FULL_RAW_STS  | [2] | RO  | 1'h0           | Raw Tx_fifo_full interrupt                                                                                                                                           |
| RXF_EMPTY_RAW_STS | [1] | RO  | 1'h1           | Raw rx_fifo_empty interrupt                                                                                                                                          |
| RX_FIFO_FULL_R    | [0] | RO  | 1'h0           | Rxf_full_r(for debug)                                                                                                                                                |

# 6.3.5.2.12 SPI\_INT\_MASK\_STS

Description: IIS interrupt raw status



| 0x002C |    |                                                                                                                                                              | Mask | statu | s (Res | et 0x0 | 000_0 | 000) |                                        |                                       |                                       |                                 | SP               | I_INT_                                | MASK                                   | _STS             |
|--------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|--------|--------|-------|------|----------------------------------------|---------------------------------------|---------------------------------------|---------------------------------|------------------|---------------------------------------|----------------------------------------|------------------|
| Bit    | 31 | 30         29         28         27         26         25         24         23         22         21         20         19         18         17         16 |      |       |        |        |       |      |                                        |                                       |                                       |                                 |                  |                                       |                                        |                  |
| Name   |    | Reserved                                                                                                                                                     |      |       |        |        |       |      |                                        |                                       |                                       |                                 |                  |                                       |                                        |                  |
| Туре   |    | Reserved                                                                                                                                                     |      |       |        |        |       |      |                                        |                                       |                                       |                                 |                  |                                       |                                        |                  |
| 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   |    |                                                                                                                                                              |      | Rese  | erved  |        |       |      | TXF<br>_EM<br>PTY<br>_MA<br>SK_<br>STS | RXF<br>_FU<br>LL_<br>MAS<br>K_S<br>TS | TIM<br>E_O<br>UT_<br>MAS<br>K_S<br>TS | RX_<br>OVF<br>_MA<br>SK_<br>STS | Res<br>erve<br>d | TXF<br>_FU<br>LL_<br>MAS<br>K_S<br>TS | RXF<br>_EM<br>PTY<br>_MA<br>SK_<br>STS | Res<br>erve<br>d |
| Туре   |    | RO RO RO RO RO RO RO RO                                                                                                                                      |      |       |        |        |       |      |                                        |                                       |                                       |                                 |                  |                                       |                                        |                  |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                      |      |       |        |        |       |      |                                        |                                       | 0                                     | 0                               | 0                |                                       |                                        |                  |

| Field Name         | Bit | R/W | Reset<br>Value | Description                               |
|--------------------|-----|-----|----------------|-------------------------------------------|
| TXF_EMPTY_MASK_STS | [7] | RO  | 1'h1           | Txf_empty interrupt mask status.          |
| RXF_FULL_MASK_STS  | [6] | RO  | 1'h0           | Rxf_full interrupt mask status.           |
| TIME_OUT_MASK_STS  | [5] | RO  | 1'h0           | Slave mode time out interrupt mask status |
| RX_OVF_MASK_STS    | [4] | RO  | 1'h0           | Rx_overrun_reg interrupt mask status      |
| Reserved           | [3] | RO  | 1'h0           |                                           |
| TXF_FULL_MASK_STS  | [2] | RO  | 1'h0           | Tx_fifo_full interrupt mask status        |
| RXF_EMPTY_MASK_STS | [1] | RO  | 1'h1           | Rx_fifo_empty interrupt mask status       |
| Reserved           | [0] | RO  | 1'h0           |                                           |

# 6.3.5.2.13 SPI\_STS1

Description: SPI RX FIFO write address and read address

| 0x0030 | <b>&gt;</b> . |          | RXF                 | addres   | ss (Res | set 0x0 | 0000_0 | 000) |    |         |    |    |    |         | SPI_ | STS1 |
|--------|---------------|----------|---------------------|----------|---------|---------|--------|------|----|---------|----|----|----|---------|------|------|
| Bit    | 31            | 30       | 29                  | 28       | 27      | 26      | 25     | 24   | 23 | 22      | 21 | 20 | 19 | 18      | 17   | 16   |
| Name   |               | Reserved |                     |          |         |         |        |      |    |         |    |    |    |         |      |      |
| Туре   |               |          |                     |          |         |         |        | R    | 0  |         |    |    |    |         |      |      |
| 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   | -             | Reserve  | d                   |          | RX      | F_WADI  | DR     |      | ı  | Reserve | d  |    | R) | KF_RADI | OR   |      |
| Туре   |               | RO       |                     | RO RO RO |         |         |        |      |    |         |    |    |    |         |      |      |
| Reset  | 0             | 0        | 0 0 0 0 0 0 0 0 0 0 |          |         |         |        |      |    | 0       | 0  | 0  | 0  | 0       |      |      |



| Field Name | Bit    | R/W | Reset Value | Description           |
|------------|--------|-----|-------------|-----------------------|
| RXF_WADDR  | [12:8] | RO  | 5'h0        | RX FIFO write address |
| Reserved   | [7:5]  | RO  | 3'h0        |                       |
| RXF_RADDR  | [4:0]  | RO  | 5'h0        | RX FIFO read address  |

# 6.3.5.2.14 SPI\_STS2

Description: SPI status register

| 0x0034 |    |          | Regi | ster de | escript | ion (R | eset 0 | x0000_ | 12AA) |    |    |    |    |    | SPI | STS2 |
|--------|----|----------|------|---------|---------|--------|--------|--------|-------|----|----|----|----|----|-----|------|
| Bit    | 31 | 30       | 29   | 28      | 27      | 26     | 25     | 24     | 23    | 22 | 21 | 20 | 19 | 18 | 17  | 16   |
| Name   |    |          |      |         |         |        |        | Rese   | erved |    |    |    |    |    |     |      |
| Туре   |    |          |      |         |         |        |        | R      | 0     |    |    |    |    |    |     |      |
| 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   | I  | Reserved | t    |         |         |        |        |        |       |    |    |    |    |    |     |      |
| Туре   |    | RO       |      |         |         |        |        |        |       |    |    |    |    |    |     |      |
| Reset  | 0  | 0        | 0    | 0       | 0       | 0      | 0      | 0      | 0     | 0  | 0  | 0  | 0  | 0  | 0   | 0    |

| Field Name     | Bit  | R/W | Reset Value | Description                                                                                                                                            |
|----------------|------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI_CS         | [12] | RO  | 1'h1        | Spi_cs(for debug)                                                                                                                                      |
| SPI_SCK        | [11] | RO  | 1'h0        | Spi_sck(for debug)                                                                                                                                     |
| SPI_TXD        | [10] | RO  | 1'h0        | Spi_txd(for debug)                                                                                                                                     |
| SPI_RXD        | [9]  | RO  | 1'h1        | Spi_rxd(for debug)                                                                                                                                     |
| BUSY           | [8]  | RO  | 1'h0        | "1" transmit process "0" idle state                                                                                                                    |
| TXF_REAL_EMPTY | [7]  | RO  | 1'h1        | TX FIFO has no data                                                                                                                                    |
| TXF_REAL_FULL  | [6]  | RO  | 1'h0        | TX FIFO is real full. (not relates to TX full threshold)                                                                                               |
| RXF_REAL_EMPTY | [5]  | RO  | 1'h1        | RX FIFO has no data                                                                                                                                    |
| RXF_REAL_FULL  | [4]  | RO  | 1'h0        | RX FIFO is real full. (not relates to TX full threshold)                                                                                               |
| TXF_EMPTY      | [3]  | RO  | 1'h1        | This bit is set when the number of TX FIFO data byte is less than the TX empty interrupt watermark value. Auto cleared when the condition disappears.  |
| TXF_FULL       | [2]  | RO  | 1'h0        | This bit is set when the number of TX FIFO data byte is larger than the TX full interrupt watermark value. Auto cleared when the condition disappears. |
| RXF_EMPTY      | [1]  | RO  | 1'h1        | This bit is set when the number of RX FIFO data byte is less                                                                                           |



|          |     |    |      | than the RX empty interrupt watermark value. Auto cleared when the condition disappears.                                                               |
|----------|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| RXF_FULL | [0] | RO | 1'h0 | This bit is set when the number of RX FIFO data byte is larger than the RX full interrupt watermark value. Auto cleared when the condition disappears. |

# 6.3.5.2.15 SPI\_DSPWAIT

Description: This register is used for DSP control

| 0x0038 |    | Register description (Reset 0x0000_0001) SPI_DSPWA |    |    |    |    |    |    |    |    |    |    | WAIT |    |    |    |
|--------|----|----------------------------------------------------|----|----|----|----|----|----|----|----|----|----|------|----|----|----|
| Bit    | 31 | 30                                                 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18 | 17 | 16 |
| Name   |    | Reserved                                           |    |    |    |    |    |    |    |    |    |    |      |    |    |    |
| Туре   |    |                                                    |    |    |    |    |    | R  | .0 |    |    |    |      |    |    |    |
| 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   |    | Reserved IIS_DSPWAIT                               |    |    |    |    |    |    |    |    |    |    |      |    |    |    |
| Туре   |    | RO R/W                                             |    |    |    |    |    |    |    |    |    |    |      |    |    |    |
| Reset  | 0  | 0                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 1  |

| Field Name  | Bit   | R/W | Reset Value | Description                           |
|-------------|-------|-----|-------------|---------------------------------------|
| SPI_DSPWAIT | [3:0] | R/W | 4'h1        | This register is used for DSP control |

# 6.3.5.2.16 SPI\_STS3

Description: This register is used to observe the status

| 0x003C |    |                           | Regi | ster de  | script | ion (R | eset 0 | x0000_ | 0000) |    |    |        |    |    | SPI_ | STS3 |
|--------|----|---------------------------|------|----------|--------|--------|--------|--------|-------|----|----|--------|----|----|------|------|
| Bit    | 31 | 30                        | 29   | 28       | 27     | 26     | 25     | 24     | 23    | 22 | 21 | 20     | 19 | 18 | 17   | 16   |
| Name   |    | Reserved                  |      |          |        |        |        |        |       |    |    |        |    |    |      |      |
| Туре   |    | RO                        |      |          |        |        |        |        |       |    |    |        |    |    |      |      |
| 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   |    |                           | -    | Reserved | d      |        |        |        |       |    |    | RX_CNT | -  |    |      |      |
| Туре   |    |                           |      | RO       |        |        |        | RO     |       |    |    |        |    |    |      |      |
| Reset  | 0  | 0                         | 0    | 0        | 0      | 0      | 0      | 0      | 0     | 0  | 0  | 0      | 0  | 0  | 0    | 0    |

| Field Name | Bit   | R/W | Reset Value | Description                            |
|------------|-------|-----|-------------|----------------------------------------|
| RX_CNT     | [8:0] | RO  | 9'h0        | working in only receive mode as master |



### 6.3.5.2.17 SPI\_CTL6

Description: This register is used to configuration of the SPI interface

| 0x0040 |    |                                                | Regi   | ster de                               | escript | ion (Re | eset 0 | <0000_ | 1010) |     |   |    |   |   | SPI_ | CTL6 |
|--------|----|------------------------------------------------|--------|---------------------------------------|---------|---------|--------|--------|-------|-----|---|----|---|---|------|------|
| Bit    | 31 | 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |                                       |         |         |        |        |       |     |   | 16 |   |   |      |      |
| Name   |    |                                                |        |                                       |         |         |        | Rese   | erved |     |   |    |   |   |      |      |
| Туре   |    |                                                |        |                                       |         |         |        | R      | .0    |     |   |    |   |   |      |      |
| 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   |    | Reserve                                        | 1      | TXF_EMPTY_THLD Reserved TXF_FULL_THLD |         |         |        |        |       |     |   |    |   |   |      |      |
| Туре   |    | RO                                             | R/W RO |                                       |         |         |        |        |       | R/W |   |    |   |   |      |      |
| Reset  | 0  | 0                                              | 0      | 1                                     | 0       | 0       | 0      | 0      | 0     | 0   | 0 | 1  | 0 | 0 | 0    | 0    |

| Field Name     | Bit    | R/W | Reset Value | Description                                                         |
|----------------|--------|-----|-------------|---------------------------------------------------------------------|
| TXF_EMPTY_THLD | [12:8] | R/W | 5'h10       | TX FIFO data empty threshold. Relative with rx_fifo_empty interrupt |
| Reserved       | [7:5]  | RO  | 3'h0        |                                                                     |
| TXF_FULL_THLD  | [4:0]  | R/W | 5'h10       | TX FIFO data full threshold. Relative with rx_fifo_full interrupt   |

# 6.3.5.2.18 SPI\_STS4

Description: SPI status register

| 0x0044 |    |                                       | Regi | ster de | escript | ion (Re | eset 0 | x0000_ | 0000) |    |    |    |    |    | SPI_ | STS4 |
|--------|----|---------------------------------------|------|---------|---------|---------|--------|--------|-------|----|----|----|----|----|------|------|
| Bit    | 31 | 30                                    | 29   | 28      | 27      | 26      | 25     | 24     | 23    | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    | Reserved                              |      |         |         |         |        |        |       |    |    |    |    |    |      |      |
| Type   |    | RO                                    |      |         |         |         |        |        |       |    |    |    |    |    |      |      |
| 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   | i  | Reserved TXF_WADDR Reserved TXF_RADDR |      |         |         |         |        |        |       |    |    |    |    |    |      |      |
| Туре   |    | RO RO RO                              |      |         |         |         |        |        |       |    |    |    |    |    |      |      |
| Reset  | 0  | 0                                     | 0    | 0       | 0       | 0       | 0      | 0      | 0     | 0  | 0  | 0  | 0  | 0  | 0    | 0    |

| Field Name | Bit    | R/W | Reset Value | Description           |
|------------|--------|-----|-------------|-----------------------|
| TXF_WADDR  | [12:8] | RO  | 5'h0        | TX FIFO write address |
| Reserved   | [7:5]  | RO  | 3'h0        |                       |
| TXF_RADDR  | [4:0]  | RO  | 5'h0        | TX FIFO read address  |

# 6.3.5.2.19 SPI\_FIFO\_RST

Description: Used to reset TX/RX FIFO



| 0x0048 |    |                               | Regi                               | ster de | escript | ion (Re | eset 0 | x0000_   | 0000) |    |     |    |    | SPI | _FIFO | _RST                     |
|--------|----|-------------------------------|------------------------------------|---------|---------|---------|--------|----------|-------|----|-----|----|----|-----|-------|--------------------------|
| Bit    | 31 | 30                            | 29                                 | 28      | 27      | 26      | 25     | 24       | 23    | 22 | 21  | 20 | 19 | 18  | 17    | 16                       |
| Name   |    | Reserved                      |                                    |         |         |         |        |          |       |    |     |    |    |     |       |                          |
| Туре   |    | RO                            |                                    |         |         |         |        |          |       |    |     |    |    |     |       |                          |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                    |         |         |         |        |          |       |    |     | 0  |    |     |       |                          |
| Bit    | 15 | 14                            | 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |         |         |         |        |          |       |    |     |    | 0  |     |       |                          |
| Name   |    |                               |                                    |         |         |         | ı      | Reserved | d     |    |     |    |    |     |       | SPI_<br>FIF<br>O_R<br>ST |
| Туре   |    | RO RA                         |                                    |         |         |         |        |          |       |    | R/W |    |    |     |       |                          |
| Reset  | 0  |                               |                                    |         |         |         |        |          |       |    |     | 0  |    |     |       |                          |

| Field Name   | Bit | R/W | Reset Value | Description                                          |
|--------------|-----|-----|-------------|------------------------------------------------------|
| SPI_FIFO_RST | [0] | R/W | 1'h0        | "1": reset all FIFOs. FIFO address will changed to 0 |

# 6.3.6 Application Notes

# 6.3.6.1 Programming Model

### 6.3.6.1.1 MICRO/PLUS mode program examples

 MICRO/PLUS mode, master, 32 bits per-channel, MCLK 80M, SCK 20M, CS0 is valid, RX at rising edge, TX at negedge, SCK idle phase being low, Program control register:

 $Spi_clkd = 0x0001;$ 

 $Spi_ctl0 = 0x0e02;$ 

 $Spi_ctl1 = 0x3000;$ 

 $Spi_ctl2 = 0x0;$ 

 $Spi_ctl3 = 0x1010;$ 

 $Spi_ctl4 = 0x0;$ 

 $Spi_ctl5 = 0x0;$ 

 $Spi_ctl6 = 0x1010$ 

2. 16 bits per-channel, master, MCLK 80M, SCK 10M, only receive mode, ready to receive 0x1f words from slave, CS1 is valid, RX at falling edge, TX at rising edge, SCK idle phase being low, Program control register:

 $Spi_clkd = 0x0003;$ 

 $Spi_ctl0 = 0x0d41;$ 

Spi\_ctl1 = 0x1000;

 $Spi_ctl2 = 0x0;$ 

 $Spi_ctl3 = 0x1010;$ 

 $Spi_ctl4 = 0x021f;$ 

 $Spi_ctl5 = 0x0;$ 

 $Spi_ctl6 = 0x1010$ 



3. 8 bits per-channel, master, MCLK 48M, SCK 24M, CS2 is valid, RX at falling edge, TX at rising edge, SCK idle phase being high, LSB, dma\_en, Program control register:

```
Spi_clkd = 0x0000;

Spi_ctl0 = 0x26b2;

Spi_ctl1 = 0x3000;

Spi_ctl2 = 0x40;  //bit[6], enable dma

Spi_ctl3 = 0x1010;

Spi_ctl4 = 0x0000;

Spi_ctl5 = 0x0;

Spi_ctl6 = 0x1010
```

4. MICRO/PLUS mode, master, 32 bits per-channel, MCLK 80M, SCK 20M, CS0 is valid, RX at rising edge, TX at negedge, SCK idle phase being low, transmit only, Program control register:

```
Spi_clkd = 0x0001;

Spi_ctl0 = 0x0e02;

Spi_ctl1 = 0x2000; // transmit only

Spi_ctl2 = 0x0;

Spi_ctl3 = 0x1010;

Spi_ctl4 = 0x0;

Spi_ctl5 = 0x0;

Spi_ctl6 = 0x1010
```

5. MICRO/PLUS mode, slave, 32 bits per-channel, RX at rising edge, TX at negedge, SCK idle phase being low, Program control register:

```
Spi_clkd //no use when SPI working as slave , half SCK must have at least 4 system(MCLK) clock cycle.
```

```
Spi_ctl0 = 0x0f02;

Spi_ctl1 = 0x3000;

Spi_ctl2 = 0x20;

Spi_ctl3 = 0x1010;

Spi_ctl4 = 0x0;

Spi_ctl5 = 0x80;

Spi_ctl6 = 0x1010
```

6. MICRO/PLUS mode, slave, 8 bits per-channel, RX at falling edge, TX at rising edge, SCK idle phase being low, TX only/ RX only, Program control register:

```
Spi_ctl0 = 0x0e21;

Spi_ctl1 = 0x2000(TX only); / spi_ctl1 = 0x1000(RX only)

Spi_ctl2 = 0x20;

Spi_ctl3 = 0x1010;

Spi_ctl4 = 0x0;

Spi_ctl5 = 0x90;

Spi_ctl6 = 0x1010
```

### 6.3.6.1.2 SYNC mode program examples

Only work in master mode.

Relative register: spi\_ctl0[15:14], spi\_ctl1[4:0], spi\_ctl1[11:8],



 SYNC mode, master, 32 bits per-channel, MCLK 48M, SCK 12M, RX at rising edge, TX at falling edge, CS0 is valid, and signal sync maps to cs2, Program control register:

```
Spi_clkd = 0x0001;
```

 $Spi_ctl0 = 0x4a02;//biy[14]$  enable sync mode, bit[15] = 0 means positive pulse

Spi\_ctl1 = 0x3400;// sync pulse position will locate on top of bit0, sync maps to cs2

Spi\_ctl2 = 0x0;

Spi ctl3 = 0x1010;

 $Spi_ctl4 = 0x0;$ 

 $Spi_ctl5 = 0x0;$ 

 $Spi_ctl6 = 0x1010$ 

# 6.3.6.1.3 4-WIRE(S8) mode program examples

only work in master mode and only operation write being supported, TX at falling edgerelative register: spi\_ctl1[7], spi\_ctl1[11:8].

1. S8 mode, 8 bits per-channel, TX at falling edge, CS0 is valid and signal CD maps to cs1, program control register:

Spi\_ctl0 = 0x2c21; Spi\_ctl1: 0x3280;

### 6.3.6.1.4 3-WIRE mode program examples

Only work in master mode.

Relative register: spi\_ctl0[15], spi\_ctl1[4:0], spi\_ctl1[5], spi\_ctl1[6], spi\_ctl2[4:0]

 timing1(TX RX at falling edge), 16 bits per-channel, CS0 is valid, read command polarity is high, w/r control position is 8, read data start bit is 7, program control register:

 $spi_ctl0 = 0x0e43;$ 

 $spi_ctl1 = 0x3068;$ 

 $spi_ctl2 = 0x07;$ 

2. timing2(TX RX at rising edge), 16 bits per-channel, CS0 is valid, read command polarity is low, w/r control position is 8, read data start bit is 7, program control register:

spi\_ctl0 = 0xae43;

 $spi_ctl1 = 0x3068;$ 

 $spi_ctl2 = 0x07;$ 

### 6.3.6.2 Programming Notes

1. only receive mode

as master: set spi\_ctl4[9] = 1 and set spi\_ctl1[13:12] = "01" and program spi\_ctl4[8:0] to N, means enable rx only mode, and ready to receive N words from slave.

as slave: set  $spi_ctl1[13:12] = "01"$ , the received number depending on master the posedge of  $is_rx_only(spi_ctl4[9] = 1)$  will trigger the process, so SW should write to "0" first, then write to "1" to this bit.

#### 2. fast mode

used for slave mode. In slave mode, half SCK must have at least 4 system clock cycle.

When SCK < 14X MCLK, recommend to use fast mode.



8X : is\_fst(spi\_ctl4[14]) =1, phs\_dly([spi\_ctl4[13:12]] = 1

10X: is\_fst=1, phs\_dly = 2 12X: IS\_fst=1, phs\_dly = 3

- 3. In salve mode, spi\_ctl5[15:0]\* Tclk\_spi should not be such smaller than Tspi\_sck, so as not to make SPI stop transfer.
- 4. DMA enable
  - a) DMA should be configured first
  - b) Program SPI control register except spi\_ctl2[6]
  - c) Write spi\_ctl2[6] at last
- 5. When change SPI control register configuration, SW should ensure:
  - a) tx\_fifo is real empty at first
  - b) then, rx\_fifo is real empty
  - c) change SPI control register

# 6.4 IIS and PCM Interface

#### 6.4.1 Overview

IIS is a common digital audio interface specification. SC6820 IIS Interface can be used to implement a CODEC interface with external digital audio system working as host or slave. The IIS interface supports both IIS and PCM data format. The interface can transmit and receive data simultaneously as well as transmit or receive data alternatively at a time. This document defines function and configuration of IIS block.

SC6820 IIS module is controlled by ARM or DSP depending on global register IIS0\_CTRL\_SEL/IIS1\_CTRL\_SEL, when this bit is set to "1", DSP controls IIS, else ARM controls IIS.

SC6820 has 2 IIS controllers, IISO & IIS1.

### 6.4.2 Features

- I Compliant with the IIS/PCM standard
- I Support IIS, MSB-Justified and DSP data bus interface working on IIS mode
- Support Long Frame, Short Frame and Multi-cycle Frame working on PCM mode
- I Serial clock with programmable frequency
- I Two 32-word-deep FIFOs minimizes processor overhead at high data rates
- LRCK polarity can be configured
- I Wide selection of IIS data lengths 8,16,32bits
- I Master / slave
- MSB / LSB
- I Transmit only/ receive only / transmit and receive mode
- I 2 DMA requests
- I Single interrupt line for multiple interrupt source events

# 6.4.3 Signal Description





Figure 6-19 IIS connection as master



Figure 6-20 IIS connection as slave

# 6.4.4 Function Description

### 6.4.4.1 IIS interface and Timing modes

IIS module consists of RX/TX controller, ARM APB interface control register, clock generator and FIFO control. ARM programs IIS register, enable IIS mode, starts RX/TX data transfer. Output data is written to TX FIFO and received data is stored in RX FIFO. Each FIFO is 32-bit width plus 32-address length.

MCLK generator generates main clock for IIS block. This clock also output as master clock during hand shaking. In slave mode, external clock source can be input, working as the IIS main clock. Clock divider value and control signal for MCLK come from global control register.

The IIS SCLK generator divides main clock according to a 16-bit clock divider register, which defines half SCLK clock width. It can be programmed from 0 to 32767.





Figure 6-21 diagram of IIS

IIS interface has 4 pins, IIS\_SCK is serial clock output, IIS\_SDI is serial data input, IIS\_SDO is serial data output. IIS\_LRCK is left/right channel select. The device generating IIS\_LRCK and IIS\_SCK is the master. IIS\_LRCK and IIS\_SCK are output pins if working as master. They are input pins if working as slave.

Serial data is transmitted in two's complement format with the MSB first. Serial data can be sent at rising or falling edge of SCK, at receiver, it must be latched at rising edge. When system word length is greater than the transmitter word length, the word is truncated (least significant data bits are set to '0') for data transmission. If the receiver is sent more bits than its word length, the bits after the LSB are ignored. On the other hand, if the receiver is sent fewer bits than its word length, the missing bits are set to zero internally.

Three bus formats are available in this module. Following Figures illustrate the relationship between the SCK, LRCK and serial data I/O for different interface protocols. The polarity of LRCK is programmable. The bits per-channel is programmable up to 32bit.

IIS mode is where the MSB is available on the 2nd rising edge of SCLK following a LRCK transition.



Figure 6-22 IIS-compatible Serial Format

MSB-justified mode is where the MSB is available on the first rising edge of SCK following a LRCK transition.





Figure 6-23 MSB-justified Format

Sync mode is where the left channel MSB is available on either the 1st or 2nd rising edge of BCLK following a LRCK transition high. Right channel data immediately follows left channel data.



Figure 6-24 Synchronized Format

| Symbol | Parameter          | Min | Max | Unit |
|--------|--------------------|-----|-----|------|
| Т      | System clock cycle | T   | ı   | ns   |

Note:

T: 1/(system clock frequency)

n: register programmable integer, n-1 = 1, ...., 32767

#### 6.4.4.2 PCM interface

PCM interface is a direct voice interface connects to standard CODEC. The implementation is compliant with the MP-PCM requirements for voice transfer (8 kHz PCM SYNC and 8 or 16 bits data). The four signals of the PCM interface are:

- PCM\_CLK: PCM clock
- PCM\_SYNC: PCM 8KHz synchronization signal
- PCM OUT: PCM output data
- PCM\_IN: PCM input data

These four pins is able to share IIS interface follow this mapping:

PCM\_CLK share with IIS\_SCK,

PCM IN share with IIS SDI,

PCM\_OUT share with IIS\_SDO,

PCM SYNC share with IIS LRCK.

The data can be linear PCM (13-16 bit),  $\mu$  -Law (8 bit) or A-Law (8bit). The interface can work as either Master or Slave.

Programming IIS\_CTL 0 register bit 15 to 1 configures the PCM mode.

Long Frame Sync is the name given to a clocking format that controls the transfer of PCM data words or samples. In Long Frame Sync, the rising edge of PCM\_SYNC



indicates the start of the PCM word. When SC6820 is configured as PCM Master, generating PCM\_SYNC and PCM\_CLK, 8 bits in one frame, then PCM\_SYNC is 7-bit long. When SC6820 is configured as PCM Slave, PCM\_SYNC may be from one consecutive falling edges of PCM\_CLK to not big or equal than PCM data length (as figure shows, PCM\_SYNC is 2~7.5 bits) long.

Programming IIS\_CTL0 register bit8 to zero configures the Long Frame Sync mode.

PCM\_IN is captured on the falling edge of PCM\_CLK and PCM\_OUT transmits on the right and a post of the long programming and a post of the falling edge of programming and a post of the falling edge of programming and the programming and t

rising edge. PCM\_OUT may be configured to be high impedance on the falling edge of PCM\_CLK in the LSB position or on the rising edge. The control bit is IIS\_CTL2 bit10, if high, OE changes to low at falling edge of the last bit.



Figure 6-25 Long Frame Sync (Shown with 8-bit Sample)

In Short Frame Sync the falling edge of PCM\_SYNC indicates the start of the PCM word. PCM\_SYNC is always one clock cycle long.

As with Long Frame Sync, SC6820 samples PCM\_IN on the falling edge of PCM\_CLK and transmits PCM\_OUT on the rising edge. PCM\_OUT may be configured to be high impedance on the falling edge of PCM\_CLK in the LSB position or on the rising edge. Programming IIS\_CTL0 register bit8 to high configures the Short Frame Sync mode.



Figure 6-26 Short Frame Sync (Shown with 16-bit Sample)

More than one channel connection over the PCM interface is supported using multiple slots. Up to three channel connections can be carried over any of the first three slots.





Figure 6-27 Multi-slot Operation with Two Slots and 8-bit Compounded Samples

Three slots can be configured in one PCM frame; IIS\_CTL2 register bit 2~0 define which channel is occupied. Each bit configures one of the three channels. If bit0 is high, then slot0 is carrying data. If channel 0 and 2 is active, this register is 0x5.

PCM data format in TX/RX buffer is different between master and slave mode. If burst size is 16 or 8bit, in slave mode, data for slot 0 and slot 1 are packed into one word, which locates in lower address; data for slot2 locates in higher address; slot0 and slot2 fill higher bits (bit31~24). In master mode, only slot0 takes lower address and locates on lower bits (bit15~8); slot1, slot2 packed in higher address, and slot2 takes lower bits while slot1 in higher bits. Following table shows PCM data format for master and slave mode.

Table 6-3 PCM data format for master mode

| IIS_CTL<br>bit1~0 | Bits/channel | Data arrangement                                                                                                                       |
|-------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 00                | 8bit         | Data for channel 0 on bit 15~8, in lower address.  Data for channel 1 on bit 31~24, Data for channel 2 on bit 15~8, on higher address. |
| 01                | 16bit        | Data for channel 0 on bit 15~0, in lower address.  Data for channel 1 on bit 31~16, Data for channel 2 on bit 15~0, on higher address  |
| 1x                | 32bit        | Data for channel 0 store in low address, data for channel 1, 2 store in high address.                                                  |

Table 6-4 PCM data format for slave mode

| IIS_CTL<br>bit1~0 | Bits/channel | Data arrangement                                                                                                                        |
|-------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 00                | 8bit         | Data for channel 0 on bit 31~24, Data for channel 1 on bit 15~8, in lower address.  Data for channel 2 on bit 31~24, on higher address. |
| 01                | 16bit        | Data for channel 0 on bit 31~16, Data for channel 1 on bit 15~0,                                                                        |



|    |       | in lower address.  Data for channel 2 on bit 31~16, on higher address                 |
|----|-------|---------------------------------------------------------------------------------------|
| 1x | 32bit | Data for channel 0 store in low address, data for channel 1, 2 store in high address. |

# 6.4.5 Control Registers

# 6.4.5.1 Memory map

| Offset<br>Address | Name        | Description                                                                                                                     |
|-------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| 0x0000            | IIS_TXD     | Write data to this address initiates a character transmission through TX FIFO Read from this address retrieve data from RX FIFO |
| 0x0004            | IIS_CLKD    | Divisor is (n+1)*2                                                                                                              |
| 0x0008            | IIS_CTRL0   | Control register                                                                                                                |
| 0x000C            | IIS_CTRL1   | Control register                                                                                                                |
| 0x0010            | IIS_CTRL2   | Control register                                                                                                                |
| 0x0014            | IIS_CTRL3   | RX FIFO watermark                                                                                                               |
| 0x0018            | IIS_INT_IEN | IIS interrupt enable register                                                                                                   |
| 0x001C            | IIS_INT_CLR | IIS interrupt clear register                                                                                                    |
| 0x0020            | IIS_INT_RAW | IIS interrupt raw status                                                                                                        |
| 0x0024            | IIS_INT_STS | IIS interrupt mask status                                                                                                       |
| 0x0028            | IIS_STS1    | RX FIFO address                                                                                                                 |
| 0x002C            | IIS_STS2    | IIS internal status                                                                                                             |
| 0x0030            | IIS_STS3    | IIS internal status                                                                                                             |
| 0x0034            | IIS_DSPWAIT | Control register                                                                                                                |
| 0x0038            | IIS_CTRL4   | TX FIFO watermark                                                                                                               |
| 0x003C            | IIS_STS4    | TX FIFO address                                                                                                                 |

# 6.4.5.2 Register Descriptions

# 6.4.5.2.1 IIS\_TXD

Description: Write data to this address initiates a character transmission through TX FIFO; Read from this address retrieve data from RX FIFO.



| 0x0000 |    |    | IIS R | TX reg                    | ister(0 | x0000 | _0000) |    |    |    |    |    |    |    | IIS | _TXD |
|--------|----|----|-------|---------------------------|---------|-------|--------|----|----|----|----|----|----|----|-----|------|
| Bit    | 31 | 30 | 29    | 28                        | 27      | 26    | 25     | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16   |
| Name   |    |    |       | IIS_TXD                   |         |       |        |    |    |    |    |    |    |    |     |      |
| Туре   |    |    | R/W   |                           |         |       |        |    |    |    |    |    |    |    |     |      |
| 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   |    |    |       | IIS_TXD                   |         |       |        |    |    |    |    |    |    |    |     |      |
| Туре   |    |    | R/W   |                           |         |       |        |    |    |    |    |    |    |    |     |      |
| Reset  | 0  | 0  | 0     | 0 0 0 0 0 0 0 0 0 0 0 0 0 |         |       |        |    |    |    |    |    | 0  |    |     |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                     |
|------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------|
| IIS_TXD    | [31:0] | R/W  | 32'h0          | Write data to this address initiates a character transmission through TX FIFO Read from this address retrieve data from RX FIFO |

### 6.4.5.2.2 IIS\_CLKD

Description: Clock divisor bit 0 to 15

| 0x0004 |    |                                                 | Cloc | k divis | or (Re | set 0x | 0000_0 | 0003) |   |   |   |    |   |   | IIS_0 | CLKD |
|--------|----|-------------------------------------------------|------|---------|--------|--------|--------|-------|---|---|---|----|---|---|-------|------|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |      |         |        |        |        |       |   |   |   | 16 |   |   |       |      |
| Name   |    | Reserved                                        |      |         |        |        |        |       |   |   |   |    |   |   |       |      |
| Туре   |    | 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   |    | IIS_CLKD                                        |      |         |        |        |        |       |   |   |   |    |   |   |       |      |
| Туре   |    | IIS_CLKD                                        |      |         |        |        |        |       |   |   |   |    |   |   |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1                   |      |         |        |        |        |       |   |   |   |    |   |   |       |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                    |
|------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IIS_CLKD   | [15:0] | R/W  | 16'h3          | Specify the clock ratio between iis_sck and clk_iis.  If clk_iis runs at 5.12 MHz, and iis_sck runs at 256KHz, IIS_CLKD should be 9,  Iis_sck = clk_iis/2(+1). |

### Note:

When work in the slave mode, the frequency of iis\_sck depends on the IIS master, so the register IIS\_CLKD is not used.

# 6.4.5.2.3 IIS\_CTL0

Description: IIS control register



| 0x0008 |            |            | Cont                          | rol reg                                                                    | jister ( | Reset | 0x000 | 0_00C | 1) |   |     |             |     |           | IIS_      | CTL0 |
|--------|------------|------------|-------------------------------|----------------------------------------------------------------------------|----------|-------|-------|-------|----|---|-----|-------------|-----|-----------|-----------|------|
| Bit    | 31         | 30         | 29 28 27 26 25 24 23 22 21 20 |                                                                            |          |       |       |       |    |   |     |             | 19  | 18        | 17        | 16   |
| Name   |            | Reserved   |                               |                                                                            |          |       |       |       |    |   |     |             |     |           |           |      |
| 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   | PCM<br>_EB | DMA<br>_EN | Rese                          | SCK                                                                        |          |       |       |       |    |   | CHN | IS_S<br>LVD | LSB | NG_<br>TX | NG_<br>RX |      |
| Type   | R/W        | R/W        | R                             | RO         R/W         R/W         R/W         R/W         R/W         R/W |          |       |       |       |    |   |     | W           | R/W | R/W       | R/W       | R/W  |
| Reset  | 0          | 0          | 0                             | 0                                                                          | 0        | 0     | 0     | 0     | 1  | 1 | 0   | 0           | 0   | 0         | 0         | 1    |

| Field Name    | Bit     | R/W | Reset Value | Description                                                                                                                                                   |
|---------------|---------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCM_EB        | [15]    | R/W | 1'h0        | "1" : PCM mode "0" : IIS mode                                                                                                                                 |
| DMA_EN        | [14]    | R/W | 1'h0        | "1" : enable DMA                                                                                                                                              |
| Reserved      | [13:12] | R/W | 2'h0        |                                                                                                                                                               |
| SCK_REV       | [11]    | R/W | 1'h0        | SCK inverse enable (IIS mode: set to 1 Pcm mode: set to 0)                                                                                                    |
| IS_LRCK_PH    | [10]    | R/W | 1'h0        | Active level of left / right channel(0 for PCM mode)  "0": low for left  "1": high for left                                                                   |
| IS_SYNC_MD    | [9]     | R/W | 1'h0        | Output LRCK or SYNC for IIS mode "0": LRCK "1": SYNC(DSP mode)                                                                                                |
| IS_IISC_SHRTF | [8]     | R/W | 1'h0        | "0": MSB justified in IIS mode Long frame in PCM mode  "1": iis-compatible format in IIS mode Short frame in PCM mode When DSP mode, this bit should set to 0 |
| RTX_MD        | [7:6]   | R/W | 2'h3        | "00": idle mode "01": receive mode "10": transmit mode "11": transmit and receive                                                                             |
| BPCHN         | [5:4]   | R/W | 2'h0        | Serial bit per channel "00": 8 bits "01": 16 bits "1x": 32 bits                                                                                               |
| IS_SLVD       | [3]     | R/W | 1'h0        | "0": IIS/PCM work as master                                                                                                                                   |



|       |     |     |      | "1": IIS/PCM work as slave                                                       |
|-------|-----|-----|------|----------------------------------------------------------------------------------|
| LSB   | [2] | R/W | 1'h0 | "1": enable transmit data from LSB                                               |
|       |     |     |      | (PCM can't support this bit)                                                     |
| NG_TX | [1] | R/W | 1'h0 | "1" enable TX data shift out at clock neg-edge(use default value, can' set to 1) |
| NG_RX | [0] | R/W | 1'h1 | "1" enable RX data shift in at clock neg-edge (use default value, can' set to 0) |

### Note:

- [1] NG\_RX, NG\_TX should be default config
- [2] When PCM slave mode, Long Frame sync, Low for left config(PCM\_EB=1, IS\_SLVD=1, IS\_IISC\_SHRTF=1), can't support LSB mode(LSB = 1).
- [3] PCM RX and TX mode should be set both, when use PCM RX mode, and write data to tx fifo.

  Because, PCM sck is controlled by TX mode.
- [4] PCM multi slot config, when slot 0 set only, pcm cyc < 3
- [5] PCM mode, slave mode can't support High\_for\_left(IS\_LRCK\_PH=1)
- [6] DSP mode, slave can't support High\_for\_left(IS\_LRCK\_PH=1)
- [7] DSP mode, can't support iis-compatible format

#### 6.4.5.2.4 IIS\_CTL1

Description: IIS configure register

| 0x000C |                    |                    | Cont                    | rol reiç                                                                                                                                         | gster ( | Reset | 0x000 | 0_0000 | )) |                   |      |   |   |   | IIS_ | CTL1 |
|--------|--------------------|--------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|-------|--------|----|-------------------|------|---|---|---|------|------|
| Bit    | 31                 | 30                 | 29                      | 9         28         27         26         25         24         23         22         21         20         19         18         17         16 |         |       |       |        |    |                   |      |   |   |   |      |      |
| Name   |                    | Reserved           |                         |                                                                                                                                                  |         |       |       |        |    |                   |      |   |   |   |      |      |
| Туре   |                    |                    |                         |                                                                                                                                                  |         |       |       | R      | 0  |                   |      |   |   |   |      |      |
| 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   | IS_R<br>XIO<br>STP | IS_T<br>XIO<br>STP | IS_F<br>SCN<br>T_E<br>B | IS_N<br>UM_<br>CNT                                                                                                                               |         |       |       |        |    | ITVL <sub>.</sub> | _NUM |   |   |   |      |      |
| Туре   | R/W                | 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    |

| Field Name  | Bit  | R/W | Reset Value | Description                                 |
|-------------|------|-----|-------------|---------------------------------------------|
| IS_RXIOSTP  | [15] | R/W | 1'h0        | Receive IO stop enable "1" : enalbe         |
| IS_TXIOSTP  | [14] | R/W | 1'h0        | Transmit IO stop enable "1" : enable        |
| IS_FSCNT_EB | [13] | R/W | 1'h0        | Clock counter enable, for debug "1": enable |



| IS_NUM_CNT | [12]   | R/W | 1'h0  | Count clock for one "0" : Irck cycle "1" : sclk cycle                                                                                                                                       |
|------------|--------|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ITVL_NUM   | [11:0] | R/W | 12'h0 | Used for timeout decision for slave mode  If the slave has not sampled the edge of iis_sck in the interval (n*4+3)*Tclk_iis, slave will stop the receive process and send timeout interrupt |

# 6.4.5.2.5 IIS\_CTL2

Description: IIS control register

| 0x0010 |    |    | Cont   | rol reg | jister ( | Reset             | 0x0000 | 0_0021 | )     |        |    |    |    |    | IIS_   | CTL2 |
|--------|----|----|--------|---------|----------|-------------------|--------|--------|-------|--------|----|----|----|----|--------|------|
| Bit    | 31 | 30 | 29     | 28      | 27       | 26                | 25     | 24     | 23    | 22     | 21 | 20 | 19 | 18 | 17     | 16   |
| Name   |    |    |        |         |          |                   |        | Rese   | erved |        |    |    |    |    |        |      |
| Туре   |    |    |        |         |          |                   |        | R      | 0     |        |    |    |    |    |        |      |
| 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   |    | s  | YNC_PC | s       |          | PCM<br>_OE<br>_EN |        |        | P     | PCM_CY | С  |    |    | Р  | CM_SLC | T    |
| Туре   |    |    | R/W    |         |          | R/W               |        |        |       | R/W    |    |    |    |    | R/W    |      |
| Reset  | 0  | 0  | 0      | 0       | 0        | 0                 | 0      | 0      | 0     | 0      | 1  | 0  | 0  | 0  | 0      | 1    |

| Field Name | Bit     | R/W | Reset Value | Description                                                                                                                                                                            |
|------------|---------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SYNC_POS   | [15:11] | R/W | 5'h0        | SYNC position when working in DSP format:  0: MSB is available on the 2 <sup>nd</sup> rising edge of SCK  Channel length-1: MSB is available on the 1 <sup>ST</sup> rising edge of SCK |
| PCM_OE_EN  | [10]    | R/W | 1'h0        | "1": Enable data oe change to low at falling edge of last bit (0: enable data oe only for valid data 1: enable data oe for all transimission)                                          |
| PCM_CYC    | [9:3]   | R/W | 7'h4        | Pcm_cycle, used for multi_slot<br>PCM<br>(if not multi slot, set to 0<br>Mult slot:<br>1: indicates 1 slot interval<br>between 2 pcm sync(if long<br>frame sync)                       |



|          |       |     |      | 2:indicates 2 slot interval between 2 pcm sync )                                                                                                              |
|----------|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCM_SLOT | [2:0] | R/W | 3'h1 | Pcm_slot, used for multi_slot<br>PCM<br>"001": slot 0 is used<br>"010": slot 1 is used<br>"100": slot 2 is used<br>"011": slot 0 and slot 1 are in<br>use<br> |

# 6.4.5.2.6 IIS\_CTL3

Description: IIS RX FIFO FULL/EMPTY watermark value

| 0x0014 |    |          | RXF | waterr | nark (F | Reset ( | 0x0000 | _0808 | )     |         |    |    | IIS_C1 |         |      | CTL3 |
|--------|----|----------|-----|--------|---------|---------|--------|-------|-------|---------|----|----|--------|---------|------|------|
| Bit    | 31 | 30       | 29  | 28     | 27      | 26      | 25     | 24    | 23    | 22      | 21 | 20 | 19     | 18      | 17   | 16   |
| Name   |    |          |     |        |         |         |        | Rese  | erved |         |    |    |        |         |      |      |
| Туре   |    |          |     |        |         |         |        | R     | 0     |         |    |    |        |         |      |      |
| 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   | F  | Reserved | t   |        | RXF_    | EMPTY_  | THLD   |       |       | Reserve | t  |    | RXF    | _FULL_1 | THLD |      |
| Туре   |    | RO       |     |        |         |         |        |       | RO    |         |    |    |        |         |      |      |
| Reset  | 0  | 0        | 0   | 0      | 1       | 0       | 0      | 0     | 0     | 0       | 0  | 0  | 1      | 0       | 0    | 0    |

| Field Name     | Bit    | R/W | Reset Value | Description                  |
|----------------|--------|-----|-------------|------------------------------|
| RXF_EMPTY_THLD | [12:8] | R/W | 5'h8        | Receive data full threshold  |
| Reserved       | [7:5]  | R/W | 3'h0        |                              |
| RXF_FULL_THLD  | [4:0]  | R/W | 5'h0        | Receive data empty threshold |

# 6.4.5.2.7 IIS\_INT\_EN

Description: IIS interrupt enable register



| 0x0018 |    |    | Inter | upt er                       | nable ( | Reset | 0x000 | 0_000 | 0)                               |                                 |                                 |                           |                  |                                 | IIS_IN                           | T_EN             |
|--------|----|----|-------|------------------------------|---------|-------|-------|-------|----------------------------------|---------------------------------|---------------------------------|---------------------------|------------------|---------------------------------|----------------------------------|------------------|
| Bit    | 31 | 30 | 29    | 28                           | 27      | 26    | 25    | 24    | 23                               | 22                              | 21                              | 20                        | 19               | 18                              | 17                               | 16               |
| Name   |    |    |       |                              |         |       |       | Rese  | erved                            |                                 |                                 |                           |                  |                                 |                                  |                  |
| Туре   |    |    |       |                              |         |       |       | R     | (O                               |                                 |                                 |                           |                  |                                 |                                  |                  |
| 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   |    |    |       | Rese                         | erved   |       |       |       | TXF<br>_EM<br>PTY<br>_INT<br>_EN | RXF<br>_FU<br>LL_I<br>NT_<br>EN | TIM<br>E_O<br>UT_I<br>NT_<br>EN | RX_<br>OVF<br>_INT<br>_EN | Res<br>erve<br>d | TXF<br>_FU<br>LL_I<br>NT_<br>EN | RXF<br>_EM<br>PTY<br>_INT<br>_EN | Res<br>erve<br>d |
| Туре   |    |    |       | RO RW RW RW RO RW RO RO      |         |       |       |       |                                  |                                 | RO                              |                           |                  |                                 |                                  |                  |
| Reset  | 0  | 0  | 0     | 0                            | 0       | 0     | 0     | 0     | 0                                | 0                               | 0                               | 0                         | 0                | 0                               | 0                                | 0                |

| Field Name       | Bit | R/W | Reset<br>Value | Description                         |
|------------------|-----|-----|----------------|-------------------------------------|
| TXF_EMPTY_INT_EN | [7] | R/W | 1'h0           | Rx_fifo_full interrupt enable       |
| RXF_FULL_INT_EN  | [6] | R/W | 1'h0           | Rx_fifo_empty interrupt enable      |
| TIME_OUT_INT_EN  | [5] | R/W | 1'h0           | Slave mode timeout interrupt enable |
| RX_OVF_INT_EN    | [4] | R/W | 1'h0           | Rx_overrun_reg interrupt enable     |
| Reserved         | [3] | R/W | 1'h0           |                                     |
| TXF_FUL_INT_EN   | [2] | R/W | 1'h0           | Tx_fifo_full interrupt enable       |
| RXF_EMPTY_INT_EN | [1] | R/W | 1'h0           | Rx_fifo_empty interrupt enable      |
| Reserved         | [0] | R/W | 1'h0           |                                     |

# 6.4.5.2.8 IIS\_INT\_CLR

Description: IIS interrupt clear register



| 0x001C |    |    | Inter | rupt cl                 | ear (R | eset 0 | (0000_ | 0000) |       |    |                                  |                                |                  | II:                              | S_INT                                  | CLR              |
|--------|----|----|-------|-------------------------|--------|--------|--------|-------|-------|----|----------------------------------|--------------------------------|------------------|----------------------------------|----------------------------------------|------------------|
| Bit    | 31 | 30 | 29    | 28                      | 27     | 26     | 25     | 24    | 23    | 22 | 21                               | 20                             | 19               | 18                               | 17                                     | 16               |
| Name   |    |    |       |                         |        |        |        | Rese  | erved |    |                                  |                                |                  |                                  |                                        |                  |
| Туре   |    |    |       |                         |        |        |        | R     | 0     |    |                                  |                                |                  |                                  |                                        |                  |
| Reset  | 0  | 0  | 0     | 0                       | 0      | 0      | 0      | 0     | 0     | 0  | 0                                | 0                              | 0                | 0                                | 0                                      | 0                |
| Bit    | 15 | 14 | 13    | 13 12 11 10 9 8 7 6 5 4 |        |        |        |       |       |    | 4                                | 3                              | 2                | 1                                | 0                                      |                  |
| Name   |    |    |       |                         | Rese   | erved  |        |       |       |    | TIM<br>E_O<br>UT_I<br>NT_<br>CLR | RX_<br>OVF<br>_INT<br>_CL<br>R | Res<br>erve<br>d | TXF<br>_FU<br>LL_I<br>NT_<br>CLR | RXF<br>_EM<br>PTY<br>_INT<br>_CL<br>_R | Res<br>erve<br>d |
| Туре   |    |    |       | RO WO WO                |        |        |        |       |       |    | wo                               | RO                             | wo               | wo                               | RO                                     |                  |
| Reset  | 0  | 0  | 0     | 0                       | 0      | 0      | 0      | 0     | 0     | 0  | 0                                | 0                              | 0                | 0                                | 0                                      | 0                |

| Field Name        | Bit | R/W | Reset<br>Value | Description                                  |
|-------------------|-----|-----|----------------|----------------------------------------------|
| TIME_OUT_INT_CLR  | [5] | WO  | 1'h0           | Write "1" clear slave mode timeout interrupt |
| RX_OVF_INT_CLR    | [4] | WO  | 1'h0           | Write "1" clear<br>Rx_overrun_reg interrupt  |
| Reserved          | [3] | RO  | 1'h0           |                                              |
| TXF_FULL_INT_CLR  | [2] | WO  | 1'h0           | Write "1" clear Tx_fifo_full interrupt       |
| RXF_EMPTY_INT_CLR | [1] | WO  | 1'h0           | Write "1" clear<br>Rx_fifo_empty interrupt   |
| Reserved          | [0] | RO  | 1'h0           |                                              |

# 6.4.5.2.9 IIS\_INT\_RAW\_STS

Description: IIS interrupt raw status

| 0x0020 |    |    | Raw | status                   | (Rese | t 0x00 | 00_00 | 8A)  |                                       |                                      |                                      |                                | II                              | S_INT                                | _RAW                                  | _STS                           |
|--------|----|----|-----|--------------------------|-------|--------|-------|------|---------------------------------------|--------------------------------------|--------------------------------------|--------------------------------|---------------------------------|--------------------------------------|---------------------------------------|--------------------------------|
| Bit    | 31 | 30 | 29  | 28                       | 27    | 26     | 25    | 24   | 23                                    | 22                                   | 21                                   | 20                             | 19                              | 18                                   | 17                                    | 16                             |
| Name   |    |    |     |                          |       |        |       | Rese | erved                                 |                                      |                                      |                                |                                 |                                      |                                       |                                |
| Туре   |    |    |     |                          |       |        |       | Rese | erved                                 |                                      |                                      |                                |                                 |                                      |                                       |                                |
| Reset  | 0  | 0  | 0   | 0                        | 0     | 0      | 0     | 0    | 0                                     | 0                                    | 0                                    | 0                              | 0                               | 0                                    | 0                                     | 0                              |
| Bit    | 15 | 14 | 13  | 3 12 11 10 9 8 7 6 5 4 3 |       |        |       |      |                                       |                                      |                                      | 3                              | 2                               | 1                                    | 0                                     |                                |
| Name   |    |    |     | Rese                     | erved |        |       |      | TXF<br>_EM<br>PTY<br>_RA<br>W_S<br>TS | RXF<br>_FU<br>LL_<br>RA<br>W_S<br>TS | TIM<br>E_O<br>UT_<br>RA<br>W_S<br>TS | RX_<br>OVF<br>_RA<br>W_S<br>TS | TX_<br>FIF<br>O_E<br>MPT<br>Y_W | TXF<br>_FU<br>LL_<br>RA<br>W_S<br>TS | RXF<br>_EM<br>PTY<br>_RA<br>W_S<br>TS | RX_<br>FIF<br>O_F<br>ULL<br>_R |
| Туре   |    |    |     | RO RO RO F               |       |        |       |      |                                       |                                      | RO                                   | RO                             | RO                              | RO                                   | RO                                    |                                |
| Reset  | 0  | 0  | 0   | 0                        | 0     | 0      | 0     | 0    | 1                                     | 0                                    | 0                                    | 0                              | 1                               | 0                                    | 1                                     | 0                              |

| Field Name Bit | R/W | Reset | Description |
|----------------|-----|-------|-------------|
|----------------|-----|-------|-------------|



|                   |     |    | Value |                                                                                                                                                                      |
|-------------------|-----|----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TXF_EMPTY_RAW_STS | [7] | RO | 1'h1  | Raw txf_empty interrupt, This bit is set when the number of tx fifo data byte is less than the tx empty watermark value. Auto cleared when the condition disappears. |
| RXF_FULL_RAW_STS  | [6] | RO | 1'h0  | Raw rxf_full interrupt. This bit is set when the number of rx fifo data byte is larger than the rx full watermark value. Auto cleared when the condition disappears. |
| TIME_OUT_RAW_STS  | [5] | RO | 1'h0  | Raw slave mode time out interrupt                                                                                                                                    |
| RX_OVF_RAW_STS    | [4] | RO | 1'h0  | Raw Rx_overrun_reg                                                                                                                                                   |
| TX_FIFO_EMPTY_W   | [3] | RO | 1'h1  | Txf_empty_w(for debug)                                                                                                                                               |
| TXF_FULL_RAW_STS  | [2] | RO | 1'h0  | Raw Tx_fifo_full interrupt                                                                                                                                           |
| RXF_EMPTY_RAW_STS | [1] | RO | 1'h1  | Raw rx_fifo_empty interrupt                                                                                                                                          |
| RX_FIFO_FULL_R    | [0] | RO | 1'h0  | Rxf_full_r(for debug)                                                                                                                                                |

# 6.4.5.2.10 IIS\_INT\_MASK\_STS

Description: IIS interrupt mask status

| 0x0024 |    | Mask status (Reset 0x0000_0000) IIS_INT_MASK_STS |                               |    |    |    |   |      |       |    |                                       |                                 | STS              |                                       |                                        |                  |
|--------|----|--------------------------------------------------|-------------------------------|----|----|----|---|------|-------|----|---------------------------------------|---------------------------------|------------------|---------------------------------------|----------------------------------------|------------------|
| Bit    | 31 | 30                                               | 29 28 27 26 25 24 23 22 21 20 |    |    |    |   |      |       |    | 20                                    | 19                              | 18               | 17                                    | 16                                     |                  |
| Name   |    | Reserved                                         |                               |    |    |    |   |      |       |    |                                       |                                 |                  |                                       |                                        |                  |
| Туре   |    |                                                  |                               |    |    |    |   | Rese | erved |    |                                       |                                 |                  |                                       |                                        |                  |
| 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   |    | Reserved                                         |                               |    |    |    |   |      |       |    | TIM<br>E_O<br>UT_<br>MAS<br>K_S<br>TS | RX_<br>OVF<br>_MA<br>SK_<br>STS | Res<br>erve<br>d | TXF<br>_FU<br>LL_<br>MAS<br>K_S<br>TS | RXF<br>_EM<br>PTY<br>_MA<br>SK_<br>STS | Res<br>erve<br>d |
| Туре   | RO |                                                  |                               |    |    |    |   |      | RO    | RO | RO                                    | RO                              | RO               | RO                                    | RO                                     | RO               |
| Reset  | 0  | 0                                                | 0                             | 0  | 0  | 0  | 0 | 0    | 0     | 0  | 0                                     | 0                               | 0                | 0                                     | 0                                      | 0                |

| Field Name         | Bit | R/W | Reset<br>Value | Description                      |
|--------------------|-----|-----|----------------|----------------------------------|
| TXF_EMPTY_MASK_STS | [7] | RO  | 1'h1           | Txf_empty interrupt mask status. |
| RXF_FULL_MASK_STS  | [6] | RO  | 1'h0           | Rxf_full interrupt mask status.  |



| TIME_OUT_MASK_STS      | [5] | RO | 1'h0 | Slave mode time out interrupt mask status |
|------------------------|-----|----|------|-------------------------------------------|
| RX_OVF_MASK_STS        | [4] | RO | 1'h0 | Rx_overrun_reg interrupt mask status      |
| Reserved               | [3] | RO | 1'h1 |                                           |
| TX_FIFO_FULL_MASK_STS  | [2] | RO | 1'h0 | Tx_fifo_full interrupt mask status        |
| RX_FIFO_EMPTY_MASK_STS | [1] | RO | 1'h1 | Rx_fifo_empty interrupt mask status       |
| Reserved               | [0] | RO | 1'h0 |                                           |

# 6.4.5.2.11 IIS\_STS1

Description: IIS RX FIFO write address and read address

| 0x0028 |    | RXF address (Reset 0x0000_0000) IIS_STS1 |    |    |     |       |     |    |    |         |    |             | STS1 |    |    |    |
|--------|----|------------------------------------------|----|----|-----|-------|-----|----|----|---------|----|-------------|------|----|----|----|
| Bit    | 31 | 30                                       | 29 | 28 | 27  | 26    | 25  | 24 | 23 | 22      | 21 | 20          | 19   | 18 | 17 | 16 |
| Name   |    | Reserved                                 |    |    |     |       |     |    |    |         |    |             |      |    |    |    |
| Туре   |    | 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   |    | Reserve                                  | d  |    | RXF | _WR_A | DDR |    |    | Reserve | t  | RXF_RD_ADDR |      |    |    |    |
| Туре   |    | RO                                       |    | RO |     |       |     |    | RO |         |    |             | RO   |    |    |    |
| Reset  | 0  | 0                                        | 0  | 0  | 0   | 0     | 0   | 0  | 0  | 0       | 0  | 0           | 0    | 0  | 0  | 0  |

| Field Name  | Bit    | R/W | Reset Value | Description           |
|-------------|--------|-----|-------------|-----------------------|
| RXF_WR_ADDR | [12:8] | RO  | 5'h0        | RX FIFO write address |
| Reserved    | [7:5]  | RO  | 3'h0        |                       |
| RXF_RD_ADDR | [4:0]  | RO  | 5'h0        | RX FIFO read address  |

# 6.4.5.2.12 IIS\_STS2

Description: IIS status register



| 0x002C | Status register (Reset 0x0000_00AA) IIS_STS |                                  |    |    |    |    |            |                   |                  |                   |                  | STS2 |    |    |    |   |
|--------|---------------------------------------------|----------------------------------|----|----|----|----|------------|-------------------|------------------|-------------------|------------------|------|----|----|----|---|
| Bit    | 31                                          | 30 29 28 27 26 25 24 23 22 21 20 |    |    |    |    |            |                   |                  |                   | 20               | 19   | 18 | 17 | 16 |   |
| Name   |                                             | Reserved                         |    |    |    |    |            |                   |                  |                   |                  |      |    |    |    |   |
| Туре   |                                             | 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   |                                             |                                  |    |    |    |    | _RE<br>ALF | TXF<br>_EM<br>PTY | TXF<br>_FU<br>LL | RXF<br>_EM<br>PTY | RXF<br>_FU<br>LL |      |    |    |    |   |
| Туре   | RO            |                                  |    |    |    |    |            |                   | RO               |                   |                  |      |    |    |    |   |
| Reset  | 0                                           | 0                                | 0  | 0  | 0  | 0  | 0          | 0                 | 1                | 0                 | 1                | 0    | 1  | 0  | 1  | 0 |

| Field Name    | Bit  | R/W | Reset Value | Description                                                                                                                                           |
|---------------|------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| IIS_LRCK      | [12] | RO  | 1'h0        | IIS_LRCK, for debug                                                                                                                                   |
| IIS_SCK       | [11] | RO  | 1'h0        | IIS_SCK, for debug                                                                                                                                    |
| IIS_DO        | [10] | RO  | 1'h0        | IIS_DO, for debug                                                                                                                                     |
| IIS_DI        | [9]  | RO  | 1'hX        | IIS_DI, for debug                                                                                                                                     |
| BUSY          | [8]  | RO  | 1'h0        | BUSY, for debug                                                                                                                                       |
| TXF_REALEMPTY | [7]  | RO  | 1'h1        | TX FIFO is real empty. TX FIFO has no data                                                                                                            |
| TXF_REALFULL  | [6]  | RO  | 1'h0        | TX FIFO is real full.(not relates to register TXF_FULL_THLD)                                                                                          |
| RXF_REALEMPTY | [5]  | RO  | 1'h1        | RX FIFO is real empty. RX FIFO has no data                                                                                                            |
| RXF_REALFULL  | [4]  | RO  | 1'h0        | RX FIFO is real full.(not relates to register RXF_FULL_THLD)                                                                                          |
| TXF_EMPTY     | [3]  | RO  | 1'h1        | This bit is set when the number of TX FIFO data byte is less than the TX empty watermark value. Auto cleared when the condition disappears.           |
| TXF_FULL      | [2]  | RO  | 1'h0        | This bit is set when the number of TX FIFO data byte is larger than the TX full watermark value. Auto cleared when the condition disappears.          |
| RXF_EMPTY     | [1]  | RO  | 1'h1        | This bit is set when the number of RX FIFO data byte is less than the RX empty interrupt watermark value. Auto cleared when the condition disappears. |
| RXF_FULL      | [0]  | RO  | 1'h0        | This bit is set when the number of RX FIFO data byte is larger than the RX full watermark value. Auto cleared when the                                |



|  |  | condition diconnects  |
|--|--|-----------------------|
|  |  | condition disappears. |

## 6.4.5.2.13 IIS\_STS3

Description: IIS status register

| 0x0030 |    |                                              | Statu                       | ıs regi | ster(R | eset 0 | <0000_ | 0000) |     |   |   |   |   |   | IIS_ | STS3 |
|--------|----|----------------------------------------------|-----------------------------|---------|--------|--------|--------|-------|-----|---|---|---|---|---|------|------|
| Bit    | 31 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                             |         |        |        |        |       |     |   |   |   |   |   |      |      |
| Name   |    | Reserved                                     |                             |         |        |        |        |       |     |   |   |   |   |   |      |      |
| Туре   |    |                                              |                             |         |        |        |        | R     | 0   |   |   |   |   |   |      |      |
| 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   |    |                                              |                             |         |        |        |        | LRCI  | CNT |   |   |   |   |   |      |      |
| Туре   |    |                                              | RO                          |         |        |        |        |       |     |   |   |   |   |   |      |      |
| Reset  | 0  | 0                                            | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |         |        |        |        |       |     |   |   |   |   |   |      |      |

| Field Name | Bit    | R/W | Reset Value | Description                                                               |
|------------|--------|-----|-------------|---------------------------------------------------------------------------|
| LRCKCNT    | [15:0] | RO  | 16'h0       | Number of clk_iis cycle per SCK cycle or LRCK cycle, depends on ctl1[12]. |

#### 6.4.5.2.14 IIS\_DSPWAIT

Description: This register is used for DSP control

| 0x0034 |    |                           | Cont | rol reg | jister(F | Reset C | x0000 | _0001 | )  |    |    |    | IIS_DSPWAIT |        |       | WAIT |
|--------|----|---------------------------|------|---------|----------|---------|-------|-------|----|----|----|----|-------------|--------|-------|------|
| Bit    | 31 | 30                        | 29   | 28      | 27       | 26      | 25    | 24    | 23 | 22 | 21 | 20 | 19          | 18     | 17    | 16   |
| Name   |    | Reserved                  |      |         |          |         |       |       |    |    |    |    |             |        |       |      |
| Туре   |    |                           |      |         |          |         |       | R     | 0  |    |    |    |             |        |       |      |
| 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   |    |                           |      |         |          | Rese    | erved |       |    |    |    |    |             | IIS_DS | PWAIT |      |
| Туре   |    | RO R/W                    |      |         |          |         |       |       |    |    |    |    |             |        |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 1 |      |         |          |         |       |       |    |    |    |    |             |        |       |      |

| Field Name  | Bit   | R/W | Reset Value | Description                           |
|-------------|-------|-----|-------------|---------------------------------------|
| IIS_DSPWAIT | [3:0] | R/W | 4'h1        | This register is used for DSP control |

#### 6.4.5.2.15 IIS\_CTL4

Description: IIS TX FIFO full/empty watermark register



| 0x0038 |    |          | TXF                           | watern              | nark (F | Reset 0 | )x0000 | _0808 | )     |         |        |   |               |    | IIS_ | CTL4 |
|--------|----|----------|-------------------------------|---------------------|---------|---------|--------|-------|-------|---------|--------|---|---------------|----|------|------|
| Bit    | 31 | 30       | 29 28 27 26 25 24 23 22 21 20 |                     |         |         |        |       |       |         |        |   | 19            | 18 | 17   | 16   |
| Name   |    |          |                               |                     |         |         |        | Rese  | erved |         |        |   |               |    |      |      |
| Туре   |    |          |                               |                     |         |         |        | R     | 0     |         |        |   |               |    |      |      |
| 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   |    | Reserved | t                             |                     | TXF_I   | EMPTY_  | THLD   |       | -     | Reserve | t      |   | TXF_FULL_THLD |    |      |      |
| Туре   |    | RO       |                               | R/W RO              |         |         |        |       |       |         | RO R/W |   |               |    |      |      |
| Reset  | 0  | 0        | 0                             | 0 0 1 0 0 0 0 0 0 0 |         |         |        |       |       |         | 0      | 1 | 0             | 0  | 0    |      |

| Field Name     | Bit    | R/W | Reset Value | Description                  |
|----------------|--------|-----|-------------|------------------------------|
| TXF_EMPTY_THLD | [12:8] | R/W | 5'h8        | TX FIFO data empty threshold |
| Reserved       | [7:5]  | R/W | 3'h0        |                              |
| TXF_FULL_THLD  | [4:0]  | R/W | 5'h8        | TX FIFO data full threshold  |

#### 6.4.5.2.16 IIS\_STS4

Description: IIS TXF FIFO write address and read address

| 0x003C |    |          | TXF               | addres                    | s (Res | et 0x0 | 000_0 | 000) |    |         |     |    |             |    | IIS_ | STS4 |
|--------|----|----------|-------------------|---------------------------|--------|--------|-------|------|----|---------|-----|----|-------------|----|------|------|
| Bit    | 31 | 30       | 29                | 28                        | 27     | 26     | 25    | 24   | 23 | 22      | 21  | 20 | 19          | 18 | 17   | 16   |
| Name   |    | Reserved |                   |                           |        |        |       |      |    |         |     |    |             |    |      |      |
| Туре   |    |          |                   |                           |        |        |       | R    | .0 |         |     |    |             |    |      |      |
| 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   | I  | Reserved | ł                 |                           | TXF    | _WR_AD | DDR   |      | F  | Reserve | d d |    | TXF_RD_ADDR |    |      |      |
| Туре   |    | RO       |                   | RO RO                     |        |        |       |      |    |         |     | RO |             |    |      |      |
| Reset  | 0  | 0        | 0 0 0 0 0 0 0 0 0 |                           |        |        |       |      |    | 0       | 0   | 0  | 0           | 0  |      |      |

| Field Name  | Bit    | R/W | Reset Value | Description           |
|-------------|--------|-----|-------------|-----------------------|
| TXF_WR_ADDR | [12:8] | RO  | 5'h0        | TX FIFO write address |
| Reserved    | [7:5]  | RO  | 3'h0        |                       |
| TXF_RD_ADDR | [4:0]  | RO  | 5'h0        | TX FIFO read address  |

#### Note

[1] in slave mode, when write data to tx fifo, the first data will read to shifter register, prepare for TX, and TXF\_RD\_ADDR will inc 1. When master request data, slave tx fifo will tx data to master.



## 6.4.6 Application Notes

#### 6.4.6.1 IIS Program examples

1. Justified format, master, 16 bits per-channel, LRCK low for left, Program control register:

```
iis_clkd = 32'0000_000a
iis_ctl0 = 32'h0000_08d1
iis_ctl1 = 32'h0000_0f11
iis_ctl2 = 32'h0000_0000
```

2. IIS format, master , 8 bits per-channel, LRCK high for left, Program control register:

```
iis_clkd = 32'0000_000a
iis_ctl0 = 32'h0000_0dc1
iis_ctl1 = 32'h0000_0f11
iis_ctl2 = 32'h0000_0000
```

3. DSP (sync) format, master, 16 bits per-channel, MSB is available on the 1<sup>st</sup> rising edge, Program control register

```
iis_clkd = 32'0000_000a
iis_ctl0 = 32'h0000_0ad1
iis_ctl1 = 32'h0000_0f11
iis_ctl2 = 32'h0000_0000
```

4. DSP format, master, 16 bits per-channel, MSB is available on the 1<sup>st</sup> rising edge, Program control register:

```
iis_clkd = 32'0000_000a
iis_ctl0 = 32'h0000_0ed1
iis_ctl1 = 32'h0000_3f11
iis_ctl2 = 32'h0000_7800
```

5. Justified mode, slave, 8 bits per-channel, enable clock counter, Program control register:

```
iis_ctl0 = 32'h0000_08c9
iis_ctl1 = 32'h0000_3f22
iis_ctl2 = 32'h0000_0000
```

#### 6.4.6.2 PCM program examples

Programming IIS\_CTL0 register bit[15] "1" enable SC6820 working in PCM mode

1. Long Frame format, master, 8 bits per-channel, RX at falling edge, TX at rising edge, Program control register:

```
iis_clkd = 32'0000_000a
iis_ctl0 = 32'h0000_80c1
iis_ctl1 = 32'h0000_0f11
iis_ctl2 = 32'h0000_0001
```

2. Short Frame format, master, 8 bits per-channel,

```
iis_clkd = 32'0000_000a
iis_ctl0 = 32'h0000_81c1
iis_ctl1 = 32'h0000_0f11
```



iis ctl2 = 32'h0000 0001

3. Multi-cycle format, master, 8 bits per-channel, pcm\_oe=1,pcm\_cyc=1, slot0 is occupied

iis\_clkd = 32'0000\_000a

iis ctl0 = 32'h0000 80c1

 $iis_ctl1 = 32'h0000_0f11$ 

 $iis_ctl2 = 32'h0000_0409$ 

4. Muti-cycle format, master, 8 bits per-channel, pcm cyc=2, slot0 and slot1 are occupied

iis\_clkd = 32'0000\_000a

iis\_ctl0 = 32'h0000\_80c1

iis\_ctl1 = 32'h0000\_0f11

 $iis_ctl2 = 32'h0000_0013$ 

5. Long frame format, slave, 16 bits per-channel, enable clock count,

 $iis_ctl0 = 32'h0000_80c9$ 

iis\_ctl1 = 32'h0000\_3f11

iis\_ctl2 = 32'h0000\_0001

6. Short frame format, slave, 16 bits per-channel, enable clock count,

iis ctl0 = 32'h0000 81cd

iis ctl1 = 32'h0000 3a1

iis\_ctl2 = 32'h0000\_0001

#### 6.5 I2C Interface

#### 6.5.1 Overview

**I2C:** Inter-Integrated Circuit

2 wire serial system is a two-wire, bi-directional serial bus that provides a simple and efficient method of data exchange between devices. It is most suitable for applications requiring occasional communication over a short distance between many devices.

The interface defines 3 transmission speeds:

I normal: 100kbps

I fast: 400kbps

I high speed:3.5Mbps

SC6820 has 4 IIC controllers, IIC0&IIC1&IIC2&IIC3.

#### 6.5.2 Features

I2C features list

- I Software programmable clock frequency
- I Software programmable acknowledge bit
- I Interrupt driven data-transfers
- I Start/Stop/Repeated Start/Acknowledge generation
- I Supports Clock Stretching/Wait state generation
- I Single Master Operation
- I 8 word buffer mode support
- I Only normal and fast modes are supported in this design



#### 6.5.3 Signal Description

The 2 wire serial interface uses a serial data line (SDA) and a serial clock line (SCL) for data transfers. All devices connected to these two signals must have open drain or open collector outputs. Both lines must be pulled-up to VCC by external resistors. The tri-state buffers for the SCL and SDA lines have to be added at a higher hierarchical level.

Connections should be made according to the following figure:



Figure 6-28 I2

**I2C PAD connection** 

## 6.5.4 Function Description



Figure 6-29 I2C system diagram

#### 6.5.4.1 System Configuration

The 2 wire serial system uses a serial data line (SDA) and a serial clock line (SCL) for data transfers. All devices connected to these two signals must have open drain or open collector outputs. The logic AND function is exercised on both lines with external pull-up resistors.

The 2 wire serial controller implemented here is a single master device; therefore it starts generating a clock as soon as it is enabled. The user should program this register to the desired value before starting any transfers.

Data is transmitted synchronously to SCL on the SDA line on a byte-by-byte basis. Each data byte is 8 bits long. There is one SCL clock pulse for each data bit with the MSB being transmitted first. There is an acknowledge bit following each transferred byte. Each bit is sampled during the high period of SCL; therefore the SDA line may be changed only during the low period of SCL and must be held stable during the high period of SCL. A transition on the SDA line while SCL is high is interpreted as a command (START or STOP command).



#### 6.5.4.2 Wire Serial Protocol

Normally, a standard communication consists of four parts:

- I START signal generation
- I Slave address transfer
- I Data transfer
- I STOP signal generation



Figure 6-30

**I2C system diagram** 

#### 1. START signal

When the bus is free/idle, that is no master device is engaging the bus (both SCL and SDA lines are high), a master can initiate a transfer by sending a START signal. A START signal is defined as a high-to-low transition of SDA while SCL is high. The START signal denotes the beginning of a new data transfer.

A repeated START is a START signal without first generating a STOP signal. The master uses this method to communicate with another slave or the same slave in a different transfer direction (e.g. writing to device to reading from device) without releasing the bus.

The controller generates a START signal when the start bit in the 2ws\_command Register is set and the read or write bits are set. Depending on the current status of the SCL line a START or Repeated START is generated.

#### 2. Slave Address Transfer

The first byte of data transferred by the master immediately after the START signal is the slave address. This is a seven-bit calling address followed by a RW bit. The RW bit signals the slave data transfer direction. No two slaves in the system can have the same address. Only the slave with an address that matches the one transmitted by the master will respond by returning an acknowledge bit by pulling the SDA low at the 9th SCL clock cycle.

The controller treats a Slave Address Transfer as any other write action. Store the slave device's address in the 2ws\_command register and set the write bit. The controller will then transfer the slave address on the bus.

#### 3. Data Transfer

Once successful slave addressing is achieved, the data transfer can proceed on a byte-by-byte basis in the direction specified by the RW bit sent by the master. Each transferred byte is followed by an acknowledge bit on the 9th SCL clock cycle. If the slave signals a No Acknowledge (NACK), the master can generate a STOP signal to



abort the data transfer or generate a repeated START signal and start a new transfer cycle.

If the master, as the receiving device, does not acknowledge the slave, the slave releases the SDA line for the master to generate a STOP or repeated START signal.

For writing data to a slave, store the data to transmit in the 2ws\_command register and set the write bit. For reading data from a slave, set the read bit. When the transfer is done, an interrupt is generated to MCU. The 2ws\_command bit 8 to bit 15 contains valid data. The user may issue a new write or read command at this time.

## 3. STOP signal

The master can terminate the communication by generating a STOP signal. A STOP signal is defined as a low-to-high transition of SDA while SCL is at logical '1'.

#### 6.5.4.3 Arbitration Procedure

Since the 2 wire serial controller supports single master configurations only, no Arbitration logic is added to the controller. Only clock synchronization is supported since slave devices can use this mechanism for clock stretching.

#### 1. Clock Synchronization

Since the logical AND function is performed on the signals, a high to low transition on SCL or SDA affect all devices connected to the bus. The SCL clock signal can be synchronized between multiple masters using this feature. Each device starts counting its SCL low period when the current master drives SCL low. Once a device's clock has gone low, it holds the SCL line low until the clock high state is reached.



Figure 6-31

Clock synchronization during the arbitration procedure

#### 2. Clock Stretching

Slave devices can use the clock synchronization mechanism to slow down the transfer bit rate. After the master has driven SCL low the slave can drive SCL low for the required period and then release it. If the slave's SCL low period is greater than the master's SCL low period, the resulting SCL bus signal low period is stretched, thus inserting wait-states.

## 6.5.5 Control Registers

#### 6.5.5.1 Memory map

ARM base address: 0x8600\_0000 IIC0



0x8600\_1000 IIC1 0x8600\_2000 IIC2 0x8600\_2000 IIC3

| Offset<br>Address | Name         | Description                                  |
|-------------------|--------------|----------------------------------------------|
| 0x0000            | 2WS_CONTROL  | 2 wire serial system control register        |
| 0x0004            | 2WS_COMMAND  | 2 wire serial system command register        |
| 0x0008            | 2WS_DIVIDOR0 | 2 wire serial system dividor register0       |
| 0x000C            | 2WS_DIVIDOR1 | 2 wire serial system dividor register1       |
| 0x0010            | 2WS_RST      | 2 wire serial system reset register          |
| 0x0014            | 2WS_CMD_BUF  | 2 wire serial system command buffer register |

## 6.5.5.2 Register Descriptions

#### 6.5.5.2.1 2WS\_CONTROL

Description: 2 wire serial system control register

| 0x0000 | •  | •       | 2ws | systen   | cont            | rol reg | ister (l | Reset    | 0x0000 | _0000                    | )                         |            | 2WS_CONTROL |                  |             |             |  |
|--------|----|---------|-----|----------|-----------------|---------|----------|----------|--------|--------------------------|---------------------------|------------|-------------|------------------|-------------|-------------|--|
| Bit    | 31 | 30      | 29  | 28       | 27              | 26      | 25       | 24       | 23     | 22                       | 21                        | 20         | 19          | 18               | 17          | 16          |  |
| Name   |    |         |     | Reserved |                 |         |          |          |        |                          |                           |            |             |                  |             |             |  |
| Туре   |    |         |     |          |                 |         |          | R        | 0      |                          |                           |            |             |                  |             |             |  |
| 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   |    | Reserve | d   | 2ws_     | 2ws_cmdbuf_wptr |         |          | s_st_cmo | lbuf   | 2ws<br>_cm<br>d_ex<br>ec | 2ws<br>_cm<br>dbuf<br>_en | 2ws<br>_en | 2ws<br>_ie  | 2ws<br>_bus<br>y | 2ws<br>_ack | 2ws<br>_int |  |
| Туре   |    | RO      |     |          | R/W             |         |          | R/W      |        |                          | R/W                       | R/W        | R/W         | RO               | RO          | RO          |  |
|        |    |         |     |          | 0 0             |         |          |          |        |                          |                           |            |             |                  |             |             |  |

| Field Name          | Bit     | Туре | Reset<br>Value | Description                                     |
|---------------------|---------|------|----------------|-------------------------------------------------|
|                     | [31:13] | RO   | 19'h0          | Reserved                                        |
| 2ws_<br>cmdbuf_wptr | [12:10] | R/W  | 3'h0           | 2ws command buffer write pointer                |
| 2ws_st_cmdbuf       | [9:7]   | R/W  | 3'h0           | The state of 2ws command buffer state machine.  |
| 2ws_cmd_exec        | [6]     | R/W  | 1'h0           | Start to exec the command in the command buffer |
| 2ws_cmdbuf_en       | [5]     | R/W  | 1'h0           | Enable the command buffer mode                  |
| 2ws_en              | [4]     | R/W  | 1'h0           | 2ws module enable                               |
| 2ws_ie              | [3]     | R/W  | 1'h0           | 2ws interrupt enable                            |
| 2ws_busy            | [2]     | RO   | 1'h0           | 2ws data line value                             |
| 2ws_ack             | [1]     | RO   | 1'h0           | 2ws received ack value                          |



| 2ws_int [0] R |
|---------------|
|---------------|

#### 6.5.5.2.2 2WS\_COMMAND

Description: 2 wire serial system command register

| 0x0004 |    |                                                 | 2ws | systen | n comi | mand r | egiste | r (Res | et 0x0 | 000_00 | 000) |                  | 2WS_COMMAND       |                   |            |             |
|--------|----|-------------------------------------------------|-----|--------|--------|--------|--------|--------|--------|--------|------|------------------|-------------------|-------------------|------------|-------------|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |     |        |        |        |        |        |        |        |      |                  |                   | 16                |            |             |
| Name   |    | Reserved                                        |     |        |        |        |        |        |        |        |      |                  |                   |                   |            |             |
| Type   |    |                                                 |     |        |        |        |        | R      | .0     |        |      |                  |                   |                   |            |             |
| 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   |    | 1 2WS 1                                         |     |        |        |        |        |        |        |        |      | cmd<br>_sto<br>p | cmd<br>_rea<br>_d | cmd<br>_writ<br>e | tx_a<br>ck | int_a<br>ck |
| Type   |    | R/W RO RO R/W R                                 |     |        |        |        |        |        |        |        | R/W  | 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           |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                      |
|------------|---------|------|----------------|--------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                         |
| 2ws_data   | [15:8]  | R/W  | 8'h0           | 2ws data received or data need to be transmitted |
| 2ws_busy   | [7]     | RO   | 1'h1           | 2ws busy in exec commands                        |
| 2ws_ack    | [6]     | RO   | 1'h0           | 2ws received ack value                           |
| cmd_start  | [5]     | R/W  | 1'h0           | 2ws start command                                |
| cmd_stop   | [4]     | R/W  | 1'h0           | 2ws stop command                                 |
| cmd_read   | [3]     | R/W  | 1'h0           | 2ws read command                                 |
| cmd_write  | [2]     | R/W  | 1'h0           | 2ws write command                                |
| tx_ack     | [1]     | R/W  | 1'h0           | 2ws transmit ack that need to be send            |
| int_ack    | [0]     | R/W  | 1'h0           | 2ws interrupt clear bit                          |

## 6.5.5.2.3 2WS\_DIVIDOR0

Description: 2 wire serial system dividor register0



| 0x0008 |    |                                                                               | 2 wir | e seria | l syste | em div | idor re | egister | 0 (Res | et 0x0 | 000_00 | 040) |   | 2WS | _DIVI | OOR0 |
|--------|----|-------------------------------------------------------------------------------|-------|---------|---------|--------|---------|---------|--------|--------|--------|------|---|-----|-------|------|
| Bit    | 31 | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17   16 |       |         |         |        |         |         |        |        |        |      |   |     |       |      |
| Name   |    | Reserved                                                                      |       |         |         |        |         |         |        |        |        |      |   |     |       |      |
| Туре   |    | 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   |    | 2ws_dividor0                                                                  |       |         |         |        |         |         |        |        |        |      |   |     |       |      |
| Туре   |    | RW                                                                            |       |         |         |        |         |         |        |        |        |      |   |     |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                             |       |         |         |        |         |         |        |        |        |      |   |     |       |      |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                               |
|--------------|---------|------|----------------|-------------------------------------------|
|              | [31:16] | RO   | 16'h0          | Reserved                                  |
| 2ws_dividor0 | [15:0]  | R/W  | 16'h0          | 2ws clock dividor [15:0], default is 0x40 |

#### 6.5.5.2.4 2WS\_DIVIDOR1

Description: 2 wire serial system dividor register1

| 0x000C |    |                                                                               | 2 wir | e seria | l syste | em div | idor re | egister | 2 wire serial system dividor register1 (Reset 0x0000_0000) 2WS_DIVIDOR1 |   |   |   |   |   |   |   |  |  |  |
|--------|----|-------------------------------------------------------------------------------|-------|---------|---------|--------|---------|---------|-------------------------------------------------------------------------|---|---|---|---|---|---|---|--|--|--|
| Bit    | 31 | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17   16 |       |         |         |        |         |         |                                                                         |   |   |   |   |   |   |   |  |  |  |
| Name   |    | Reserved                                                                      |       |         |         |        |         |         |                                                                         |   |   |   |   |   |   |   |  |  |  |
| Туре   |    | 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   |    | 2ws_dividor1                                                                  |       |         |         |        |         |         |                                                                         |   |   |   |   |   |   |   |  |  |  |
| Туре   |    | R/W                                                                           |       |         |         |        |         |         |                                                                         |   |   |   |   |   |   |   |  |  |  |
| Reset  | 0  | 0                                                                             | 0     | 0       | 0       | 0      | 0       | 0       | 0                                                                       | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                               |
|--------------|---------|------|----------------|-------------------------------------------|
|              | [31:16] | RO   | 16'h0          | Reserved                                  |
| 2ws_dividor1 | [15:0]  | R/W  | 16'h0          | 2ws clock dividor [31:16], default is 0x0 |

## Note:

Change the value of prescale register only when the w2s\_control[4] bit is cleared. Due to the structure of the I2C interface, the controller uses "4\*SCL" clock internally.

Example: PCLK = 26MHz, desired SCL = 100khz,

prescale = 26MHz/(4\*100khz) - 1 = 64 (dec) = 40 (hex)

Reset value: 0x40

#### 6.5.5.2.5 2WS\_RST

Description: 2 wire serial system reset register



| 0x0010 |                             |                                                                          | 2ws | systen | n reset | regist | er (Re | set 0x | 0000_0 | 0000) |             |   |   |    | 2WS | RST |
|--------|-----------------------------|--------------------------------------------------------------------------|-----|--------|---------|--------|--------|--------|--------|-------|-------------|---|---|----|-----|-----|
| Bit    | 31                          | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17 |     |        |         |        |        |        |        |       |             |   |   | 16 |     |     |
| Name   |                             | Reserved                                                                 |     |        |         |        |        |        |        |       |             |   |   |    |     |     |
| Туре   |                             | RO                                                                       |     |        |         |        |        |        |        |       |             |   |   |    |     |     |
| 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   |                             | Reserved                                                                 |     |        |         |        |        |        |        |       | 2ws<br>_rst |   |   |    |     |     |
| Type   |                             | RO                                                                       |     |        |         |        |        |        |        |       | R/W         |   |   |    |     |     |
| Reset  | 0                           | 0                                                                        | 0   | 0      | 0       | 0      | 0      | 0      | 0      | 0     | 0           | 0 | 0 | 0  | 0   | 0   |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                          |
|------------|--------|------|----------------|------------------------------------------------------|
|            | [31:1] | RO   | 31'h0          | Reserved                                             |
| 2ws_rst    | [0]    | R/W  | 1'h0           | Write with bit 0 set to 1 will reset the 2ws module. |

#### 6.5.5.2.6 2WS\_CMD\_BUF

Description: 2ws system command buffer register

| 0x0014 |    |                                                 | 2ws | systen | n comi | mand b | ouffer | registe | er (Res | et 0x0 | 000_0 | 000) |   | 2WS | _CMD | BUF |
|--------|----|-------------------------------------------------|-----|--------|--------|--------|--------|---------|---------|--------|-------|------|---|-----|------|-----|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |     |        |        |        |        |         |         |        |       |      |   |     |      |     |
| Name   |    | Reserved                                        |     |        |        |        |        |         |         |        |       |      |   |     |      |     |
| Туре   |    |                                                 |     |        |        |        |        | R       | 0       |        |       |      |   |     |      |     |
| 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   |    | 2ws_cmd_buf                                     |     |        |        |        |        |         |         |        |       |      |   |     |      |     |
| Туре   |    | R/W                                             |     |        |        |        |        |         |         |        |       |      |   |     |      |     |
| Reset  | 0  | 0                                               | 0   | 0      | 0      | 0      | 0      | 0       | 0       | 0      | 0     | 0    | 0 | 0   | 0    | 0   |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                         |
|-------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | [31:16] | RO   | 31'h0          | Reserved                                                                                                                                                                                                                                                                            |
| 2ws_cmd_buf | [15:0]  | R/W  | 16'h0          | Write command to this register will save the command to the command buffer. Read from this register after the commands are all finished will return the results of the corresponding commands. The format of the command and the return result is the same as i2c_command register. |

## 6.5.6 Application Notes

List all data formats. Detail the programming flow for the module.

Standard mode; a single master operation; a master-transmitter addressing a slave receiver with a 7-bit address; single common mode



w2s rst

= 0x0000:

//

```
= 0x0040;
                              //
w2s_dividor0
w2s dividor1
              = 0x0000:
w2s control
                  = 0x0018;
                                  // 2ws en = 1; 2ws ie = 1
w2s command = 0x9C25;
                              // 1001110
                                                 0010 0101
                                                  W lack
                      //ADDRESS W
                                           S
w2s_command = 0xFE05;
                              // 11111110
                                           0000 0101
                         DATA
w2s_command = 0xFE15;
                              // 11111110
                                           0001 0101
                      // DATA
    Fast mode; a single master operation; combined format; 7-bit address; common
    buffer mode: a burst of 8 commands is written to the buffer
w2s rst
              = 0x0000:
w2s dividor0
             = 0x0040;
                              //
w2s_dividor1
             = 0x0000:
                                  // 2ws cmdbuf en=1; 2ws en=1; 2ws ie=1
w2s control
                  = 0x0038:
                              // 1001110
                                                 0010 0101
w2s_command = 0x9C25;
                                             0
                      // ADDRESS W
                                                  W lack
                              //
w2s_command = 0x2005;
w2s_command = 0x9D15;
                              //
                              //
w2s command = 0x001B;
w2s_command = 0x9C25;
                              //
w2s_command = 0x2005;
                              //
                              //
w2s command = 0x9D15;
w2s\_command = 0x001B;
                              11
                              //
w2s command = 0x9C25;
w2s_command = 0x2005;
w2s command = 0x9D15;
                              //
w2s command = 0x001B;
w2s command = 0x9C25;
                              //
                              //
w2s_command = 0x2005;
w2s command = 0x9D15;
                              //
w2s command = 0x001B;
                              //
```

# 6.6 Keypad Interface

#### 6.6.1 Overview

Here Keypad means "keypad controller" which is one APB device in ARM system. The keypad controller scans the external "key matrix" whose maximum size is 8 rows x 8 columns. It scans the "key matrix" row by row and checks the keys of the row one by one. There are at most four keys "pressed". "released" status can be detected in the same time, which is the so called "multi-key detection". On the other hand, one pressed key can generate multi interrupts periodically to software and this mode is named the "long key" mode.

For the reason that the external "key matrix" is pure mechanical, if the geometric shape constituted by any three "pressed keys" is a "right-angled triangle ", the keypad controller will detect another "inductive pressed" key. For example, if key 1 (x1, y1),



key 2 (x2, y2), key 3 (x1, y2) are pressed then the key 4 (x2, y1) will also be detected as the "pressed" key. The keypad controller will check the geometric shape constituted by the three "pressed keys" and if above condition is detected one "error" status will be reported to software, which should discard current error multi-keys combination.

Finally, low power of the keypad controller is very important. If the controller finds that none key is pressed in the specific time, the clock of most logic inside the controller will be disabled to save power and controller goes into the sleep mode. In the sleep mode controller will be sensitive to any change of the "key matrix". In other words, any key's press or release will wakes up the controller to scan the "key matrix".

#### 6.6.2 Features

- I Support maximum 8 row x 8 column key matrix and size is programmable
- I Support at most four keys detection under "multi-key" mode
- I Support "long key" or "single key" mode for any pressed key
- I Support "right-angled triangle" geometric shape detection for the pressed keys
- I Support sleep mode to save power
- I Support programmable "de-bounce" time for key's press and release
- I Support programmable I/O polarity
- I Support programmable scan speed

## 6.6.3 Signal Description



Figure 6-32 Keypad connection with external key matrix

The above diagram shows how to interface the keypad controller and the key matrix with pad internal pull-up resistance when the key matrix is 8 rows x 8 columns. For key matrix, the input is keyout 0 ~ keyout 7 and the output is the keyin 0 ~ keyin 7. Every keyout signal can be enabled or disabled. The keyout signal will be forced to be "low level" when it is enabled and only one keyout should be enabled at any time during scanning.





Figure 6-33 Single-key mode



Figure 6-34 Long-key mode





Figure 6-35 Multi-key mode

## 6.6.4 Function Description



Figure 6-36 Keypad controller diagram

## 6.6.5 Control Registers

#### 6.6.5.1 Memory map

Physical base address: 0x8700\_0000

| Offset<br>Address | Name                | Description                                    |
|-------------------|---------------------|------------------------------------------------|
| 0x0000            | KPD_CTRL            | Keypad global control register                 |
| 0x0004            | KPD_INT_EN          | Keypad INT enable register                     |
| 0x0008            | KPD_INT_RAW_STATUS  | Keypad INT raw status register                 |
| 0x000C            | KPD_INT_MASK_STATUS | Keypad INT status register                     |
| 0x0010            | KPD_INT_CLR         | Keypad INT clear register                      |
| 0x0014            |                     | Reserved                                       |
| 0x0018            | KPD_POLARITY        | Keypad I/O polarity control register           |
| 0x001C            | KPD_DEBOUNCE_CNT    | Keypad de-bouncing time configuration register |
| 0x0020            | KPD_LONG_KEY_CNT    | Keypad long-key time configuration register    |



| Offset<br>Address | Name               | Description                                     |
|-------------------|--------------------|-------------------------------------------------|
| 0x0024            | KPD_SLEEP_CNT      | Keypad sleep wait time configuration register   |
| 0x0028            | KPD_CLK_DIVIDE_CNT | Keypad scan clock division coefficient register |
| 0x002C            | KPD_ KEY_STATUS    | Keypad key status register                      |
| 0x0030            | KPD_SLEEP_STATUS   | Keypad sleep status register                    |
| 0x0034            | KPD_DEBUG_STATUS1  | Keypad debug status register1                   |
| 0x0038            | KPD_DEBUG_STATUS2  | Keypad debug status register2                   |

## 6.6.5.2 Register Descriptions

## 6.6.5.2.1 KPD\_CTRL

| 0x0000 |    |         | Keyp | ad co                     | ntrol re | egister | ,  |                             |                             |                             | 1                           | $\overline{}$               |                                 |                                 | KPD_0         | CTRL                            |
|--------|----|---------|------|---------------------------|----------|---------|----|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|---------------------------------|---------------------------------|---------------|---------------------------------|
| Bit    | 31 | 30      | 29   | 28                        | 27       | 26      | 25 | 24                          | 23                          | 22                          | 21                          | 20                          | 19                              | 18                              | 17            | 16                              |
| Name   |    | Reerved |      |                           |          |         |    | KP<br>D_<br>CO<br>L7_<br>EN | KP<br>D_<br>CO<br>L6_<br>EN | KP<br>D_<br>CO<br>L5_<br>EN | KP<br>D_<br>CO<br>L4_<br>EN | KP<br>D_<br>CO<br>L3_<br>EN | KP<br>D_<br>RO<br>W7<br>_E<br>N | KP<br>D_<br>RO<br>W6<br>_E<br>N | KP D_RO W5 _R | KP<br>D_<br>RO<br>W4<br>_E<br>N |
| Туре   |    |         |      | RO                        |          |         |    | 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                           | 0                           | 0                               | 0                               | 0             | 0                               |
| Bit    | 15 | 14      | 13   | 13 12 11 10 9 8 7 6 5 4 3 |          |         |    |                             |                             | 3                           | 2                           | 1                           | 0                               |                                 |               |                                 |
| Name   |    |         |      | Reserved                  |          |         |    |                             |                             |                             |                             | KP D O G K Y E N            | R D'L E P'R                     | KP<br>D_<br>EN                  |               |                                 |
|        |    |         | RO   |                           |          |         |    |                             |                             |                             | R/W                         | R/W                         | R/W                             |                                 |               |                                 |
| Type   |    |         |      |                           |          |         | KU |                             |                             |                             |                             |                             |                                 | 10 11                           | IX/VV         | IK/VV                           |

| Field Name  | Bit     | R/W | Reset Value | Description             |
|-------------|---------|-----|-------------|-------------------------|
|             | [31:25] | R   | 0           | Reserved                |
| KPD_COL7_EN | [24]    | R/W | 0           | Enable bit for column 7 |
| KPD_COL6_EN | [23]    | R/W | 0           | Enable bit for column 6 |
| KPD_COL5_EN | [22]    | R/W | 0           | Enable bit for column 5 |
| KPD_COL4_EN | [21]    | R/W | 0           | Enable bit for column 4 |



| KPD_COL3_EN     | [20]   | R/W | 0 | Enable bit for column 3                                                                                                                                 |
|-----------------|--------|-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| KPD_ROW7_EN     | [19]   | R/W | 0 | Enable bit for row 7                                                                                                                                    |
| KPD_ROW6_EN     | [18]   | R/W | 0 | Enable bit for row 6                                                                                                                                    |
| KPD_ROW5_EN     | [17]   | R/W | 0 | Enable bit for row 5                                                                                                                                    |
| KPD_ROW4_EN     | [16]   | R/W | 0 | Enable bit for row 4                                                                                                                                    |
|                 | [15:3] | R   | 0 | Reserved                                                                                                                                                |
| KPD_LONG_KEY_EN | [2]    | R/W | 0 | When set to 1, keypad can enter long key mode if a key is pressed for a long time                                                                       |
| KPD_SLEEP_EN    | [1]    | R/W | 0 | When set to 1, the keypad can enter sleep mode if there is no key press for a certain time. The scan will stop until there has a press pulse.           |
| KPD_EN          | [0]    | R/W | 0 | Keypad global enable signal. Set to1 will make whole keypad work by generate the clk_en signal to do scan and other process. Notice: port signal kpd_eb |
|                 |        |     |   | directly generates RTCLK clock gating.                                                                                                                  |

# 6.6.5.2.2 KPD\_INT\_EN

| 0x0004 |    |    | Keyp | ad int | errupt | enable                                                   | 9                                                        |                                                    |                                                |                                                   |                                                   |                                            |                                  | K                                                 | PD_IN                                             | T_EN                    |
|--------|----|----|------|--------|--------|----------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------|------------------------------------------------|---------------------------------------------------|---------------------------------------------------|--------------------------------------------|----------------------------------|---------------------------------------------------|---------------------------------------------------|-------------------------|
| Bit    | 31 | 30 | 29   | 28     | 27     | 26                                                       | 25                                                       | 24                                                 | 23                                             | 22                                                | 21                                                | 20                                         | 19                               | 18                                                | 17                                                | 16                      |
| Name   |    |    |      |        |        |                                                          |                                                          | Rese                                               | erved                                          |                                                   |                                                   |                                            |                                  |                                                   |                                                   |                         |
| Туре   |    |    |      |        |        |                                                          |                                                          | R                                                  | .0                                             |                                                   |                                                   |                                            |                                  |                                                   |                                                   |                         |
| 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   |    |    |      |        | KP D4  | KP<br>D3<br>_L<br>ON<br>G_<br>KE<br>Y_I<br>NT<br>_E<br>N | KP<br>D2<br>_L<br>ON<br>G_<br>KE<br>Y_I<br>NT<br>_E<br>N | KP<br>D1 _L<br>ON<br>G_<br>KE<br>Y_I<br>NT _E<br>N | KP<br>D4<br>_R<br>EL<br>EA<br>_ INT<br>_E<br>N | KP<br>D3<br>_R<br>EL<br>EA<br>_<br>INT<br>_E<br>N | KP<br>D2<br>_R<br>EL<br>EA<br>_<br>INT<br>_E<br>N | KP<br>D1<br>_R<br>EL<br>EA<br>_ INT<br>_ N | KP<br>D4<br>PRE<br>SS<br>NT<br>N | KP<br>D3<br>_P<br>RE<br>SS<br>_<br>INT<br>_E<br>N | KP<br>D2<br>_P<br>RE<br>SS<br>_<br>INT<br>_E<br>N | KP D1 P, EE SS   ET E Z |
| Туре   |    | R  | RO.  |        | R/W    | 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                                                 | 0                                          | 0                                | 0                                                 | 0                                                 | 0                       |



| Field Name               | Bit     | R/W | Reset Value | Description                               |
|--------------------------|---------|-----|-------------|-------------------------------------------|
|                          | [31:12] | R   | 0           | Reserved                                  |
| KPD4_LONG_<br>KEY_INT_EN | [11]    | R/W | 0           | Keypad long-key interrupt enable for No.4 |
| KPD3_LONG_<br>KEY_INT_EN | [10]    | R/W | 0           | Keypad long-key interrupt enable for No.3 |
| KPD2_LONG_<br>KEY_INT_EN | [9]     | R/W | 0           | Keypad long-key interrupt enable for No.2 |
| KPD1_LONG_<br>KEY_INT_EN | [8]     | R/W | 0           | Keypad long-key interrupt enable for No.1 |
| KPD4_RELEA_<br>INT_EN    | [7]     | R/W | 0           | Keypad release interrupt enable for No.4  |
| KPD3_RELEA_<br>INT_EN    | [6]     | R/W | 0           | Keypad release interrupt enable for No.3  |
| KPD2_RELEA_<br>INT_EN    | [5]     | R/W | 0           | Keypad release interrupt enable for No.2  |
| KPD1_RELEA_<br>INT_EN    | [4]     | R/W | 0           | Keypad release interrupt enable for No.1  |
| KPD4_PRESS_<br>INT_EN    | [3]     | R/W | 0           | Keypad press interrupt enable for No.4    |
| KPD3_PRESS_<br>INT_EN    | [2]     | R/W | 0           | Keypad press interrupt enable for No.3    |
| KPD2_PRESS_<br>INT_EN    | [1]     | R/W | 0           | Keypad press interrupt enable for No.2    |
| KPD1_PRESS_<br>INT_EN    | [0]     | R/W | 0           | Keypad press interrupt enable for No.1    |

6.6.5.2.3 KPD\_INT\_RAW\_STATUS



| 0x0008 |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Keypad interrupt raw status |    |         |                                               |                                               |                                |                                        |                                        |                                        | KPD_INT_RAW_STAT<br>US                 |                  |                                        |                           |                                    |
|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|----|---------|-----------------------------------------------|-----------------------------------------------|--------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|------------------|----------------------------------------|---------------------------|------------------------------------|
| Bit    | 31 | 30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 29                          | 28 | 27      | 26                                            | 25                                            | 24                             | 23                                     | 22                                     | 21                                     | 20                                     | 19               | 18                                     | 17                        | 16                                 |
| Name   |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |    |         |                                               |                                               | Rese                           | erved                                  |                                        |                                        |                                        |                  |                                        |                           |                                    |
| Туре   |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |    |         |                                               |                                               | R                              | 0                                      |                                        |                                        |                                        |                  |                                        |                           |                                    |
| 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   |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |    | KP D4 - | KP<br>D3<br>_L<br>ON<br>G_<br>KE<br>Y_I<br>NT | KP<br>D2<br>_L<br>ON<br>G_<br>KE<br>Y_I<br>NT | KP<br>D1<br>_CN<br>G KE<br>Y_T | KP<br>D4<br>_R<br>EL<br>EA<br>_<br>INT | KP<br>D3<br>_R<br>EL<br>EA<br>_<br>INT | KP<br>D2<br>_R<br>EL<br>EA<br>_<br>INT | KP<br>D1<br>_R<br>EL<br>EA<br>_<br>INT | KP D4 P RESS   Z | KP<br>D3<br>_P<br>RE<br>SS<br>_<br>INT | KP<br>D2<br>P<br>RE<br>SS | KP<br>D1<br>P<br>RE<br>SS<br>- INT |
| Туре   |    | RO         R/W         R/W |                             |    |         |                                               |                                               |                                | R/W                                    |                                        |                                        |                                        |                  |                                        |                           |                                    |
| Reset  | 0  | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0                           | 0  | 0       | 0                                             | 0                                             | 0                              | 0                                      | 0                                      | 0                                      | 0                                      | 0                | 0                                      | 0                         | 0                                  |

| Field Name            | Bit     | R/W | Reset Value | Description                        |
|-----------------------|---------|-----|-------------|------------------------------------|
|                       | [31:12] | R   | 0           | Reserved                           |
| KPD4_LONG_<br>KEY_INT | [11]    | R/W | 0           | Keypad long-key interrupt for No.4 |
| KPD3_LONG_<br>KEY_INT | [10]    | R/W | 0           | Keypad long-key interrupt for No.3 |
| KPD2_LONG_<br>KEY_INT | [9]     | R/W | 0           | Keypad long-key interrupt for No.2 |
| KPD1_LONG_<br>KEY_INT | [8]     | R/W | 0           | Keypad long-key interrupt for No.1 |
| KPD4_RELEA_<br>INT    | [7]     | R/W | 0           | Keypad release interrupt for No.4  |
| KPD3_RELEA_<br>INT    | [6]     | R/W | 0           | Keypad release interrupt for No.3  |
| KPD2_RELEA_<br>INT    | [5]     | R/W | 0           | Keypad release interrupt for No.2  |
| KPD1_RELEA_<br>INT_EN | [4]     | R/W | 0           | Keypad release interrupt for No.1  |
| KPD4_PRESS_<br>INT    | [3]     | R/W | 0           | Keypad press interrupt for No.4    |



| KPD3_PRESS_<br>INT | [2] | R/W | 0 | Keypad press interrupt for No.3 |
|--------------------|-----|-----|---|---------------------------------|
| KPD2_PRESS_<br>INT | [1] | R/W | 0 | Keypad press interrupt for No.2 |
| KPD1_PRESS_<br>INT | [0] | R/W | 0 | Keypad press interrupt for No.1 |

#### 6.6.5.2.4 KPD\_INT\_MASK\_STATUS

| 0x000C |    | Keypad interrupt mask |    |    |                             |                                                          |                                                          |                           |                             | KPD_INT_MASK_STA<br>TUS                             |                                                     |                                                     |                                                   |                                                     |                                                    |                                                     |
|--------|----|-----------------------|----|----|-----------------------------|----------------------------------------------------------|----------------------------------------------------------|---------------------------|-----------------------------|-----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|---------------------------------------------------|-----------------------------------------------------|----------------------------------------------------|-----------------------------------------------------|
| Bit    | 31 | 30                    | 29 | 28 | 27                          | 26                                                       | 25                                                       | 24                        | 23                          | 22                                                  | 21                                                  | 20                                                  | 19                                                | 18                                                  | 17                                                 | 16                                                  |
| Name   |    | Reserved              |    |    |                             |                                                          |                                                          |                           |                             |                                                     |                                                     |                                                     |                                                   |                                                     |                                                    |                                                     |
| Туре   |    |                       |    |    |                             |                                                          |                                                          | R                         | :O                          |                                                     |                                                     |                                                     |                                                   |                                                     |                                                    |                                                     |
| 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   |    |                       |    |    | KP D4 M AS K_LO NG - KE Y_T | KP<br>D3<br>_M<br>AS<br>K_<br>LO<br>NG<br>-<br>KE<br>Y_I | KP<br>D2<br>_M<br>AS<br>K_<br>LO<br>NG<br>-<br>KE<br>Y_I | KP D1 M AS K_LO NG KE Y_I | KP D4 _M AS K_ RE LE A_ INT | KP<br>D3<br>_M<br>AS<br>K_<br>RE<br>LE<br>A_<br>INT | KP<br>D2<br>_M<br>AS<br>K_<br>RE<br>LE<br>A_<br>INT | KP<br>D1<br>_M<br>AS<br>K_<br>RE<br>LE<br>A_<br>INT | KP<br>D4<br>M<br>AS<br>K_<br>PR<br>ES<br>S_<br>IN | KP<br>D3<br>_M<br>AS<br>K_<br>PR<br>ES<br>S_<br>INT | KP<br>D2<br>M<br>AS<br>K_<br>PR<br>ES<br>S_<br>INT | KP<br>D1<br>_M<br>AS<br>K_<br>PR<br>ES<br>S_<br>INT |
| Туре   |    | R                     | 0  |    | R/W                         | 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                                                   | 0                                                   | 0                                                 | 0                                                   | 0                                                  | 0                                                   |

| Field Name                 | Bit     | R/W | Reset<br>Value | Description                                                         |
|----------------------------|---------|-----|----------------|---------------------------------------------------------------------|
|                            | [31:12] | R   | 0              | Reserved                                                            |
| KPD4_MASK_LONG_<br>KEY_INT | [11]    | R/W | 0              | No.4 keypad long-key interrupt masked by long-key interrupt enable. |
| KPD3_MASK_LONG_<br>KEY_INT | [10]    | R/W | 0              | No.3 keypad long-key interrupt masked by long-key interrupt enable. |
| KPD2_MASK_LONG_<br>KEY_INT | [9]     | R/W | 0              | No.2 keypad long-key interrupt masked by long-key interrupt enable. |
| KPD1_MASK_LONG_            | [8]     | R/W | 0              | No.1 keypad long-key                                                |



| KEY_INT                    |     |     |   | interrupt masked by long-key interrupt enable.                    |
|----------------------------|-----|-----|---|-------------------------------------------------------------------|
| KPD4_MASK_RELEA_<br>INT    | [7] | R/W | 0 | No.4 keypad release interrupt masked by release interrupt enable. |
| KPD3_MASK_RELEA_<br>INT    | [6] | R/W | 0 | No.3 keypad release interrupt masked by release interrupt enable. |
| KPD2_MASK_RELEA_<br>INT    | [5] | R/W | 0 | No.2 keypad release interrupt masked by release interrupt enable. |
| KPD1_MASK_RELEA_<br>INT_EN | [4] | R/W | 0 | No.1 keypad release interrupt masked by release interrupt enable. |
| KPD4_MASK_PRESS_<br>INT    | [3] | R/W | 0 | No.4 keypad press interrupt masked by press interrupt enable.     |
| KPD3_MASK_PRESS_<br>INT    | [2] | R/W | 0 | No.3 keypad press interrupt masked by press interrupt enable.     |
| KPD2_MASK_PRESS_<br>INT    | [1] | R/W | 0 | No.2 keypad press interrupt masked by press interrupt enable.     |
| KPD1_MASK_PRESS_<br>INT    | [0] | R/W | 0 | No.1 keypad press interrupt masked by press interrupt enable.     |

6.6.5.2.5 KPD\_INT\_CLR



| 0x0010 |    |          | Keypad interrupt clear KPD_INT_CLR |    |                           |                                                      |                                                      |                           |                                                    |                                                    |                                                 |                                                    |                                                    |                                                    |                            |                                                    |
|--------|----|----------|------------------------------------|----|---------------------------|------------------------------------------------------|------------------------------------------------------|---------------------------|----------------------------------------------------|----------------------------------------------------|-------------------------------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------|----------------------------------------------------|
| Bit    | 31 | 30       | 29                                 | 28 | 27                        | 26                                                   | 25                                                   | 24                        | 23                                                 | 22                                                 | 21                                              | 20                                                 | 19                                                 | 18                                                 | 17                         | 16                                                 |
| Name   |    | Reserved |                                    |    |                           |                                                      |                                                      |                           |                                                    |                                                    |                                                 |                                                    |                                                    |                                                    |                            |                                                    |
| Туре   |    |          |                                    |    |                           |                                                      |                                                      | R                         | .0                                                 |                                                    |                                                 |                                                    |                                                    |                                                    |                            |                                                    |
| 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   |    |          |                                    |    | KP D4 L ON G KE Y NT C LR | KP<br>D3<br>_L<br>ON<br>G_<br>KE<br>Y_I<br>NT<br>_LR | KP<br>D2<br>L<br>ON<br>G<br>KE<br>Y<br>I<br>NT<br>LR | KP D1 L ON G KE Y IT C LR | KP<br>D4<br>_R<br>EL<br>EA<br>_<br>INT<br>_C<br>LR | KP<br>D3<br>_R<br>EL<br>EA<br>-<br>INT<br>_C<br>LR | KP<br>D2<br>_R<br>EL<br>EA<br>_<br>INT _C<br>LR | KP<br>D1<br>_R<br>EL<br>EA<br>-<br>INT<br>_C<br>LR | KP<br>D4<br>_P<br>RE<br>SS<br>_<br>INT<br>_C<br>LR | KP<br>D3<br>_P<br>RE<br>SS<br>_<br>INT<br>_C<br>LR | KP D2 _P RE SS - INT _C LR | KP<br>D1<br>_P<br>RE<br>SS<br>_<br>INT<br>_C<br>LR |
| Type   |    | R        | .0                                 |    | R/W                       | 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                                               | 0                                                  | 0                                                  | 0                                                  | 0                          | 0                                                  |

| Field Name                | Bit     | R/W | Reset Value | Description                                                                |
|---------------------------|---------|-----|-------------|----------------------------------------------------------------------------|
|                           | [31:12] | R   | 0           | Reserved                                                                   |
| KPD4_LONG_<br>KEY_INT_CLR | [11]    | R/W | 0           | Write 1 to this bit will clear the No.4 key long-key interrupt raw status. |
| KPD3_LONG_<br>KEY_INT_CLR | [10]    | R/W | 0           | Write 1 to this bit will clear the No.3 key long-key interrupt raw status. |
| KPD2_LONG_<br>KEY_INT_CLR | [9]     | R/W | 0           | Write 1 to this bit will clear the No.2 key long-key interrupt raw status. |
| KPD1_LONG_<br>KEY_INT_CLR | [8]     | R/W | 0           | Write 1 to this bit will clear the No.1 key long-key interrupt raw status. |
| KPD4_RELEA_<br>INT_CLR    | [7]     | R/W | 0           | Write 1 to this bit will clear the No.4 key release interrupt raw status.  |
| KPD3_RELEA_<br>INT_CLR    | [6]     | R/W | 0           | Write 1 to this bit will clear the No.3 key release interrupt raw status.  |
| KPD2_RELEA_<br>INT_CLR    | [5]     | R/W | 0           | Write 1 to this bit will clear the No.2 key release interrupt raw status.  |
| KPD1_RELEA_               | [4]     | R/W | 0           | Write 1 to this bit will clear the No.1 key release interrupt raw          |



| INT_CLR                |     |     |   | status.                                                                 |
|------------------------|-----|-----|---|-------------------------------------------------------------------------|
| KPD4_PRESS_<br>INT_CLR | [3] | R/W | 0 | Write 1 to this bit will clear the No.4 key press interrupt raw status. |
| KPD3_PRESS_<br>INT_CLR | [2] | R/W | 0 | Write 1 to this bit will clear the No.3 key press interrupt raw status. |
| KPD2_PRESS_<br>INT_CLR | [1] | R/W | 0 | Write 1 to this bit will clear the No.2 key press interrupt raw status. |
| KPD1_PRESS_<br>INT_CLR | [0] | R/W | 0 | Write 1 to this bit will clear the No.1 key press interrupt raw status. |

## 6.6.5.2.6 KPD\_POLARITY

| 0x0018 |    |          | Regi  | ster de | script | ion (Re | eset va | alue) |    |    |      |      |       | KPD_I | POLAF | RITY |
|--------|----|----------|-------|---------|--------|---------|---------|-------|----|----|------|------|-------|-------|-------|------|
| Bit    | 31 | 30       | 29    | 28      | 27     | 26      | 25      | 24    | 23 | 22 | 21   | 20   | 19    | 18    | 17    | 16   |
| Name   |    | Reserved |       |         |        |         |         |       |    |    |      |      |       |       |       |      |
| Туре   |    |          |       |         |        |         |         | R     | 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   |    | ŀ        | KPD_C | OLUM    | N_POI  | LARIT   |         |       |    |    | KPD_ | _ROW | _POLA | RITY  |       |      |
| Type   |    |          |       |         |        |         |         |       |    |    |      |      |       |       |       |      |
| Reset  | 1  | 1        | 1     | 1       | 1      | 1       | 1       | 1     | 1  | 1  | 1    | 1    | 1     | 1     | 1     | 1    |

| Field Name              | Bit     | R/W | Reset Value | Description                                                                                                                         |
|-------------------------|---------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
|                         | [31:16] | R   | 0           | Reserved                                                                                                                            |
| KPD_COLUMN_<br>POLARITY | [15:8]  | R/W | 8'hFF       | Column input xor with this value to generate the internal column input. This register is used to control the column input polarity. |
| KPD_ROW_<br>POLARITY    | [7:0]   | R/W | 8'hFF       | Internal row output xor with this value to generate row output. This register is used to control the row output polarity.           |

## 6.6.5.2.7 KPD\_DEBOUNCE\_CNT



| 0x001C |    |     | Key press and release de-bounce time control register  KPD_DEBOUNCE_CN T |                                       |    |    |      |      |       |      |   |   |   | E_CN<br>T |   |   |
|--------|----|-----|--------------------------------------------------------------------------|---------------------------------------|----|----|------|------|-------|------|---|---|---|-----------|---|---|
| Bit    | 31 | 30  | 29                                                                       | 9 28 27 26 25 24 23 22 21 20 19 18 17 |    |    |      |      |       |      |   |   |   | 16        |   |   |
| Name   |    |     |                                                                          |                                       |    |    |      | Rese | erved |      |   |   |   |           |   |   |
| Туре   |    |     |                                                                          |                                       |    |    |      | R    | .0    |      |   |   |   |           |   |   |
| 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   |    |     |                                                                          |                                       |    |    | KPD_ | DEBO | UNCE  | _CNT |   |   |   |           |   |   |
| Туре   |    | R/W |                                                                          |                                       |    |    |      |      |       |      |   |   |   |           |   |   |
| Reset  | 0  | 0   | 0                                                                        | 0                                     | 0  | 0  | 0    | 0    | 1     | 0    | 0 | 0 | 0 | 0         | 0 | 0 |

| Field Name       | Bit     | R/W | Reset<br>Value | Description                                                                  |
|------------------|---------|-----|----------------|------------------------------------------------------------------------------|
|                  | [31:16] | RO  | 0              | Reserved                                                                     |
| KPD_DEBOUNCE_CNT | [15:0]  | R/W | 16'h0080       | Counter for de-bounce time                                                   |
|                  |         |     |                | It is the function of scan array size and clock divider number.              |
|                  |         |     |                | Default value: 165ms when clk_divider is 0 and 42 keys are enable(7*6 array) |
|                  |         |     |                | The calculation method is:                                                   |
|                  |         |     |                | y(ms)= (x +1) * array_size<br>/(32.768/(clk_div_nu<br>m+1))                  |

# 6.6.5.2.8 KPD\_LONG\_KEY\_CNT

| 0x0020 |    |                               | Long | Long key time control register  KPD_LONG_KEY_CN T |    |    |      |      |       |      |    |    |    |    |    |    |
|--------|----|-------------------------------|------|---------------------------------------------------|----|----|------|------|-------|------|----|----|----|----|----|----|
| Bit    | 31 | 30                            | 29   | 28                                                | 27 | 26 | 25   | 24   | 23    | 22   | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |    |                               |      |                                                   |    |    |      | Rese | erved |      |    |    |    |    |    |    |
| Туре   |    |                               |      |                                                   |    |    |      | R    | 0     |      |    |    |    |    |    |    |
| 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   |    |                               |      |                                                   |    |    | KPD_ | LONG | _KEY_ | _CNT |    |    |    |    |    |    |
| Туре   |    | RW                            |      |                                                   |    |    |      |      |       |      |    |    |    |    |    |    |
| Reset  | 0  | 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 |      |                                                   |    |    |      |      |       |      |    |    |    |    |    |    |

| Field Name | Bit     | R/W | Reset<br>Value | Description |
|------------|---------|-----|----------------|-------------|
|            | [31:16] | RO  | 0              | Reserved    |



| KPD_LONG_KEY_CNT | [15:0] | R/W | 16'h0400 | Counter for long key time                                                    |
|------------------|--------|-----|----------|------------------------------------------------------------------------------|
|                  |        |     |          | It is the function of scan array size and clock divider number.              |
|                  |        |     |          | Default value: 1.34s when clk_divider is 0 and 42 keys are enable(7*6 array) |
|                  |        |     |          | The calculation method is:                                                   |
|                  |        |     |          | y(ms)= (x +1) * array_size<br>/(32.768/(clk_div_nu<br>m+1))                  |

## 6.6.5.2.9 KPD\_SLEEP\_CNT

| 0x0024 |    |                                  | Coun | ter for | enter s | sleep m | node ei | nable(f | rom no | key pı | ress)    |      | к     | PD_SI | EEP_ | CNT |
|--------|----|----------------------------------|------|---------|---------|---------|---------|---------|--------|--------|----------|------|-------|-------|------|-----|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 |      |         |         |         |         |         |        |        |          | 20   | 19    | 18    | 17   | 16  |
| Name   |    |                                  |      | ı       | Reserve | d d     |         |         |        |        | <b>T</b> | KPD_ | SLEEP | _CNT  |      |     |
| Туре   |    |                                  |      |         | RO      |         |         |         |        |        |          |      | R/W   |       |      |     |
| Reset  | 0  | 0                                | 0    | 0       | 0       | 0       | 0       | 0       | 0      | 0      | 0        | 0    | 1     | 0     | 0    | 0   |
| Bit    | 15 | 14                               | 13   | 12      | 11      | 10      | 9       | 8       | 7      | 6      | 5        | 4    | 3     | 2     | 1    | 0   |
| Name   |    |                                  |      |         |         |         | ŀ       | KPD_SLE | EP_CN  | Т      |          |      |       |       |      |     |
| Туре   |    | RW                               |      |         |         |         |         |         |        |        |          |      |       |       |      |     |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0    |      |         |         |         |         |         |        |        | 0        |      |       |       |      |     |

| Field Name    | Bit     | R/W | Reset Value | Description                                                           |
|---------------|---------|-----|-------------|-----------------------------------------------------------------------|
|               | [31:23] | R   | 0           | Reserved                                                              |
| KPD_SLEEP_CNT | [22:0]  | R/W | 23'h080000  | Counter for enter sleep mode enable(from no key press)                |
|               |         |     |             | It is not the function of scan<br>number and clock divider<br>number. |
| 0.0           |         |     |             | Default value:16.384s<br>Y(ms)=(x+1)/32.768                           |

# 6.6.5.2.10 KPD\_CLK\_DIVIDE\_CNT



| 0x0028 |    |    | Keyp                        | ad sca | n clock | divide | r coeff | icients | configu | uration | registe | er. | KPD_CLK_DIVIDE_C<br>NT |    |    |    |
|--------|----|----|-----------------------------|--------|---------|--------|---------|---------|---------|---------|---------|-----|------------------------|----|----|----|
| Bit    | 31 | 30 | 29                          | 28     | 27      | 26     | 25      | 24      | 23      | 22      | 21      | 20  | 19                     | 18 | 17 | 16 |
| Name   |    |    |                             |        |         |        |         | Rese    | erved   |         |         |     |                        |    |    |    |
| Туре   |    |    |                             |        |         |        |         | R       | 0       |         |         |     |                        |    |    |    |
| 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   |    |    | Reserved KPD_CLK_DIVIDE_CNT |        |         |        |         |         |         |         |         |     |                        |    |    |    |
| Туре   |    |    | RO R/W                      |        |         |        |         |         |         |         |         |     |                        |    |    |    |
| Reset  | 0  | 0  | 0                           | 0      | 0       | 0      | 0       | 0       | 0       | 0       | 0       | 0   | 0                      | 0  | 0  | 0  |

| Field Name         | Bit    | R/W | Reset<br>Value | Description                                                                                                                                              |
|--------------------|--------|-----|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | [31:8] | R   | 0              | Reserved                                                                                                                                                 |
| KPD_CLK_DIVIDE_CNT | [7:0]  | R/W | 0              | Clk_divider[7:0], divide<br>RTCLK (32.768 kHz) used for<br>keypad. Can slow down<br>keypad's work speed.<br>The RTCLK will be divided<br>(cnt + 1) times |

# 6.6.5.2.11 KPD\_KEY\_STATUS

| 0x002C |                                  |     | Keyp       | ad key | s statu          | s regist | ter.       |     |                                  |                  |            |      | KP                    | D_KEY | _STA       | TUS |
|--------|----------------------------------|-----|------------|--------|------------------|----------|------------|-----|----------------------------------|------------------|------------|------|-----------------------|-------|------------|-----|
| Bit    | 31                               | 30  | 29         | 28     | 27               | 26       | 25         | 24  | 23                               | 22               | 21         | 20   | 19                    | 18    | 17         | 16  |
| Name   | KP<br>D4<br>_K<br>EY<br>_S<br>TS | KPD | 4_ROV<br>T | /_CN   | Res<br>erve<br>d | KPD      | 4_COL<br>T | _CN | KP<br>D3<br>_K<br>EY<br>_S<br>TS | KPD:             | 3_ROV<br>T | V_CN | Res<br>erve<br>d      | KPD   | 3_COL<br>T | _CN |
| Туре   | RO                               |     | RO         |        | RO               |          | RO         |     | RO                               |                  | RO         |      | RO                    |       | RO         |     |
| Reset  | 0                                | 1   | 1          | 1      | 0                | 1        | 1          | 1   | 0                                | 1                | 1          | 1    | 0                     | 1     | 1          | 1   |
| Bit    | 15                               | 14  | 13         | 12     | 11               | 10       | 9          | 8   | 7                                | 6                | 5          | 4    | 3                     | 2     | 1          | 0   |
| Name   | KP D2 _K EY _S TS                | KPD | 2_ROW<br>T | /_CN   | Res<br>erve<br>d | KPD:     | 2_COL<br>T | _CN | KP<br>D1<br>K<br>EY<br>S<br>TS   | KPD <sup>-</sup> | 1_ROV<br>T | V_CN | KP<br>D_OUR<br>KYCOSS | KPD   | 1_COL<br>T | _CN |
| Туре   | RO                               |     | RO         |        | RO               |          | RO         |     | RO                               |                  | RO         |      | RO                    |       | RO         |     |
| Reset  | 0                                | 1   | 1          | 1      | 0                | 1        | 1          | 1   | 0                                | 1                | 1          | 1    | 0                     | 1     | 1          | 1   |



| Field Name         | Bit     | R/W | Reset<br>Value | Description                                                                                                     |
|--------------------|---------|-----|----------------|-----------------------------------------------------------------------------------------------------------------|
| KPD4_KEY_STS       | [31]    | R   | 0              | No.4 key is pressed status                                                                                      |
| KPD4_ROW_CNT       | [30:28] | R   | 3'b111         | No.4 key row coordinate                                                                                         |
|                    | [27]    | R   |                | Reserved                                                                                                        |
| KPD4_COL_CNT       | [26:24] | R   | 3'b111         | No.4 key column coordinate                                                                                      |
| KPD3_KEY_STS       | [23]    | R   | 0              | No.3 key is pressed status.                                                                                     |
| KPD3_ROW_CNT       | [22:20] | R   | 3'b111         | No.3 key row coordinate                                                                                         |
|                    | [19]    | R   | 0              | Reserved                                                                                                        |
| KPD3_COL_CNT       | [18:16] | R   | 3'b111         | No.3 key column coordinate                                                                                      |
| KPD2_KEY_STS       | [15]    | R   | 0              | No.2 key is pressed status.                                                                                     |
| KPD2_ROW_CNT       | [14:12] | R   | 3'b111         | No.2 key row coordinate                                                                                         |
|                    | [11]    | R   | 0              | Reserved                                                                                                        |
| KPD2_COL_CNT       | [10:8]  | R   | 3'b111         | No.2 key column coordinate                                                                                      |
| KPD1_KEY_STS       | [7]     | R   | 0              | No.1 key is pressed status.                                                                                     |
| KPD1_ROW_CNT       | [6:4]   | R   | 3'b111         | No.1 key row coordinate                                                                                         |
| KPD_FOUR_KEY_CROSS | [3]     | R   | 0              | Set to 1 indicates that when 4 keys are all pressed, these keys can be constructed into right-angled coordinate |
| KPD1_COL_CNT       | [2:0]   | R   | 3'b111         | No.1 key column coordinate                                                                                      |

6.6.5.2.12 KPD\_SLEEP\_STATUS



| 0x0030 |    | Keypad sleep status register  KPD_SLEEP_STATE |    |    |    |    |    |      |       |    |                  |    |    | ATU<br>S |    |    |
|--------|----|-----------------------------------------------|----|----|----|----|----|------|-------|----|------------------|----|----|----------|----|----|
| Bit    | 31 | 30                                            | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21               | 20 | 19 | 18       | 17 | 16 |
| Name   |    |                                               |    |    |    |    |    | Rese | erved |    |                  |    |    |          |    |    |
| Туре   |    |                                               |    |    |    |    |    | R    | .0    |    |                  |    |    |          |    |    |
| 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   |    | Reserved E                                    |    |    |    |    |    |      |       |    | KP D L EE P ST S |    |    |          |    |    |
| Туре   |    | RO                                            |    |    |    |    |    |      |       |    |                  | RO |    |          |    |    |
| Reset  | 0  | 0                                             | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0                | 0  | 0  | 0        | 0  | 0  |

| Field Name    | Bit    | R/W | Reset Value | Description                                                           |
|---------------|--------|-----|-------------|-----------------------------------------------------------------------|
|               | [31:1] | R   | 0           | Reserved                                                              |
| KPD_SLEEP_STS | [0]    | R   | 0           | Set to 1 shows keypad is in sleep state, 0 shows in common scan state |

# 6.6.5.2.13 KPD\_DEBUG\_STATUS1

| 0x0034 |    |    | Keypad debug status1 register KPD_DE |                   |          |     |                          |      |       |    |    |     |    | )_DEB    | UG_S | TATU<br>S1     |
|--------|----|----|--------------------------------------|-------------------|----------|-----|--------------------------|------|-------|----|----|-----|----|----------|------|----------------|
| Bit    | 31 | 30 | 29                                   | 28                | 27       | 26  | 25                       | 24   | 23    | 22 | 21 | 20  | 19 | 18       | 17   | 16             |
| Name   |    |    |                                      |                   |          |     |                          | Rese | erved |    |    |     |    |          |      |                |
| Туре   |    |    |                                      |                   |          |     |                          | R    | .0    |    |    |     |    |          |      |                |
| 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   |    |    | Reserved                             | i                 |          | KPD | KPD_ROW_CN Reserve d KPD |      |       |    |    | CNT |    | Reserved | d    | KP D'E Y X D'E |
| Type   |    |    | RO                                   |                   | RO RO RO |     |                          |      |       |    |    |     | RO |          | RO   |                |
| Reset  | 0  | 0  | 0                                    | 0 0 0 0 0 0 0 0 0 |          |     |                          |      |       |    | 0  | 0   | 0  | 0        |      |                |

| Field Name Bit | R/W | Reset Value | Description |
|----------------|-----|-------------|-------------|
|----------------|-----|-------------|-------------|



|               | [31:11] | R | 0    | Reserved                                 |
|---------------|---------|---|------|------------------------------------------|
| KPD_ROW_CNT   | [10:8]  | R | 3'd0 | Current scanning key's column coordinate |
|               | [7]     | R | 0    | Reserved                                 |
| KPD_COL_CNT   | [6:4]   | R | 3'd0 | Current scanning key's row coordinate    |
|               | [3:1]   | R | 0    | Reserved                                 |
| KPD_KEY_VALUE | [0]     | R | 0    | Keypad scanning flag, active high.       |

## 6.6.5.2.14 KPD\_DEBUG\_STATUS2

| 0x0038 |    |    | Keyp | ad del | d debug status2 register |        |       |    |    |    | KPD_DEBUG_STAT |    |                |       | ΓΑΤU<br>S2 |    |
|--------|----|----|------|--------|--------------------------|--------|-------|----|----|----|----------------|----|----------------|-------|------------|----|
| Bit    | 31 | 30 | 29   | 28     | 27                       | 26     | 25    | 24 | 23 | 22 | 21             | 20 | 19             | 18    | 17         | 16 |
| Name   |    |    |      |        | KPD_ł                    | KEY4_S | STATE |    |    |    |                |    | KPD_ł          | KEY3_ | STATE      |    |
| Туре   |    |    |      |        |                          | RO     |       |    |    |    |                |    |                | RO    |            |    |
| Reset  | 0  | 0  | 0    | 0      | 0                        | 0      | 0     | 1  | 0  | 0  | 0              | 0  | 0              | 0     | 0          | 1  |
| Bit    | 15 | 14 | 13   | 12     | 11                       | 10     | 9     | 8  | 7  | 6  | 5              | 4  | 3              | 2     | 1          | 0  |
| Name   |    |    |      |        | KPD_KEY2_STATE           |        |       |    |    |    |                |    | KPD_KEY1_STATE |       |            |    |
| Туре   |    |    |      |        | RO                       |        |       |    |    |    |                |    |                | RO    |            |    |
| Reset  | 0  | 0  | 0    | 0      | 0                        | 0      | 0     | 1  | 0  | 0  | 0              | 0  | 0              | 0     | 0          | 1  |

| Field Name         | Bit     | R/W | Reset Value | Description                               |
|--------------------|---------|-----|-------------|-------------------------------------------|
|                    | [31:29] | R   | 0           | Reserved                                  |
| Kpd_key4_<br>state | [28:24] | R   | 5'b00001    | Key_state_4 FSM's state The same as above |
|                    | [23:21] | R   | 0           | Reserved                                  |
| Kpd_key3_<br>state | [20:16] | R   | 5'b00001    | Key_state_3 FSM's state The same as above |
|                    | [15:13] | R   | 0           | Reserved                                  |
| Kpd_key2_<br>state | [12:8]  | R   | 5'b00001    | Key_state_2 FSM's state The same as above |
|                    | [7:5]   | R   | 0           | Reserved                                  |
| Kpd_key1_          | [4:0]   | R   | 5'b00001    | Key_state_1 FSM's state                   |



| state |  | 00001: release state           |
|-------|--|--------------------------------|
|       |  | 00010: press de-bounce state   |
|       |  | 00100: press state             |
|       |  | 01000: release de-bounce state |
|       |  | 10000: release busy state      |

#### 6.6.6 Application Notes

#### 6.6.7 Clock enable

There are two clock inputs for keypad controller: clk\_rtc and APB PCLK. Before enable keypad controller to work these two clocks should be enabled. Please refer to the 0x8B00\_0008 register (GEN0 in APB global register)

| [56] | RTC_KPD_EB | Clock rtc enable for keypad  0: Clock rtc will be off for keypad use.  1: Clock rtc will be on for keypad use.                                                                                                                |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8]  | KPD_EB     | <ul><li>Keypad access enable</li><li>0: The peripheral clock (PCLK) of keypad controller will be off so its control registers cannot be accessed by MCU.</li><li>1: MCU can read or write keypad control registers.</li></ul> |

## 6.6.8 KPD configuration

Please assure the right "keypad matrix size", "row in/out polarity", "key de-bounce time", and "int enables".

Also set the keypad controller works under the "sleep mode" by enable the "KPD\_CTRL" register bit[0] can save power.

# 6.7 Pulse Width Modulation(PWM)

#### 6.7.1 Overview

SC6820 provides up to 4 PWM outputs that can be used to control a ringer or buzzer or LCD lights. Each PWM can output 0%~100% duration waves for kinds of applications.

#### 6.7.2 Features

- Support up to 4 PWM outputs;
- I Support clock pre-scaling, from 1 to 256;
- I Support configurable duty ratio, it can cover 0%~100%;

## 6.7.3 Signal Description

SC6820 has 4 PWM outputs, they are listed in Table xx.



Table xx PWM signal list

| Signal Name | Direction | Width | Description                    |
|-------------|-----------|-------|--------------------------------|
| RFCTL[3]    | 0         | 1     | PWM_A, when pin function is 1. |
| RFCTL[4]    | 0         | 1     | PWM_B, when pin function is 1. |
| RFCTL[6]    | 0         | 1     | PWM_C, when pin function is 1. |
| RFCTL[9]    | 0         | 1     | PWM_D, when pin function is 1. |

#### 6.7.4 Function Description

A PWM functional block diagram is shown in the following diagram.



Figure 6-37 PWM Block Diagram

A PWM timing diagram is shown below.



Figure 6-38 PWM Timing Diagram

If pre-scale register is P, and mod counter register is M, and duty cycle register is D, then output period  $T_O$  is  $T_{CLK}$  \* (P+1) \* (M+1), and active output period  $T_{ACT}$  is  $T_{CLK}$  \* (P+1) \* D, and duty ratio is D/(M+1).



# 6.7.5 Control Registers

#### 6.7.5.1 Memory map

ARM base address: 0x8800\_0000

| Offset<br>Address | Name          | Description            |
|-------------------|---------------|------------------------|
| 0x0000            | PWM0_PRESCALE | PWM0 prescale          |
| 0x0004            | PWM0_CNT      | PWM0 counter           |
| 0x0008            | PWM0_DIV      | PWM0 tone divider      |
| 0x000C            | PWM0_PAT_LOW  | PWM0 pattern low bits  |
| 0x0010            | PWM0_PAT_HIGH | PWM0 pattern high bits |
|                   |               |                        |
| 0x0020            | PWM1_PRESCALE | PWM1 prescale          |
| 0x0024            | PWM1_CNT      | PWM1 counter           |
| 0x0028            | PWM1_DIV      | PWM1 tone divider      |
| 0x002C            | PWM1_PAT_LOW  | PWM1 pattern low bits  |
| 0x0030            | PWM1_PAT_HIGH | PWM1 pattern high bits |
|                   |               |                        |
| 0x0040            | PWM2_PRESCALE | PWM2 prescale          |
| 0x0044            | PWM2_CNT      | PWM2 counter           |
| 0x0048            | PWM2_DIV      | PWM2 tone divider      |
| 0x004C            | PWM2_PAT_LOW  | PWM2 pattern low bits  |
| 0x0050            | PWM2_PAT_HIGH | PWM2 pattern high bits |
|                   |               |                        |
| 0x0060            | PWM3_PRESCALE | PWM3 prescale          |
| 0x0064            | PWM3_CNT      | PWM3 counter           |
| 0x0068            | PWM3_DIV      | PWM3 tone divider      |
| 0x006C            | PWM3_PAT_LOW  | PWM3 pattern low bits  |
| 0x0070            | PWM3_PAT_HIGH | PWM3 pattern high bits |

## 6.7.5.2 Register Descriptions

#### 6.7.5.2.1 PWMx\_PRESCALE

Description: PWM prescale coefficient for work clock.



| 0x0000 |    |    | PWN                                   | 0 pres                                | cale c | oeffici | ent (re | set 0x          | 0) |    |    |        | Р      | WM0_          | PRES | CALE |  |  |
|--------|----|----|---------------------------------------|---------------------------------------|--------|---------|---------|-----------------|----|----|----|--------|--------|---------------|------|------|--|--|
| 0x0020 |    |    | PWM1 prescale coefficient (reset 0x0) |                                       |        |         |         |                 |    |    |    |        |        | PWM1_PRESCAL  |      |      |  |  |
| 0x0040 |    |    | PWN                                   | PWM2 prescale coefficient (reset 0x0) |        |         |         |                 |    |    |    |        |        | PWM2_PRESCALE |      |      |  |  |
| 0x0060 |    |    | PWN                                   | PWM3 prescale coefficient (reset 0x0) |        |         |         |                 |    |    |    |        |        | WM3_          | PRES | CALE |  |  |
| Bit    | 31 | 30 | 29                                    | 28                                    | 27     | 26      | 25      | 24              | 23 | 22 | 21 | 20     | 19     | 18            | 17   | 16   |  |  |
| Name   |    |    |                                       | Reserved                              |        |         |         |                 |    |    |    |        |        |               |      |      |  |  |
| Туре   |    |    |                                       | 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   |    |    | ı                                     | Reserve                               | d      |         |         | PW<br>Mx_<br>EN |    |    | F  | PWMx_P | RESCAL | E             |      |      |  |  |
| Туре   |    |    |                                       | RO                                    |        |         |         | R/W             |    |    |    | R/     | W      |               |      |      |  |  |
| Reset  | 0  | 0  | 0                                     | 0                                     | 0      | 0       | 0       | 0               | 0  | 0  | 0  | 0      | 0      | 0             | 0    | 0    |  |  |

| Field Name    | Bit    | Туре | Reset<br>Value | Description                        |
|---------------|--------|------|----------------|------------------------------------|
|               | [31:9] | RO   | 23'h0          | Reserved                           |
| PWMx_EN       | [8]    | R/W  | 1'h0           | PWMx enable 0: disable; 1: enable. |
| PWMx_PRESCALE | [7:0]  | R/W  | 8'h0           | PWMx prescale coefficient.         |

#### 6.7.5.2.2 PWMx\_CNT

Description: PWM counter.

| 0x0004 |    |    | PWN                      | 10 cou                        | nter (re | eset 0x | (0) |   |          |   |   |   |   | l  | PWM0    | CNT |  |  |
|--------|----|----|--------------------------|-------------------------------|----------|---------|-----|---|----------|---|---|---|---|----|---------|-----|--|--|
| 0x0024 |    |    | PWM1 counter (reset 0x0) |                               |          |         |     |   |          |   |   |   |   |    | PWM1_CN |     |  |  |
| 0x0044 |    |    | PWM2 counter (reset 0x0) |                               |          |         |     |   |          |   |   |   |   |    | PWM2    | CNT |  |  |
| 0x0064 |    |    | PWI                      | PWM3 counter (reset 0x0)      |          |         |     |   |          |   |   |   |   |    | PWM3    | CNT |  |  |
| Bit    | 31 | 30 | 29                       | 29 28 27 26 25 24 23 22 21 20 |          |         |     |   |          |   |   |   |   | 18 | 17      | 16  |  |  |
| Name   |    |    |                          | Reserved                      |          |         |     |   |          |   |   |   |   |    |         |     |  |  |
| Туре   |    |    |                          |                               |          |         |     | R | .0       |   |   |   |   |    |         |     |  |  |
| 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   |    |    |                          | PWMx                          | _DUTY    |         |     |   | PWMx_MOD |   |   |   |   |    |         |     |  |  |
| Туре   |    |    |                          | R                             | w        |         |     |   | R/W      |   |   |   |   |    |         |     |  |  |
| Reset  | 0  | 0  | 0                        | 0                             | 0        | 0       | 0   | 0 | 0        | 0 | 0 | 0 | 0 | 0  | 0       | 0   |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description |
|------------|---------|------|----------------|-------------|
|            | [31:16] | RO   | 16'h0          | Reserved    |



| PWMx_DUTY | [15:8] | R/W | 8'h0 | PWMx duty counter. |
|-----------|--------|-----|------|--------------------|
| PWMx_MOD  | [7:0]  | R/W | 8'h0 | PWMx mod counter.  |

#### 6.7.5.2.3 PWMx\_DIV

Description: PWM tone divider.

| 0x0008 |    |    | PWM                           | 0 tone                              | divide | er (res | et 0x0)  | ) |   |   |   |   |   |    | PWM | D_DIV |
|--------|----|----|-------------------------------|-------------------------------------|--------|---------|----------|---|---|---|---|---|---|----|-----|-------|
| 0x0028 |    |    | PWM                           | 11 tone                             |        | PWM1_DI |          |   |   |   |   |   |   |    |     |       |
| 0x0048 |    |    | PWM                           | 2 tone                              | divide |         | PWM2_DIV |   |   |   |   |   |   |    |     |       |
| 0x0068 |    |    | PWM3 tone divider (reset 0x0) |                                     |        |         |          |   |   |   |   |   |   |    | PWM | DIV   |
| Bit    | 31 | 30 | 29                            | 29 28 27 26 25 24 23 22 21 20 19 18 |        |         |          |   |   |   |   |   |   | 18 | 17  | 16    |
| Name   |    |    |                               | Reserved                            |        |         |          |   |   |   |   |   |   |    |     |       |
| Туре   |    |    |                               | RO                                  |        |         |          |   |   |   |   |   |   |    |     |       |
| 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   |    |    |                               | PWMx_DIV                            |        |         |          |   |   |   |   |   |   |    |     |       |
| Туре   |    |    |                               | RW                                  |        |         |          |   |   |   |   |   |   |    |     |       |
| Reset  | 0  | 0  | 0                             | 0 0 0 0 0 0 0 0 0 0 0               |        |         |          |   |   |   |   |   |   | 0  |     |       |

| Field Name | Bit     | Туре | Reset<br>Value | Description        |
|------------|---------|------|----------------|--------------------|
|            | [31:16] | RO   | 16'h0          | Reserved           |
| PWMx_DIV   | [15:0]  | R/W  | 16'h0          | PWMx tone divider. |

## 6.7.5.2.4 PWMx\_PAT\_LOW

Description: PWM pattern low part.

| 0x000c |                                   |                                   | PWM                             | 0 patte                                   | ern lov | v part | (reset | 0x0) |   |  |  |  |              | PWM0 | PAT_ | LOW |  |
|--------|-----------------------------------|-----------------------------------|---------------------------------|-------------------------------------------|---------|--------|--------|------|---|--|--|--|--------------|------|------|-----|--|
| 0x002c | PWM1 pattern low part (reset 0x0) |                                   |                                 |                                           |         |        |        |      |   |  |  |  | PWM1_PAT_LOW |      |      |     |  |
| 0x004c |                                   | PWM2 pattern low part (reset 0x0) |                                 |                                           |         |        |        |      |   |  |  |  | PWM2_PAT_LOV |      |      |     |  |
| 0x006c |                                   | PWM3 pattern low part (reset 0x0) |                                 |                                           |         |        |        |      |   |  |  |  |              | PWM3 | PAT  | LOW |  |
| Bit    | 31                                | 30                                | 29                              | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |        |        |      |   |  |  |  |              |      |      |     |  |
| Name   |                                   |                                   | Reserved                        |                                           |         |        |        |      |   |  |  |  |              |      |      |     |  |
| Туре   |                                   |                                   |                                 |                                           |         |        |        | R    | 0 |  |  |  |              |      |      |     |  |
| 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   |                                   |                                   |                                 | PWMx_PAT_LOW                              |         |        |        |      |   |  |  |  |              |      |      |     |  |
| Туре   |                                   | R/W                               |                                 |                                           |         |        |        |      |   |  |  |  |              |      |      |     |  |
| Reset  | 0                                 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0     |                                 |                                           |         |        |        |      |   |  |  |  |              |      |      |     |  |

| Field Name | Bit | Туре | Reset | Description |
|------------|-----|------|-------|-------------|
|------------|-----|------|-------|-------------|



|              |         |     | Value |                        |
|--------------|---------|-----|-------|------------------------|
|              | [31:16] | RO  | 16'h0 | Reserved               |
| PWMx_PAT_LOW | [15:0]  | R/W | 16'h0 | PWMx pattern low part. |

#### 6.7.5.2.5 PWMx\_PAT\_HIGH

Description: PWM pattern high part.

| 0x0010 | PWM0 pattern high part (reset 0x0) |    |                                               |    |    |    |    |    |    |    |    |    | PWM0_PAT_LOW |               |    |    |  |  |
|--------|------------------------------------|----|-----------------------------------------------|----|----|----|----|----|----|----|----|----|--------------|---------------|----|----|--|--|
| 0x0030 |                                    |    | PWM1 pattern high part (reset 0x0)            |    |    |    |    |    |    |    |    |    |              | PWM1_PAT_HIGH |    |    |  |  |
| 0x0050 |                                    |    | PWM2 pattern high part (reset 0x0)            |    |    |    |    |    |    |    |    |    |              | PWM2_PAT_HIGH |    |    |  |  |
| 0x0070 |                                    |    | PWM3 pattern high part (reset 0x0) PWM3_PAT_I |    |    |    |    |    |    |    |    |    |              | HIGH          |    |    |  |  |
| Bit    | 31                                 | 30 | 29                                            | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19           | 18            | 17 | 16 |  |  |
| Name   | Reserved                           |    |                                               |    |    |    |    |    |    |    |    |    |              |               |    |    |  |  |
| Туре   | 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   | PWMx_PAT_HIGH                      |    |                                               |    |    |    |    |    |    |    |    |    |              |               |    |    |  |  |
| Туре   |                                    | RW |                                               |    |    |    |    |    |    |    |    |    |              |               |    |    |  |  |
| Reset  | 0                                  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0                   |    |    |    |    |    |    |    |    |    |              |               |    |    |  |  |

| Field Name    | Bit     | Туре | Reset<br>Value | Description             |  |  |  |  |  |
|---------------|---------|------|----------------|-------------------------|--|--|--|--|--|
|               | [31:16] | RO   | 16'h0          | Reserved                |  |  |  |  |  |
| PWMx_PAT_HIGH | [15:0]  | R/W  | 16'h0          | PWMx pattern high part. |  |  |  |  |  |

## 6.7.6 Application Notes

- When software uses PWM, it should set PWM global enable control register first, which is bit[24:21] of 0x8B000074; select their clock source through bit[28:25] of 0x8B000074; and set RFCTL[9]/[6]/[4]/[3] PAD function to 1;
- Before turning on PWMx\_EN of PWMx\_PRESCALE, software should configure all others control registers, then set PWMx\_EN to 1 to start the PWM output;
- When software completes PWM output, it should disable PWMx\_EN first, and then disable pwm\_eb in global control registers;
- When prescale is P, mod reg is M and duty reg is D, the output pulse width is  $T_O = (P+1) * (M+1) * T_{CLK}$ , the duty ratio is R = D/(M+1);



#### **6.8 GPIO**

#### 6.8.1 Overview

The GPIO module provides up to 176 GPIO pins of MCU. However, many of the pins are multiplexed with other functions and system design trade-off must be exercised on selecting them. All the GPIO pins can be programmed to be either input or output. When in input mode, they can be programmed to trigger interrupt to the MCU.

#### 6.8.2 Features

#### 6.8.2.1 GPIO

- I positive edge detect and interrupt generate
- I negative edge detect and interrupt generate
- both edges detect and interrupt generate
- I high level detect and interrupt generate
- I low level detect and interrupt generate
- I interrupt mask
- I interrupt clear
- I input data sample or mask
- I output data or mask
- I level interrupt generate at system powerdown
- I change level detect conditions at arbitary time
- I different interrupts happen
- I change edge detect conditions



## 6.8.3 Function Description



Fig 1 GPIO block diagram

As the above diagram shows, SW communicates with GPIO module by APB BUS. When the module has received active input signals, interrupts will be created to notify ARM core.

# 6.8.4 Control Registers

### 6.8.4.1 Memory map

### **Table 1 GPIO Control Register Address Map**

ARM base address:

For GPIO16~GPIO159 (16 gpios for one address): 0x8A00\_0000, 0x8A00\_0080, 0x8A00\_0100, 0x8A00\_0180, 0x8A00\_0200, 0x8A00\_0280, 0x8A00\_0300, 0x8A00\_0380, 0x8A00\_0400

GPIO16-144: come from external pad, refer to SC6820 pin list;

GPIO145: usbd\_vm;

GPIO146: usbd\_vp;

GPIO147: usbd\_se0\_wakeup; GPIO148-159: reserved;

For GPIO176~GPIO207 (16 gpios for one address):

0x8200\_0480, 0x8200\_04C0



GPIO176-205: come from external pad, refer to chapter 3 Pin Information;

GPIO206-207: reserved;

| Offset<br>Address | Name     | Description                       |
|-------------------|----------|-----------------------------------|
| 0x0000            | GPIODATA | GPIO bits data                    |
| 0x0004            | GPIODMSK | GPIO bits data mask               |
| 0x0008            | GPIODIR  | GPIO bits data direction          |
| 0x000C            | GPIOIS   | GPIO bits interrupt sense         |
| 0x0010            | GPIOIBE  | GPIO bits both edges interrupt    |
| 0x0014            | GPIOIEV  | GPIO bits interrupt event         |
| 0x0018            | GPIOIE   | GPIO bits interrupt enable        |
| 0x001C            | GPIORIS  | GPIO bits raw interrupt status    |
| 0x0020            | GPIOMIS  | GPIO bits masked interrupt status |
| 0x0024            | GPIOIC   | GPIO bits interrupt clear         |
| 0x0028            | GPIOINEN | GPIO input enable                 |

## 6.8.4.2 Register Descriptions

### 6.8.4.2.1 **GPIODATA**

Description: GPIO bits data register

| 0x0000 |    |     | (res     | et 0x0 | 000_00 | 000) |    |      |      |    |    |    |    |    | GPIC | ATA |
|--------|----|-----|----------|--------|--------|------|----|------|------|----|----|----|----|----|------|-----|
| Bit    | 31 | 30  | 29       | 28     | 27     | 26   | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17   | 16  |
| Name   |    |     | Reserved |        |        |      |    |      |      |    |    |    |    |    |      |     |
| Туре   |    |     |          |        |        |      |    | R    | 0    |    |    |    |    |    |      |     |
| 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   |    |     |          |        |        |      |    | GPIO | DATA |    |    |    |    |    |      |     |
| Туре   |    | R/W |          |        |        |      |    |      |      |    |    |    |    |    |      |     |
| Reset  | 0  | 0   | 0        | 0      | 0      | 0    | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0    | 0   |

| Field Name | Bit     | Туре | Reset<br>Value | Description          |
|------------|---------|------|----------------|----------------------|
|            | [31:16] | R/W  | 16'h0          | Reserved             |
| GPIODATA   | [15:0]  | R/W  | 16'h0          | GPIO bits data input |

### 6.8.4.2.2 **GPIODMSK**

Description: GPIO bits mask register



| 0x0004 |    |    | (res | et 0x0                                    | 000_00 | 000) |   |      |      |   |   |   |   |    | GPIOE | DMSK |
|--------|----|----|------|-------------------------------------------|--------|------|---|------|------|---|---|---|---|----|-------|------|
| Bit    | 31 | 30 | 29   | 29 28 27 26 25 24 23 22 21 20 19 18 17 10 |        |      |   |      |      |   |   |   |   | 16 |       |      |
| Name   |    |    |      | Reserved                                  |        |      |   |      |      |   |   |   |   |    |       |      |
| Туре   |    |    |      |                                           |        |      |   | R    | 0    |   |   |   |   |    |       |      |
| 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   |    |    |      |                                           |        |      |   | GPIO | DMSK |   |   |   |   |    |       |      |
| Туре   |    |    |      | RW                                        |        |      |   |      |      |   |   |   |   |    |       |      |
| Reset  | 0  | 0  | 0    | 0                                         | 0      | 0    | 0 | 0    | 0    | 0 | 0 | 0 | 0 | 0  | 0     | 0    |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                              |
|------------|---------|------|----------------|----------------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                                 |
| GPIODMSK   | [15:0]  | R/W  | 16'h0          | GPIODATA register can be read/write if GPIO DMSK set "1" |

### 6.8.4.2.3 **GPIODIR**

Description: GPIO bits direction register

| 0x0008 |    |     | (res | et 0x0 | 000_0 | 000) |    |      |       |    |    |    |    |    | GPI | (reset 0x0000_0000) GPIODIR |  |  |  |  |  |  |  |  |  |  |  |
|--------|----|-----|------|--------|-------|------|----|------|-------|----|----|----|----|----|-----|-----------------------------|--|--|--|--|--|--|--|--|--|--|--|
| Bit    | 31 | 30  | 29   | 28     | 27    | 26   | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17  | 16                          |  |  |  |  |  |  |  |  |  |  |  |
| Name   |    |     |      |        |       |      |    | Rese | erved |    |    |    |    |    |     |                             |  |  |  |  |  |  |  |  |  |  |  |
| Туре   |    | 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   |    |     |      |        |       |      |    | GPI  | ODIR  |    |    |    |    |    |     |                             |  |  |  |  |  |  |  |  |  |  |  |
| Туре   |    | R/W |      |        |       |      |    |      |       |    |    |    |    |    |     |                             |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0  | 0   | 0    | 0      | 0     | 0    | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0   | 0                           |  |  |  |  |  |  |  |  |  |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                              |
|------------|---------|------|----------------|--------------------------------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                                                 |
| GPIODIR    | [15:0]  | R/W  | 16'h0          | "1" configure gpio bits to be output "0" configure gpio bits to be input |

# 6.8.4.2.4 GPIOIS

Description: GPIO bits interrupt sense register



| 0x000C |    |    | (res | et 0x0                                    | 000_FI | FFF) |   |     |     |   |   |   |   |   | GI | PIOIS |
|--------|----|----|------|-------------------------------------------|--------|------|---|-----|-----|---|---|---|---|---|----|-------|
| Bit    | 31 | 30 | 29   | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |      |   |     |     |   |   |   |   |   | 16 |       |
| Name   |    |    |      | Reserved                                  |        |      |   |     |     |   |   |   |   |   |    |       |
| Туре   |    |    |      |                                           |        |      |   | R   | 0   |   |   |   |   |   |    |       |
| 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   |    |    |      |                                           |        |      |   | GPI | OIS |   |   |   |   |   |    |       |
| Туре   |    |    | R/W  |                                           |        |      |   |     |     |   |   |   |   |   |    |       |
| Reset  | 1  | 1  | 1    | 1                                         | 1      | 1    | 1 | 1   | 1   | 1 | 1 | 1 | 1 | 1 | 1  | 0     |

| Field Name | Bit     | Туре | Reset<br>Value | Description              |
|------------|---------|------|----------------|--------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                 |
| GPIOIS     | [15:0]  | R/W  | 16'hFFFF       | "1" detect signals level |
|            |         |      |                | "0" detect signals edge  |

### 6.8.4.2.5 **GPIOIBE**

Description: GPIO bits both edges interrupt register

| 0x0010 |    |     | (res     | (reset 0x0000_0000) GPIOIBE |    |    |    |     |      |    |    |    |    |    |    | OIBE |
|--------|----|-----|----------|-----------------------------|----|----|----|-----|------|----|----|----|----|----|----|------|
| Bit    | 31 | 30  | 29       | 28                          | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
| Name   |    |     | Reserved |                             |    |    |    |     |      |    |    |    |    |    |    |      |
| Туре   |    |     |          |                             |    |    |    | R   | .0   |    |    |    |    |    |    |      |
| 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   |    |     | 3        |                             |    |    |    | GPI | OIBE |    |    |    |    |    |    |      |
| Туре   |    | R/W |          |                             |    |    |    |     |      |    |    |    |    |    |    |      |
| Reset  | 0  | 0   | 0        | 0                           | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0    |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                  |
|------------|---------|------|----------------|----------------------------------------------------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                                                                     |
| GPIOIBE    | [15:0]  | R/W  | 16'h0          | "1" both edges trigger an interrupt, "0" interrupt generation event is controlled by GPIOIEV |

### 6.8.4.2.6 **GPIOIEV**

Description: GPIO bits interrupt status register



| 0x0014 |    |    | (res | et 0x0 | 000_FI | FFF) |    |      |       |    |    |    |    |    | GPI | OIEV |
|--------|----|----|------|--------|--------|------|----|------|-------|----|----|----|----|----|-----|------|
| Bit    | 31 | 30 | 29   | 28     | 27     | 26   | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17  | 16   |
| Name   |    |    |      |        |        |      |    | Rese | erved |    |    |    |    |    |     |      |
| Туре   |    |    |      |        |        |      |    | R    | 0     |    |    |    |    |    |     |      |
| 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   |    |    |      |        |        |      |    | GPI  | DIEV  |    |    |    |    |    |     |      |
| Туре   |    |    | RW   |        |        |      |    |      |       |    |    |    |    |    |     |      |
| Reset  | 1  | 1  | 1    | 1      | 1      | 1    | 1  | 1    | 1     | 1  | 1  | 1  | 1  | 1  | 1   | 1    |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                  |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                                                                                     |
| GPIOIEV    | [15:0]  | R/W  | 16'hFFFF       | GPIO bits interrupt event register:  "1" high levels trigger interrupts,  "0" low levels trigger interrupts. |

### 6.8.4.2.7 **GPIOIE**

Description: GPIO bits interrupt enable register

| 0x0018 |    |                                                | (res | et 0x0 | 000_00 | 000) |   |      |       |   |   |   |   |   | GI | PIOIE |
|--------|----|------------------------------------------------|------|--------|--------|------|---|------|-------|---|---|---|---|---|----|-------|
| Bit    | 31 | 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |      |        |        |      |   |      |       |   |   |   |   |   |    |       |
| Name   |    |                                                |      |        |        |      |   | Rese | erved |   |   |   |   |   |    |       |
| Туре   |    |                                                |      |        |        |      |   | R    | 0     |   |   |   |   |   |    |       |
| 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   |    |                                                |      |        |        |      |   | GPI  | OIE   |   |   |   |   |   |    |       |
| Туре   |    | R/W                                            |      |        |        |      |   |      |       |   |   |   |   |   |    |       |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                |      |        |        |      |   |      |       |   |   |   |   |   |    |       |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                      |
|------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                                                                                                         |
| GPIOIE     | [15:0]  | R/W  | 16'h0          | GPIO bits interrupt enable register:  "1" corresponding bit interrupt is enabled.  "0" corresponding bit interrupt isn't enabled |

### 6.8.4.2.8 **GPIORIS**

Description: GPIO bits raw interrupt status register, and it reflects the status of interrupts trigger conditions detection on pins (prior to GPIOMIS)



| 0x001C |    |    | (res                        | et 0x0                                   | 000_00 | 000) |   |     |      |   |   |   |   |   | GPI | ORIS |
|--------|----|----|-----------------------------|------------------------------------------|--------|------|---|-----|------|---|---|---|---|---|-----|------|
| Bit    | 31 | 30 | 29                          | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |      |   |     |      |   |   |   |   |   |     |      |
| Name   |    |    |                             | Reserved                                 |        |      |   |     |      |   |   |   |   |   |     |      |
| Туре   |    |    |                             |                                          |        |      |   | R   | 0    |   |   |   |   |   |     |      |
| 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   |    |    |                             |                                          |        |      |   | GPI | ORIS |   |   |   |   |   |     |      |
| Туре   |    |    | RO                          |                                          |        |      |   |     |      |   |   |   |   |   |     |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                          |        |      |   |     |      |   |   |   |   |   |     |      |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                                                                   |
| GPIORIS    | [15:0]  | RO   | 16'h0          | GPIO bits raw interrupt status register: "1" interrupt condition met "0" condition not met |

### 6.8.4.2.9 **GPIOMIS**

Description: GPIO bits masked interrupt status register

| 0x0020 |    |                               | (res | et 0x0 | 000_00 | 000) |    |    |    |    |    |    |    |    | GPI | OMIS |
|--------|----|-------------------------------|------|--------|--------|------|----|----|----|----|----|----|----|----|-----|------|
| Bit    | 31 | 30                            | 29   | 28     | 27     | 26   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16   |
| Name   |    | Reserved                      |      |        |        |      |    |    |    |    |    |    |    |    |     |      |
| Туре   |    |                               |      |        |        |      |    | R  | 0  |    |    |    |    |    |     |      |
| 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   |    | GPIOMIS                       |      |        |        |      |    |    |    |    |    |    |    |    |     |      |
| Туре   |    | RO                            |      |        |        |      |    |    |    |    |    |    |    |    |     |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |      |        |        |      |    |    |    |    |    |    |    |    |     |      |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                 |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                                                                    |
| GPIOMIS    | [15:0]  | RO   | 16'h0          | GPIO bits masked interrupt status register:  "1" Interrupt active  "0" interrupt not active |

### 6.8.4.2.10 GPIOIC



Description: GPIO bits interrupt clear register

| 0x0024 |    |                             | (res                                      | et 0x0 | 000_00 | 000) |   |   |   |   |   |   |   |   | GF | PIOIC |
|--------|----|-----------------------------|-------------------------------------------|--------|--------|------|---|---|---|---|---|---|---|---|----|-------|
| Bit    | 31 | 30                          | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |        |      |   |   |   |   |   |   |   |   |    |       |
| Name   |    |                             | Reserved                                  |        |        |      |   |   |   |   |   |   |   |   |    |       |
| Туре   |    |                             |                                           |        |        |      |   | R | 0 |   |   |   |   |   |    |       |
| 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   |    |                             |                                           | GPIOIC |        |      |   |   |   |   |   |   |   |   |    |       |
| Туре   |    |                             | wo                                        |        |        |      |   |   |   |   |   |   |   |   |    |       |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                           |        |        |      |   |   |   |   |   |   |   |   |    |       |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                             |
|------------|---------|------|----------------|-----------------------------------------------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                                                                |
| GPIOIC     | [15:0]  | WO   | 16'h0          | GPIO bits interrupt clear register:  "1" clears detected interrupt.  "0" has no effect. |

### 6.8.4.2.11 GPIOINEN

Description: GPIO input enable register

| 0x0028 |    |                                         | (reset 0x0000_FFFF) GPIOINEN |                                          |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|----|-----------------------------------------|------------------------------|------------------------------------------|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit    | 31 | 30                                      | 29                           | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |    | Reserved                                |                              |                                          |    |    |   |   |   |   |   |   |   |   |   |   |
| Туре   |    |                                         |                              |                                          |    |    |   | R | 0 |   |   |   |   |   |   |   |
| 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   |    |                                         |                              | GPIOINEN                                 |    |    |   |   |   |   |   |   |   |   |   |   |
| Туре   |    | $\overline{\Lambda}$                    | RW                           |                                          |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset  | 31 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |                              |                                          |    |    |   |   |   |   |   |   |   |   |   |   |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                        |
|------------|---------|------|----------------|--------------------------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                                           |
| GPIOINEN   | [15:0]  | RW   | 16'h0          | GPIO input enable register:  "1" input enable.  "0" input disable. |



#### 6.8.4.2.12 Related Clock & Interrupt control registers

Table 2 Related Clock & Interrupt control registers

| Address     | Register Name  | Bit Pos | Default | Description                                                                        |
|-------------|----------------|---------|---------|------------------------------------------------------------------------------------|
| 0x2090_0214 | CTRL0          | [3]     | 1       | APB clock Enable of total system                                                   |
| 0x2090_0218 | CTRL5          | [0]     | 1       | Remap control                                                                      |
| 0x8000_3000 | ARM_INT_STATUS | [8]     | 0       | GPIO interrupt status, using No.8 interrupt for GPIO and No.24 interrupt for GPIOA |
| 0x8000_3008 | ARM_INT_EN     | [8]     | 0       | GPIO interrupt enable                                                              |
| 0x8000_300c | ARM_INT_DIS    | [8]     | 0       | GPIO interrupt disable/clear                                                       |
| 0x8000_3000 | ARM_INT_STATUS | [24]    | 0       | ADI interrupt status                                                               |
| 0x8000_3008 | ARM_INT_EN     | [24]    | 0       | ADI interrupt enable                                                               |
| 0x8000_300c | ARM_INT_DIS    | [24]    | 0       | ADI interrupt disable/clear                                                        |
| 0x8B00_0008 | GEN0           | [6]     | 1       | Enable ADI's PCLK                                                                  |
| 0x8B00_005C | GLB_DLY        | [29]    | 1       | Enable clk_adi                                                                     |
| 0x8200_0600 | ADI_AGEN       | [6]     | 0       | APB clock Enable of GPIOA module                                                   |
| 0x8200_0024 | ADI_READ_CMD   | [25:0]  | 0       | ADI read command register                                                          |
| 0x8200_0028 | ADI_READ_DATA  | [31:0]  | 0       | To obtain register value on analog control module                                  |
| 0x8B00_0008 | GEN0           | [5]     | 0       | APB clock Enable of GPIO module                                                    |
| 0x8B00_0008 | GEN0           | [13]    | 0       | Pin control register bit                                                           |
|             |                |         |         |                                                                                    |

## 6.8.5 Application Notes

### 6.8.5.1 Programming Notes

1) GPIOMIS is equal to GPIOIE & GPIORIS.

### 6.9 EIC

# 6.9.1 Overview

The EIC module includes two sub-modules: EIC and SIC.

The EIC sub-module provides up to 8 EIC source input signal connection. A de-bounce mechanism is used to capture EIC's stable status and a single-trig mechanism is introduced into this sub-module to enhance the input event detect reliability. In addition, this sub-module's clock can be shut off automatically to reduce power dissipation. The de-bounce range is from 1 ms to 4 s with the step of 1 ms. Those input signals shorter than 1 ms will be omitted at this sub-module.



THE SIC sub-module is used to latch some special input signal and send interrupts to MCU core, and it can provides up to 8 SIC source input signal connection.

#### **6.9.2** Features

#### 6.9.2.1 EIC

- I high level detect and interrupt generate(not bypass mode)
- I low level detect and interrupt generate(not bypass mode)
- I interrupt mask(not bypass mode)
- interrupt clear(not bypass mode)
- I level interrupt generate at system powerdown with once active trig(not bypass mode)
- I keep interrupt stable when no interrupt clear(not bypass mode)
- I input data sample or mask(not bypass mode)
- I debounce number configurable(not bypass mode)
- I only once trig active(not bypass mode)
- I trig level condition configurable(not bypass mode)
- I high level detect and interrupt generate(bypass mode)
- I low level detect and interrupt generate(bypass mode)
- interrupt mask(bypass mode)
- interrupt clear(bypass mode)
- I input data sample or mask(bypass mode)
- I level interrupt generate at system power down(bypass mode)
- I force to open the clock of debounce

#### **6.9.2.2** SIC

- Special IRQ or FIQ interrupt on channel 0 is used to latch some input signal status and trigger IRQ or FIQ interrupt by level detecting (no edge detecting)
- Special IRQ or FIQ interrupt on channel 0 is multiplexed from 8 independent input sources
- Using Latch circuit to realize interrupt generation, SICINTMSK connected to the set port of Latch, and SICINTCLR connected to the clear port of Latch.
- I Provide raw status for each of 8 input sources on special channel
- I Provide polarity control bit for each of 8 input sources on special channel
- I Provide only one clear bit to clear all latches on special channel
- I Each input source can be enabled or disabled independently on special channel

## **6.9.3** Function Description





Fig 2 EIC block diagram

As the above diagram shows, SW communicates with EIC module by APB BUS. When the module has received active input signals, interrupts will be created to notify ARM core.

### 6.9.4 Control Registers

### 6.9.4.1 Memory map

# **Table 3 EIC Control Register Address Map**

ARM base address: 0x8A00\_1000 (EIC) (EIC0-EIC15)

0x8200\_0700 (EICA) (EIC160-175)

EIC0-2: come from external pad, refer to SC6820 pin list

EIC3-15: reserved;

EIC160: from TP\_XL pad;

EIC161: reserved;

EIC162: CHAR\_INT;

EIC163: PBINT

EIC164: HEAD\_BUTTON;

EIC165: HEADMIC\_DETECTION;

EIC166: CHGR\_OVI;

EIC167-175:

| Offset<br>Address | Name    | Description         |
|-------------------|---------|---------------------|
| 0x0000            | EICDATA | EIC bits data input |
| 0x0004            | EICDMSK | EIC bits data mask  |



| Offset<br>Address | Name     | Description                      |
|-------------------|----------|----------------------------------|
| 0x0014            | EICIEV   | EIC bits interrupt event         |
| 0x0018            | EICIE    | EIC bits interrupt enable        |
| 0x001C            | EICRIS   | EIC bits raw interrupt status    |
| 0x0020            | EICMIS   | EIC bits masked interrupt status |
| 0x0024            | EICIC    | EIC bits interrupt clear         |
| 0x0028            | EICTRIG  | EIC bits trig control            |
|                   |          |                                  |
| 0x0040            | EIC0CTRL | EIC0 control register            |
| 0x0044            | EIC1CTRL | EIC1 control register            |
| 0x0048            | EIC2CTRL | EIC2 control register            |
| 0x004C            | EIC3CTRL | EIC3 control register            |
| 0x0050            | EIC4CTRL | EIC4 control register            |
| 0x0054            | EIC5CTRL | EIC5 control register            |
| 0x0058            | EIC6CTRL | EIC6 control register            |
| 0x005C            | EIC7CTRL | EIC7 control register            |

# **Table 4 SIC Control Register Address Map**

ARM base address: 0x8A00\_1080

SIC0: uart0\_rxd, internal source. SIC1: uart0\_ctsn, internal source; SIC2: uart1\_rxd, internal source; SIC3: uart2\_rxd, internal source;

SIC4: usbd\_se0\_wakeup, internal source;

SIC5: uart2\_ctsn, internal source;

SIC6: ARM core power-up require, internal source;

SIC7: reserved;

| Offset<br>Address | Name      | Description            |
|-------------------|-----------|------------------------|
| 0x0000            | SICINTEN  | SIC interrupt enable   |
| 0x0004            | SICINTRAW | SIC raw interrupt      |
| 0x0008            | SICINTMSK | SIC interrupt mask     |
| 0x000C            | SICINTCLR | SIC interrupt clear    |
| 0x0010            | SICINTPOL | SIC interrupt polarity |



| Offset<br>Address | Name       | Description        |
|-------------------|------------|--------------------|
| 0x0014            | SICINTMODE | SIC interrupt mode |
|                   |            |                    |

**6.9.4.2** Register Descriptions

### 6.9.4.2.1 EICDATA

Description: EIC bits data register, read only

| 0x0000 |    |                                              | (res | et 0x0 | 000_00 | 000) |   |   |   |   |   |   |   |   | EICI | DATA |
|--------|----|----------------------------------------------|------|--------|--------|------|---|---|---|---|---|---|---|---|------|------|
| Bit    | 31 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |      |        |        |      |   |   |   |   |   |   |   |   |      |      |
| Name   |    | Reserved                                     |      |        |        |      |   |   |   |   |   |   |   |   |      |      |
| Туре   |    | RO                                           |      |        |        |      |   |   |   |   |   |   |   |   |      |      |
| 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   |    | Reserved                                     |      |        |        |      |   |   |   |   |   |   |   |   |      |      |
| Туре   |    | RO RO                                        |      |        |        |      |   |   |   |   |   |   |   |   |      |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0                  |      |        |        |      |   |   |   |   | 0 |   |   |   |      |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description         |
|------------|--------|------|----------------|---------------------|
|            | [31:8] | RO   | 24'h0          | Reserved            |
| EICDATA    | [7:0]  | RO   | 8'h0           | EIC bits data input |

Note: EICDATA synchronizes the original data inputs with 2 cycles of Rtcdiv5\_clk, so SW need delay 2ms to get the exact value of original data inputs when Rtcdiv5\_clk is enabled.

### 6.9.4.2.2 EICDMSK

Description: EIC bits data mask register



| 0x0004 |    |                                              | (res                    | et 0x0 | 000_00 | 000) |   |   |   |   |   |      |     |   | EICE | MSK |
|--------|----|----------------------------------------------|-------------------------|--------|--------|------|---|---|---|---|---|------|-----|---|------|-----|
| Bit    | 31 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                         |        |        |      |   |   |   |   |   |      |     |   |      |     |
| Name   |    | Reserved                                     |                         |        |        |      |   |   |   |   |   |      |     |   |      |     |
| Туре   |    | 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   |    |                                              |                         | Rese   | erved  |      |   |   |   |   |   | EICD | MSK |   |      |     |
| Туре   |    | RO R/W                                       |                         |        |        |      |   |   |   |   |   |      |     |   |      |     |
| Reset  | 0  | 0                                            | 0 0 0 0 0 0 0 0 0 0 0 0 |        |        |      |   |   |   |   |   |      | 0   |   |      |     |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                     |
|------------|--------|------|----------------|-------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                        |
| EICDMSK    | [7:0]  | R/W  | 8'h0           | EICDATA register can be read if EICDMSK set "1" |

### 6.9.4.2.3 EICIEV

Description: EIC bits interrupt status register

| 0x0014 |    |                                                | (res | et 0x0 | 000_00 | )FF) |   |      |       |   |   |     |     |   | Е | CIEV |
|--------|----|------------------------------------------------|------|--------|--------|------|---|------|-------|---|---|-----|-----|---|---|------|
| Bit    | 31 | 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |      |        |        |      |   |      |       |   |   |     |     |   |   |      |
| Name   |    |                                                |      |        |        |      |   | Rese | erved |   |   |     |     |   |   |      |
| Туре   |    | 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   |    |                                                |      | Rese   | erved  |      |   |      |       |   |   | EIC | IEV |   |   |      |
| Туре   |    | RO                                             |      |        |        |      |   |      |       |   |   |     |     |   |   |      |
| Reset  | 0  | 0 0 0 0 0 0 1 1 1 1 1 1 1                      |      |        |        |      |   |      |       |   |   |     |     |   |   |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                  |
|------------|--------|------|----------------|--------------------------------------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                                                     |
| EICIEV     | [7:0]  | R/W  | 8'hFF          | EIC bits interrupt status register:  "1" high levels trigger interrupts,  "0" low levels trigger interrupts. |

# 6.9.4.2.4 EICIE

Description: EIC bits interrupt enable register



| 0x0018 |    |    | (res                                         | et 0x0                    | 000_00 | 000) |   |      |       |   |   |   |   |   | ļ | EICIE |
|--------|----|----|----------------------------------------------|---------------------------|--------|------|---|------|-------|---|---|---|---|---|---|-------|
| Bit    | 31 | 30 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                           |        |      |   |      |       |   |   |   |   |   |   |       |
| Name   |    |    |                                              |                           |        |      |   | Rese | erved |   |   |   |   |   |   |       |
| Туре   |    |    | 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   |    |    | Reserved EICIE                               |                           |        |      |   |      |       |   |   |   |   |   |   |       |
| Туре   |    |    | RO R/W                                       |                           |        |      |   |      |       |   |   |   |   |   |   |       |
| Reset  | 0  | 0  | 0                                            | 0 0 0 0 0 0 0 0 0 0 0 0 0 |        |      |   |      |       |   |   |   | 0 |   |   |       |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                     |
|------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                                                                        |
| EICIE      | [7:0]  | R/W  | 8'h0           | EIC bits interrupt enable register:  "1" corresponding bit interrupt is enabled.  "0" corresponding bit interrupt isn't enabled |

### 6.9.4.2.5 EICRIS

Description: EIC bits raw interrupt status register, and it reflects the status of interrupts trigger conditions detection on pins (prior to EICMIS)

| 0x001C | (reset 0x0000_0000) EI |                             |    |    |    |    |    |      |       |    |    |     | CRIS |    |    |    |
|--------|------------------------|-----------------------------|----|----|----|----|----|------|-------|----|----|-----|------|----|----|----|
| Bit    | 31                     | 30                          | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20  | 19   | 18 | 17 | 16 |
| Name   |                        |                             |    |    |    |    |    | Rese | erved |    |    |     |      |    |    |    |
| Туре   |                        |                             |    |    |    |    |    | R    | 0     |    |    |     |      |    |    |    |
| 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  |                             |    |    |    |    |    | 8    | 7     | 6  | 5  | 4   | 3    | 2  | 1  | 0  |
| Name   | Reserved               |                             |    |    |    |    |    |      |       |    |    | EIC | RIS  |    |    |    |
| Туре   |                        |                             |    | R  | 0  |    |    |      |       |    |    | R   | 0    |    |    |    |
| Reset  | 0                      | 0 0 0 0 0 0 0               |    |    |    |    |    |      | 0     | 0  | 0  | 0   | 0    | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                               |
|------------|--------|------|----------------|-------------------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                                  |
| EICRIS     | [7:0]  | RO   | 8'h0           | EIC bits raw interrupt status register: "1" interrupt condition met "0" condition not met |

### 6.9.4.2.6 EICMIS



Description: EIC bits masked interrupt status register

| 0x0020 |    |                                     | (res | et 0x0 | 000_00 | 000) |    |      |       |    |    |    |    |    | EI | CMIS |
|--------|----|-------------------------------------|------|--------|--------|------|----|------|-------|----|----|----|----|----|----|------|
| Bit    | 31 | 30                                  | 29   | 28     | 27     | 26   | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
| Name   |    |                                     |      |        |        |      |    | Rese | erved |    |    |    |    |    |    |      |
| Туре   |    |                                     |      |        |        |      |    | R    | 0     |    |    |    |    |    |    |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0       |      |        |        |      |    |      |       |    |    |    | 0  |    |    |      |
| Bit    | 15 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |      |        |        |      |    |      |       | 0  |    |    |    |    |    |      |
| Name   |    | Reserved EICMIS                     |      |        |        |      |    |      |       |    |    |    |    |    |    |      |
| Туре   |    | RO RO                               |      |        |        |      |    |      |       |    |    |    |    |    |    |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0         |      |        |        |      |    |      |       |    |    |    |    |    |    |      |

Note: EICMIS = EICIE & EICRIS

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                              |
|------------|--------|------|----------------|------------------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                                 |
| EICMIS     | [7:0]  | RO   | 8'h0           | EIC bits masked interrupt status register: "1" Interrupt active "0" interrupt not active |

### 6.9.4.2.7 EICIC

Description: EIC bits interrupt clear register

| 0x0024 | (reset 0x0000_0000) EICIC |                             |    |    |    |    |    |      |       |    |    | EICIC |     |    |    |    |
|--------|---------------------------|-----------------------------|----|----|----|----|----|------|-------|----|----|-------|-----|----|----|----|
| Bit    | 31                        | 30                          | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20    | 19  | 18 | 17 | 16 |
| Name   |                           |                             |    |    |    |    |    | Rese | erved |    |    |       |     |    |    |    |
| Туре   |                           |                             |    |    |    |    |    | W    | 0     |    |    |       |     |    |    |    |
| 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   | Reserved                  |                             |    |    |    |    |    |      |       |    |    | EIG   | CIC |    |    |    |
| Туре   | wo                        |                             |    |    |    |    |    |      |       |    |    |       |     |    |    |    |
| Reset  | 0                         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |      |       |    |    |       |     |    |    |    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                       |
|------------|--------|------|----------------|-------------------------------------------------------------------|
|            | [31:8] | WO   | 24'h0          | Reserved                                                          |
| EICIC      | [7:0]  | WO   | 8'h0           | EIC bits interrupt clear register: "1" clears detected interrupt. |



|  |  | "0" has no effect. |
|--|--|--------------------|

### 6.9.4.2.8 EICTRIG

Description: EIC bits trig control register

| 0x0028 |          |                             | (res | et 0x0 | 000_0 | 000) |    |      |       |    |    |      |     |    | EIC | TRIG |
|--------|----------|-----------------------------|------|--------|-------|------|----|------|-------|----|----|------|-----|----|-----|------|
| Bit    | 31       | 30                          | 29   | 28     | 27    | 26   | 25 | 24   | 23    | 22 | 21 | 20   | 19  | 18 | 17  | 16   |
| Name   |          |                             |      |        |       |      |    | Rese | erved |    |    |      |     |    |     |      |
| Туре   |          |                             |      |        |       |      |    | W    | 10    |    |    |      |     |    |     |      |
| 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   | Reserved |                             |      |        |       |      |    |      |       |    |    | EICT | RIG |    |     |      |
| Туре   |          | wo                          |      |        |       |      |    |      |       |    |    |      |     |    |     |      |
| Reset  | 0        | 0                           | 0    | 0      | 0     | 0    | 0  | 0    | 0     | 0  | 0  | 0    | 0   | 0  | 0   | 0    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                         |
|------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:8] | WO   | 24'h0          | Reserved                                                                                                                                                            |
| EICTRIG    | [7:0]  | WO   | 8'h0           | EIC bits trig control register:  "1": generate the trig_start pulse  "0": no effect  It must set EICTRIG for using de-bounce function and getting active interrupt. |

## 6.9.4.2.9 EIC0CTRL

Description: EIC0 control register

| 0x0040 |                      |                     | (rese | t 0x00 | 00_40    | 00_4032) EICOCTR                                          |   |      |       |   |   |   |   |   |   | CTRL |
|--------|----------------------|---------------------|-------|--------|----------|-----------------------------------------------------------|---|------|-------|---|---|---|---|---|---|------|
| Bit    | 31                   | 30                  | 29    | 28     | 27       | 27   26   25   24   23   22   21   20   19   18   17   16 |   |      |       |   |   |   |   |   |   |      |
| Name   |                      |                     |       |        |          |                                                           |   | Rese | erved |   |   |   |   |   |   |      |
| Туре   |                      |                     |       |        |          |                                                           |   | R    | 0     |   |   |   |   |   |   |      |
| 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   | FO RC E_ CL K_ DB NC | DB<br>NC<br>_E<br>N | Rese  | erved  | DBNC_CNT |                                                           |   |      |       |   |   |   |   |   |   |      |
| Туре   | R/W                  | R/W                 | R     | 0      | RW       |                                                           |   |      |       |   |   |   |   |   |   |      |
| Reset  | 0                    | 1                   | 0     | 0      | 0        | 0                                                         | 0 | 0    | 0     | 0 | 1 | 1 | 0 | 0 | 1 | 0    |

|--|



|                |         |     | Value   |                                                                   |
|----------------|---------|-----|---------|-------------------------------------------------------------------|
| /              | [31:16] | RO  | 16'd0   | Reserved                                                          |
| FORCE_CLK_DBNC | [15]    | R/W | 1'h0    | 1: clock of dbnc forced open; 0: no effect                        |
| DBNC_EN        | [14]    | R/W | 1'h1    | de-bounce mechanism enable or disable: 1 enable,0 disable(bypass) |
| /              | [13:12] | RO  | 2'd0    | Reserved                                                          |
| DBNC_CNT       | [11:0]  | R/W | 12'h032 | de-bounce counter period value setting, the unit is millisecond   |

## 6.9.4.2.10 EIC1CTRL

Description: EIC1 control register

| 0x0042 |                                        |                     | (rese | t 0x00 | 00_40                     | 32)                   |    |    |    |      |       |    |    |    | EIC10 | CTRL |
|--------|----------------------------------------|---------------------|-------|--------|---------------------------|-----------------------|----|----|----|------|-------|----|----|----|-------|------|
| Bit    | 31                                     | 30                  | 29    | 28     | 27                        | 26                    | 25 | 24 | 23 | 22   | 21    | 20 | 19 | 18 | 17    | 16   |
| Name   |                                        |                     |       |        |                           | Reserved              |    |    |    |      |       |    |    |    |       |      |
| Туре   |                                        |                     |       |        |                           |                       |    | R  | 0  |      |       |    |    |    |       |      |
| 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   | FO<br>RC<br>E_<br>CL<br>K_<br>DB<br>NC | DB<br>NC<br>_E<br>N | Rese  | erved  |                           |                       | C  |    |    | DBNC | C_CNT |    |    |    |       |      |
| Туре   | R/W                                    | R/W                 | R     | 0      |                           |                       |    |    |    | R    | W     |    |    |    |       |      |
| Reset  | 0                                      | 1                   | 0     | 0      | 0 0 0 0 0 0 1 1 0         |                       |    |    |    |      |       |    |    |    |       |      |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                          |
|----------------|---------|------|----------------|----------------------------------------------------------------------|
| 1              | [31:16] | RO   | 16'd0          | Reserved                                                             |
| FORCE_CLK_DBNC | [15]    | R/W  | 1'h0           | 1: clock of dbnc forced open; 0: no effect                           |
| DBNC_EN        | [14]    | R/W  | 1'h1           | de-bounce mechanism enable or disable:<br>1 enable,0 disable(bypass) |
| 1              | [13:12] | RO   | 2'd0           | Reserved                                                             |
| DBNC_CNT       | [11:0]  | R/W  | 12'h032        | de-bounce counter period value setting, the unit is millisecond      |

## 6.9.4.2.11 EIC2CTRL

Description: EIC2 control register



| 0x0048 |               |          | (rese | t 0x00 | 00_40 | 32) |    |      |       |      |       |    |    |    | EIC2 | CTRL |
|--------|---------------|----------|-------|--------|-------|-----|----|------|-------|------|-------|----|----|----|------|------|
| Bit    | 31            | 30       | 29    | 28     | 27    | 26  | 25 | 24   | 23    | 22   | 21    | 20 | 19 | 18 | 17   | 16   |
| Name   |               |          |       |        |       |     |    | Rese | erved |      |       |    |    |    |      |      |
| Туре   |               |          |       |        |       |     |    | R    | 0     |      |       |    |    |    |      |      |
| 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   | F R L L K B C | DB NC LE | Rese  | erved  |       |     |    |      |       | DBNC | C_CNT |    |    |    |      |      |
| Туре   | R/W           | R/W      | R     | 0      |       |     |    |      |       | R    | W     |    |    |    |      |      |
| Reset  | 0             | 1        | 0     | 0      | 0     | 0   | 0  | 0    | 0     | 0    | 1     | 1  | 0  | 0  | 1    | 0    |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                          |
|----------------|---------|------|----------------|----------------------------------------------------------------------|
| 1              | [31:16] | RO   | 16'd0          | Reserved                                                             |
| FORCE_CLK_DBNC | [15]    | R/W  | 1'h0           | 1: clock of dbnc forced open; 0: no effect                           |
| DBNC_EN        | [14]    | R/W  | 1'h1           | de-bounce mechanism enable or disable:<br>1 enable,0 disable(bypass) |
| /              | [13:12] | RO   | 2'd0           | Reserved                                                             |
| DBNC_CNT       | [11:0]  | R/W  | 12'h032        | de-bounce counter period value setting, the unit is millisecond      |

# 6.9.4.2.12 EIC3CTRL

Description: EIC3 control register



| 0x004C |                                        |                     | (rese | t 0x00 | 00_40 | 32) |    |      |       |      |       |    |    |    | EIC3 | CTRL |
|--------|----------------------------------------|---------------------|-------|--------|-------|-----|----|------|-------|------|-------|----|----|----|------|------|
| Bit    | 31                                     | 30                  | 29    | 28     | 27    | 26  | 25 | 24   | 23    | 22   | 21    | 20 | 19 | 18 | 17   | 16   |
| Name   |                                        |                     |       |        |       |     |    | Rese | erved |      |       |    |    |    |      |      |
| Туре   |                                        |                     |       |        |       |     |    | R    | 0     |      |       |    |    |    |      |      |
| 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   | FO<br>RC<br>E_<br>CL<br>K_<br>DB<br>NC | DB<br>NC<br>_E<br>N | Rese  | erved  |       |     |    |      |       | DBNC | C_CNT |    |    |    |      |      |
| Туре   | R/W                                    | R/W                 | R     | 0      |       |     |    |      |       | R    | w     |    |    |    |      |      |
| Reset  | 0                                      | 1                   | 0     | 0      | 0     | 0   | 0  | 0    | 0     | 0    | 1     | 1  | 0  | 0  | 1    | 0    |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                          |
|----------------|---------|------|----------------|----------------------------------------------------------------------|
| 1              | [31:16] | RO   | 16'd0          | Reserved                                                             |
| FORCE_CLK_DBNC | [15]    | R/W  | 1'h0           | 1: clock of dbnc forced open; 0: no effect                           |
| DBNC_EN        | [14]    | R/W  | 1'h1           | de-bounce mechanism enable or disable:<br>1 enable,0 disable(bypass) |
| /              | [13:12] | RO   | 2'd0           | Reserved                                                             |
| DBNC_CNT       | [11:0]  | R/W  | 12'h032        | de-bounce counter period value setting, the unit is millisecond      |

# 6.9.4.2.13 EIC4CTRL

Description: EIC4 control register



| 0x0050 |               |                     | (rese | t 0x00 | 00_40                     | 32) |    |      |       |      |       |    |    |    | EIC4 | CTRL |
|--------|---------------|---------------------|-------|--------|---------------------------|-----|----|------|-------|------|-------|----|----|----|------|------|
| Bit    | 31            | 30                  | 29    | 28     | 27                        | 26  | 25 | 24   | 23    | 22   | 21    | 20 | 19 | 18 | 17   | 16   |
| Name   |               |                     |       |        |                           |     |    | Rese | erved |      |       |    |    |    |      |      |
| Туре   |               |                     |       |        |                           |     |    | R    | 0     |      |       |    |    |    |      |      |
| 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   | F R L L K B C | DB<br>NC<br>_E<br>N | Rese  | erved  |                           |     |    |      |       | DBNC | C_CNT |    |    |    |      |      |
| Туре   | R/W           | R/W                 | R     | 0      |                           |     |    |      |       | R    | w     |    |    |    |      |      |
| Reset  | 0             | 1                   | 0     | 0      | 0                         | 0   | 0  | 0    | 0     | 0    | 1     | 1  | 0  | 0  | 1    | 0    |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                          |
|----------------|---------|------|----------------|----------------------------------------------------------------------|
| 1              | [31:16] | RO   | 16'd0          | Reserved                                                             |
| FORCE_CLK_DBNC | [15]    | R/W  | 1'h0           | 1: clock of dbnc forced open; 0: no effect                           |
| DBNC_EN        | [14]    | R/W  | 1'h1           | de-bounce mechanism enable or disable:<br>1 enable,0 disable(bypass) |
| /              | [13:12] | RO   | 2'd0           | Reserved                                                             |
| DBNC_CNT       | [11:0]  | R/W  | 12'h032        | de-bounce counter period value setting, the unit is millisecond      |

# 6.9.4.2.14 EIC5CTRL

Description: EIC5 control register



| 0x0054 |                                        |                     | (rese | t 0x00 | 00_40 | 32) |    |      |       |      |       |    |    |    | EIC5 | CTRL |
|--------|----------------------------------------|---------------------|-------|--------|-------|-----|----|------|-------|------|-------|----|----|----|------|------|
| Bit    | 31                                     | 30                  | 29    | 28     | 27    | 26  | 25 | 24   | 23    | 22   | 21    | 20 | 19 | 18 | 17   | 16   |
| Name   |                                        |                     |       |        |       |     |    | Rese | erved |      |       |    |    |    |      |      |
| Туре   |                                        |                     |       |        |       |     |    | R    | 0     |      |       |    |    |    |      |      |
| 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   | FO<br>RC<br>E_<br>CL<br>K_<br>DB<br>NC | DB<br>NC<br>_E<br>N | Rese  | erved  |       |     |    |      |       | DBNC | C_CNT |    |    |    |      |      |
| Туре   | R/W                                    | R/W                 | R     | 0      |       |     |    |      |       | R    | w     |    |    |    |      |      |
| Reset  | 0                                      | 1                   | 0     | 0      | 0     | 0   | 0  | 0    | 0     | 0    | 1     | 1  | 0  | 0  | 1    | 0    |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                          |
|----------------|---------|------|----------------|----------------------------------------------------------------------|
| 1              | [31:16] | RO   | 16'd0          | Reserved                                                             |
| FORCE_CLK_DBNC | [15]    | R/W  | 1'h0           | 1: clock of dbnc forced open; 0: no effect                           |
| DBNC_EN        | [14]    | R/W  | 1'h1           | de-bounce mechanism enable or disable:<br>1 enable,0 disable(bypass) |
| /              | [13:12] | RO   | 2'd0           | Reserved                                                             |
| DBNC_CNT       | [11:0]  | R/W  | 12'h032        | de-bounce counter period value setting, the unit is millisecond      |

# 6.9.4.2.15 EIC6CTRL

Description: EIC6 control register



| 0x0058 |                      |                     | (rese | t 0x00 | 00_40 | 32) |    |      |       |      |       |    |    |    | EIC6 | CTRL |
|--------|----------------------|---------------------|-------|--------|-------|-----|----|------|-------|------|-------|----|----|----|------|------|
| Bit    | 31                   | 30                  | 29    | 28     | 27    | 26  | 25 | 24   | 23    | 22   | 21    | 20 | 19 | 18 | 17   | 16   |
| Name   |                      |                     |       |        |       |     |    | Rese | erved |      |       |    |    |    |      |      |
| Туре   |                      |                     |       |        |       |     |    | R    | 0     |      |       |    |    |    |      |      |
| 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   | FO RC E_ CL K_ DB NC | DB<br>NC<br>_E<br>N | Rese  | erved  |       |     |    |      |       | DBNC | C_CNT |    |    | C  |      |      |
| Туре   | R/W                  | R/W                 | R     | 0      |       |     |    |      |       | R    | w     |    |    |    |      |      |
| Reset  | 0                    | 1                   | 0     | 0      | 0     | 0   | 0  | 0    | 0     | 0    | 1     | 1  | 0  | 0  | 1    | 0    |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                          |
|----------------|---------|------|----------------|----------------------------------------------------------------------|
| 1              | [31:16] | RO   | 16'd0          | Reserved                                                             |
| FORCE_CLK_DBNC | [15]    | R/W  | 1'h0           | 1: clock of dbnc forced open; 0: no effect                           |
| DBNC_EN        | [14]    | R/W  | 1'h1           | de-bounce mechanism enable or disable:<br>1 enable,0 disable(bypass) |
| /              | [13:12] | RO   | 2'd0           | Reserved                                                             |
| DBNC_CNT       | [11:0]  | R/W  | 12'h032        | de-bounce counter period value setting, the unit is millisecond      |

# 6.9.4.2.16 EIC7CTRL

Description: EIC7 control register



| 0x005C |                                        |                     | (rese | t 0x00 | 00_40 | 32) |    |      |       |      |     |    |    |    | EIC7 | CTRL |
|--------|----------------------------------------|---------------------|-------|--------|-------|-----|----|------|-------|------|-----|----|----|----|------|------|
| Bit    | 31                                     | 30                  | 29    | 28     | 27    | 26  | 25 | 24   | 23    | 22   | 21  | 20 | 19 | 18 | 17   | 16   |
| Name   |                                        |                     |       |        |       |     |    | Rese | erved |      |     |    |    |    |      |      |
| Туре   |                                        |                     |       |        |       |     |    | R    | 0     |      |     |    |    |    |      |      |
| 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  | 3    | 2     | 1    | 0   |    |    |    |      |      |
| Name   | FO<br>RC<br>E_<br>CL<br>K_<br>DB<br>NC | DB<br>NC<br>_E<br>N | Rese  | erved  |       |     |    |      |       | DBNC | CNT |    |    |    |      |      |
| Туре   | R/W                                    | R/W                 | R     | 0      |       | R/W |    |      |       |      |     |    |    |    |      |      |
| Reset  | 0                                      | 1                   | 0     | 0      | 0     | 0   | 0  | 0    | 0     | 0    | 1   | 1  | 0  | 0  | 1    | 0    |

| Field-Name     | Bit     | Туре | Reset<br>Value | Description                                                          |
|----------------|---------|------|----------------|----------------------------------------------------------------------|
| /              | [31:16] | RO   | 16'd0          | Reserved                                                             |
| FORCE_CLK_DBNC | [15]    | R/W  | 1'h0           | 1: clock of dbnc forced open; 0: no effect                           |
| DBNC_EN        | [14]    | R/W  | 1'h1           | de-bounce mechanism enable or disable:<br>1 enable,0 disable(bypass) |
| /              | [13:12] | RO   | 2'd0           | Reserved                                                             |
| DBNC_CNT       | [11:0]  | R/W  | 12'h032        | de-bounce counter period value setting, the unit is millisecond      |

## 6.9.4.2.17 SICINTEN

Description: SIC interrupt enable register

| 0x0000 |    |          | (res | et 0x0 | 000_0 | 000) |    |      |       |          |    |    |    |    | SICI | NTEN |  |  |
|--------|----|----------|------|--------|-------|------|----|------|-------|----------|----|----|----|----|------|------|--|--|
| Bit    | 31 | 30       | 29   | 28     | 27    | 26   | 25 | 24   | 23    | 22       | 21 | 20 | 19 | 18 | 17   | 16   |  |  |
| Name   |    |          |      |        |       |      |    | Rese | erved |          |    |    |    |    |      |      |  |  |
| Туре   |    | 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   |    | Reserved |      |        |       |      |    |      |       | SICINTEN |    |    |    |    |      |      |  |  |
| Туре   |    |          |      | R      | 0     |      |    |      | RW    |          |    |    |    |    |      |      |  |  |
| Reset  | 0  | 0        | 0    | 0      | 0     | 0    | 0  | 0    | 0     | 0        | 0  | 0  | 0  | 0  | 0    | 0    |  |  |

|--|



|          | [31:8] | RO | 24'h0 | Reserved                                                                              |
|----------|--------|----|-------|---------------------------------------------------------------------------------------|
| SICINTEN | [7:0]  | RW | 8'h0  | SIC interrupt enable register:  "1": enable bit interrupt  "0": disable bit interrupt |

### 6.9.4.2.18 SICINTRAW

Description: SIC raw interrupt register

| 0x0004 |    |    | (res | et 0x0 | 000_00 | 000) |    |      |           |    |    |    | SICINTRAW |    |    |    |  |
|--------|----|----|------|--------|--------|------|----|------|-----------|----|----|----|-----------|----|----|----|--|
| Bit    | 31 | 30 | 29   | 28     | 27     | 26   | 25 | 24   | 23        | 22 | 21 | 20 | 19        | 18 | 17 | 16 |  |
| Name   |    |    |      |        |        |      |    | Rese | eserved   |    |    |    |           |    |    |    |  |
| Туре   |    | 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   |    |    |      | Rese   | erved  |      |    |      | SICINTRAW |    |    |    |           |    |    |    |  |
| Туре   |    |    |      | R      | 0      |      |    |      | RW        |    |    |    |           |    |    |    |  |
| Reset  | 0  | 0  | 0    | 0      | 0      | 0    | 0  | 0    | 0         | 0  | 0  | 0  | 0         | 0  | 0  | 0  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                            |
|------------|--------|------|----------------|----------------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                               |
| SICINTRAW  | [7:0]  | RW   | 8'h0           | SIC raw interrupt status register:  "1" interrupt condition met  "0" condition not met |

### 6.9.4.2.19 SICINTMSK

Description: SIC interrupt mask register

| 0x0008 |                           |    | (res | et 0x0 | 000_0 | 000) |    |      |         |    |    |       | SICINTMSK |   |   |   |  |
|--------|---------------------------|----|------|--------|-------|------|----|------|---------|----|----|-------|-----------|---|---|---|--|
| Bit    | 31                        | 30 | 29   | 28     | 27    | 26   | 25 | 24   | 23      | 22 | 18 | 17    | 16        |   |   |   |  |
| Name   |                           |    |      |        |       |      |    | Rese | eserved |    |    |       |           |   |   |   |  |
| Туре   |                           | RO |      |        |       |      |    |      |         |    |    |       |           |   |   |   |  |
| 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   |                           |    |      | Rese   | erved |      |    |      |         |    |    | SICIN | TMSK      |   |   |   |  |
| Туре   |                           |    |      | R      | 0     |      |    |      |         |    |    | R     | 0         |   |   |   |  |
| Reset  | 0                         | 0  | 0    | 0      | 0     | 0    | 0  | 0    | 0       | 0  | 0  | 0     | 0         | 0 | 0 | 0 |  |



| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                 |
|------------|--------|------|----------------|-----------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                    |
| SICINTMSK  | [7:0]  | RO   | 8'h0           | SIC interrupt mask register  "1" Interrupt active  "0" interrupt not active |

Note: SICINTMSK = SICINTEN & SICINTRAW, and SICINTMSK are connected to the set port of Latch

### 6.9.4.2.20 SICINTCLR

Description: SIC interrupt clear register

| 0x000C |    |    | (res | et 0x0 | 000_0 | 000) |    |      |           |    |    | _  | SICINTCLR |    |    |    |  |
|--------|----|----|------|--------|-------|------|----|------|-----------|----|----|----|-----------|----|----|----|--|
| Bit    | 31 | 30 | 29   | 28     | 27    | 26   | 25 | 24   | 23        | 22 | 21 | 20 | 19        | 18 | 17 | 16 |  |
| Name   |    |    |      |        |       |      |    | Rese | eserved   |    |    |    |           |    |    |    |  |
| Туре   |    | 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   |    |    |      | Rese   | erved |      |    |      | SICINTCLR |    |    |    |           |    |    |    |  |
| Туре   |    |    |      | R      | 0     |      |    |      | 1         |    |    | V  | VO        |    |    |    |  |
| Reset  | 0  | 0  | 0    | 0      | 0     | 0    | 0  | 0    | 0         | 0  | 0  | 0  | 0         | 0  | 0  | 0  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                     |
|------------|--------|------|----------------|---------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                        |
| SICINTCLR  | [7:0]  | WO   | 8'h0           | SIC interrupt clear register: "1" clears detected interrupt. "0" has no effect. |

Note: SICINTCLR are connected to the "clear" port of Latch, and it need disable the "set" port of Latch by changing SICINTPOL to clear SIC interrupt.

### 6.9.4.2.21 SICINTPOL

Description: SIC interrupt polarity register



| 0x0010 |                         |    | (res | et 0x0 | 000_00 | 000) |    |      |         |    |    |       |       | SICINTPOL |    |    |  |
|--------|-------------------------|----|------|--------|--------|------|----|------|---------|----|----|-------|-------|-----------|----|----|--|
| Bit    | 31                      | 30 | 29   | 28     | 27     | 26   | 25 | 24   | 23      | 22 | 21 | 20    | 19    | 18        | 17 | 16 |  |
| Name   |                         |    |      |        |        |      |    | Rese | eserved |    |    |       |       |           |    |    |  |
| Туре   |                         | RO |      |        |        |      |    |      |         |    |    |       |       |           |    |    |  |
| 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   |                         |    |      | Rese   | erved  |      |    |      |         |    |    | SICIN | NTPOL |           |    |    |  |
| Туре   |                         |    |      | R      | 0      |      |    |      | 1       |    |    |       | RW    |           |    |    |  |
| Reset  | 0 0 0 0 0 0 0           |    |      |        |        |      |    |      | 0       | 0  | 0  | 0     | 0     | 0         | 0  | 0  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                     |
|------------|--------|------|----------------|-------------------------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                                        |
| SICINTPOL  | [7:0]  | RW   | 8'h0           | SIC polarity register: "0": high levels trigger interrupts, "1": low levels trigger interrupts. |

### 6.9.4.2.22 SICINTMODE

Description: SIC interrupt mode register

| 0x0014 |    |          | (res | et 0x0 | 000_0 | 000) |    |    |            |    |    |    |    | SI | ICINTM | 10DE |
|--------|----|----------|------|--------|-------|------|----|----|------------|----|----|----|----|----|--------|------|
| Bit    | 31 | 30       | 29   | 28     | 27    | 26   | 25 | 24 | 23         | 22 | 21 | 20 | 19 | 18 | 17     | 16   |
| Name   |    | Reserved |      |        |       |      |    |    |            |    |    |    |    |    |        |      |
| Туре   |    | 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   |    |          |      | Rese   | erved |      |    |    | SICINTMODE |    |    |    |    |    |        |      |
| Туре   |    |          |      | R      | 0     |      |    |    | RW         |    |    |    |    |    |        |      |
| Reset  | 0  | 0        | 0    | 0      | 0     | 0    | 0  | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0      | 0    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                   |
|------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                                                      |
| SICINTMODE | [7:0]  | RW   | 8'h0           | SIC interrupt mode register:  "1": interrupt active without chip sleep  "0": interrupt active with chip sleep |



## 6.9.4.2.23 Related Clock & Interrupt control registers

Table 5 Related Clock & Interrupt control registers

| Address     | Register Name  | Bit Pos | Default | Description                                                                     |
|-------------|----------------|---------|---------|---------------------------------------------------------------------------------|
| 0x2090_0214 | CTRL0          | [3]     | 1       | APB clock Enable of total system                                                |
| 0x2090_0218 | CTRL5          | [0]     | 1       | Remap control                                                                   |
| 0x8000_3000 | ARM_INT_STATUS | [24]    | 0       | ARM interrupt status, using No.8 interrupt for EIC and No.24 interrupt for EICA |
| 0x8000_3008 | ARM_INT_EN     | [24]    | 0       | ARM interrupt enable                                                            |
| 0x8000_300c | ARM_INT_DIS    | [24]    | 0       | ARM interrupt disable/clear                                                     |
| 0x8B00_0008 | GEN0           | [6]     | 1       | Enable ADI's PCLK                                                               |
| 0x8B00_005C | GLB_DLY        | [29]    | 1       | Enable clk_adi                                                                  |
| 0x8200_0024 | ADI_READ_CMD   | [25:0]  | 0       | ADI read command register                                                       |
| 0x8200_0028 | ADI_READ_DATA  | [31:0]  | 0       | To obtain register value                                                        |
| 0x8B00_0008 | GEN0           | [9]     | 0       | APB clock Enable of EIC module                                                  |
| 0x8B00_0008 | GEN0           | [24]    | 0       | Rtcdiv5_clk Enable of EIC module                                                |
| 0x8200_0600 | ADI_AGEN       | [3]     | 0       | APB clock Enable of EICA                                                        |
| 0x8200_0600 | ADI_AGEN       | [11]    | 0       | Rtcdiv5_clk clock Enable of EICA                                                |
| 0x8B00_0008 | GEN0           | [13]    | 0       | Pin control register bit                                                        |
| 0x8B00_004C | GEN3           | [29]    | 0       | Software reset EIC module                                                       |



## 6.9.5 Application Notes

#### 6.9.5.1 Programming Model

For EIC sub-module, software needs to adopt corresponding steps as follows:

- 1) When system resets, EIC module is also under the reset status and cannot capture the EIC input signals. At the process of system initialization, ARM needs to configure the EIC input signal detecting conditions, such as '1'/'0' detection, read INT status registers and write EICIC to clear the EIC INTs. Then, if necessary, ARM sends a trig\_start pulse to commence one EIC signal detection process. Before system enters deep-sleep mode or closes PCLK, it ought to assure that EIC INT has been enabled and cleared and system has sent out active trig\_start pulse.
- 2) After receiving the trig\_start pulse, EIC module starts the process of EIC signal detection. If EIC captures one stable input signal, it will send an INT to ARM, shut off the clock of debounce circuit automatically and wait for next trig\_start pulse.
- 3) When ARM receives the EIC INT again, it enters INT process flow. And if EIC input condition changes, ARM needs to configure those detecting condition registers again. Then, if necessary, ARM sends a trig\_start pulse again to commence a new EIC signal detection process.
- 4) Step 1 to step 3 cycles.
- 5) For the debounce bypass mode, ARM can receive INT without the need of sending trig\_start pulse.

#### **6.9.5.2** Programming Notes

- 1) The register, EICIEV, is used to set the input signal constraints for INT trigger.
- 2) EICINT comes from EICMIS, which EICMIS is equal to EICIE & EICRIS. So, if it needs to get some EIC' INT, the EICIE should be unmasked. And if ARM has received one EIC INT, it maybe need to mask the corresponding bit of EICIE to avoid to received the same INT, and set corresponding bits 1 to of EICIC.
- 3) The interval of two EIC trigger instructions needs be longer than 2 ms.
- 4) To quit EIC FSM correctly, it needs 2 or 3 additional milliseconds. So it needs consider the additional time for exact debounce period.

# 6.10 Auxiliary ADC

### 6.10.1 Overview

The AuxADC is a 16-channel ADC, it samples VBAT voltage, touch panel signals, etc. The channel assignment is shown in the following table:

Table 6-5 ADC Channel Assignment

| Channel ID | Application                                                        |
|------------|--------------------------------------------------------------------|
| Ch0        | General signal input channel, the signal is from external input.   |
| Ch1        | General signal input channel, the signal is from external input.   |
| Ch2        | TPC X signal input channel, the signal is from external input.     |
| Ch3        | TPC Y signal input channel, the signal is from external input.     |
| Ch4        | PROG2ADC (in Charger) signal input channel, the signal is on chip. |
| Ch5        | VBAT signal input channel, the signal is on chip.                  |



| Ch6       | VCHGSEN signal input channel, the signal is on chip.             |
|-----------|------------------------------------------------------------------|
| Ch7       | General signal input channel, the signal is from external input. |
| Ch8       | General signal input channel, the signal is from external input. |
| Ch9       | VCHGBandGap signal input channel, the signal is on chip.         |
| Ch10      | VDCDC to ARM signal input channel, the signal is on chip.        |
| Ch11      | VDCDC to others signal input channel, the signal is on chip.     |
| Ch12~Ch15 | Reserved                                                         |

The ADC mainly arbitrates multi-channel ADC request and controls the sampling process of analog part. Among these 16 channels, all channels can be controlled by SW, and therefore, they are called SW channels. When some channel is used to measure touch panel signals, the touch panel controller (TPC) can control its sampling, they are also called HW channels.

#### 6.10.2 Features

- I Sample frequency >= 85 kHz;
- I Support arbitration between SW and HW channels;
- I Support up to 16 channels;
- I Support interrupt functions;
- I Configurable channel ID for TPC channel;
- I Configurable sampling delay for TPC channel;

## 6.10.3 Signal Description

There are 16 signal sources to ADC, 6 are from external, 4 are connected on chip and others are reserved. The external input signals are for ADC channels 0, 1, 2, 3, 7 and 8, as listed in the following table:

Table 6-6 ADC signal list

| Signal Name | Direction | Width | Description                                         |
|-------------|-----------|-------|-----------------------------------------------------|
| ADCI0 (Ch0) | Ab        | 1     | General signal input, it is for ADC channel 0.      |
| ADCI1 (Ch1) | I         | 1     | General signal input, it is for ADC channel 1.      |
| TP_XL (Ch2) | I/O       | 1     | TPC signal in Y direction, it is for ADC channel 3. |
| TP_YD (Ch3) | I/O       | 1     | TPC signal in X direction, it is for ADC channel 2. |
| ADCI2 (Ch7) | I         | 1     | General signal input, it is for ADC channel 7.      |
| ADCI3 (Ch8) | I         | 1     | General signal input, it is for ADC channel 8.      |

### 6.10.4 Function Description

The ADC application circuit is as follows.





Figure 6-39 ADC Application Diagram

The ADC is controlled by system through APB bus, and it is used to check 16 signals from different sources. ADC does the channel arbitration and ADC conversion control. Because channels 2 and 3 are for TPC, there are some signals between ADC and TPC for their interaction. The ADC's block diagram is shown in the following figure.



Figure 6-40 ADC controller block diagram

The ADC includes a digital control part and an analog conversion part. The digital control part arbitrates and responds to the sampling request, sends the control to the analog part. The analog part consist of a DAC (digital to analog convertor), and a comparator. The DAC converses the input data to a reference voltage, while the comparator compares the reference voltage and input voltage and sends out a compare result.

First, the digital part powers up the analog part, and gives an initial data (0x200) to the analog part. After the initial process, the ADC starts the MSB conversion. The initial data is for half reference voltage. If the input voltage is greater than it, the data will be changed to 0x300, else the data will be changed to 0x100. After such 10 iterations, all 10 bits are complete, and the active ADC data occurs and can be outputted. The ADC conversion process is as in the figure below.





Figure 6-41 ADC Conversion

The TPC channels have larger internal resistance than others channels, so they need longer initial time, it includes 26 6.5MHz clocks, others are 10 6.5MHz clocks. When ADC is controlled by SW entirely, every channel can use the ADC one by one without request confliction. But the TPC can always run, the ADC can arbitrate the requests from SW channel or TPC channel automatically, so software can insert SW request randomly, the switch of ADC between SW channels and TPC channels is as below.



Figure 6-42 ADC Switch Diagram

Normally, the TPC holds the ADC for a long time and it is HW request, so we assign a lower priority for HW channels, a higher priority for SW channels. When there is only one channel active, ADC responds to it. When there are two requests, ADC will respond to the SW channel first, then the HW one. ADC's response is at the end of sampling, thus it can guarantee every sampling is an atom operation.

An example for ADC usage is shown in the following figure.



Figure 6-43 ADC Usage Example

### 6.10.5 Control Registers

## **6.10.5.1 Memory map**

ARM base address: 0x8200\_0300



| Offset<br>Address | Name            | Description               |
|-------------------|-----------------|---------------------------|
| 0x0000            | ADC_CTRL        | ADC control               |
| 0x0004            | ADC_CS          | ADC channel configuration |
| 0x0008            | ADC_TPC_CH_CTRL | TPC channel control       |
| 0x000C            | ADC_DAT         | ADC data                  |
| 0x0010            | ADC_IRQ_EN      | ADC interrupt enable      |
| 0x0014            | ADC_IRQ_CLR     | ADC interrupt clear       |
| 0x0018            | ADC_IRQ_STATUS  | ADC interrupt status      |
| 0x001C            | ADC_IRQ_SRC     | ADC interrupt source      |

## 6.10.5.2 Register Descriptions

## 6.10.5.2.1 ADC\_CTRL

Description: ADC module control.

| 0x0000 |    |          | ADC | contro | ol regis | ster (re | eset 0x | (0) |    |    |    |                        |                   | ADC_CTRL          |                  |            |  |  |
|--------|----|----------|-----|--------|----------|----------|---------|-----|----|----|----|------------------------|-------------------|-------------------|------------------|------------|--|--|
| Bit    | 31 | 30       | 29  | 28     | 27       | 26       | 25      | 24  | 23 | 22 | 21 | 20                     | 19                | 18                | 17               | 16         |  |  |
| Name   |    | Reserved |     |        |          |          |         |     |    |    |    |                        |                   |                   |                  |            |  |  |
| Туре   |    |          |     |        |          |          |         | R   | 0  |    |    |                        |                   |                   |                  |            |  |  |
| 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   |    |          |     |        | ſ        | Reserved | 1       |     |    |    |    | ADC<br>_ST<br>ATU<br>S | HW_<br>INT_<br>EN | TPC<br>_CH<br>_ON | SW_<br>CH_<br>ON | ADC<br>_EN |  |  |
| Туре   |    |          |     |        |          | RO       |         |     |    |    |    | RO                     | 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          |  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                |
|------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------|
|            | [31:5] | RO   | 27'h0          | Reserved                                                                                                                   |
| ADC_STATUS | [4]    | RO   | 1'h0           | ADC sampling status, 1: for completing an active sampling                                                                  |
| HW_INT_EN  | [3]    | R/W  | 1'h0           | TPC channel IRQ enable, It is only for test purpose.                                                                       |
| TPC_CH_ON  | [2]    | R/W  | 1'h0           | TPC channel on/off, 0: turn off TPC channel; 1: turn on TPC channel. It is only for TPC channel, here, is for channel 2/3. |
| SW_CH_ON   | [1]    | R/W  | 1'h0           | SW channel on/off, 0: turn off some a SW channel; 1: turn on some a SW channel.                                            |
| ADC_EN     | [0]    | R/W  | 1'h0           | ADC global enable,                                                                                                         |



|  | 0: ADC module disable; |
|--|------------------------|
|  | 1: ADC module enable.  |

### 6.10.5.2.2 ADC\_CS

Description: ADC channel configuration.

| 0x0004 |    |            | ADC | chann | el con | figura | tion (r | eset 0 | (Of) |    |                  |                   |        | ADC_CS |    |    |  |
|--------|----|------------|-----|-------|--------|--------|---------|--------|------|----|------------------|-------------------|--------|--------|----|----|--|
| Bit    | 31 | 30         | 29  | 28    | 27     | 26     | 25      | 24     | 23   | 22 | 21               | 20                | 19     | 18     | 17 | 16 |  |
| Name   |    | Reserved   |     |       |        |        |         |        |      |    |                  |                   |        |        |    |    |  |
| Туре   |    | 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   |    |            |     |       | Rese   | erved  |         |        |      |    | ADC<br>_SL<br>OW | ADC<br>_SC<br>ALE | ADC_CS |        |    |    |  |
| Туре   |    | RO R/W R/W |     |       |        |        |         |        |      |    |                  | R/W               | R/W    |        |    |    |  |
| Reset  | 0  | 0          | 0   | 0     | 0      | 0      | 0       | 0      | 0    | 0  | 0                | 0                 | 1      | 1      | 1  | 1  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                    |
|------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:6] | RO   | 26'h0          | Reserved                                                                                                                                       |
| ADC_SLOW   | [5]    | R/W  | 1'h0           | ADC coversion speed control, 0: quick mode, coversion initial includes 10 ADC clocks; 1: slow mode, conversion initial includes 26 ADC clocks. |
| ADC_SCALE  | [4]    | R/W  | 1'h0           | ADC scale setting for current ADC channel, 0: little scale, 0 ~ 1.2 V; 1: big scale, 0 ~ 3.0 V.                                                |
| ADC_CS     | [3:0]  | R/W  | 4'h0           | ADC channel ID, It is in 0 ~ 15.                                                                                                               |

# 6.10.5.2.3 ADC\_TPC\_CH\_CTRL

Description: TPC channel control.

| 0x0008 |    | U           | TPC | chann  | el con  | trol (re | set 0x | 32)  |       |      |      |    | ADC_TPC_CH_CTRL |      |      |    |  |
|--------|----|-------------|-----|--------|---------|----------|--------|------|-------|------|------|----|-----------------|------|------|----|--|
| Bit    | 31 | 30          | 29  | 28     | 27      | 26       | 25     | 24   | 23    | 22   | 21   | 20 | 19              | 18   | 17   | 16 |  |
| Name   |    |             |     |        |         |          |        | Rese | erved |      |      |    |                 |      |      |    |  |
| Туре   |    |             | 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   |    |             | -   | TPC_CH | I_DELAY | ,        |        |      |       | TPC_ | Y_CH |    |                 | TPC_ | X_CH |    |  |
| Туре   |    | R/W R/W R/W |     |        |         |          |        |      |       |      |      |    |                 |      |      |    |  |
| Reset  | 0  | 0           | 0   | 0      | 0       | 0        | 0      | 0    | 0     | 0    | 1    | 1  | 0               | 0    | 1    | 0  |  |



| Field Name   | Bit     | Туре | Reset<br>Value | Description                                               |
|--------------|---------|------|----------------|-----------------------------------------------------------|
|              | [31:16] | RO   | 16'h0          | Reserved                                                  |
| TPC_CH_DELAY | [15:8]  | R/W  | 8'h0           | TPC channel sampling delay, it is 6.5MHz clock number.    |
| TPC_Y_CH     | [7:4]   | R/W  | 4'h3           | TPC Y channel ID. it can be 0 ~ 15, here, it should be 3. |
| TPC_X_CH     | [3:0]   | R/W  | 4'h2           | TPC X channel ID. it can be 0 ~ 15, here, it should be 2. |

## 6.10.5.2.4 ADC\_DAT

Description: ADC conversion result.

| 0x000C |    |    | ADC   | data (   | reset 0 | )x0) |    |    |    |    |      |      |    |    | ADC | DAT |
|--------|----|----|-------|----------|---------|------|----|----|----|----|------|------|----|----|-----|-----|
| Bit    | 31 | 30 | 29    | 28       | 27      | 26   | 25 | 24 | 23 | 22 | 21   | 20   | 19 | 18 | 17  | 16  |
| Name   |    |    |       | Reserved |         |      |    |    |    |    |      |      |    |    |     |     |
| Туре   |    |    | 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   |    |    | Rese  | erved    |         |      |    |    |    |    | ADC_ | _DAT |    |    |     |     |
| Туре   |    |    | RO RO |          |         |      |    |    |    |    |      |      |    |    |     |     |
| Reset  | 0  | 0  | 0     | 0        | 0       | 0    | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0   | 0   |

| Field Name | Bit     | Туре | Reset<br>Value | Description            |
|------------|---------|------|----------------|------------------------|
|            | [31:10] | RO   | 22'h0          | Reserved               |
| ADC_DAT    | [9:0]   | RO   | 10'h0          | ADC conversion result. |

### 6.10.5.2.5 ADC\_IRQ\_EN

Description: ADC interrupt enable.

| 0x0010 |    |    | ADC | interru | upt en | able (r | eset 0: | x0)      |       |    |    |    |     | Αſ | DC_IR | Q_EN                   |
|--------|----|----|-----|---------|--------|---------|---------|----------|-------|----|----|----|-----|----|-------|------------------------|
| Bit    | 31 | 30 | 29  | 28      | 27     | 26      | 25      | 24       | 23    | 22 | 21 | 20 | 19  | 18 | 17    | 16                     |
| Name   |    |    |     |         |        |         |         | Rese     | erved |    |    |    |     |    |       |                        |
| Туре   |    |    | 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   |    |    |     |         |        |         |         | Reserved | i     |    |    |    |     |    |       | ADC<br>_IR<br>Q_E<br>N |
| Туре   |    | RO |     |         |        |         |         |          |       |    |    |    | R/W |    |       |                        |
| Reset  | 0  | 0  | 0   | 0       | 0      | 0       | 0       | 0        | 0     | 0  | 0  | 0  | 0   | 0  | 0     | 0                      |



| Field Name | Bit    | Туре | Reset<br>Value | Description                                                      |
|------------|--------|------|----------------|------------------------------------------------------------------|
|            | [31:1] | RO   | 31'h0          | Reserved                                                         |
| ADC_IRQ_EN | [0]    | R/W  | 1'h0           | ADC interrupt enable, 0: interrupt disable; 1: interrupt enable. |

## 6.10.5.2.6 ADC\_IRQ\_CLR

Description: ADC interrupt clear.

| 0x0014 |    |    | ADC | interr   | upt cle | ar (res | et 0x0 | )        |    |    |    |    |    | ADO | :_IRQ | CLR                     |
|--------|----|----|-----|----------|---------|---------|--------|----------|----|----|----|----|----|-----|-------|-------------------------|
| Bit    | 31 | 30 | 29  | 28       | 27      | 26      | 25     | 24       | 23 | 22 | 21 | 20 | 19 | 18  | 17    | 16                      |
| Name   |    |    |     | Reserved |         |         |        |          |    |    |    |    |    |     |       |                         |
| Туре   |    |    | 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   |    |    |     |          |         |         | ı      | Reserved | 1  |    |    |    |    |     |       | ADC<br>_IR<br>Q_C<br>LR |
| Туре   |    | RO |     |          |         |         |        |          |    |    |    | WO |    |     |       |                         |
| Reset  | 0  | 0  | 0   | 0        | 0       | 0       | 0      | 0        | 0  | 0  | 0  | 0  | 0  | 0   | 0     | 0                       |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                              |
|-------------|--------|------|----------------|------------------------------------------|
|             | [31:1] | RO   | 31'h0          | Reserved                                 |
| ADC_IRQ_CLR | [0]    | wo   | 1'h0           | ADC interrupt clear. Write "1" to clear. |

## 6.10.5.2.7 ADC\_IRQ\_STSTUS

Description: ADC masked interrupt.

| 0x0018 |    |    | ADC | interru  | upt sta | tus (re | eset 0x | (0)      |    |    |    |    | Α  | DC_IR | Q_ST | ATUS                           |
|--------|----|----|-----|----------|---------|---------|---------|----------|----|----|----|----|----|-------|------|--------------------------------|
| Bit    | 31 | 30 | 29  | 28       | 27      | 26      | 25      | 24       | 23 | 22 | 21 | 20 | 19 | 18    | 17   | 16                             |
| Name   |    |    |     | Reserved |         |         |         |          |    |    |    |    |    |       |      |                                |
| Туре   |    |    |     | 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   |    |    |     |          |         |         | ı       | Reserved | i  |    |    |    |    |       |      | ADC<br>_IR<br>Q_S<br>TAT<br>US |
| Туре   |    |    | RO  |          |         |         |         |          |    |    |    |    | RO |       |      |                                |
| Reset  | 0  | 0  | 0   | 0        | 0       | 0       | 0       | 0        | 0  | 0  | 0  | 0  | 0  | 0     | 0    | 0                              |



| Field-Name     | Bit    | Туре | Reset<br>Value | Description           |
|----------------|--------|------|----------------|-----------------------|
|                | [31:1] | RO   | 31'h0          | Reserved              |
| ADC_IRQ_STATUS | [0]    | RO   | 1'h0           | ADC masked interrupt. |

#### 6.10.5.2.8 ADC\_IRQ\_RAW

Description: ADC raw interrupt.

| 0x001C |    |    | ADC | raw in | terrup | t  |    |          |       |    |    |    |    | ADC | _IRQ_ | RAW                     |
|--------|----|----|-----|--------|--------|----|----|----------|-------|----|----|----|----|-----|-------|-------------------------|
| Bit    | 31 | 30 | 29  | 28     | 27     | 26 | 25 | 24       | 23    | 22 | 21 | 20 | 19 | 18  | 17    | 16                      |
| Name   |    |    |     |        |        |    |    | Rese     | erved |    |    |    |    |     |       |                         |
| Туре   |    |    | 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   |    |    |     |        |        |    | 1  | Reserved | i     |    |    |    |    |     |       | ADC<br>_IR<br>Q_R<br>AW |
| Туре   |    |    | RO  |        |        |    |    |          |       |    |    |    |    | RO  |       |                         |
| Reset  | 0  | 0  | 0   | 0      | 0      | 0  | 0  | 0        | 0     | 0  | 0  | 0  | 0  | 0   | 0     | 0                       |

| Field Name  | Bit    | Туре | Reset<br>Value | Description        |
|-------------|--------|------|----------------|--------------------|
|             | [31:1] | RO   | 31'h0          | Reserved           |
| ADC_IRQ_RAW | [0]    | RO   | 1'h0           | ADC raw interrupt. |

# 6.10.6 Application Notes

### 6.10.6.1 Program Flow

Before configure module, set some global parameters,

Set bit[13] of 0x8200\_0600 to enable CLK\_ADC;

Set bit[14] of 0x8200\_0600 to enable CLK\_AUXAD;

Set bit[5] of 0x8200\_0600 to enable AuxADC module;

Set or reset bit[4] of 0x8200\_0604 to reset AuxADC module;

Set bit[24] of 0x8000\_3008 to enable ADI interrupt, later, we need scan ADI interrupt status, check bit[0] of 0x8200\_0380 for ADC module interrupt and bit[4] of 0x8200\_0380 for TPC module interrupt;

Some registers are configured through ADI module, so ADI must be ready before do these.

### Flow for SW request channels

- Clear ARM's ADI interrupt and ADC interrupt, and enable them;
- Configure ADC module registers;
- Enable ADC module, set "ADC\_EN" bit of ADC\_CTRL, and the ADC is ready to work;



- When program needs to use ADC, set its channel ID, and switch on the ADC SW channel;
- When ARM's ADI interrupt asserts, and "adc\_irq" occurs or "adc\_status" flag become '1', read out the sample data;
- Switch off the ADC SW channel and set channel ID to last one.

### Flow for HW request channels (only for TPC application)

- Clear ARM's ADI interrpt, ADC interrupt and TPC interrupt, and enable them;
- Configure ADC and TPC registers;
- Enable ADC and TPC module, set "ADC\_EN" bit of ADC\_CTRL, and the ADC is ready to work;
- When TPC receives "down\_irq", switch on TPC channel, and run the TPC, then ADC will work;
- ADC responses the TPC's continue request, TPC responses to "done\_irq";
- If need insert SW ADC request, program insert SW request arbitrarily;
- When TPC receives "up\_irq", stop the TPC, switch off the TPC channel and cancel TPC selection.

### 6.10.6.2 Program Notes

- If channel 2 or 3 are used for TPC channel, then ADC\_CS[3:0] = 2 or ADC\_CS[3:0] = 3 are same function, it means that ADC\_CS[3:0] can be Y channel also can be X channel when for TPC application;
- SW should guarantee two SW channels cannot be accessed at same time;
- In SW channel control, switch on and switch off SW channel must be occurred in pair;
- When ADC is in sampling, do not change control registers randomly;
- When insert SW request, firstly, update channel selection etc. registers, lastly, switch on SW channel;

# 6.11 Touch Pannel Controller (TPC)

#### 6.11.1 Overview

SC6820 has one on-chip touch panel controller module, which shares both the channel 3 and channel 2 of auxiliary ADC. The TPC measures the position of pressure point, records these position information, and generates interrupts for system responding pen down/up and getting data.

### 6.11.2 Features

- I Support de-bouncing;
- I Support noise filter;
- I Support position calculation;
- I Configurable sampling time interval;
- I Configurable sample number;
- I Support 3-D measure with X/Y/Z;
- I Raw X/Y ADC output or X/Y position output;
- I Raw Z ADC output:
- I Support switch between X and Y analog input;
- I Support wake up;



### 6.11.3 Signal Description

There are 4 signals for sampling control. TP\_XL and TP\_XR are for X direction, and TP\_YU and TP\_YD are for Y direction; they are listed in the Table xx.

Table 6-7 TPC signal list

| Signal Name | Direction | Width | Description                                                                                                                          |
|-------------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------|
| TP_XL       | I/O       | 1     | High level output in X direction when it is output; TPC signal in Y direction when it is input, it is connected to AuxADC channel 3. |
| TP_XR       | 0         | 1     | Low level output in X direction.                                                                                                     |
| TP_YU       | 0         | 1     | High level output in Y direction.                                                                                                    |
| TP_YD       | I/O       | 1     | Low level output in Y direction when it is output; TPC signal in X direction when it is input, it is connected to AuxADC channel 2.  |

### 6.11.4 Function Description

The touch panel application circuit is as follows.



Figure 6-44 Touch panel application diagram

The TPC's block diagram is shown in the following figure.





Figure 6-45 TPC block diagram

The TPC includes de-bouncing, de-noise, data FIFO, sampling control logic, etc.

The TPC supports 3D measure, it means it can measure different input from X/Y/Z, the X/Y is used for location, and the Z is used for pressure.

The sampling of X/Y is shown below.



Figure 6-46 Sampling of X/Y

The sampling of Z is different from X/Y, and it is shown below.



Figure 6-47 Sampling of Z

The method is based X, Y, Z data,  $R_{touch} = (1024/Z-1) * R_x * X/1024 + R_y * (1-Y/1024)$ 



Here, X is raw ADC value of X, Y is raw ADC value of Y, Z is raw ADC value of Z,  $R_x$  is total resistance of X,  $R_y$  is total resistance of Y. Because above formulas include division, TPC only reports raw Z data, the  $R_{touch}$  or pressure is calculated by SW. The control of 4 TPC PAD is shown in the following table.

Table 6-8 TPC pad control

| PAD   | Sampling Y    | Sampling X    | Sampling Z1   | Idle              |
|-------|---------------|---------------|---------------|-------------------|
| TP_YU | output '1'    | input         | output '1'    | output '0'        |
| TP_YD | output '0'    | input to adc2 | input         | input             |
| TP_XL | input to adc3 | output '1'    | input to adc3 | input, pad wpu on |
| TP_XR | input         | output '0'    | output '0'    | input             |

The detail TPC sampling control flow is as in the following figure.



Figure 6-48 TPC sampling control flow

The de-bouncing logic checks the pen-down signal and cleans it. During pressing the panel, bounce always exists, and it may be short, or it may be long. In order to cancel some inactive pressing, de-bouncing is needed. A configurable check interval is used to control the input sample. If every result is the same in specified check times, it is considered an active pressing; otherwise, it is considered an inactive pressing. The de-bouncing process is show in the following figure.



Figure 6-49 De-bouncing diagram

The de-noise logic tries to remove the exceptional samples. After measuring, there are several sample values for one point. To get the most reasonable result, some processing is needed for these data, such as noise filtering.

The normal noise filter is an average filter or median filter. The average filter can get smoother signal wave, while the median filter is good to cancel discrete noise.

The average filter is as follows.

$$X = X_0C_0 + X_1C_1 + X_2C_2 + ... + X_nC_n$$

where  $X_i$  (I = 0, 1, ..., n) are sample values,  $C_i$  (I = 0, 1, ..., n) are filter coefficients, and X is filter output.

The median filter is as follows.

$$X = median(X_0, X_1, X_2, ..., X_n)$$

where  $X_i$  (I = 0, 1, ..., n) are sample values, X is filter output, and median() gets the median value from  $X_i$  (I = 0, 1, ..., n) sequence. For example, if  $X_0 < X_1 < X_2$ , median( $X_0$ ,  $X_1$ ,  $X_2$ ) =  $X_1$ .

Expect for calibration, we need the active coordinate data. We assume the panel is a linear device, so the X and Y positions are a linear function of their measured value. Therefore, their formulas are as follows.

$$X = a_X^* A_X + b_X$$
$$Y = a_Y^* A_Y + b_Y$$

X is sample result in horizontal,  $a_X$  and  $b_X$  are line parameters for X; Y is sample result in vertical,  $a_Y$  and  $b_Y$  are line parameters for Y.  $A_X$  and  $A_Y$  are ADC outputs.

If we configure the  $a_X$ ,  $b_X$ ,  $a_Y$  and  $b_Y$ , we can calculate the position result for every pressure based on the above formulas.

### 6.11.5 Control Registers

### 6.11.5.1 Memory map

ARM base address: 0x8200\_0280

| Offset<br>Address | Name             | Description                    |
|-------------------|------------------|--------------------------------|
| 0x0000            | TPC_CTRL         | Touch panel controller control |
| 0x0004            | TPC_SAMPLE_CTRL0 | TPC sample control0            |



| Offset<br>Address | Name              | Description                     |
|-------------------|-------------------|---------------------------------|
| 0x0008            | TPC_SAMPLE_CTRL1  | TPC sample control1             |
| 0x000C            | TPC_BOUNCE_CTRL   | TPC bounce control              |
| 0x0010            | TPC_FILTER_CTRL   | TPC filter control              |
| 0x0014            | TPC_CALC_CTRL     | TPC calculation control         |
| 0x0018            | TPC_CALC_X_COEF_A | TPC calculation x coefficient a |
| 0x001C            | TPC_CALC_X_COEF_B | TPC calculation x coefficient b |
| 0x0020            | TPC_CALC_Y_COEF_A | TPC calculation y coefficient a |
| 0x0024            | TPC_CALC_Y_COEF_B | TPC calculation y coefficient b |
| 0x0028            | TPC_IRQ_EN        | TPC interrupt enable            |
| 0x002C            | TPC_IRQ_STATUS    | TPC interrupt status            |
| 0x0030            | TPC_IRQ_RAW       | TPC raw interrupt status        |
| 0x0034            | TPC_IRQ_CLR       | TPC interrupt clear             |
| 0x0038            | TPC_BUF_CTRL      | TPC buffer control              |
| 0x003C            | TPC_X_DATA        | TPC X data                      |
| 0x0040            | TPC_Y_DATA        | TPC Y data                      |
| 0x0044            | TPC_Z_DATA        | TPC Z data                      |

# 6.11.5.2 Register Descriptions

### 6.11.5.2.1 TPC\_CTRL

Description: Touch panel control.

| 0x0000 |    |                             | Touc | h pan | el cont | rol (re | set 0x | 0d08) |      |       |                  |                 |                  |                                 | TPC_                    | CTRL       |
|--------|----|-----------------------------|------|-------|---------|---------|--------|-------|------|-------|------------------|-----------------|------------------|---------------------------------|-------------------------|------------|
| Bit    | 31 | 30                          | 29   | 28    | 27      | 26      | 25     | 24    | 23   | 22    | 21               | 20              | 19               | 18                              | 17                      | 16         |
| Name   |    | Reserved                    |      |       |         |         |        |       |      |       |                  |                 |                  |                                 |                         |            |
| Туре   |    | 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   |    |                             |      | PRES  | CALE    |         |        |       | Rese | erved | TPC<br>_ST<br>OP | TPC<br>_RU<br>N | TPC<br>_MO<br>DE | XY_I<br>NPU<br>T_S<br>WIT<br>CH | PEN<br>_RE<br>Q_P<br>OL | TPC<br>_EN |
| Туре   |    |                             |      | R/    | w w     |         |        |       | R    | 0     | wo               | wo              | R/W              | R/W                             | R/W                     | R/W        |
| Reset  | 0  | 0                           | 0    | 0     | 1       | 1       | 0      | 1     | 0    | 0     | 0                | 0               | 1                | 0                               | 0                       | 0          |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                     |
|------------|---------|------|----------------|-------------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                        |
| PRESCALE   | [15:8]  | R/W  | 8'h0d          | The pre-scale coefficient for ADC 6.5MHz clock. |



|                 |       |     |      | The divided clock is interval count clock. 0 and 1 as bypass.                            |
|-----------------|-------|-----|------|------------------------------------------------------------------------------------------|
|                 | [7:6] | RO  | 2'h0 | Reserved                                                                                 |
| TPC_STOP        | [5]   | WO  | 1'h0 | TPC stop control, write '1' to stop TPC work, and it is cleared by HW.                   |
| TPC_RUN         | [4]   | WO  | 1'h0 | TPC run control, write '1' to start TPC work, and it is cleared by HW.                   |
| TPC_MODE        | [3]   | R/W | 1'h1 | TPC work mode, 0: 2D mode, includes X and Y; 1: 3D mode, includes X, Y and Z1.           |
| XY_INPUT_SWITCH | [2]   | R/W | 1'h0 | X/Y analog input switch,  0: x for x, y for y;  1: x for y, y for x.                     |
| PEN_REQ_POL     | [1]   | R/W | 1'h0 | External pen request polarity, 0: '0' for down, '1' for up; 1: '0' for up, '1' for down. |
| TPC_EN          | [0]   | R/W | 1'h0 | Touch panel controller enable, 0: TPC disabled; 1: TPC enabled.                          |

# 6.11.5.2.2 TPC\_SAMPLE\_CTRL0

Description: TPC sample control.

| 0x0004 |    |                                                                                                                                                                         | TPC sample control0 (reset 0x4200) |          |        |    |   |   |   |   |    |        | TPC_SAMPLE_CTR |    |   |   |
|--------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------|--------|----|---|---|---|---|----|--------|----------------|----|---|---|
| Bit    | 31 | 31         30         29         28         27         26         25         24         23         22         21         20         19         18         17         16 |                                    |          |        |    |   |   |   |   |    |        |                | 16 |   |   |
| Name   |    | Reserved                                                                                                                                                                |                                    |          |        |    |   |   |   |   |    |        |                |    |   |   |
| Туре   |    | 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   |    |                                                                                                                                                                         | F                                  | POINT_II | NTERVA | L  |   |   |   |   | SA | AMPLE_ | INTERV         | AL |   |   |
| Туре   |    | R/W R/W                                                                                                                                                                 |                                    |          |        |    |   |   |   |   |    |        |                |    |   |   |
| Reset  | 0  | 1                                                                                                                                                                       | 0                                  | 0        | 0      | 0  | 1 | 0 | 0 | 0 | 0  | 0      | 0              | 0  | 0 | 0 |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                          |
|-----------------|---------|------|----------------|--------------------------------------------------------------------------------------|
|                 | [31:16] | RO   | 16'h0          | Reserved                                                                             |
| POINT_INTERVAL  | [15:8]  | R/W  | 8'h42          | The interval between 2 output points, (A point includes Y, X, Z1), it should be > 1. |
| SAMPLE_INTERVAL | [7:0]   | R/W  | 8'h0           | The interval between 2 samplings. (Y and X, X and Z1)                                |

# 6.11.5.2.3 TPC\_SAMPLE\_CTRL1



Description: TPC sample control.

| 0x0008 |    |       | TPC   | sampl | e cont | rol1 (re | eset 0 | (8271) |       |         |         |    | TPC | SAME | PLE_C | TRL1 |
|--------|----|-------|-------|-------|--------|----------|--------|--------|-------|---------|---------|----|-----|------|-------|------|
| Bit    | 31 | 30    | 29    | 28    | 27     | 26       | 25     | 24     | 23    | 22      | 21      | 20 | 19  | 18   | 17    | 16   |
| Name   |    |       |       |       |        |          |        | Rese   | erved |         |         |    |     |      |       |      |
| Туре   |    |       |       | 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   |    | SAMPL | E_NUM |       |        |          |        |        | ı     | DATA_IN | ITERVAI | -  |     |      |       |      |
| Туре   |    | R     | W     | R/W   |        |          |        |        |       |         |         |    |     |      |       |      |
| Reset  | 1  | 0     | 0     | 0     | 0      | 0        | 1      | 0      | 0     | 1       | 1       | 1  | 0   | 0    | 0     | 1    |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                             |
|---------------|---------|------|----------------|-----------------------------------------------------------------------------------------|
|               | [31:16] | RO   | 16'h0          | Reserved                                                                                |
| SAMPLE_NUM    | [15:12] | R/W  | 4'h8           | The number of samples, active range is <= 8 for filter limiting. It should be >= 1.     |
| DATA_INTERVAL | [11:0]  | R/W  | 12'h271        | The interval between 2 active data, (A data filter from some points), it should be > 1. |

# 6.11.5.2.4 TPC\_BOUNCE\_CTRL

Description: TPC de-bounce control.

| 0x000C |    |    | TPC                                 | bounc    | e cont | rol (re | set 0x2 | 29)  |       |   |        |         | TPC | _BOU | NCE_ | CTRL                    |
|--------|----|----|-------------------------------------|----------|--------|---------|---------|------|-------|---|--------|---------|-----|------|------|-------------------------|
| Bit    | 31 | 30 | 29 28 27 26 25 24 23 22 21 20 19 18 |          |        |         |         |      |       |   |        |         |     | 18   | 17   | 16                      |
| Name   |    |    |                                     |          |        |         |         | Rese | erved |   |        |         |     |      |      |                         |
| Туре   |    | 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   |    |    |                                     | Reserved | d      |         |         |      |       | [ | DEBOUN | ICE_NUI | И   |      |      | DEB<br>OUN<br>CE_<br>EN |
| Туре   |    |    |                                     | RO       |        |         |         | RW   |       |   |        |         |     |      |      | R/W                     |
| Reset  | 0  | 0  | 0                                   | 0        | 0      | 0       | 0       | 0    | 0     | 0 | 1      | 0       | 1   | 0    | 0    | 1                       |

| Field Name   | Bit    | Туре | Reset<br>Value | Description                                                    |
|--------------|--------|------|----------------|----------------------------------------------------------------|
|              | [31:9] | RO   | 23'h0          | Reserved                                                       |
| DEBOUNCE_NUM | [8:1]  | R/W  | 8'h14          | De-bouncing check number.                                      |
| DEBOUNCE_EN  | [0]    | R/W  | 1'h1           | De-bouncing enable, 0: debounce disabled; 1: debounce enabled. |



### 6.11.5.2.5 TPC\_FILTER\_CTRL

Description: TPC filter control.

| 0x0010 |    |    | TPC      | filter c                                  | ontrol | (reset | 0x23) |   |   |   |                             |     | TF  | PC_FIL | TER_ | CTRL              |
|--------|----|----|----------|-------------------------------------------|--------|--------|-------|---|---|---|-----------------------------|-----|-----|--------|------|-------------------|
| Bit    | 31 | 30 | 29       | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |        |       |   |   |   |                             |     |     |        | 16   |                   |
| Name   |    |    | Reserved |                                           |        |        |       |   |   |   |                             |     |     |        |      |                   |
| Туре   |    |    |          |                                           |        |        |       | R | 0 |   |                             |     |     |        |      |                   |
| 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   |    |    |          |                                           | Rese   | erved  |       |   |   |   | FILTER_TAP FILTER_TAP MO DE |     |     |        |      | FILT<br>ER_<br>EN |
| Туре   |    |    |          |                                           | R      | 0      |       |   | R | w |                             | R/W | R/W |        |      |                   |
| Reset  | 0  | 0  | 0        | 0                                         | 0      | 0      | 0     | 0 | 0 | 0 | 1                           | 0   | 0   | 0      | 1    | 1                 |

| Field-Name  | Bit    | Туре | Reset<br>Value | Description                                                                                                 |
|-------------|--------|------|----------------|-------------------------------------------------------------------------------------------------------------|
|             | [31:6] | RO   | 26'h0          | Reserved                                                                                                    |
| FITLER_TAP  | [5:2]  | R/W  | 4'h8           | Filter taps. When in average mode, tap should be 1/2/4/8; when in median mode, tap should be >= 1 and <= 8. |
| FILTER_MODE | [1]    | R/W  | 1'h1           | Filter mode, 0: average filter; 1: median filter.                                                           |
| FILTER_EN   | [0]    | R/W  | 1'h1           | Noise filter enable, 0: disabled; 1: enabled.                                                               |

### 6.11.5.2.6 TPC\_CALC\_CTRL

Description: TPC calculation control.

| 0x0014 |                           |          | TPC                                    | calcul | ation c | ontrol | (reset   | 0x0) |   |   |   |   | - | ГРС_С | ALC_ | CTRL            |
|--------|---------------------------|----------|----------------------------------------|--------|---------|--------|----------|------|---|---|---|---|---|-------|------|-----------------|
| Bit    | 31                        | 30       | 30 29 28 27 26 25 24 23 22 21 20 19 18 |        |         |        |          |      |   |   |   |   |   |       | 17   | 16              |
| Name   |                           |          | Reserved                               |        |         |        |          |      |   |   |   |   |   |       |      |                 |
| Туре   |                           |          |                                        |        |         |        |          | R    | 0 |   |   |   |   |       |      |                 |
| 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   |                           |          |                                        |        |         | F      | Reserved | d    |   |   |   |   |   | DUN   | ИМҮ  | CAL<br>C_E<br>N |
| Type   |                           | RO R/W R |                                        |        |         |        |          |      |   |   |   |   |   |       | R/W  |                 |
| Reset  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |          |                                        |        |         |        |          |      |   |   |   | 0 | 0 |       |      |                 |

| Field Name | Bit | Туре | Reset<br>Value | Description |
|------------|-----|------|----------------|-------------|
|------------|-----|------|----------------|-------------|



|         | [31:3] | RO  | 29'h0 | Reserved                                                                                                           |
|---------|--------|-----|-------|--------------------------------------------------------------------------------------------------------------------|
| DUMMY   | [2:1]  | R/W | 2'h0  | Reserved                                                                                                           |
| CALC_EN | [0]    | R/W | 1'h1  | Calculation enable, 0: disabled; 1: enabled. It should be disabled during calibration, and enabled in normal mode. |

### 6.11.5.2.7 TPC\_CALC\_X\_COEF\_A

Description: TPC calculation coefficient a for X.

| 0x0018 |    |    | TPC  | calcul | ation c | coeffic | ient a t | ior X (ı  | eset 0 | x0) |    |    | TPC_CALC_X_COEF_<br>A |    |    |    |
|--------|----|----|------|--------|---------|---------|----------|-----------|--------|-----|----|----|-----------------------|----|----|----|
| Bit    | 31 | 30 | 29   | 28     | 27      | 26      | 25       | 24        | 23     | 22  | 21 | 20 | 19                    | 18 | 17 | 16 |
| Name   |    |    |      |        |         |         |          | Rese      | erved  |     |    |    |                       |    |    |    |
| Туре   |    |    |      |        |         |         |          | R         | 0      |     |    |    |                       |    |    |    |
| 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   |    |    | Rese | erved  |         |         |          | X_COEF_A  |        |     |    |    |                       |    |    |    |
| Туре   |    |    | R    | 0      |         |         |          |           |        |     | R  | W  |                       |    |    |    |
| Reset  | 0  | 0  | 0    | 0      | 0       | 0       | 0        | 0         | 0      | 0   | 0  | 0  | 0                     | 0  | 0  | 0  |

| Field-Name | Bit     | Туре | Reset<br>Value | Description                                  |
|------------|---------|------|----------------|----------------------------------------------|
|            | [31:10] | RO   | 22'h0          | Reserved                                     |
| X_COEF_A   | [9:0]   | R/W  | 10'h0          | a <sub>x</sub> . It is S2.8, in [-2, 1.996]. |

# 6.11.5.2.8 TPC\_CALC\_X\_COEF\_B

Description: TPC calculation coefficient b for X.

| 0x001C |    |    | TPC      | calcul                    | ation o | oeffic | ient b | for X (ı | reset 0 | )x0) |        |    | TPC | CALC | C_X_C | OEF_<br>B |
|--------|----|----|----------|---------------------------|---------|--------|--------|----------|---------|------|--------|----|-----|------|-------|-----------|
| Bit    | 31 | 30 | 29       | 28                        | 27      | 26     | 25     | 24       | 23      | 22   | 21     | 20 | 19  | 18   | 17    | 16        |
| Name   |    |    |          | Reserved                  |         |        |        |          |         |      |        |    |     |      |       |           |
| Туре   |    |    |          |                           |         |        |        | R        | 0       |      |        |    |     |      |       |           |
| 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   |    |    | Reserved | d                         |         |        |        |          |         | Х    | _COEF_ | В  |     |      |       |           |
| Туре   |    |    | RO       |                           | R/W     |        |        |          |         |      |        |    |     |      |       |           |
| Reset  | 0  | 0  | 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 |         |        |        |          |         |      |        |    |     | 0    |       |           |

| Field Name B | Bit T | Туре | Reset | Description |
|--------------|-------|------|-------|-------------|
|--------------|-------|------|-------|-------------|



|          |         |     | Value |                                              |
|----------|---------|-----|-------|----------------------------------------------|
|          | [31:11] | RO  | 21'h0 | Reserved                                     |
| X_COEF_B | [10:0]  | R/W | 11'h0 | b <sub>x</sub> . It is S11, in [-1024, 1023] |

Note:  $X = a_x * ADC_x + b_x$ 

# 6.11.5.2.9 TPC\_CALC\_Y\_COEF\_A

Description: TPC calculation coefficient a for Y.

| 0x0020 |    |    | TPC  | calcul | ation c | coeffic | ient a f | or Y (ı | eset 0 | x0) |      | TPC_CALC_Y_COEF_A |    |    |    |    |
|--------|----|----|------|--------|---------|---------|----------|---------|--------|-----|------|-------------------|----|----|----|----|
| Bit    | 31 | 30 | 29   | 28     | 27      | 26      | 25       | 24      | 23     | 22  | 21   | 20                | 19 | 18 | 17 | 16 |
| Name   |    |    |      |        |         |         |          | Rese    | erved  |     |      |                   |    |    |    |    |
| Туре   |    |    | 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   |    |    | Rese | erved  |         |         |          |         |        |     | Y_CC | EF_A              |    |    |    |    |
| Туре   |    |    | R    | 0      |         |         | R/W      |         |        |     |      |                   |    |    |    |    |
| Reset  | 0  | 0  | 0    | 0      | 0       | 0       | 0        | 0       | 0      | 0   | 0    | 0                 | 0  | 0  | 0  | 0  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                 |
|------------|---------|------|----------------|---------------------------------------------|
|            | [31:10] | RO   | 22'h0          | Reserved                                    |
| Y_COEF_A   | [9:0]   | R/W  | 10'h0          | a <sub>y</sub> . It is S2.8, in [-2, 1.996] |

# 6.11.5.2.10 TPC\_CALC\_Y\_COEF\_B

Description: TPC calculation coefficient b for Y.

| 0x0024 |    |    | TPC      | calcul   | ation o | oeffic                  | ient b | for Y (ı | reset 0 | )x0) |        |    | TPC | CALC | C_Y_C | OEF_<br>B |
|--------|----|----|----------|----------|---------|-------------------------|--------|----------|---------|------|--------|----|-----|------|-------|-----------|
| Bit    | 31 | 30 | 29       | 28       | 27      | 26                      | 25     | 24       | 23      | 22   | 21     | 20 | 19  | 18   | 17    | 16        |
| Name   |    |    |          | Reserved |         |                         |        |          |         |      |        |    |     |      |       |           |
| Туре   |    |    |          | 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   |    | ı  | Reserved | i        |         |                         |        |          |         | Υ    | _COEF_ | В  |     |      |       |           |
| Туре   |    |    | RO       | O R/W    |         |                         |        |          |         |      |        |    |     |      |       |           |
| Reset  | 0  | 0  | 0        | 0        | 0       | 0 0 0 0 0 0 0 0 0 0 0 0 |        |          |         |      |        |    |     |      |       |           |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                  |
|------------|---------|------|----------------|----------------------------------------------|
|            | [31:11] | RO   | 21'h0          | Reserved                                     |
| Y_COEF_B   | [10:0]  | R/W  | 11'h0          | b <sub>y</sub> . It is S11, in [-1024, 1023] |



Note:  $Y = a_y * ADC_y + b_y$ 

### 6.11.5.2.11 TPC\_IRQ\_EN

Description: TPC interrupt enable.

| 0x0028 |    |    | TPC         | interru | ıpt ena | ıble (re | eset 0x | (0)  |       |    |    |    |    | TF                      | PC_IR             | J_EN                    |
|--------|----|----|-------------|---------|---------|----------|---------|------|-------|----|----|----|----|-------------------------|-------------------|-------------------------|
| Bit    | 31 | 30 | 29          | 28      | 27      | 26       | 25      | 24   | 23    | 22 | 21 | 20 | 19 | 18                      | 17                | 16                      |
| Name   |    |    |             |         |         |          |         | Rese | erved |    |    |    |    |                         |                   |                         |
| Туре   |    |    | 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   |    |    |             |         |         | F        | Reserve | d    |       |    |    |    |    | DON<br>E_IR<br>Q_E<br>N | UP_I<br>RQ_<br>EN | DO<br>WN_<br>IRQ<br>_EN |
| Туре   |    |    | RO RW RW RW |         |         |          |         |      |       |    |    |    |    |                         |                   |                         |
| Reset  | 0  | 0  | 0           | 0       | 0       | 0        | 0       | 0    | 0     | 0  | 0  | 0  | 0  | 0                       | 0                 | 0                       |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                                                      |
|-------------|--------|------|----------------|------------------------------------------------------------------|
|             | [31:3] | RO   | 29'h0          | Reserved                                                         |
| DONE_IRQ_EN | [2]    | R/W  | 1'h0           | Specified sample done interrupt enable, 0: disabled; 1: enabled. |
| UP_IRQ_EN   | [1]    | R/W  | 1'h0           | Press up interrupt enable, 0: disabled; 1: enabled.              |
| DOWN_IRQ_EN | [0]    | R/W  | 1'h0           | Press down interrupt enable, 0: disabled; 1: enabled.            |

# 6.11.5.2.12 TPC\_IRQ\_STATUS

Description: TPC masked interrupt.



| 0x002C |    |    | TPC         | interru  | ıpt sta | tus (re | set 0x  | 0) |    |    |    |    | Т  | PC_IR                    | Q_ST               | ATUS                         |
|--------|----|----|-------------|----------|---------|---------|---------|----|----|----|----|----|----|--------------------------|--------------------|------------------------------|
| Bit    | 31 | 30 | 29          | 28       | 27      | 26      | 25      | 24 | 23 | 22 | 21 | 20 | 19 | 18                       | 17                 | 16                           |
| Name   |    |    |             | Reserved |         |         |         |    |    |    |    |    |    |                          |                    |                              |
| Туре   |    |    | 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   |    |    |             |          |         | F       | Reserve | d  |    |    |    |    |    | DON<br>E_IR<br>Q_S<br>TS | UP_I<br>RQ_<br>STS | DO<br>WN_<br>IRQ<br>_ST<br>S |
| Туре   |    |    | RO RO RO RO |          |         |         |         |    |    |    |    |    |    |                          |                    |                              |
| Reset  | 0  | 0  | 0           | 0        | 0       | 0       | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0                        | 0                  | 0                            |

| Field-Name   | Bit    | Туре | Reset<br>Value | Description      |
|--------------|--------|------|----------------|------------------|
|              | [31:3] | RO   | 29'h0          | Reserved         |
| DONE_IRQ_STS | [2]    | RO   | 1'h0           | Masked DONE_IRQ. |
| UP_IRQ_STS   | [1]    | RO   | 1'h0           | Masked UP_IRQ.   |
| DOWN_IRQ_STS | [0]    | RO   | 1'h0           | Masked DOWN_IRQ. |

### 6.11.5.2.13 TPC\_IRQ\_RAW

Description: TPC raw interrupt.

| 0x0030 |    |          | TPC | raw in   | terrup | t statu | s (rese  | et 0x0) |    |    |    |    |    | TPC                           | _IRQ_                  | RAW                          |
|--------|----|----------|-----|----------|--------|---------|----------|---------|----|----|----|----|----|-------------------------------|------------------------|------------------------------|
| Bit    | 31 | 30       | 29  | 28       | 27     | 26      | 25       | 24      | 23 | 22 | 21 | 20 | 19 | 18                            | 17                     | 16                           |
| Name   |    |          |     | Reserved |        |         |          |         |    |    |    |    |    |                               |                        |                              |
| Туре   |    |          | 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   |    |          |     |          |        | ı       | Reserved | d       |    |    |    |    |    | DDO<br>NE_I<br>RQ_<br>RA<br>W | UP_I<br>RQ_<br>RA<br>W | DO<br>WN_<br>IRQ<br>_RA<br>W |
| Туре   |    | RO RO RO |     |          |        |         |          |         |    |    |    |    |    |                               |                        |                              |
| Reset  | 0  | 0        | 0   | 0        | 0      | 0       | 0        | 0       | 0  | 0  | 0  | 0  | 0  | 0                             | 0                      | 0                            |

| Field Name   | Bit    | Туре | Reset<br>Value | Description   |
|--------------|--------|------|----------------|---------------|
|              | [31:3] | RO   | 29'h0          | Reserved      |
| DONE_IRQ_RAW | [2]    | RO   | 1'h0           | Raw DONE_IRQ. |
| UP_IRQ_RAW   | [1]    | RO   | 1'h0           | Raw UP_IRQ.   |
| DOWN_IRQ_RAW | [0]    | RO   | 1'h0           | Raw DOWN_IRQ. |



### 6.11.5.2.14 TPC\_IRQ\_CLR

Description: TPC interrupt clear.

| 0x0034 |    |    | TPC         | interru  | ıpt cle | ar (res | et 0x0   | )  |    |    |    |    |    | TPO                      | C_IRQ              | CLR                           |
|--------|----|----|-------------|----------|---------|---------|----------|----|----|----|----|----|----|--------------------------|--------------------|-------------------------------|
| Bit    | 31 | 30 | 29          | 28       | 27      | 26      | 25       | 24 | 23 | 22 | 21 | 20 | 19 | 18                       | 17                 | 16                            |
| Name   |    |    |             | Reserved |         |         |          |    |    |    |    |    |    |                          |                    |                               |
| Туре   |    |    |             | 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   |    |    |             |          |         | F       | Reserved | d  |    |    |    |    |    | DON<br>E_IR<br>Q_C<br>LR | UP_I<br>RQ_<br>CLR | DO<br>WN_<br>IRQ<br>_CL<br>_R |
| Туре   |    |    | RO WO WO WO |          |         |         |          |    |    |    |    |    |    |                          |                    |                               |
| Reset  | 0  | 0  | 0           | 0        | 0       | 0       | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0                        | 0                  | 0                             |

| Field Name   | Bit    | Туре | Reset<br>Value | Description                      |
|--------------|--------|------|----------------|----------------------------------|
|              | [31:3] | RO   | 29'h0          | Reserved                         |
| DONE_IRQ_CLR | [2]    | WO   | 1'h0           | Write '1' to clear DONE_IRQ.     |
| UP_IRQ_CLR   | [1]    | WO   | 1'h0           | Write '1' to clear Raw UP_IRQ.   |
| DOWN_IRQ_CLR | [0]    | WO   | 1'h0           | Write '1' to clear Raw DOWN_IRQ. |

# 6.11.5.2.15 TPC\_BUF\_CTRL

Description: TPC buffer control.

| 0x0038 |    |    | TPC | buffer                    | contro | ol (rese | et 0x25 | 5) |    |    |                 |                  |    | TPC_   | BUF_0 | CTRL |
|--------|----|----|-----|---------------------------|--------|----------|---------|----|----|----|-----------------|------------------|----|--------|-------|------|
| Bit    | 31 | 30 | 29  | 28                        | 27     | 26       | 25      | 24 | 23 | 22 | 21              | 20               | 19 | 18     | 17    | 16   |
| Name   |    |    |     | Reserved                  |        |          |         |    |    |    |                 |                  |    |        |       |      |
| Type   |    |    |     | RO                        |        |          |         |    |    |    |                 |                  |    |        |       |      |
| 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   |    |    |     |                           | Rese   | erved    |         |    |    |    | BUF<br>_EM<br>P | BUF<br>_FU<br>LL |    | BUF_LI | ENGTH |      |
| Type   |    |    |     | RO RO R/W                 |        |          |         |    |    |    |                 |                  |    |        |       |      |
| Reset  | 0  | 0  | 0   | 0 0 0 0 0 0 0 0 1 0 0 1   |        |          |         |    |    |    |                 |                  |    |        |       | 1    |

| Field-Name | Bit    | Туре | Reset<br>Value | Description                                        |
|------------|--------|------|----------------|----------------------------------------------------|
|            | [31:6] | RO   | 26'h0          | Reserved                                           |
| BUF_EMP    | [5]    | RO   | 1'h1           | Internal buffer empty status, '1' for empty.       |
| BUF_FULL   | [4]    | RO   | 1'h0           | Internal buffer full status, '1' for full.         |
| BUF_LENGTH | [3:0]  | R/W  | 4'h5           | Specify sample done length. When writing length is |



|  | equal to it, done_irq occurs. It should be >= 1. |
|--|--------------------------------------------------|
|--|--------------------------------------------------|

### 6.11.5.2.16 TPC\_X/Y/Z\_DATA

Description: TPC X/Y/Z data.

| 0x003C |    |          | TPC  | X data                 | (reset | 0x0) |    |    |    |    |    |    | TPC_X_DATA |            |            |    |  |  |
|--------|----|----------|------|------------------------|--------|------|----|----|----|----|----|----|------------|------------|------------|----|--|--|
| 0x0040 |    |          | TPC  | TPC Y data (reset 0x0) |        |      |    |    |    |    |    |    |            |            | TPC_Y_DATA |    |  |  |
| 0x0044 |    |          | TPC  | TPC Z data (reset 0x0) |        |      |    |    |    |    |    |    |            | TPC_Z_DATA |            |    |  |  |
| Bit    | 31 | 30       | 29   | 28                     | 27     | 26   | 25 | 24 | 23 | 22 | 21 | 20 | 19         | 18         | 17         | 16 |  |  |
| Name   |    | Reserved |      |                        |        |      |    |    |    |    |    |    |            |            |            |    |  |  |
| Туре   |    |          |      |                        |        |      |    | R  | 0  |    |    |    |            |            |            |    |  |  |
| 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   |    |          | Rese | erved                  |        |      |    |    |    |    | DA | TA |            |            |            |    |  |  |
| Туре   |    |          | R    | 0                      |        |      |    | RO |    |    |    |    |            |            |            |    |  |  |
| Reset  | 0  | 0        | 0    | 0                      | 0      | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0          | 0          | 0  |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                               |
|------------|---------|------|----------------|-------------------------------------------|
|            | [31:10] | RO   | 22'h0          | Reserved                                  |
| DATA       | [9:0]   | RO   | 10'h0          | X/Y ADC or position value or Z ADC value. |

## 6.11.6 Application Notes

#### 6.11.6.1 Program Flow

Before configure module, set some global parameters,

Set bit[13] of 0x8200\_0600 to enable CLK\_ADC;

Set bit[14] of 0x8200\_0600 to enable CLK\_AUXAD;

Set bit[5]/[4]/[12]/[8] of 0x8200\_0600 to enable AuxADC/TPC/RTC\_TPC/RTC\_ARCH;

Set or reset bit[4]/[5] of 0x8200\_0604 to reset AuxADC/TPC module;

Set bit[24] of 0x8000\_3008 to enable ADI interrupt, later, we need scan ADI interrupt status, check bit[0] of 0x8200\_0380 for ADC module interrupt and bit[4] of 0x8200\_0380 for TPC module interrupt:

Some registers are configured through ADI module, so ADI must be ready before do these.

Its work flow is as follows:

- Clear ARM's ADI, ADC, and TPC interrupt, and enable DOWN and UP interrupt;
- Configure ADC and TPC module registers;
- Enable ADC and TPC module;
- When ARM's ADI interrupt asserts, if "down\_irq" occurs, run the TPC, and clear the DONE interrupt, then enable the DONE interrupt;
- If "done\_irq" occurs, read out sample data;



- If the ADC is needed for other purposes, SW can use it directly, without caring about TPC:
- If "up\_irq" occurs, stop the TPC, and disable the DONE interrupt; if necessary, SW can stop TPC at anytime;
- If "down\_irq" occurs, adjust control registers, and start a new process with the same flow.

### 6.11.6.2 Program Notes

- When in 2D mode, the read order is X/Y, When in 3D mode, reading order is Z/X/Y, since the read address will increases 1 after reads Y data, so the Y data is always read out lastly;
- When in work, the de-bouncing should be always turned on, the TP\_XL includes pen input signal and sampling control, so we need filter the sampling control;
- When enable de-bouncing, because the bouncing during release pen and de-bouncing, the de-bounced signal includes some invalid part, it is shown in Figure xx. Thus, we should discard those data sampled in invalid range.



Figure xx Invalid Part in De-bounced Signal

- When in 3D mode, the status from sampling Z to idle will include an obvious charge process in TP\_XL pad if panel has a big capacitance, it maybe affect the UP interrupt, we need control the sampling speed, the reference speed is writing a FIFO data more than 1ms.

### 6.12 SIM Card Interface

#### 6.12.1 Overview

SIM: Subscriber Identity Module

The SIM card interface is implemented according to GSM SIM card standard and conformed to ISO7816. It only supports protocol type T = 0 asynchronous half duplex character transmission mode. The SIM card interface is used to transfer data to/from a SIM card in an asynchronous fashion in half duplex mode through a bi-directional I/O pin.

#### 6.12.2 Features

- I Programmable generation of clock to SIM card
- I Programmable transmission baud rate
- Support for T = 0 asynchronous protocol type
- I Character transmitting and receiving with one 16 byte Tx FIFO and one 16 byte Rx FIFO
- I Parity checking and error handling
- I Transmission and receiving in DMA mode
- Retransmission after detecting parity error
- I Support different interrupt modes
- 1 2 hardware controllers support 4 software controllers



# 6.12.3 Signal Description

Table 6-9 Signal Description

| PAD Name  | Direction | Attribute | Description                       |
|-----------|-----------|-----------|-----------------------------------|
| SIM_PE    | Output    | Internal  | Used to power up / down SIM card  |
| SIM_RST   | Output    | PAD       | Used to reset SIM card            |
| SIM_CLK   | Output    | PAD       | Used to supply clock for SIM card |
| SIM_DAT_I | Input     | PAD       | Serial data in                    |
| SIM_DAT_O | Output    | PAD       | Serial data out                   |



Figure 6-50 SIM Interface Signals

SIM card interface signals are compliant with ISO7816-2 standard where each signal connects to the corresponding SIM card pins listed as the table.

Table 6-10 SIM Card Pin List

| C1 : Vcc = 5V | C5 : Gnd |
|---------------|----------|
| C2 : Reset    | C6 : Vpp |
| C3 : Clock    | C7 : I/O |
| C4 : RFU      | C8: RFU  |

APB bus is used to configure and control the SIM card controller.



### 6.12.4 Function Description

### 6.12.4.1 SIM Controller Interface Block Diagram



Figure 6-51 SIM Interface Block Diagram

### 6.12.4.2 SIM Clock and Baud Rate Control

The SIM card clock is generated and sent from the SIM card controller to the SIM card. The SIM\_CTL1 register bits [10:8] decide the generated SIM clock frequency.

Table 6-11 SIM Clock and Baud Rate

| Clock mode, 0x8500_001C [10:8] | SIM clock frequency |
|--------------------------------|---------------------|
| 0                              | MCU clock / 2       |
| 1                              | MCU clock / 4       |
| 2                              | MCU clock / 8       |
| 3                              | MCU clock / 16      |
| 4                              | MCU clock / 32      |
| 5                              | MCU clock / 64      |
| 6                              | MCU clock / 128     |
| 7                              | MCU clock / 256     |

The baud rate that the SIM card controller uses in Tx and Rx is controlled through programming SIM\_CLK\_DVD register.

The clock output to the SIM card needs to match the baud rate that the SIM card controller uses so that the Rx and Tx can be done correctly.

### 6.12.4.3 Resource

Memory:

TX FIFO: 16X8 RX FIFO: 16X8

#### 6.12.4.4 SIM Controller Operations Procedure

The SIM interface device and the SIM card shall be conducted through the following consecutive operations:

- I Connection and activation of the contacts by the interface device
- I Deactivation of the contacts by the interface device
- I Reset of the card
- I Subsequent information exchange between the card and the interface device



#### 6.12.4.4.1 Activation and Deactivation of the contacts

The SIM card shall not be activated until the contacts are connected to the interface device to avoid possible damage to any SIM card meeting these standards.

The activation of the contacts by the SIM interface device shall consist of the following consecutive operations:

- I RST is in state L.
- I VCC shall be powered.
- I I/O in the interface device shall be put in reception mode.
- I CLK shall be provided with a suitable and stable clock.



Figure 6-52 Activation and Deactivation Timing Sequence

The SIM card controller is implemented with the some modules; the activation/deactivation control module controls the activation/deactivation sequence of the SIM interface.

After sending an activate command (writing 1 to SIM\_CTL0 register bit 11), the activation sequence will be sent to the SIM card.

The following are brief list of commands for the activation functions.

- I Program active deactiva en bit to 1 to enable activation function.
- Program do\_act bit to 1 to start activation sequence.

When information-exchanging is terminated or aborted (unresponsive card or detection of card removal), the electrical contacts should be deactivated.

The deactivation by the interface device shall consist of the following consecutive operations:

- I State L on RST
- I State L on CLK
- I State A on I/O
- I VDD inactive

Software program do-deact bit to 1 to begin deactivation sequence.

### 6.12.4.4.2 Reset of the Card

A card reset is initiated by the interface device, whereupon the card shall respond with an Answer to Reset.

By the end of the activation of the contacts (RST is in L, VDD powered and stable, I/O in reception mode in the interface device, CLK provided suitable and stable clock), the card answering asynchronously is ready for reset.

The clock signal is applied to CLK at time T0. The I/O line shall be to state Z within 200 clock cycles of the clock signal (t2) being applied to CLK (time t2 T0).

The internal reset takes effect a few clock cycles after reset. Answer to Reset on I/O shall begin between 400 and 40,000 clock cycles (t1) after the clock signal applied to CLK (time t1 after T0).



A card with an active low reset is reset by RST in L for at least 40,000 clock cycles (t3) after the clock signal is applied on CLK (time t3 after T0). Thus if no Answer to Reset began within 40,000 clock cycles (t3) with RST in state L, RST is put to state H (at time T1). The Answer to Reset on I/O shall begin between 400 and 40,000 clock cycles (t1) after the rising edge of the signal on RST (time t1 after T1).

If the answer to Reset does not begin within 40,000 clock cycles (t3) with RST in state H (t3 after T1), the signal on RST shall be returned to state L (at time T2) and the contacts shall be deactivated by the interface device.



#### NOTES:

The internal state of the card is assumed undefined before reset. Therefore, the design of the card has to avoid improper operations.

In order to continue the dialogue with the card, RST shall be maintained in the state where an answer occurs on I/O.

Reset of a card can be initiated by the interface device at its discretion at any time.

Interface devices may support one or more of these types of reset behavior. The priority of testing for asynchronous or synchronous cards is not defined in the standard.

### 6.12.4.4.3 Subsequent information exchange between the card and the interface device

### 6.12.4.4.3.1

#### **Character frame**

For asynchronous transmission type, the character of frame during answer to reset is like in the following diagram.





### Figure 6-54 The Character of Frame

A character consists of ten consecutive bits:

- A start bit in state A;
- I Eight bits of information, designated B0 to B7 and conveying a data byte;
- I A tenth bit bi used for even parity checking.

At the SIM interface, a data byte consists of 8 bits  $B_0 \sim B_7$ , from the least significant bit (LSB,  $B_0$ ) to the most significant bit (MSB,  $B_7$ )

### 6.12.4.4.3.2 T = 0, Asynchronous Half Duplex Character Transmission Protocol

The following diagram shows the byte transmission frame structure. without parity error



Figure 6-55 T=0 Byte Transmission Diagram

The interface device transmits a header over five successive bytes designated CLA, INS, A1, A2; L. CLA is an instruction class. The value FF is reserved for PTS.

INS is an instruction code in the instruction class. The instruction code is valid only if the least significant bit is 0, and the most significant half byte is neither 6 nor 9. P1, P2 are a reference (e.g., an address) completing the instruction cod.P3 codes the number n of data bytes (D1... Dn) which are to be transmitted during the command. The direction of movement of these data is a function of the instruction. In an outgoing data transfer command, P3 = 0 introduces a 256 byte data transfer from the card. In an incoming data transfer command, P3 = 0 introduces no transfer of data. All remaining encoding possibilities for the header are specified in ISO7816.

#### 6.12.4.4.3.3 SIM Data Tx and Rx

The Tx will start when the tx\_enable is 1, there is data in the FIFO and the last Rx is completed. The tx\_int\_mark sets the condition under which the tx\_int will happen. When the empty entry in the tx\_fifo is less than tx\_int mark, tx\_empty int will be set.

The Rx will start when the rx\_enable is 1, when the last Tx is done and there is data coming in from the data input. The rx\_int\_mark sets the condition under which the rx\_int will happen. When the data entry in the rx\_fifo is greater than rx\_int mark, rx\_full int will be set.

The bit\_convention register decides MSB and LSB in the Tx/Rx serial data, logic\_level register decides if high electrical level represents logic 1 in Tx/Rx serial data, and odd\_parity register bit decides if using odd or even parity in Tx/Rx data.

In the SIM interface module, a timer is also designed to check if the receive portion is idle for a certain period of time and generate an interrupt when it happens. The watch\_dog\_count\_limit register defines the idle period in data bit streaming. Watch\_dog\_repeat\_en register decides if the timer starts right after the interrupt is acknowledged (the interrupt is cleared). Writing 1 to watch\_dog\_trigger starts the timer counting. Any activity in the Rx portion will reset the timer counting.



#### 6.12.4.4.3.4 Rx/Tx Control

The Rx/Tx control module controls the transmitting and receiving data to/from the SIM card. The SIM card controller receives/transmits data according to the data-level and bit ordering that are specified in the Logic\_level (bit 1) and Bit\_convention (bit 0) bits in the SIM\_CTL0 register. The data format is: 10 bits per character, 1 start bit + 8 data bits + 1 parity bit.

The SIM card controller includes a 16 byte Tx FIFO for data transmission. It uses a pointer to monitor the number of data in the Tx FIFO that have not yet been transmitted. The MCU can access the pointer by reading the SIM\_STS1 register bits 4 to bit 0.

The SIM card controller also uses a configurable Tx interrupt threshold that can be configured by writing to the SIM\_CTL1 register bits 4 to 7. This field specifies the number of empty characters that should be available in the Tx FIFO before issuing an interrupt. Whenever the number of empty characters exceeds this value, an interrupt is generated to the MCU. This interrupt is automatically cleared when the number of empty bytes in the Tx FIFO equals to or falls below the specified Tx interrupt threshold value.

The SIM card controller also includes a 16 byte Rx FIFO for data receiving. It uses a pointer to monitor the number of bytes in the Rx FIFO that have not yet been read by the MCU. The MCU reads the SIM\_STS1 register bits 0 to 4 to access the pointer.

The SIM card controller also uses a configurable Rx interrupt threshold that can be configured by writing to the SIM\_CTL1 register bits 0 to 3. This field specifies the number of unread data that should be available in the Rx FIFO before issuing an interrupt. Whenever the number of unread data exceeds this value, an interrupt is generated to the MCU. This interrupt is automatically cleared when the number of unread data in the Rx FIFO equals to or falls below the specified Rx interrupt threshold value.

#### 6.12.4.4.3.5 Retransmission

The SIM card controller supports retransmission upon detecting an error condition. The SIM card controller checks the I/O line from the SIM card 11 bits after the start bit leading edge. If the detected I/O is a zero (error ACK), it assumes an error occurred and retransmits the byte. If the error ACK signal is repeated for the programmable number of times specified in the SIM\_SHE register, The SIM card interface sets the bad Tx parity error bit in the status register (SIM\_STS0 bit 3) and issues an interrupt.

For the transmission from the SIM card controller to the SIM card, when the SIM card controller detects a parity error following the transmission of a data byte, it performs the following sequence:

- The SIM card interface retransmits the data.
- I If the retransmission succeeds, it ignores the initial failure.
- If the retransmission fails for the number of times specified in the programmable SIM\_SHE register, the SIM card interface sets the bad parity bit interrupt the SIM\_STS0 register, issues an interrupt to the MCU, and stops retransmission of the byte.



### 6.12.4.5 SIM Power Supply

VSIM is the power supply to the SIM card. During the activation/deactivation process, VSIM output is automatically controlled. The on/off of VSIM can also be controlled by directly programming the SIM\_CTL0 register bit 7.

### 6.12.4.6 Unresponsive Card Detection

The SIM interface can detect an unresponsive card by means of a watchdog timer function, which determines the maximum allowable time that a data byte should take to arrive from the SIM card. The MCU can configure the watchdog timer by programming the SIM\_WDT register. The watchdog timer can function in two modes: auto mode and single mode. In the auto mode, the watchdog timer is continuously enabled. In the single mode, the watchdog timer disables itself when a data byte is received from the card, or after it has timed out.

#### 6.12.4.7 SIM Interface Watchdog

There are two separate watchdogs in SIM card module.

- I One watchdog is used to report Rx idle for a preprogrammed time.
- I The other watchdog is for time out when RX retransmission is on error.

#### 6.12.4.8 SIM Interconnection

It is recommended to connect the SIM card as follows.

- I Connect a 2.2 uF capacitor at VSIM.
- I Connect a 10 k $\Omega$  resistor from SIMDA pin to VSIM.
- I The driving strength setting on SIMRST, SIMCLK and SIMDA should be 00 (the default).

### 6.12.5 Control Registers

### **6.12.5.1** Memory map

ARM base address: 0x8500\_0000 (SIM0) 0x8500\_3000 (SIM1) DSP base address 0x0000 0000

| Offset<br>Address | Name          | Description                       |
|-------------------|---------------|-----------------------------------|
| 0x0000            | SIM_TX        | SIM card transmit register        |
| 0x0004            | SIM_RX        | SIM card receiver register        |
| 0x0008            | SIM_STS0      | SIM card status register 0        |
| 0x000c            | SIM_STS1      | SIM card status register 1        |
| 0x0010            | SIM_IE        | SIM card interrupt enable         |
| 0x0014            | SIM_ICLR      | SIM card interrupt clear          |
| 0x0018            | SIM_CTL0      | SIM card control register 0       |
| 0x001c            | SIM_CTL1      | SIM card control register 1       |
| 0x0020            | SIM_RX_CK_DVD | SIM card RX clock divider control |
| 0x0024            | SIM_SEH       | SIM card retransmit control       |
| 0x0028            | SIM_TGC       | SIM card turnaround guard control |
| 0x002c            | SIM_WDT       | SIM card watchdog control         |
| 0x0030            | SIM_INT_M     | SIM card interrupt mask           |



| Offset<br>Address | Name          | Description                       |
|-------------------|---------------|-----------------------------------|
| 0x0034            | SIM_TX_CK_DVD | SIM card TX clock divider control |
| 0x0038            | SIM_WDT1      | SIM card watchdog control 1       |

# 6.12.5.2 Register Descriptions

### 6.12.5.2.1 SIM\_TX Registers

Description: SIM card transmit register

| 0x0000 |    | Transmit Buffer register(Reset 0x0000) |    |      |       |    |    |     |        |    |    | SIM_TX |    |    |    |    |
|--------|----|----------------------------------------|----|------|-------|----|----|-----|--------|----|----|--------|----|----|----|----|
| Bit    | 31 | 30                                     | 29 | 28   | 27    | 26 | 25 | 24  | 23     | 22 | 21 | 20     | 19 | 18 | 17 | 16 |
| Name   |    |                                        |    |      |       |    |    | Res | erved  |    |    |        |    |    |    |    |
| 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   |    |                                        |    | Rese | erved |    |    |     | SIM_TX |    |    |        |    |    |    |    |
| Туре   | RO |                                        |    |      |       |    |    |     | wo     |    |    |        |    |    |    |    |
| Reset  | 0  | 0                                      | 0  | 0    | 0     | 0  | 0  | 0   | 0      | 0  | 0  | 0      | 0  | 0  | 0  | 0  |

| Field Name | Bit    | R/W | Reset Value | Description                                                                     |
|------------|--------|-----|-------------|---------------------------------------------------------------------------------|
|            | [31:8] | RO  | 24'h0       | Reserved                                                                        |
| SIM_TX     | [7:0]  | WO  |             | Writing to this reg will send data to Tx FIFO and then the data get transmitted |

# 6.12.5.2.2 SIM\_RX Registers

Description: SIM card receiver register

| 0x0004 | Receive Buffer register (Reset 0x0000) |    |    |      |       |    |    |      |        |    |    |    | SIM_RX |    |    |    |
|--------|----------------------------------------|----|----|------|-------|----|----|------|--------|----|----|----|--------|----|----|----|
| Bit    | 31                                     | 30 | 29 | 28   | 27    | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19     | 18 | 17 | 16 |
| Name   |                                        |    |    |      |       |    |    | Rese | served |    |    |    |        |    |    |    |
| Туре   | 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   |                                        |    |    | Rese | erved |    |    |      | SIM_RX |    |    |    |        |    |    |    |
| Туре   | RO                                     |    |    |      |       |    |    |      | RO     |    |    |    |        |    |    |    |
| Reset  | 0                                      | 0  | 0  | 0    | 0     | 0  | 0  | 0    | 0      | 0  | 0  | 0  | 0      | 0  | 0  | 0  |

| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
|            | [31:8] | RO  | 24'h0       | Reserved    |



| SIM_RX | [7:0] | RO | Read from this address retrieve data from Rx FIFO |
|--------|-------|----|---------------------------------------------------|
|        |       |    |                                                   |

# 6.12.5.2.3 SIM\_STS0 Registers

Description: SIM card status registers 0

| 0x0008 |    | SIM       | Card S | tatus l | Regist | ers (Re | eset 0x         | (0002)                  |                                      |                  |                 |                                |                         |                         | SIM_                    | STS0                     |
|--------|----|-----------|--------|---------|--------|---------|-----------------|-------------------------|--------------------------------------|------------------|-----------------|--------------------------------|-------------------------|-------------------------|-------------------------|--------------------------|
| Bit    | 31 | 30        | 29     | 28      | 27     | 26      | 25              | 24                      | 23                                   | 22               | 21              | 20                             | 19                      | 18                      | 17                      | 16                       |
| Name   |    | Reserved  |        |         |        |         |                 |                         |                                      |                  |                 |                                |                         |                         |                         |                          |
| Туре   |    |           |        |         |        |         |                 | R                       | 0                                    |                  |                 |                                |                         |                         |                         |                          |
| 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   |    |           | Rese   | erved   |        |         | RX_<br>TOU<br>T | ACT<br>IVE_<br>DON<br>E | EAR<br>LY_<br>ANS<br>_TO<br>_RS<br>T | CAR<br>D_O<br>UT | CAR<br>D_I<br>N | RX_<br>TOU<br>T_U<br>NRE<br>SP | TX_<br>PAR<br>_ER<br>_R | RX_<br>PAR<br>_ER<br>_R | TX_<br>FIF<br>O_E<br>MP | RX_<br>FIF<br>O_F<br>ULL |
| Туре   |    |           | R      | .0      |        |         | RO              | RO                      | RO                                   | RO               | RO              | RO                             | RO                      | RO                      | RO                      | RO                       |
| Reset  | 0  | 0 0 0 0 0 |        |         |        |         |                 | 0                       | 0                                    | 0                | 0               | 0                              | 0                       | 0                       | 1                       | 0                        |

| Field Name       | Bit     | R/W | Reset Value | Description                                              |
|------------------|---------|-----|-------------|----------------------------------------------------------|
|                  | [31:10] | RO  | 22'h0       | Reserved                                                 |
| RX_TOUT          | [9]     | RO  | 1'h0        | Int status bit to show Rx time out under idle state      |
| ACT_DONE         | [8]     | RO  | 1'h0        | Int status bit to show activation is done                |
| EARLY_ANS_TO_RST | [7]     | RO  | 1'h0        | Int status bit for early answer to reset                 |
| CARD_OUT         | [6]     | RO  | 1'h0        | Int status bit for card removed (not support in SC6820)  |
| CARD_IN          | [5]     | RO  | 1'h0        | Int status bit for card inserted (not support in SC6820) |
| RX_TOUT_UNRSP    | [4]     | RO  | 1'h0        | Int status bit for Rx time out or card unresponsive      |
| TX_PAR_ERR       | [3]     | RO  | 1'h0        | Int status bit for Tx parity error                       |
| RX_PAR_ERR       | [2]     | RO  | 1'h0        | Int status bit for Rx parity error                       |
| TX_FIFO_EPT      | [1]     | RO  | 1'h1        | Tx FIFO data number bigger than tx_int_mark              |
| RX_FIFO_FULL     | [0]     | RO  | 1'h0        | Rx FIFO data number bigger than rx_int_mark              |



# 6.12.5.2.4 SIM\_STS1 Registers

Description: SIM card status registers 1

| 0x000C |    | SIM                     | Card S            | tatus I                   | Regist           | ers (Re                 | eset 0x           | (0000) |         |     |    |    | SIM_STS1 |         |     |    |
|--------|----|-------------------------|-------------------|---------------------------|------------------|-------------------------|-------------------|--------|---------|-----|----|----|----------|---------|-----|----|
| Bit    | 31 | 30                      | 29                | 28                        | 27               | 26                      | 25                | 24     | 23      | 22  | 21 | 20 | 19       | 18      | 17  | 16 |
| Name   |    |                         |                   |                           |                  |                         |                   | Rese   | erved   |     |    |    |          |         |     |    |
| Туре   |    |                         |                   |                           |                  |                         |                   | R      | 0       |     |    |    |          |         |     |    |
| 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   |    | DEA<br>CTI<br>VE_<br>ON | ACT<br>IVE_<br>ON | SIM<br>_AC<br>TIVE<br>_ST | SIM<br>_DA<br>TA | CAR<br>D_I<br>NSE<br>RT |                   | ΤX     | _FIFO_C | CNT |    |    | RX       | _FIFO_0 | ONT |    |
| Туре   |    | RO                      | RO                | RO                        | RO               | RO                      | RO                |        |         |     |    |    | RO       |         |     |    |
| Reset  | 0  | 0                       | 0                 | 0                         | 0                | 0                       | 0 0 0 0 0         |        |         |     | 0  | 0  | 0        | 0       |     |    |

|             | D.      | D 044 | 5           | 5                                                  |
|-------------|---------|-------|-------------|----------------------------------------------------|
| Field Name  | Bit     | R/W   | Reset Value | Description                                        |
|             | [31:15] | RO    | 17'h0       | Reserved                                           |
| DEACTIVE_ON | [14]    | RO    | 1'h0        | Busy in deactivation process                       |
| ACTIVE_ON   | [13]    | RO    | 1'h0        | Busy in activation process                         |
| SIM_ATC_ST  | [12]    | RO    | 1'h0        | Activation status, 1: activated; 0: not activated. |
| SIM_DATA    | [11]    | RO    | 1'h0        | Reflect of sim data io pin                         |
| CARD_INSERT | [10]    | RO    | 1'h0        | Reflect of card in input pin (not support)         |
| TX_FIFO_CNT | [9:5]   | RO    | 5'h0        | Tx FIFO data count, bit 9 used for debug only.     |
| RX_FIFO_CNT | [4:0]   | RO    | 5'h0        | Rx FIFO data count, bit 4 used for debug only.     |

# 6.12.5.2.5 SIM\_IE Registers

Description: SIM card interrupt enable



| 0x0010 |    |    | SIM      | Card Ir | nterrup | t Enak | ole (Re            | set 0x                     | 0000)                    |                         |                    |                   | SIM_                      |                           |                   |                    |  |
|--------|----|----|----------|---------|---------|--------|--------------------|----------------------------|--------------------------|-------------------------|--------------------|-------------------|---------------------------|---------------------------|-------------------|--------------------|--|
| Bit    | 31 | 30 | 29       | 28      | 27      | 26     | 25                 | 24                         | 23                       | 22                      | 21                 | 20                | 19                        | 18                        | 17                | 16                 |  |
| Name   |    |    | Reserved |         |         |        |                    |                            |                          |                         |                    |                   |                           |                           |                   |                    |  |
| Туре   |    |    |          |         |         |        |                    | R                          | 0                        |                         |                    |                   |                           |                           |                   |                    |  |
| 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   |    |    | Rese     | erved   |         |        | RX_<br>TOU<br>T_IE | ACT<br>IVE_<br>DON<br>E_IE | EAR<br>LY_<br>ATR<br>_IE | CAR<br>D_O<br>UT_I<br>E | CAR<br>D_I<br>N_IE | UNR<br>ESP<br>_IE | TX_<br>PAR<br>_ER<br>R_IE | RX_<br>PAR<br>_ER<br>R_IE | TX_<br>EMP<br>_IE | RX_<br>FUL<br>L_IE |  |
| Туре   |    | RO |          |         |         |        |                    |                            |                          |                         | R/W                | 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                  |  |

| Field Name    | Bit     | R/W | Reset Value | Description                                     |
|---------------|---------|-----|-------------|-------------------------------------------------|
|               | [31:10] | RO  | 22'h0       | Reserved                                        |
| RX_TOUT_IE    | [9]     | R/W | 1'h0        | Enable bit for Rx time out                      |
| ACT_DONE_IE   | [8]     | R/W | 1'h0        | Enable bit for active done                      |
| EARLY_ATR_IE  | [7]     | R/W | 1'h0        | Enable bit for early answer to reset            |
| CARD_OUT_IE   | [6]     | R/W | 1'h0        | Enable bit for card_out (not support in SC6820) |
| CARD_IN_IE    | [5]     | R/W | 1'h0        | Enable bit for card_in (not support in SC6820)  |
| URSP_CARD_IE  | [4]     | R/W | 1'h0        | Enable bit for unresp_card                      |
| TX_PRT_ERR_IE | [3]     | R/W | 1'h0        | Enable bit for tx_parity_error                  |
| RX_PRT_ERR_IE | [2]     | R/W | 1'h0        | Enable bit for rx_parity_error                  |
| TX_EPT_IE     | [1]     | R/W | 1'h0        | Enable bit for Tx empty int                     |
| RX_FULL_IE    | [0]     | R/W | 1'h0        | Enable bit for Rx full int                      |

6.12.5.2.6 SIM\_ICLR Registers

Description: SIM card interrupt clear



| 0x0014 |    |                          | SIM  | Card Ir | nterrup | t Clea | r (Res                  | et 0x0(                         | 000)                          |                          |                         |                        |                                |                                | SIM                    | ICLR                    |
|--------|----|--------------------------|------|---------|---------|--------|-------------------------|---------------------------------|-------------------------------|--------------------------|-------------------------|------------------------|--------------------------------|--------------------------------|------------------------|-------------------------|
| Bit    | 31 | 30                       | 29   | 28      | 27      | 26     | 25                      | 24                              | 23                            | 22                       | 21                      | 20                     | 19                             | 18                             | 17                     | 16                      |
| Name   |    |                          |      |         |         |        |                         | Rese                            | erved                         |                          |                         |                        |                                |                                |                        |                         |
| Туре   |    |                          |      |         |         |        |                         | R                               | .0                            |                          |                         |                        |                                |                                |                        |                         |
| 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   |    |                          | Rese | erved   |         |        | RX_<br>TOU<br>T_C<br>LR | ACT<br>IVE_<br>DON<br>E_C<br>LR | EAR<br>LY_<br>ATR<br>_CL<br>R | CAR<br>D_O<br>UT_<br>CLR | CAR<br>D_I<br>N_C<br>LR | UNR<br>ESP<br>_CL<br>R | TX_<br>PAR<br>_ER<br>R_C<br>LR | RX_<br>PAR<br>_ER<br>R_C<br>LR | TX_<br>EMP<br>_CL<br>R | RX_<br>FUL<br>L_C<br>LR |
| Туре   |    | RO R/W R/W R/W R/W R/W F |      |         |         |        |                         |                                 |                               |                          | R/W                     | 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                       |

| Field Name     | Bit     | R/W | Reset Value | Description                                        |
|----------------|---------|-----|-------------|----------------------------------------------------|
|                | [31:10] | RO  | 22'h0       | Reserved                                           |
| RX_TOUT_CLR    | [9]     | WO  | 1'h0        | Int clear bit for Rx time out                      |
| ACT_DONE_CLR   | [8]     | WO  | 1'h0        | Int clear bit for active done                      |
| EARLY_ATR_CLR  | [7]     | wo  | 1'h0        | Int clear bit for early answer to reset            |
| CARD_OUT_CLR   | [6]     | wo  | 1'h0        | Int clear bit for card_out (not support in SC6820) |
| CARD_IN_CLR    | [5]     | wo  | 1'h0        | Int clear bit for card_in (not support in SC6820)  |
| URSP_CARD_CLR  | [4]     | WO  | 1'h0        | Int clear bit for unresp_card                      |
| TX_PRT_ERR_CLR | [3]     | WO  | 1'h0        | Int clear bit for tx_parity_error                  |
| RX_PRT_ERR_CLR | [2]     | WO  | 1'h0        | Int clear bit for rx_parity_error                  |
| TX_EPT_CLR     | [1]     | WO  | 1'h0        | Int clear bit for Tx empty int                     |
| RX_FULL_CLR    | [0]     | WO  | 1'h0        | Int clear bit for Rx full int                      |

6.12.5.2.7 SIM\_CTL0 Registers

Description: SIM card control registers 0



| 0x0018 |                         |                                                | SIM                      | Card C           | ontrol     | Regis     | ters 0    | (Reset                        | 0x000          | 00)             |                         |                         |                               |                 | SIM_                    | CTL0             |
|--------|-------------------------|------------------------------------------------|--------------------------|------------------|------------|-----------|-----------|-------------------------------|----------------|-----------------|-------------------------|-------------------------|-------------------------------|-----------------|-------------------------|------------------|
| Bit    | 31                      | 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                          |                  |            |           |           |                               |                |                 |                         |                         |                               |                 |                         |                  |
| Name   |                         |                                                |                          |                  |            |           |           | Rese                          | erved          |                 |                         |                         |                               |                 |                         |                  |
| Туре   |                         |                                                |                          |                  |            |           |           | R                             | 0              |                 |                         |                         |                               |                 |                         |                  |
| 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   | TX_<br>DOU<br>T_L<br>OW | AUT<br>O_A<br>CT_<br>DEA<br>CT                 | ACT<br>_DE<br>ACT<br>_EN | DO_<br>DEA<br>CT | DO_<br>ACT | TX_<br>EN | RX_<br>EN | CAR<br>D_O<br>UT_<br>LTC<br>H | PW<br>R_E<br>N | SIM<br>_RS<br>T | TX_<br>FIF<br>O_R<br>ST | RX_<br>FIF<br>O_R<br>ST | LOO<br>PBA<br>CK_<br>MO<br>DE | ODD<br>_PA<br>R | LOG<br>IC_L<br>EVE<br>L | BIT_<br>CON<br>V |
| Туре   | R/W                     | R/W                                            | R/W                      | R/W              | R/W        | 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                       | 0                       | 0                             | 0               | 0                       | 0                |

| Field Name     | Bit     | R/W | Reset Value | Description                                                              |
|----------------|---------|-----|-------------|--------------------------------------------------------------------------|
|                | [31:16] | RO  | 16'h0       | Reserved                                                                 |
| TX_DOUT_LOW    | [15]    | R/W | 1'h0        | Force the Tx data to low logic level.                                    |
| AUTO_ACT_DEACT | [14]    | R/W | 1'h0        | Enable the auto start of active/deactive when card_in or card_out happen |
| ACT_DEACT_EN   | [13]    | R/W | 1'h0        | Enable the active/deactive procedure                                     |
| DO_DEACT       | [12]    | R/W | 1'h0        | Do deactivate operation                                                  |
| DO_ACT         | [11]    | R/W | 1'h0        | Do activate operation                                                    |
| TX_EN          | [10]    | R/W | 1'h0        | Enable the sim Tx                                                        |
| RX_EN          | [9]     | R/W | 1'h0        | Enable the sim Rx                                                        |
| CARD_OUT_LATCH | [8]     | R/W | 1'h0        | This bit will be 1 if card_out happened (not support in SC6820)          |
| POWER_EN       | [7]     | R/W | 1'h0        | Enable the Power supply to sim card                                      |
| SIM_RST        | [6]     | R/W | 1'h0        | Reset the sim card module                                                |
| TX_FIFO_RST    | [5]     | R/W | 1'h0        | Reset the Tx FIFO                                                        |
| RX_FIFO_RST    | [4]     | R/W | 1'h0        | Reset the Rx FIFO                                                        |
| LOOPBACK_MODE  | [3]     | R/W | 1'h0        | Transmit data looped back to receive.                                    |
| ODD_PRT        | [2]     | R/W | 1'h0        | 0: Even Parity 1: Odd Parity                                             |
| LOGIC_LEVEL    | [1]     | R/W | 1'h0        | 0: high logic level represent "0" 1: high logic level represent "1"      |
| BIT_COVT       | [0]     | R/W | 1'h0        | Bit convention: 0: MSB (bit 7) transmitted first                         |



|  |  |  |  | 1: LSB | (bit 0) transmitted first |
|--|--|--|--|--------|---------------------------|
|--|--|--|--|--------|---------------------------|

# 6.12.5.2.8 SIM\_CTL1 Registers

Description: SIM card control registers 1

| 0x001C |     |          | SIM | Card C                                    | ontrol     | Regis   | ter 1 ( | Reset | 0x0000 | ))     |       |   |   |        | SIM_  | CTL1 |
|--------|-----|----------|-----|-------------------------------------------|------------|---------|---------|-------|--------|--------|-------|---|---|--------|-------|------|
| Bit    | 31  | 30       | 29  | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |            |         |         |       |        |        |       |   |   |        |       |      |
| Name   |     | Reserved |     |                                           |            |         |         |       |        |        |       |   |   |        |       |      |
| Туре   |     |          |     |                                           |            |         |         | R     | 0      |        |       |   |   |        |       |      |
| 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   | AD_ | _SPD_C   | TRL | CLK<br>_PO<br>L                           | CLK<br>_EN | С       | LK_MOD  | Œ     |        | TX_INT | _MARK |   |   | RX_INT | _MARK |      |
| Туре   |     | R/W      |     | R/W                                       | 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    |

| Field Name   | Bit     | R/W | Reset Value | Description                                                                                                                                                                             |
|--------------|---------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | [31:16] | RO  | 16'h0       | Reserved                                                                                                                                                                                |
| AD_SPEED_CTL | [15:13] | R/W | 3'h0        | Control the speed of the active/deactive sequence. 0: slowest, 7: fastest.                                                                                                              |
| CLK_POL      | [12]    | R/W | 1'h0        | Set the polarity of the sim_clk signal When the sim clk is stopped                                                                                                                      |
| CLK_EN       | [11]    | R/W | 1'h0        | Enable for the sim clk output                                                                                                                                                           |
| CLK_MODE     | [10:8]  | R/W | 3'h0        | Select the sim clk speed. The sim CLK is divided From the ARM bus clock: 0: ARM CLK/2 1: ARM CLK/4 2: ARM CLK/8 3: ARM CLK/16 4: ARM CLK/32 5: ARM CLK/64 6: ARM CLK/128 7: ARM CLK/256 |
| TX_INT_MARK  | [7:4]   | R/W | 4'h0        | Tranmit_Int_WaterMark                                                                                                                                                                   |
| RX_INT_MARK  | [3:0]   | R/W | 4'h0        | Receive_Int_WaterMark                                                                                                                                                                   |

# 6.12.5.2.9 SIM\_RX\_CK\_DVD Registers

Description: SIM card RX clock divider control



| 0x0020 |    |          | SIM                     | Card R                           | X Cloc | k Divi | der Co | ntrol ( | Reset  | 0x595 | 2) |   |   | SIM_R | X_CK | DVD |
|--------|----|----------|-------------------------|----------------------------------|--------|--------|--------|---------|--------|-------|----|---|---|-------|------|-----|
| Bit    | 31 | 30       | 29                      | 29 28 27 26 25 24 23 22 21 20 19 |        |        |        |         |        |       |    |   |   |       |      | 16  |
| Name   |    | Reserved |                         |                                  |        |        |        |         |        |       |    |   |   |       |      |     |
| Туре   |    |          |                         |                                  |        |        |        | R       | 0      |       |    |   |   |       |      |     |
| 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   |    |          |                         |                                  |        |        | 5      | SIM_RX_ | CLK_DI | V     |    |   |   |       |      |     |
| Туре   |    |          |                         | R/W                              |        |        |        |         |        |       |    |   |   |       |      |     |
| Reset  | 0  | 1        | 0 1 1 0 0 1 0 1 0 0 1 0 |                                  |        |        |        |         |        |       |    |   |   |       |      |     |

| Field Name    | Bit     | R/W | Reset Value | Description                                  |
|---------------|---------|-----|-------------|----------------------------------------------|
|               | [31:16] | RO  | 16'h0       | Reserved                                     |
| SIM_RX_CK_DIV | [15:0]  | R/W | 16'h5952    | Clock divider bit 0 to 15 for receiving data |

# 6.12.5.2.10 SIM\_SEH Registers

Description: SIM card retransmit control

| 0x0024 |    |                                | SIM | Card R           | etrans                  | mit Co                 | ontrol (          | (Reset            | 0x000 | 0)     |        |    |    |        | SIM    | SEH |
|--------|----|--------------------------------|-----|------------------|-------------------------|------------------------|-------------------|-------------------|-------|--------|--------|----|----|--------|--------|-----|
| Bit    | 31 | 30                             | 29  | 28               | 27                      | 26                     | 25                | 24                | 23    | 22     | 21     | 20 | 19 | 18     | 17     | 16  |
| Name   |    | Reserved                       |     |                  |                         |                        |                   |                   |       |        |        |    |    |        |        |     |
| Туре   |    |                                |     |                  |                         |                        |                   | R                 | 0     |        |        |    |    |        |        |     |
| 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   | TX | _ETU_S                         | EL  | Res<br>erve<br>d | TX_<br>DMA<br>_SE<br>_L | RX_<br>DMA<br>_SE<br>L | DMA<br>_TX<br>_EN | DMA<br>_RX<br>_EN |       | TX_RET | RX_LMT |    |    | RX_RET | RX_LM1 | -   |
| Туре   |    | R/W RO R/W R/W R/W R/W R/W R/W |     |                  |                         |                        |                   |                   |       |        |        |    |    |        |        |     |
| Reset  | 0  |                                |     |                  |                         |                        |                   |                   |       |        |        |    |    |        |        |     |

| Field Name | Bit     | R/W | Reset Value | Description                                                                                                                                   |
|------------|---------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:16] | RO  | 16'h0       | Reserved                                                                                                                                      |
| TX_ETU_SEL | [15:13] | R/W | 3'h0        | Select the Tx etu divider:  0x111: the Tx etu is decided by sim_tx_clock_divider at address 0x0034  Others: the Tx etu is the same as Rx etu. |
|            | [12]    | RO  | 1'h0        | Reserved                                                                                                                                      |
| TX_DMA_SEL | [11]    | R/W | 1'h0        | In TX mode, once TX FIFO empty, whether DMA request keep its value until DMA                                                                  |



|              |       |     |      | acknowledge is arrived or not 0: keep 1: not keep                                                                             |
|--------------|-------|-----|------|-------------------------------------------------------------------------------------------------------------------------------|
| RX_DMA_SEL   | [10]  | R/W | 1'h0 | In RX mode, once RX FIFO full, whether DMA request keep its value until DMA acknowledge is arrived or not 0: keep 1: not keep |
| DMA_TX_EN    | [9]   | R/W | 1'h0 | TX DMA mode enable                                                                                                            |
| DMA_RX_EN    | [8]   | R/W | 1'h0 | RX DMA mode enable                                                                                                            |
| TX_RETRX_LMT | [7:4] | R/W | 4'h0 | Tx retransmit limit                                                                                                           |
| RX_RETRX_LMT | [3:0] | R/W | 4'h0 | Rx retransmit limit                                                                                                           |

# 6.12.5.2.11 SIM\_TGC Registers

Description: SIM card turnaround guard control

| 0x0028 |    |          | SIM | Card T | urnarc | ound G | uard ( | Contro | l (Rese | et 0x30 | 30) |       |       |    | SIM | TGC |
|--------|----|----------|-----|--------|--------|--------|--------|--------|---------|---------|-----|-------|-------|----|-----|-----|
| Bit    | 31 | 30       | 29  | 28     | 27     | 26     | 25     | 24     | 23      | 22      | 21  | 20    | 19    | 18 | 17  | 16  |
| Name   |    | Reserved |     |        |        |        |        |        |         |         |     |       |       |    |     |     |
| Туре   |    |          |     |        |        |        |        | R      | .0      |         |     |       |       |    |     |     |
| 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   |    |          |     | TGC_   | TIME   |        |        |        |         |         |     | GUARE | _TIME |    |     |     |
| Туре   |    | R/W R/W  |     |        |        |        |        |        |         |         |     |       |       |    |     |     |
| Reset  | 0  | 0        | 1   | 1      | 0      | 0      | 0      | 0      | 0       | 0       | 1   | 1     | 0     | 0  | 0   | 0   |

| Field Name | Bit     | R/W | Reset Value | Description                                                                              |
|------------|---------|-----|-------------|------------------------------------------------------------------------------------------|
|            | [31:16] | RO  | 16'h0       | Reserved                                                                                 |
| TGC_TIME   | [15:8]  | R/W | 8'h30       | Times in bit unit between the Rx and Tx.                                                 |
| GUARD_TIME | [7:0]   | R/W | 8'h30       | Times in bit unit between the consecutive byte during data transmission to the SIM card. |

# 6.12.5.2.12 SIM\_WDT Registers

Description: SIM card watchdog control



| 0x002C |    |                         | SIM     | Card W | Vatchd | og Co | ntrol ( | Reset  | 0x0802 | 2) |    |    |     |    | SIM                                  | WDT                                 |
|--------|----|-------------------------|---------|--------|--------|-------|---------|--------|--------|----|----|----|-----|----|--------------------------------------|-------------------------------------|
| Bit    | 31 | 30                      | 29      | 28     | 27     | 26    | 25      | 24     | 23     | 22 | 21 | 20 | 19  | 18 | 17                                   | 16                                  |
| Name   |    | Reserved                |         |        |        |       |         |        |        |    |    |    |     |    |                                      |                                     |
| Туре   |    | 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   |    |                         |         |        |        | ٧     | VDOG_0  | CNT_LM | Т      |    |    |    |     |    | WD<br>OG_<br>RTX<br>_TO<br>UT_<br>EN | WD<br>OG_<br>RX_<br>TOU<br>T_E<br>N |
| Туре   |    |                         | R/W R/W |        |        |       |         |        |        |    |    |    | R/W |    |                                      |                                     |
| Reset  | 0  | 0 0 0 1 0 0 0 0 0 0 0 0 |         |        |        |       |         |        |        |    |    | 1  | 0   |    |                                      |                                     |

| Field Name       | Bit     | R/W | Reset Value | Description                                                                                                                                                                                                 |
|------------------|---------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | [31:16] | RO  | 16'h0       | Reserved                                                                                                                                                                                                    |
| WDOG_CNT_LMT     | [15:2]  | R/W | 14'h200     | Watch dog timer limit for Rx retransmit watch dog                                                                                                                                                           |
| WDOG_RTX_TOUT_EN | [1]     | R/W | 1'h1        | Enable the Rx retransmit watch dog timer. This timer watches when Rx re-transition is happening and it will flag the unresponsive card int when the data from the sim card is time out (no data comes back) |
| WDOG_RX_TOUT_EN  | [0]     | RW  | 1'h0        | Enable the Rx time out watch dog                                                                                                                                                                            |

6.12.5.2.13 SIM\_INT\_M Registers

Description: SIM card interrupt mask



| 0x0030 | SIM Card Interrupt Mask (Reset 0x0000) |          |    |    |    |    |                         |                                 |                               |                          |                         | SIM_INT_N              |                                |                                |                        |                         |
|--------|----------------------------------------|----------|----|----|----|----|-------------------------|---------------------------------|-------------------------------|--------------------------|-------------------------|------------------------|--------------------------------|--------------------------------|------------------------|-------------------------|
| Bit    | 31                                     | 30       | 29 | 28 | 27 | 26 | 25                      | 24                              | 23                            | 22                       | 21                      | 20                     | 19                             | 18                             | 17                     | 16                      |
| Name   |                                        | Reserved |    |    |    |    |                         |                                 |                               |                          |                         |                        |                                |                                |                        |                         |
| Туре   | 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   | Reserved                               |          |    |    |    |    | RX_<br>TOU<br>T_M<br>SK | ACT<br>IVE_<br>DON<br>E_M<br>SK | EAR<br>LY_<br>ATR<br>_MS<br>K | CAR<br>D_O<br>UT_<br>MSK | CAR<br>D_I<br>N_M<br>SK | UNR<br>ESP<br>_MS<br>K | TX_<br>PAR<br>_ER<br>R_M<br>SK | RX_<br>PAR<br>_ER<br>R_M<br>SK | TX_<br>EMP<br>_MS<br>K | RX_<br>FUL<br>L_M<br>SK |
| Туре   | RO RO RO RO RO FO                      |          |    |    |    |    |                         |                                 | RO                            | RO                       | RO                      | RO                     | RO                             |                                |                        |                         |
| Reset  | 0                                      | 0        | 0  | 0  | 0  | 0  | 0                       | 0                               | 0                             | 0                        | 0                       | 0                      | 0                              | 0                              | 0                      | 0                       |

| Field Name     | Bit     | R/W | Reset Value | Description                                                |  |  |  |
|----------------|---------|-----|-------------|------------------------------------------------------------|--|--|--|
|                | [31:10] | RO  | 22'h0       | Reserved                                                   |  |  |  |
| RX_TOUT_MSK    | [9]     | RO  | 1'h0        | Masked Int status bit to show Rx time out under idle state |  |  |  |
| ACT_DONE_MSK   | [8]     | RO  | 1'h0        | Masked int bit for active done                             |  |  |  |
| EATR_MSK       | [7]     | RO  | 1'h0        | Masked int bit for early answer to reset                   |  |  |  |
| CARD_OUT_MSK   | [6]     | RO  | 1'h0        | Masked int bit for card_out                                |  |  |  |
| CARD_IN_MSK    | [5]     | RO  | 1'h0        | Masked int bit for card_in                                 |  |  |  |
| URSP_CARD_MSK  | [4]     | RO  | 1'h0        | Masked int bit for unresp_card                             |  |  |  |
| TX_PRT_ERR_MSK | [3]     | RO  | 1'h0        | Masked int bit for Tx_parity_error                         |  |  |  |
| RX_PRT_ERR_MSK | [2]     | RO  | 1'h0        | Masked int bit for Rx_parity_error                         |  |  |  |
| TX_EMP_MSK     | [1]     | RO  | 1'h0        | Masked int bit for Tx empty int                            |  |  |  |
| RX_FULL_MSK    | [0]     | RO  | 1'h0        | Masked int bit for Rx full int                             |  |  |  |

6.12.5.2.14 SIM\_TX\_CK\_DVD Registers

Description: SIM card TX clock divider control



| 0x0034 | SIM Card TX Clock Divider Control (Reset 0x5952) |                |    |    |    |    |    |    |    |    |    | SIM_TX_CK_DVD |    |    |    |    |
|--------|--------------------------------------------------|----------------|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|
| Bit    | 31                                               | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20            | 19 | 18 | 17 | 16 |
| Name   | Reserved                                         |                |    |    |    |    |    |    |    |    |    |               |    |    |    |    |
| Туре   | 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   |                                                  | SIM_TX_CLK_DIV |    |    |    |    |    |    |    |    |    |               |    |    |    |    |
| Туре   |                                                  | R/W            |    |    |    |    |    |    |    |    |    |               |    |    |    |    |
| Reset  | 0                                                | 1              | 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | 0  | 1             | 0  | 0  | 1  | 0  |

| Field Name    | Bit     | R/W | Reset Value | Description                           |  |  |
|---------------|---------|-----|-------------|---------------------------------------|--|--|
|               | [31:16] | RO  | 16'h0       | Reserved                              |  |  |
| SIM_TX_CK_DIV | [15:0]  | R/W | 16'h5952    | Clock divider bit 0 to 15 for Tx data |  |  |

### 6.12.5.2.15 SIM\_WDT1 Registers

Description: SIM card watchdog control 1

| 0x0038 | SIM Card Watchdog Control 1(Reset 0x0200) |        |          |    |    |    |    |    |    | SIM_WDT1 |    |    |    |    |    |    |
|--------|-------------------------------------------|--------|----------|----|----|----|----|----|----|----------|----|----|----|----|----|----|
| Bit    | 31                                        | 30     | 29       | 28 | 27 | 26 | 25 | 24 | 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | Reserved                                  |        |          |    |    |    |    |    |    |          |    |    |    |    |    |    |
| Туре   | 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   | Rese                                      | erved  | SIM_WDT1 |    |    |    |    |    |    |          |    |    |    |    |    |    |
| Туре   | R                                         | RO R/W |          |    |    |    |    |    |    |          |    |    |    |    |    |    |
| Reset  | 0                                         | 0      | 0        | 0  | 0  | 0  | 1  | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit     | R/W | Reset Value | Description                            |  |  |
|------------|---------|-----|-------------|----------------------------------------|--|--|
|            | [31:14] | RO  | 18'h0       | Reserved                               |  |  |
| SIM_WDT1   | [13:0]  | R/W | 14'h200     | Watch dog count limit for Rx time out. |  |  |

# 6.12.6 Application Notes

- 1. SC6820 have 2 hardware sim controllers, and it can be act as 4 software controllers.
- 2. Hardware SIM0 act as software sim0 & sim2; Hardware SIM1 act as software sim1 & sim3
- 3. To reset simcard, software should write 32'h8B00\_004C bit 5 for SIM0, bit 6 for SIM1
- 4. To enable SIM0/SIM1 interrupt, software should write 32'h20A0\_0010 bit 12 for SIM0 and SIM1  $\,$



- 5. To configure the clock plority when sim clock is stop, software should write 32'h8C00\_0000 bit[19] for sim0,
  - bit[20] for sim1, bit[30] for sim2, bit[31] for sim3
- 6. To enable simcard, software should write 32'h8B00\_0008 bit[3] for SIM0, bit[16] for SIM1.
- 7. To switch the sim0/sim2 of SIM0, or sim1/sim3 of SIM1, software should first open the pin reg write property by
  - wirte  $32'h8B00\_0008$  bit[13], then write bit[4] 0 for SIM0's sim0, 1 for SIM0's sim2; write bit[5] 0 for SIM1's sim1, 1 for SIM1's sim3.
- 8. after all of this register are configured, the software can configure the sim internal registers.

### 6.13 SDIO Host Controller

### 6.13.10verview

The SD/SDIO Host Controller is a Host Controller with an ARM processor interface. The SDIO Host Controller handles SD/SDIO Protocol at transmission level, packing data, adding cyclic redundancy check (CRC), start/end bit, and checking for transaction format correctness.

#### 6.13.2Features

- Meets SD Host Controller Standard Specification Draft Version 1.0
- Meets SDIO card specification version 1.0.
- I Meets SD Memory Card Security Specification version 1.01.
- I Supports both DMA and Non-DMA mode of operation
- I Host clock rate variable between 0 and 48 MHz
- I Supports 1 bit, 4 bit SD modes.
- I Allows card to interrupt host in 1bit, 4 bit SD modes.
- Upto 10Mbytes per second read and write rates using 4 parallel data lines (sd4 bit mode)
- I Cyclic Redundancy Check CRC7 for command and CRC16 for data integrity
- I Designed to work with I/O cards, Read-only cards and Read/Write cards.
- I Supports Read wait Control, Suspend/Resume operation.
- Supports FIFO Overrun and Underrun condition by stopping SD clock
- I Conforms to AMBA specification AHB (2.0)

### 6.13.3 Signal Description

The connection of SDIO host PADs is shown in the following figure.





Figure 6-56 SDIO Host connection

# 6.13.4Function Description



Figure 6-57 Function Block Diagram

#### 6.13.4.1 AHB Master

The AHB master initiates a read or write transaction with the memory if the Data transaction is done using DMA data transfer method.

#### 6.13.4.2 AHB Target

The AHB target is having the SD/SDIO control registers and these registers are programmed by the ARM processor through the AHB target interface. The data transaction is performed through the AHB target interface in case of Programmed IO method of data transfer.



#### 6.13.4.3 SD/SDIO Host Controller

The SD/SDIO Host Controller comprises of Host\_AHB interface, SD/SDIO controller registers, Bus monitor, Clk\_gen, CRC generator and checker (CRC7 and CRC16),. The Host\_AHB interface acts as the bridge between the ARM processor and Host Controller. The SD/SDIO controller registers are programmed by the ARM processor through AHB target interface. Interrupts are generated to the ARM processor based on the values set in the Interrupt status register and Interrupt enable registers. Bus monitor will check for any violations occurring in the SD bus and time-out conditions.

The Clock generation block will generate the SD clock depending on the value programmed by the ARM processor in the Clock Control Register. The CRC7 and CRC16 generator calculate the CRC for command and Data respectively to send the CRC to the SD/SDIO card. The CRC7 and CRC16 checker checks for any CRC error in the Response and Data send by the SD/SDIO card.

## 6.13.5Control Registers

## 6.13.5.1 Memory map

ARM base address: 0x2090\_0000

| Offset<br>Address | Name         | Description                               |
|-------------------|--------------|-------------------------------------------|
| 0x0000            | SYS_ADDR     | System address                            |
| 0x0004            | BLK_SIZE     | Block size and count                      |
| 0x0008            | ARG          | Argument                                  |
| 0x000C            | TR_MODE      | Transfer mode and command                 |
| 0x0010            | RESP0        | Response 0, 1                             |
| 0x0014            | RESP2        | Response 2, 3                             |
| 0x0018            | RESP4        | Response 4, 5                             |
| 0x001C            | RESP6        | Response 6, 7                             |
| 0x0020            | BUF_PRT      | Buffer data port                          |
| 0x0024            | PRES_STATE   | Present state                             |
| 0x0028            | SD_CTRL1     | SD Control Register1                      |
| 0x002C            | SD_CTRL2     | SD Control Register2                      |
| 0x0030            | INT_ST       | Normal and error interrupt status         |
| 0x0034            | INT_ST_EN    | Interrupt status enable                   |
| 0x0038            | INT_SIG_EN   | Interrupt signal enable                   |
| 0x003C            | CMD12_ST     | Auto CMD12 error status                   |
| 0x0040            | CAP1         | Capabilities 1                            |
| 0x0044            | CAP2         | Capabilities 2 (reserved)                 |
| 0x0048            | MAX_CUR_CAP1 | Maximum current capabilities 1            |
| 0x004C            | MAX_CUR_CAP2 | Maximum current capabilities 2 (reserved) |
|                   |              |                                           |
| 0x002C            | SLT_INT_ST   | Slot interrupt status and version number  |



Note:

The SD host controller registers given above are for Slot 1. The same set of registers is used for Slot 2.

Address range for Slot 1: 0x0000 ~ 0x00FF Address range for Slot 2: 0x0100 ~ 0x01FF

## 6.13.5.2 Register Descriptions

#### 6.13.5.2.1 SYS\_ADDR

Description: DMA system address

| 0x0000 |    |              | Syste | em Ad | dress | (reset | 0x000 | 0_0000 | ))     |    |    |    |    |    | SYS_A | DDR |
|--------|----|--------------|-------|-------|-------|--------|-------|--------|--------|----|----|----|----|----|-------|-----|
| Bit    | 31 | 30           | 29    | 28    | 27    | 26     | 25    | 24     | 23     | 22 | 21 | 20 | 19 | 18 | 17    | 16  |
| Name   |    | DMA_SYS_ADDR |       |       |       |        |       |        |        |    |    |    |    |    |       |     |
| Туре   |    |              |       |       |       |        |       | R      | W      |    |    |    |    |    |       |     |
| 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   |    |              |       |       |       |        | I     | DMA_SY | S_ADDF | ₹  |    |    |    |    |       |     |
| Туре   |    |              |       |       |       |        |       | R      | W      |    |    |    |    |    |       |     |
| Reset  | 0  | 0            | 0     | 0     | 0     | 0      | 0     | 0      | 0      | 0  | 0  | 0  | 0  | 0  | 0     | 0   |

| Field-Name   | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMA_SYS_ADDR | [31:0] | R/W  | 32'h0          | This register contains the system memory address for a DMA transfer. When the Host Controller (HC) stops a DMA transfer, this register shall point to the system address of the next contiguous data position. It can be accessed only if no transaction is executing (i.e., after a transaction has stopped). Read operations during a transfer return an invalid value. The Host Driver (HD) shall initialize this register before starting a DMA transaction. After DMA has stopped, the next system address of the next contiguous data position can be read from this register. The DMA transfer waits at every boundary specified by the Host DMA Buffer Size in the Block Size register. The Host Controller generates DMA Interrupt to request to update this register. The HD set the next system address of the next data position to this register. When most upper byte of this register (0x0003) is written, the HC restarts the DMA transfer. When restarting DMA by the resume command or by setting Continue Request in the Block Gap Control register, the HC shall start at the next contiguous address stored here in the System Address register |

6.13.5.2.2 BLK\_SIZE

Description: Block Size and Count



| 0x0004 |                         |       | Bloc        | k Size  | and C | ount (r                 | eset 0 | x0000 | _0000) |       |        |    |    |    | BLK_ | SIZE |
|--------|-------------------------|-------|-------------|---------|-------|-------------------------|--------|-------|--------|-------|--------|----|----|----|------|------|
| Bit    | 31                      | 30    | 29          | 28      | 27    | 26                      | 25     | 24    | 23     | 22    | 21     | 20 | 19 | 18 | 17   | 16   |
| Name   |                         |       |             | BLK_CNT |       |                         |        |       |        |       |        |    |    |    |      |      |
| Туре   |                         |       |             | R/W     |       |                         |        |       |        |       |        |    |    |    |      |      |
| Reset  | 0                       | 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   | TR_<br>BLK<br>_SIZ<br>E | HST_I | DMA_BU<br>E | IF_SIZ  |       |                         |        |       |        | TR_BL | K_SIZE |    |    |    |      |      |
| Type   | R/W                     |       | R/W         |         | R/W   |                         |        |       |        |       |        |    |    |    |      |      |
| Reset  | 0                       | 0     | 0           | 0       | 0     | 0 0 0 0 0 0 0 0 0 0     |        |       |        |       |        |    |    |    | 0    |      |

| Field Name       | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BLK_CNT          | [31:16] | R/W  | 16'h0          | Block count. This register is enabled when <b>Block Count Enable</b> in the Transfer Mode register is set to 1 and is valid only for multiple block transfers. The HC decrements the block count after each block transfer and stops when the count reaches zero.  It can be accessed only if no transaction is                                                                                  |
|                  |         |      |                | executing (i.e., after a transaction has stopped). Read operations during transfer return an invalid value and write operations shall be ignored.                                                                                                                                                                                                                                                |
|                  |         |      |                | When saving transfer context as a result of Suspend command, the number of blocks yet to be transferred can be determined by reading this register. When restoring transfer context prior to issuing a Resume command, the HD shall restore the previously saved block count.0x0000: stop count0x0001: 1 block0x0002: 2 blocks0xFFFF: 65535 blocks                                               |
| TR_BLK_SIZE      | [15]    | R/W  | 1'h0           | Transfer block size bit [12]. This bit is added to support 4 kb data block transfer.                                                                                                                                                                                                                                                                                                             |
| HST_DMA_BUF_SIZE | [14:12] | R/W  | 3'h0           | Host DMA buffer size. To perform long DMA transfer, System Address register shall be updated at every system boundary during DMA transfer. These bits specify the size of contiguous buffer in the system memory. The DMA transfer shall wait at every boundary specified by these fields and the HC generates the <b>DMA Interrupt</b> to request the HD to update the System Address register. |
|                  |         |      |                | These bits shall be used when the <b>DMA Support</b> in the Capabilities register is set to 1 and this function is active when the <b>DMA Enable</b> in the Transfer Mode register is set to 1.                                                                                                                                                                                                  |
|                  |         |      |                | 000: 4 KB (detect A11 carry out) 001: 8 KB (detect A11 carry out) 010: 16 KB (detect A11 carry out)                                                                                                                                                                                                                                                                                              |



|             |        |     |       | 011: 32 KB (detect A11 carry out) 100: 64 KB (detect A11 carry out) 101: 128 KB (detect A11 carry out) 110: 256 KB (detect A11 carry out) 111: no limit, HC will not generate the DMA interrupt                                                                                                                                                                                                           |
|-------------|--------|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TR_BLK_SIZE | [11:0] | R/W | 12'h0 | Transfer block size. This register specifies the block size for block data transfers for CMD17, CMD18, CMD24, CMD25, and CMD53. It can be accessed only if no transaction is executing (i.e., after a transaction has stopped). Read operations during transfer return an invalid value and write operations shall be ignored.  0x0000: no data transfer 0x0001: 1 byte 0x0002: 2 bytes 0x0200: 512 bytes |

## 6.13.5.2.3 TR\_MODE

Description: Transfer mode and command

| 0x000C |      |       | Trans | sfer m | ode ar   | d com | mand | (reset | 0x000 | 0_000                        | 0)                       |                          | TR_MODE          |                               |                        |            |  |
|--------|------|-------|-------|--------|----------|-------|------|--------|-------|------------------------------|--------------------------|--------------------------|------------------|-------------------------------|------------------------|------------|--|
| Bit    | 31   | 30    | 29    | 28     | 27       | 26    | 25   | 24     | 23    | 22                           | 21                       | 20                       | 19               | 18                            | 17                     | 16         |  |
| Name   | Rese | erved |       |        | CMD_     | INDEX |      |        | CMD_  |                              |                          |                          | Res<br>erve<br>d | RESP_TYPE<br>_SEL             |                        |            |  |
| Туре   | R    | 0     |       |        | R        | w     |      |        | R/    | R/W 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    | 15   | 14    | 13    | 12     | 11       | 10    | 9    | 8      | 7     | 6                            | 5                        | 4                        | 3                | 2                             | 1                      | 0          |  |
| Name   |      |       |       |        | Reserved | i     |      |        |       | CM<br>D_C<br>OM<br>P_A<br>TA | MUL<br>T_B<br>LK_<br>SEL | DAT<br>A_DI<br>R_S<br>EL | Res<br>erve<br>d | AUT<br>O_C<br>MD1<br>2_E<br>N | BLK<br>_CN<br>T_E<br>N | DMA<br>_EN |  |
| Туре   |      |       |       |        | RO       |       |      |        |       | R/W                          | R/W                      | R/W                      | RO               | R/W                           | R/W                    | R/W        |  |
| Reset  | 0    | 0     | 0     | 0      | 0        | 0     | 0    | 0      | 0     | 0                            | 0                        | 0                        | 0                | 0                             | 0                      | 0          |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                        |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:30] | RO   | 2'h0           | Reserved                                                                                                                                                           |
| CMD_INDEX  | [29:24] | R/W  | 6'h0           | Command index, set to the command number (CMD0-63, ACMD0-63)                                                                                                       |
| CMD_TYPE   | [23:22] | R/W  | 2'h0           | Commend type. There are three types of special commands, Suspend, Resume and Abort. These bits shall bet set to 00b for all other commands. 00: Normal 01: Suspend |



|                |         | 1     | Ī     | 10: Resume                                                                                                                                                                                                                                                   |
|----------------|---------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |         |       |       | 11: Abort                                                                                                                                                                                                                                                    |
| D.T. DDE 051   | FO.43   | 5.047 | 411.0 |                                                                                                                                                                                                                                                              |
| DATA_PRE_SEL   | [21]    | R/W   | 1'h0  | Data present select                                                                                                                                                                                                                                          |
|                |         |       |       | 0: no data present                                                                                                                                                                                                                                           |
|                |         |       |       | 1: data present                                                                                                                                                                                                                                              |
|                |         |       |       | This bit is set to 1 to indicate that data is present and shall be transferred using the DAT line. It is set to 0 for the following:                                                                                                                         |
|                |         |       |       | Commands using only CMD line (e.g., CMD52)                                                                                                                                                                                                                   |
|                |         |       |       | <ol> <li>Commands with no data transfer but using<br/>busy signal on DAT[0] line (R1b or R5b, e.g.,<br/>CMD38)</li> </ol>                                                                                                                                    |
|                |         |       |       | 3. Resume Command                                                                                                                                                                                                                                            |
| CMD_IND_CHK_EN | [20]    | R/W   | 1'h0  | Command index check enable  0: disable                                                                                                                                                                                                                       |
|                |         |       |       | 1: enable  If this bit is set to 1, the HC shall check the index field in the Response to see if it has the same value as the command index. If it is not, it is reported as a Command Index Error. If this bit is set to 0, the Index field is not checked. |
| CMD_CRC_CHK_EN | [19]    | R/W   | 1'h0  | Command CRC check enable                                                                                                                                                                                                                                     |
|                | []      |       |       | 0: disable                                                                                                                                                                                                                                                   |
|                |         |       |       | 1; enable                                                                                                                                                                                                                                                    |
|                |         |       | ~     | If this bit is set to 1, the HC shall check the CRC field in the Response. If an error is detected, it is reported as a Command CRC Error. If this bit is set to 0, the CRC field is not checked.                                                            |
|                | [18]    | R/W   | 1'h0  | Reserved                                                                                                                                                                                                                                                     |
| DECD TYPE CEL  | -       | R/W   | 2'h0  |                                                                                                                                                                                                                                                              |
| RESP_TYPE_SEL  | [17:16] | R/VV  | 2110  | Response type select                                                                                                                                                                                                                                         |
|                |         |       |       | 00: no response<br>01: response length 136                                                                                                                                                                                                                   |
|                |         | •     |       | 10: response length 48                                                                                                                                                                                                                                       |
|                |         |       |       | 11: response length 48, check Busy after                                                                                                                                                                                                                     |
|                |         |       |       | response                                                                                                                                                                                                                                                     |
|                | [15:7]  | R/W   | 9'h0  | Reserved                                                                                                                                                                                                                                                     |
| CMD_COMP_ATA   | [6]     | R/W   | 1'h0  | Command completion signal enable for CE-ATA device                                                                                                                                                                                                           |
|                |         |       |       | 0: device will not send command completion                                                                                                                                                                                                                   |
|                |         |       |       | signal  1: device will send command completion signal                                                                                                                                                                                                        |
| MULT_BLK_SEL   | [5]     | R/W   | 1'h0  | Multiple/single block select                                                                                                                                                                                                                                 |
|                | [-]     | ,     |       | 0: single block                                                                                                                                                                                                                                              |
|                |         |       |       | 1: multiple blocks                                                                                                                                                                                                                                           |
| DATA_DIR_SEL   | [4]     | R/W   | 1'h0  | Data transfer direction select                                                                                                                                                                                                                               |
|                |         |       |       | 0: write (Host to Card)                                                                                                                                                                                                                                      |
|                |         |       |       | 1: read (Card to Host)                                                                                                                                                                                                                                       |



|               | [3] | R/W | 1'h0 | Reserved                                                                                                                                                                                                                                                                                                                    |
|---------------|-----|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AUTO_CMD12_EN | [2] | R/W | 1'h0 | Auto CMD12 enable 0: disable 1: enable Multiple block transfers for memory require CMD12 to stop the transaction. When this bit is set to 1, the HC shall issue CMD12 automatically when last block transfer is completed. The HD shall not set this bit to issue commands that do not require CMD12 to stop data transfer. |
| BLK_CNT_EN    | [1] | R/W | 1'h0 | Block count enable 0: disable 1: enable This bit is used to enable the Block count register, which is only relevant for multiple block transfers. When this bit is 0, the Block Count register is disabled, which is useful in executing an infinite transfer.                                                              |
| DMA_EN        | [0] | R/W | 1'h0 | DMA enable 0: disable 1: enable DMA can be enabled only if <b>DMA Support</b> bit in the Capabilities register is set. If this bit is set to 1, a DMA operation shall begin when the HD writes to the upper byte of Command register (0x000F).                                                                              |

## 6.13.5.2.4 RESPONSE

Description: Response 0, 1, 2, 3, 4, 5, 6, and 7

| 0x0010 |    |                               | Resp | onse (           | and 1 |    | RESP0&1 |        |           |    |    |    |    |    |    |    |
|--------|----|-------------------------------|------|------------------|-------|----|---------|--------|-----------|----|----|----|----|----|----|----|
| Bit    | 31 | 30                            | 29   | 28               | 27    | 26 | 25      | 24     | 23        | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |    |                               | 7    | RESPONSE [31:16] |       |    |         |        |           |    |    |    |    |    |    |    |
| Туре   |    |                               |      | 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   |    |                               |      |                  |       |    | ı       | RESPON | ISE [15:0 | )] |    |    |    |    |    |    |
| Туре   |    |                               | RO   |                  |       |    |         |        |           |    |    |    |    |    |    |    |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |      |                  |       |    |         |        |           |    |    |    |    |    |    |    |



| 0x0014 |    |                               | Resp                                      | onse 2           | 2 and 3 | 3 (rese | t 0x00 | 00_00 | 00)      |    |   |   |   | RESP2&3 |   |    |
|--------|----|-------------------------------|-------------------------------------------|------------------|---------|---------|--------|-------|----------|----|---|---|---|---------|---|----|
| Bit    | 31 | 30                            | 29 28 27 26 25 24 23 22 21 20 19 18 17 10 |                  |         |         |        |       |          |    |   |   |   |         |   | 16 |
| Name   |    |                               |                                           | RESPONSE [63:48] |         |         |        |       |          |    |   |   |   |         |   |    |
| Туре   |    |                               |                                           |                  |         |         |        | R     | 0        |    |   |   |   |         |   |    |
| 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   |    |                               |                                           |                  |         |         | R      | ESPON | SE [47:3 | 2] |   |   |   |         |   |    |
| Туре   |    |                               |                                           |                  |         |         |        | R     | 0        |    |   |   |   |         |   |    |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                           |                  |         |         |        |       |          |    |   |   |   |         |   |    |

| 0x0018 |    |                                                 | Resp | onse 4 | 4 and | 5 (rese | t 0x00 | 00_00  | 00)      |    |   |   |   |   | RES | P4&5 |
|--------|----|-------------------------------------------------|------|--------|-------|---------|--------|--------|----------|----|---|---|---|---|-----|------|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |      |        |       |         |        |        |          |    |   |   |   |   |     |      |
| Name   |    |                                                 |      |        |       |         | F      | RESPON | SE [95:8 | 0] |   |   |   |   |     |      |
| Туре   |    |                                                 |      |        |       |         |        | R      | :O       |    |   |   |   |   |     |      |
| 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   |    |                                                 |      |        |       |         | F      | RESPON | SE [79:6 | 4] |   |   |   |   |     |      |
| Туре   |    | RO                                              |      |        |       |         |        |        |          |    |   |   |   |   |     |      |
| Reset  | 0  | 0                                               | 0    | 0      | 0     | 0       | 0      | 0      | 0        | 0  | 0 | 0 | 0 | 0 | 0   | 0    |

| 0x001C |    | Response 6 and 7 (reset 0x0000_0000) RESP6&7 |    |    |    |    |    |        |           |     |    |    | P6&7 |    |    |    |
|--------|----|----------------------------------------------|----|----|----|----|----|--------|-----------|-----|----|----|------|----|----|----|
| Bit    | 31 | 30                                           | 29 | 28 | 27 | 26 | 25 | 24     | 23        | 22  | 21 | 20 | 19   | 18 | 17 | 16 |
| Name   |    |                                              |    |    |    |    | RE | SPONS  | E [127:1  | 12] |    |    |      |    |    |    |
| Туре   |    |                                              |    |    |    |    |    | R      | 0         |     |    |    |      |    |    |    |
| 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   |    |                                              | X  |    |    |    | RI | ESPONS | SE [111:9 | 96] |    |    |      |    |    |    |
| Туре   |    | RO                                           |    |    |    |    |    |        |           |     |    |    |      |    |    |    |
| Reset  | 0  | 0                                            | 0  | 0  | 0  | 0  | 0  | 0      | 0         | 0   | 0  | 0  | 0    | 0  | 0  | 0  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                          |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESPONSE   | [127:0] | RO   | 128'h0         | The following table describes the mapping of command responses from the SD Bus to this register for each response type. In the table, R[] refers to a bit range within the response data as transmitted on the SD Bus, and REP[] refers to a bit range within the Response register. |

# 6.13.5.2.5 BUF\_PRT



Description: Buffer Data Port

| 0x0020 |    | Buffer Data Port (reset 0x0000_0000) BUF_PRT |    |    |    |    |    |      |      |    |    |    |    |    |    |    |
|--------|----|----------------------------------------------|----|----|----|----|----|------|------|----|----|----|----|----|----|----|
| Bit    | 31 | 30                                           | 29 | 28 | 27 | 26 | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |    |                                              |    |    |    |    |    | BUF_ | DATA |    |    |    |    |    |    |    |
| Туре   |    |                                              |    |    |    |    |    | R    | W    |    |    |    |    |    |    |    |
| 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   |    |                                              |    |    |    |    |    | BUF_ | DATA |    |    |    |    |    |    |    |
| Туре   |    | R/W                                          |    |    |    |    |    |      |      |    |    |    |    |    |    |    |
| Reset  | 0  | 0                                            | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                        |
|------------|--------|------|----------------|------------------------------------------------------------------------------------|
| BUF_DATA   | [31:0] | R/W  | 32'h0          | The Host Controller Buffer can be accessed through this 32-bit Data Port Register. |

## 6.13.5.2.6 PRES\_STATE

Description: Present State

| 0x0024 |          |      | Pres  | ent Sta  | ate (res                | set 0x0           | )1f0_0                  | 000)                     |    |         |          |    |    | PR                               | RES_S                   | TATE                        |
|--------|----------|------|-------|----------|-------------------------|-------------------|-------------------------|--------------------------|----|---------|----------|----|----|----------------------------------|-------------------------|-----------------------------|
| Bit    | 31       | 30   | 29    | 28       | 27                      | 26                | 25                      | 24                       | 23 | 22      | 21       | 20 | 19 | 18                               | 17                      | 16                          |
| Name   |          |      | i     | Reserved | i                       |                   |                         | CM<br>D_SI<br>G_L<br>VL  |    | DAT3_0_ | SIG_LVI  | _  |    | Rese                             | erved                   |                             |
| Туре   |          |      |       | RO       |                         |                   |                         | RO                       |    | R       | 0        |    |    | R                                | 0                       |                             |
| Reset  | 0        | 0    | 0     | 0        | 0                       | 0                 | 0                       | 1                        | 1  | 1       | 1        | 1  | 0  | 0                                | 0                       | 0                           |
| Bit    | 15       | 14   | 13    | 12       | 11                      | 10                | 9                       | 8                        | 7  | 6       | 5        | 4  | 3  | 2                                | 1                       | 0                           |
| Name   |          | Rese | erved |          | BUF<br>_RE<br>AD_<br>EN | BUF<br>_WR<br>_EN | REA<br>D_A<br>CTI<br>VE | WRI<br>TE_<br>ACT<br>IVE |    | ı       | Reserved | i  |    | DAT<br>_LIN<br>E_A<br>CTR<br>IVE | CM<br>D_I<br>NH_<br>DAT | CM<br>D_I<br>NH_<br>CM<br>D |
| Туре   | RO RO RO |      |       |          |                         |                   | RO                      | RO                       | RO |         |          |    |    | RO                               | RO                      | RO                          |
| Reset  | 0        | 0    | 0     | 0        | 0                       | 0                 | 0                       | 0                        | 0  | 0       | 0        | 0  | 0  | 0                                | 0                       | 0                           |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                           |
|----------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [31:25] | RO   | 7'h0           | Reserved                                                                                                                                                                                              |
| CMD_SIG_LVL    | [24]    | RO   | 1'h0           | CMD line signal level. This status is used to check <b>CMD</b> line level to recover from errors, and for debugging.                                                                                  |
| DAT3_0_SIG_LVL | [23:20] | RO   | 4'h0           | DAT [3:0] line signal level. This status is used to check <b>DAT</b> line level to recover from errors, and for debugging. This is especially useful in detecting the busy signal level from DAT [0]. |



|              |         |    | I    | 1001 ( DATIO)                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|---------|----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |         |    |      | [23]: for DAT[3]<br>[22]: for DAT[2]                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              |         |    |      | [21]: for DAT[1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |         |    |      | [20]: for DAT[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              | [19:12] | RO | 8'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| BUF_READ_EN  | [11]    | RO | 1'h0 | Buffer read enable. This status is used for non-DMA read transfers. This read only flag indicates that valid data exists in the Host side buffer. If this bit is 1, readable data exists in the buffer. A change of this bit from 1 to 0 occurs when all the block data is read from the buffer. A change of this bit from 0 to 1 occurs when all the block data is ready in the buffer and the Buffer Read Ready Interrupt is generated.  0: read disable  1: read enable         |
| BUF_WR_EN    | [10]    | RO | 1'h0 | Buffer write enable. This status is used for non-DMA write transfers. This write only flag indicates if space is available for write data. If this bit is 1, data can be written to the buffer. A change of this bit from 1 to 0 occurs when all the block data is written to the buffer. A change of this bit from 0 to 1 occurs when top of block data can be written to the buffer and the <b>Buffer Write</b> Ready Interrupt is generated.  0: write disable  1: write enable |
| READ_ACTIVE  | [9]     | RO | 1'h0 | Read transfer active. This status is used for                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| KEAD_AOTIVE  | [9]     | KO | 1110 | detecting completion of a read transfer. This bit is set to 1 for either of the following conditions:                                                                                                                                                                                                                                                                                                                                                                              |
|              |         |    |      | After the end bit of the read command                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|              |         |    |      | When writing a 1 to continue Request in the Block Gap Control register to restart a read transfer                                                                                                                                                                                                                                                                                                                                                                                  |
|              |         |    |      | This bit is cleared to 0 for either of the following conditions:                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |         |    |      | <ol> <li>When the last data block as specified by<br/>block length is transferred to the system.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                        |
|              |         |    |      | <ol> <li>When all valid data blocks have been<br/>transferred to the system and no current<br/>block transfers are being sent as a result of<br/>the Stop at Block Gap Request set to 1. A<br/>transfer complete interrupt is generated<br/>when this bit changes to 0.</li> </ol>                                                                                                                                                                                                 |
|              |         |    |      | 0: no valid data                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |         |    |      | 1: transferring data                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| WRITE_ACITVE | [8]     | RO | 1'h0 | Write transfer active. This status indicates a write transfer is active. If this bit is 0, it means no valid write data exists in the HC. This bit is set in either of the following cases:  1. After the end bit of the write com mand                                                                                                                                                                                                                                            |
|              |         |    |      | When writing a 1 to Continue Request in the Block Gap Control register to restart a write                                                                                                                                                                                                                                                                                                                                                                                          |



|                 |       |    |      | transfor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|-------|----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 |       |    |      | transfer This bit is cleared in either of the following cases:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                 |       |    |      | After getting the CRC status of the last data block as specified by the t ransfer count (Single or Multiple)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |       |    |      | <ol> <li>After getting a CRC status of any block<br/>where data transmission is about to be<br/>stopped by a Stop at Block Gap Request.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 |       |    |      | During a write transaction, a Block Gap Event interrupt is generated when this bit is changed to 0, as a result of the Stop at Block Gap Request being set. This status is useful for the HD in determining when to issue commands during write busy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                 |       |    |      | 0: no valid data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                 |       |    |      | 1: transferring data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                 | [7:3] | RO | 5'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DAT_LINE_ACTIVE | [2]   | RO | 1'h0 | DAT line active. This bit indicates whether one of the <b>DAT</b> line on SD bus is in use.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 |       |    |      | 0: DAT line inactive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                 |       |    |      | 1: DAT line active                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CMD_INH_DAT     | [1]   | RO | 1'h0 | Command inhibit (DAT)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                 |       |    |      | This status bit is generated if either the <b>DAT Line Active</b> or the <b>Read Transfer Active</b> is 1. If this bit is 0, it indicates the HC can issue the next SD command. Commands with busy signal belong to <b>Command Inhibit (DAT)</b> (e.g., R1b, R5b type). Changing from 1 to 0 generates a <b>Transfer Complete</b> interrupt in the Normal Interrupt status register.Note: The SD Host Driver can save registers in the range of 0x0000 ~ 0x000D for a suspend transaction after this bit has changed from 1 to 0.  0: can issue command that uses the DAT line                                                                                                                                                                    |
|                 |       |    |      | 1: cannot issue command that uses the DAT line                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CMD_INH_CMD     | [0]   | RO | 1'h0 | Command inhibit (CMD)  If this bit is 0, it indicates the CMD line is not in use and the HC can issue a SD command using the CMD line. This bit is set immediately after the Command register (0x000F) is written. This bit is cleared when the command response is received. Even if the Command Inhibit (DAT) is set to 1, Commands using only the CMD line can be issued if this bit is 0. Changing from 1 to 0 generates a Command complete interrupt in the Normal Interrupt Status register. If the HC cannot issue the command because of a command conflict error or because of Command Not Issued By Auto CMD12 Error, this bit shall remain 1 and the Command Complete is not set. Status issuing Auto CMD12 is not read from this bit. |

6.13.5.2.7 SD\_CTRL1

587 of 1011



Description: SD Control Register1

| 0x0028 |             |    | SD C     | ontrol   | Regis | ter1 (r                       | eset 0                    | x0000_                  | 0000) |      |          |    | SD_CTRL1                       |                          |                          |                                        |
|--------|-------------|----|----------|----------|-------|-------------------------------|---------------------------|-------------------------|-------|------|----------|----|--------------------------------|--------------------------|--------------------------|----------------------------------------|
| Bit    | 31          | 30 | 29       | 28       | 27    | 26                            | 25                        | 24                      | 23    | 22   | 21       | 20 | 19                             | 18                       | 17                       | 16                                     |
| Name   |             | ı  | Reserved | i        |       | WK_<br>EN_<br>CRD<br>_RE<br>M | WK_<br>EN_<br>CRD<br>_INS | CM<br>D_SI<br>G_L<br>VL |       | Rese | erved    |    | INT_<br>AT_<br>BLK<br>_GA<br>P | RD_<br>WAI<br>T_C<br>TRL | CON<br>T_R<br>EQU<br>EST | STP<br>_AT<br>_BL<br>K_G<br>AP_<br>REQ |
| Туре   |             |    | RO       |          |       | R/W                           | R/W                       | R/W                     |       | R    | 0        |    | 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    | 15          | 14 | 13       | 12       | 11    | 10                            | 9                         | 8                       | 7     | 6    | 5        | 4  | 3                              | 2                        | 1                        | 0                                      |
| Name   |             |    | I        | Reserved | d     |                               |                           | SD_<br>BUS<br>_PW<br>R  |       |      | Reserved | i  |                                | HI_S<br>PD_<br>EN        | SD4<br>B_M<br>ODE        | Res<br>erve<br>d                       |
| Туре   | RO          |    |          |          |       |                               | R/W                       | RO                      |       |      |          |    | R/W                            | R/W                      | RO                       |                                        |
| Reset  | 0 0 0 0 0 0 |    |          |          |       |                               | 0                         | 0                       | 0     | 0    | 0        | 0  | 0                              | 0                        | 0                        | 0                                      |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                           |
|----------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [31:27] | RO   | 5'h0           | Reserved                                                                                                                                                                                                                                                                              |
| WK_EN_CRD_REM  | [26]    | R/W  | 1'h0           | Wakeup event enable on SD card removal. This bit enables wakeup event via Card Removal assertion in the Normal Interrupt Status register. FN_WUS (Wakeup Support) in CIS does not affect this bit. 0: disable 1: enable                                                               |
| WK_EN_CRD_INS  | [25]    | R/W  | 1'h0           | Wakeup event enable on SD card insertion. This bit enables wakeup event via Card Insertion assertion in the Normal Interrupt Status register. FN_WUS (Wakeup Support) in CIS does not affect this bit. 0: disable 1: enable                                                           |
| WK_EN_CRD_INT  | [24]    | R/W  | 1'h0           | Wakeup event enable on SD card interrupt. This bit enables wakeup event via Card Interrupt assertion in the Normal Interrupt Status register. This bit can be set to 1 if FN_WUS (Wakeup Support) in CIS is set to 1. 0: disable 1: enable                                            |
|                | [23:20] | RO   | 4'h0           | Reserved                                                                                                                                                                                                                                                                              |
| INT_AT_BLK_GAP | [19]    | R/W  | 1'h0           | Interrupt at block gap. This bit is valid only in 4-bit mode of the SDIO card and selects a sample point in the interrupt cycle. Setting to 1 enables interrupt detection at the block gap for a multiple block transfer. If the SD card cannot signal an interrupt during a multiple |



|                    |      |     |      | block transfer, this bit should be set to 0. When the HD detects an SD card insertion, it shall set this bit according to the CCCR of the SDIO card.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RD_WAIT_CTRL       | [18] | R/W | 1'h0 | Read wait control. The read wait function is optional for SDIO cards. If the card supports read wait, set this bit to enable use of the read wait protocol to stop read data using DAT[2] line. Otherwise, the HC has to stop the SD clock to hold read data, which restricts commands generation. When the HD detects an SD card insertion, it shall set this bit according to the CCCR of the SDIO card. If the card does not support read wait, this bit shall never be set to 1 or DAT line conflict may occur. If this bit is set to 0, Suspend/Resume cannot be supported.  0: disable read wait control  1: enable read wait control                                                                                                                                                                    |
| CONT_REQUEST       | [17] | R/W | 1'h0 | Continue request. This bit is used to restart a transaction that was stopped using the Stop at Block Gap Request. To cancel stop at the block gap, set Stop at Block Gap Request to 0 and set this bit to restart the transfer.  The HC automatically clears this bit in either of the following cases:  1. In the case of a read transaction, the DAT Line Active changes from 0 to 1 as a read transaction restarts  2. In the case of a write transaction, the Write transfer active changes from 0 to 1 as the write transaction restarts  Therefore it is not necessary for Host driver to set this bit to 0. If Stop at Block Gap Request is set to 1, any write to this bit is ignored.  0: ignored  1: restart                                                                                         |
| STP_AT_BLK_GAP_REQ | [16] | R/W | 1'h0 | Stop at block gap request. This bit is used to stop executing a transaction at the next block gap for both DMA and non-DMA transfers. Until the transfer complete is set to 1, indicating a transfer completion, the HD shall leave this bit set to 1. Clearing both the Stop at Block Gap Request and Continue Request shall not cause the transaction to restart. Read Wait is used to stop the read transaction at the block gap. The HC shall honor Stop at Block Gap Request for write transfers, but for read transfers it requires that the SD card support Read Wait. Therefore the HD shall not set this bit during read transfers unless the SD card supports Read Wait and has set Read Wait Control to 1. In case of write transfers in which the HD writes data to the Buffer Data Port register, |



|            |        |     |      | the HD shall set this bit after all block data is written. If this bit is set to 1, the HD shall not write data to Buffer data port register. This bit affects Read Transfer Active, Write Transfer Active, DAT line active and Command Inhibit (DAT) in the Present State register.  0: transfer  1: stop                                                                                                                     |
|------------|--------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [15:9] | RO  | 7'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SD_BUS_PWR | [8]    | R/W | 1'h0 | SD bus power. Before setting this bit, the SD host driver shall set SD Bus Voltage Select. If the HC detects the No Card State, this bit shall be cleared.  0: power off 1: power on                                                                                                                                                                                                                                           |
|            | [7:3]  | RO  | 5'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                       |
| HI_SPD_EN  | [2]    | R/W | 1'h0 | High speed enable. This bit is optional. Before setting this bit, the HD shall check the High Speed Support in the Capabilities register. If this bit is set to 0 (default), the HC outputs CMD line and DAT line at the falling edge of the SD clock (up to 25 MHz). If this bit is set to 1, the HC outputs CMD line and DAT line at the rising edge of the SD clock (up to 50 MHz). 0: normal speed mode 1: high speed mode |
| SD4B_MODE  | [1]    | R/W | 1'h0 | Data transfer width, SD1 or SD4. This bit selects the data width of the HC. The HD shall select it to match the data width of the SD card.  0: 1-bit mode  1: 4-bit mode                                                                                                                                                                                                                                                       |
| 4 %        | [0]    | RO  | 1'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                       |

6.13.5.2.8 SD\_CTRL2

Description: SD Control Register2



| 0x002C |               |    | SD Control Register2 (reset 0x0000_0000) |                        |                        |                        |          |     |         |    |          |                  |     | SD_CTRL2         |                                |                    |  |  |
|--------|---------------|----|------------------------------------------|------------------------|------------------------|------------------------|----------|-----|---------|----|----------|------------------|-----|------------------|--------------------------------|--------------------|--|--|
| Bit    | 31            | 30 | 29                                       | 28                     | 27                     | 26                     | 25       | 24  | 23      | 22 | 21       | 20               | 19  | 18               | 17                             | 16                 |  |  |
| Name   | Reserved      |    |                                          | SW_<br>RST<br>_DA<br>T | SW_<br>RST<br>_CM<br>D | SW_<br>RST<br>_AL<br>L | Reserved |     |         |    |          | DATA_TIMEOUT_CNT |     |                  |                                |                    |  |  |
| Туре   |               |    | RO                                       |                        |                        | R/W                    | R/W      | R/W |         | R  | .0       |                  |     | R/W              |                                |                    |  |  |
| 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   | SDCLK_FRQ_SEL |    |                                          |                        |                        |                        |          |     |         | ı  | Reserved | d                |     | SDC<br>LK_<br>EN | INT_<br>CLK<br>_ST<br>ABL<br>E | INT_<br>CLK<br>_EN |  |  |
| Туре   | R/W           |    |                                          |                        |                        |                        |          |     |         | RO |          |                  | R/W | RO               | R/W                            |                    |  |  |
| Reset  | 0             | 0  | 0                                        | 0                      | 0                      | 0                      | 0        | 0   | 0       | 0  | 0        | 0                | 0   | 0                | 0                              | 0                  |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:27] | RO   | 5'h0           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SW_RST_DAT | [26]    | R/W  | 1'h0           | Software reset for DAT line. Only part of data circuit is reset. DMA circuit is also reset. The following registers and bits are cleared by this bit:  • Buffer Data Port Register:  ¡ Buffer is cleared and initialized.  • Present State register:  ¡ Buffer Read Enable  ¡ Buffer Write Enable  ¡ Read Transfer Active  ¡ Write Transfer Active  ¡ DAT Line Active  ¡ Command Inhibit (DAT)  • Block Gap Control register:  ¡ Continue Request  ¡ Stop At Block Gap Request  • Normal Interrupt Status register  ¡ Buffer Read Ready  ¡ Buffer Write Ready  ¡ Block Gap Event Transfer Complete  0: work  1: reset |
| SW_RST_CMD | [25]    | R/W  | 1'h0           | Software reset for CMD line. Only part of command circuit is reset. The following registers and bits are cleared by this bit:  • Present State register  ¡ Command Inhibit (CMD)  • Normal Interrupt Status register  ¡ Command Complete                                                                                                                                                                                                                                                                                                                                                                              |



|                  |         |     |      | 0: work                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|---------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |         |     |      | 1: reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| SW_RST_ALL       | [24]    | R/W | 1'h0 | Software reset for all. This reset affects the entire HC except for the card detection circuit. Register bits of type ROC, RW, RW1C, RWAC are cleared to 0. During its initialization, the HD shall set this bit to 1 to reset the HC. The HC shall reset this bit to 0 when Capabilities registers are valid and the HD can read them. Additional use of Software Reset for All may not affect the value of the Capabilities registers. If this bit is set to 1, the SD card shall reset itself and must be reinitialized by the HD.  0: work  1: reset                                                                                                                   |
|                  | [23:20] | RO  | 4'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DATA_TIMEOUT_CNT | [19:16] | R/W | 4'h0 | Data timeout counter value. This value determines the interval by which DAT line timeouts are detected. Refer to the <b>Data Timeout Error</b> in the Error Interrupt Status register for information on factors that dictate timeout generation. Timeout clock frequency will be generated by dividing the base clock TMCLK by this value. When setting this register, prevent inadvertent timeout events by clearing the <b>Data Timeout Error Status Enable</b> (in the Error Interrupt Status Enable register).  0000: TMCLK * 2^(13)  0001: TMCLK * 2^(14)  1110: TMCLK * 2^(27)  1111: reserved                                                                      |
| SDCLK_FRQ_SEL    | [15:8]  | R/W | 8'h0 | SD clock frequency select. This register is used to select the frequency of the SDCLK pin. The frequency is not programmed directly; rather this register holds the divisor of the Base Clock Frequency for SD clock in the Capabilities register. Only the following settings are allowed.  0x00: base clock (10~63 MHz) 0x01: base clock divided by 2 0x02: base clock divided by 4 0x04: base clock divided by 4 0x04: base clock divided by 16 0x10: base clock divided by 32 0x20: base clock divided by 64 0x40: base clock divided by 128 0x80: base clock divided by 256 Setting 0x00 specifies the highest frequency of the SD Clock. When setting multiple bits, |



|                |       |     |      | but multiple bits should not be set. The two default divider values can be calculated by the frequency that is defined by the Base Clock Frequency for SD Clock in the Capabilities register.  1. 25 MHz divider value 2. 400 kHz divider value The frequency of the SDCLK is set by the following formula:  Clock Frequency = (Base clock) / divisor Thus choose the smallest possible divisor which results in a clock frequency that is less than or equal to the target frequency. |
|----------------|-------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [7:3] | RO  | 5'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| SDCLK_EN       | [2]   | R/W | 1'h0 | SD clock enable. The HC shall stop SDCLK when writing this bit to 0. SDCLK Frequency Select can be changed when this bit is 0. Then, the HC shall maintain the same clock frequency until SDCLK is stopped (stop at SDCLK = 0). If the HC detects the No Card state, this bit shall be cleared.  0: disable 1: enable                                                                                                                                                                  |
| INT_CLK_STABLE | [1]   | RO  | 1'h0 | Internal clock stable. This bit is set to 1 when SD clock is stable after writing to Internal Clock Enable in this register to 1. The SD Host Driver shall wait to set SD Clock Enable until this bit is 1.Note: This is useful when using PLL for a clock oscillator that requires setup time.  0: not ready 1: ready                                                                                                                                                                 |
| INT_CLK_EN     | [0]   | R/W | 1'h0 | Internal clock enable. This bit is set to 0 when the HD is not using the HC or the HC awaits a wakeup event. The HC should stop its internal clock to go to the very low power state. Still, registers shall be able to be read and written. Clock starts to oscillate when this bit is set to 1. When clock oscillation is stable, the HC shall set Internal Clock Stable in this register to 1. This bit shall not affect card detection.  0: stop 1: oscillate                      |

6.13.5.2.9 INT\_ST

Description: Normal and error interrupt status



| 0x0030 |             |        | Norm | nal and                       | l error  | interru | upt sta | itus (re                | eset 0x                        | 0000_                   | 0000)                            |                           |                                      |                          | IN                              | T_ST                         |
|--------|-------------|--------|------|-------------------------------|----------|---------|---------|-------------------------|--------------------------------|-------------------------|----------------------------------|---------------------------|--------------------------------------|--------------------------|---------------------------------|------------------------------|
| Bit    | 31          | 30     | 29   | 28                            | 27       | 26      | 25      | 24                      | 23                             | 22                      | 21                               | 20                        | 19                                   | 18                       | 17                              | 16                           |
| Name   | VNI         | DR_ERR | _ST  | TRG<br>T_R<br>ESP<br>_ER<br>R | Reserved |         |         | SW_<br>RST<br>_AL<br>_L | AUT<br>O_C<br>MD1<br>2_E<br>RR | CUR<br>_LM<br>T_E<br>RR | DAT<br>A_E<br>ND_<br>BIT_<br>ERR | DAT<br>A_C<br>RC_<br>ERR  | DAT<br>A_TI<br>ME<br>OUT<br>_ER<br>R | CM<br>D_I<br>ND_<br>ERR  | CM<br>D_E<br>ND_<br>BIT_<br>ERR | CM<br>D_C<br>RC_<br>ERR      |
| Туре   |             | R/W    |      | R/W                           |          | RO      |         |                         | 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                                | 0                         | 0                                    | 0                        | 0                               | 0                            |
| Bit    | 15          | 14     | 13   | 12                            | 11       | 10      | 9       | 8                       | 7                              | 6                       | 5                                | 4                         | 3                                    | 2                        | 1                               | 0                            |
| Name   | ERR<br>_INT |        |      | Rese                          | erved    |         |         | CAR<br>D_I<br>NT        | Rese                           | erved                   | BUF<br>_RE<br>AD_<br>RDY         | BUF<br>_WR<br>ITE_<br>RDY | DMA<br>_INT                          | BLK<br>_GA<br>P_E<br>VNT | TR_<br>CO<br>MPL<br>ETE         | CM<br>D_C<br>OM<br>PLE<br>TE |
| Туре   | RO          |        |      | R                             | 0        |         |         | R/W                     | R                              | 0                       | R/W                              | R/W                       | 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                            |

#### Note:

Read-only status, write 1 to clear status: register bits indicate status when read, a set bit indicating a event may be cleared by writing 1, Writing 0 has no effect

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VNDR_ERR_ST    | [31:29] | R/W  | 3'h0           | Vender specified error status. Additional status bits can be defined in this register by the vendor.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| TRGT_RESP_ERR  | [28]    | R/W  | 1'h0           | Target response error status. This occurs when detecting error in m_hresp.  0: no error  1: error                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                | [27:25] | RO   | 3'h0           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| AUTO_CMD12_ERR | [24]    | R/W  | 1'h0           | Auto CMD12 error. This occurs when detecting that one of the bits in Auto CMD12 Error Status register has changed from 0 to 1. This bit is set to 1 also when Auto CMD12 is not executed due to the previous command error.  0: no error 1: error                                                                                                                                                                                                                                                                                                            |
| CUR_LMT_ERR    | [23]    | R/W  | 1'h0           | Current limit error. By setting the SD Bus Power bit in the Power Control Register, the HC is requested to supply power for the SD Bus. If the HC supports the Current Limit Function, it can be protected from an illegal card by stopping power supply to the card in which case this bit indicates a failure status. Reading 1 means the HC is not supplying power to SD card due to some failure. Reading 0 means that the HC is supplying power and no error has occurred. This bit shall always set to be 0, if the HC does not support this function. |



|                  | 1    |     |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------|------|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |      |     |       | 0: no error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  |      |     |       | 1: power failure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DATA_END_BIT_ERR | [22] | R/W | 1'h0  | Data end bit error. This occurs when detecting 0 at the end bit position of read data which uses the DAT line or the end bit position of the CRC status.  0: no error  1: error                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                  |      |     |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| DATA_CRC_ERR     | [21] | R/W | 1'h0  | Data CRC error. This occurs when detecting CRC error when transferring read data which uses the DAT line or when detecting the Write CRC Status having a value of other than "010".  0: no error  1: error                                                                                                                                                                                                                                                                                                                                                                                            |
| DATA_TIMEOUT_ERR | [20] | R/W | 1'h0  | Data timeout error. This occurs when detecting one of the following timeout conditions.  1. Busy Timeout for R1b, R5b type  2. Busy Timeout after Write CRC status  3. Write CRC status Timeout  4. Read Data Timeout  0: no error  1: timeout                                                                                                                                                                                                                                                                                                                                                        |
| CMD_IND_ERR      | [19] | R/W | 1'h0  | Command index error. This occurs if a Command Index error occurs in the Command Response.  0: no error  1: error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| CMD_END_BIT_ERR  | [18] | R/W | 1'h0  | Command end bit error. This occurs when detecting that the end bit of a command response is 0.  0: no error 1: end bit error generated                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CMD_CRC_ERROR    | [17] | R/W | 1'h0  | Command CRC error. Command CRC Error is generated in two cases.  1. If a response is returned and the Command Timeout Error is set to 0, this bit is set to 1 when detecting a CRC error in the command response  2. The HC detects a CMD line conflict by monitoring the CMD line when a command is issued. If the HC drives the CMD line to 1 level, but detects 0 level on the CMD line at the next SDCLK edge, then the HC shall abort the command (stop driving CMD line) and set this bit to 1. The Command Timeout Error shall also be set to 1 to distinguish CMD line conflict.  0: no error |
| 0115 TU 150::    |      |     | 411.5 | 1: CRC error generated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CMD_TIMEOUT_ERR  | [16] | R/W | 1'h0  | Command timeout error. This occurs only if the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |



|               |        |     |      | no response is returned within 64 SDCLK cycles from the end bit of the command. If the HC detects a CMD line conflict, in which case Command CRC Error shall also be set. This bit shall be set without waiting for 64 SDCLK cycles because the command will be aborted by the HC.  0: no error  1: timeout                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|--------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ERR_INT       | [15]   | RO  | 1'h0 | Vender specified error status. Additional status bits can be defined in this register by the vendor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|               | [14:9] | RO  | 6'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CARD_INT      | [8]    | R/W | 1'h0 | Card interrupt. Writing this bit to 1 does not clear this bit. It is cleared by resetting the SD card interrupt factor. In 1-bit mode, the HC shall detect the Card Interrupt without SD Clock to support wakeup. In 4-bit mode, the card interrupt signal is sampled during the interrupt cycle, so there are some sample delays between the interrupt signal from the card and the interrupt to the Host system. When this status has been set and the HD needs to start this interrupt service, Card Interrupt Status Enable in the Normal Interrupt Status register shall be set to 0 in order to clear the card interrupt statuses latched in the HC and stop driving the Host System. After completion of the card interrupt service (the reset factor in the SD card and the interrupt signal may not be asserted), set Card Interrupt Status Enable to 1 and start sampling the interrupt signal again.  0: no card interrupt generated |
| A X           | [7:6]  | RO  | 2'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| BUF_READ_RDY  | [5]    | R/W | 1'h0 | Buffer read ready. This status is set if the Buffer Read Enable changes from 0 to 1. 0: not ready to read buffer 1: ready to read buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| BUF_WRITE_RDY | [4]    | R/W | 1'h0 | Buffer write ready. This status is set if the Buffer Write Enable changes from 0 to 1.  0: not ready to write buffer  1: ready to write buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DMA_INT       | [3]    | R/W | 1'h0 | DMA interrupt. This status is set if the HC detects the Host DMA Buffer Boundary in the Block Size register.  0: no DMA interrupt  1: DMA interrupt generated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| BLK_GAP_EVENT | [2]    | R/W | 1'h0 | Block gap event. If the Stop at Block Gap<br>Request in the Block Gap Control Register is<br>set, this bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



|              |     |     |      | Read Transaction: This bit is set at the falling edge of the DAT Line Active Status (when the transaction is stopped at SD Bus timing. The Read Wait must be supported in order to use this function).  Write Transaction: This bit is set at the falling edge of Write Transfer Active Status (after getting CRC status at SD Bus timing).  0: no block gap event  1: transaction stopped at block gap                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|-----|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TR_COMPLETE  | [1] | R/W | 1'h0 | Transfer complete. This bit is set when a read/write transaction is completed.  Read Transaction: This bit is set at the falling edge of Read Transfer Active Status. There are two cases in which the Interrupt is generated. The first is when a data transfer is completed as specified by data length (after the last data has been read to the Host System). The second is when data has stopped at the block gap and completed the data transfer by setting the Stop at Block Gap Request in the Block Gap Control register (after valid data has been read to the Host System).  Write Transaction: This bit is set at the falling edge of the DAT Line Active Status. There are two cases in which the Interrupt is generated. The first is when the last data is written to the card as specified by data length and Busy signal is released. The second is when data transfers are stopped at the block gap by setting Stop at Block Gap Request in the Block Gap Control register and data transfers completed (after valid data is written to the SD card and the busy signal is released).  Note: Transfer Complete has higher priority than Data Timeout Error. If both bits are set to 1, the data transfer can be considered complete.  0: no data transfer complete |
| CMD_COMPLETE | [0] | R/W | 1'h0 | Command complete. This bit is set when getting the end bit of the command response (except auto CMD12).  Note: Command Timeout Error has higher priority than Command Complete. If both are set to 1, it can be considered that the response was not received correctly.  0: no command complete  1: command complete                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

## 6.13.5.2.10 INT\_ST\_EN

Description: Normal and error interrupt status enable



| 0x0034 |      |         | Normal and error interrupt status enable (reset 0x0000_0000) |                                      |    |          |    |                         |                                |                                         |                                 |                                             | INT_ST_EN                      |                                        |                                |                                       |
|--------|------|---------|--------------------------------------------------------------|--------------------------------------|----|----------|----|-------------------------|--------------------------------|-----------------------------------------|---------------------------------|---------------------------------------------|--------------------------------|----------------------------------------|--------------------------------|---------------------------------------|
| Bit    | 31   | 30      | 29                                                           | 28                                   | 27 | 26       | 25 | 24                      | 23                             | 22                                      | 21                              | 20                                          | 19                             | 18                                     | 17                             | 16                                    |
| Name   | VNDR | :_ERR_S | ST_EN                                                        | TRG<br>T_R<br>ESP<br>_ER<br>R_E<br>N | -  | Reserved |    |                         | CUR<br>_LM<br>T_E<br>RR_<br>EN | DAT<br>A_E<br>ND_<br>BIT_<br>ERR<br>_EN | DAT<br>A_C<br>RC_<br>ERR<br>_EN | DAT<br>A_TI<br>ME<br>OUT<br>_ER<br>R_E<br>N | CM<br>D_I<br>ND_<br>ERR<br>_EN | CM<br>D_E<br>ND_<br>BIT_<br>ERR<br>_EN | CM<br>D_C<br>RC_<br>ERR<br>_EN | CM<br>D_TI<br>ME<br>OUT<br>R_E<br>R_N |
| Туре   |      | R/W     |                                                              | R/W                                  |    | RO       |    |                         | 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                               | 0                                           | 0                              | 0                                      | 0                              | 0                                     |
| Bit    | 15   | 14      | 13                                                           | 12                                   | 11 | 10       | 9  | 8                       | 7                              | 6                                       | 5                               | 4                                           | 3                              | 2                                      | 1                              | 0                                     |
| Name   |      |         | į                                                            | Reserved                             | d  |          |    | CAR<br>D_I<br>NT_<br>EN | Rese                           | erved                                   | BUF<br>_RE<br>AD_<br>RDY<br>_EN | BUF<br>_WR<br>ITE_<br>RDY<br>_EN            | DMA<br>_INT<br>_EN             | BLK<br>_GA<br>P_E<br>VNT<br>_EN        | TR_<br>CO<br>MPL<br>ETE<br>_EN | CM<br>D_C<br>OM<br>PLE<br>TE_<br>EN   |
| Туре   |      |         |                                                              | RO                                   |    |          |    | R/W                     | R                              | 0                                       | R/W                             | R/W                                         | 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                                     |

| Field Name          | Bit     | Type | Reset<br>Value | Description                                               |
|---------------------|---------|------|----------------|-----------------------------------------------------------|
| VNDR_ERR_ST_EN      | [31:29] | R/W  | 3'h0           | Vender specified error signal enable 0: masked 1: enabled |
| TRGT_RESP_ERR_EN    | [28]    | R/W  | 1'h0           | Target response error signal enable 0: masked 1: enabled  |
|                     | [27:25] | RO   | 3'h0           | Reserved                                                  |
| AUTO_CMD12_ERR_EN   | [24]    | R/W  | 1'h0           | Auto CMD12 error signal enable 0: masked 1: enabled       |
| CUR_LMT_ERR_EN      | [23]    | R/W  | 1'h0           | Current limit error signal enable 0: masked 1: enabled    |
| DATA_END_BIT_ERR_EN | [22]    | R/W  | 1'h0           | Data end bit error signal enable 0: masked 1: enabled     |
| DATA_CRC_ERR_EN     | [21]    | R/W  | 1'h0           | Data CRC error signal enable 0: masked 1: enabled         |
| DATA_TIMEOUT_ERR_EN | [20]    | R/W  | 1'h0           | Data timeout error signal enable 0: masked 1: enabled     |
| CMD_IND_ERR_EN      | [19]    | R/W  | 1'h0           | Command index error signal enable 0: masked               |



|                    |        |     |      | 1: enabled                                               |
|--------------------|--------|-----|------|----------------------------------------------------------|
| CMD_END_BIT_ERR_EN | [18]   | R/W | 1'h0 | Command end bit error signal enable 0: masked 1: enabled |
| CMD_CRC_ERROR_EN   | [17]   | R/W | 1'h0 | Command CRC error signal enable 0: masked 1: enabled     |
| CMD_TIMEOUT_ERR_EN | [16]   | R/W | 1'h0 | Command timeout error signal enable 0: masked 1: enabled |
|                    | [15:9] | RO  | 7'h0 | Reserved                                                 |
| CARD_INT_EN        | [8]    | R/W | 1'h0 | Card interrupt signal enable 0: masked 1: enabled        |
|                    | [7:6]  | RO  | 2'h0 | Reserved                                                 |
| BUF_READ_RDY_EN    | [5]    | R/W | 1'h0 | Buffer read ready signal enable 0: masked 1: enabled     |
| BUF_WRITE_RDY_EN   | [4]    | R/W | 1'h0 | Buffer write ready signal enable 0: masked 1: enabled    |
| DMA_INT_EN         | [3]    | R/W | 1'h0 | DMA interrupt signal enable 0: masked 1: enabled         |
| BLK_GAP_EVENT_EN   | [2]    | R/W | 1'h0 | Block gap event signal enable 0: masked 1: enabled       |
| TR_COMPLETE_EN     | [1]    | R/W | 1'h0 | Transfer complete signal enable 0: masked 1: enabled     |
| CMD_COMPLETE_EN    | [0]    | R/W | 1'h0 | Command complete signal enable 0: masked 1: enabled      |

# 6.13.5.2.11 INT\_SIG\_EN

Description: Normal and error interrupt signal enable



| 0x0038 |      |         |       | nal and<br>00_000                    |    | interru  | upt sig | nal en                                | able (r                        | eset                                    |                                 |                                             | INT_SIG_EN                     |                                        |                                |                                       |  |  |
|--------|------|---------|-------|--------------------------------------|----|----------|---------|---------------------------------------|--------------------------------|-----------------------------------------|---------------------------------|---------------------------------------------|--------------------------------|----------------------------------------|--------------------------------|---------------------------------------|--|--|
| Bit    | 31   | 30      | 29    | 28                                   | 27 | 26       | 25      | 24                                    | 23                             | 22                                      | 21                              | 20                                          | 19                             | 18                                     | 17                             | 16                                    |  |  |
| Name   | VNDR | :_ERR_S | ST_EN | TRG<br>T_R<br>ESP<br>_ER<br>R_E<br>N | -  | Reserved | i       | AUT<br>O_C<br>MD1<br>2_E<br>RR_<br>EN | CUR<br>_LM<br>T_E<br>RR_<br>EN | DAT<br>A_E<br>ND_<br>BIT_<br>ERR<br>_EN | DAT<br>A_C<br>RC_<br>ERR<br>_EN | DAT<br>A_TI<br>ME<br>OUT<br>_ER<br>R_E<br>N | CM<br>D_I<br>ND_<br>ERR<br>_EN | CM<br>D_E<br>ND_<br>BIT_<br>ERR<br>_EN | CM<br>D_C<br>RC_<br>ERR<br>_EN | CM<br>D_TI<br>ME<br>OUT<br>R_E<br>R_N |  |  |
| Туре   |      | R/W     |       | R/W                                  |    | RO       |         |                                       | 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                               | 0                                           | 0                              | 0                                      | 0                              | 0                                     |  |  |
| Bit    | 15   | 14      | 13    | 12                                   | 11 | 10       | 9       | 8                                     | 7                              | 6                                       | 5                               | 4                                           | 3                              | 2                                      | 1                              | 0                                     |  |  |
| Name   |      |         | į     | Reserved                             | d  |          |         | CAR<br>D_I<br>NT_<br>EN               | Rese                           | erved                                   | BUF<br>_RE<br>AD_<br>RDY<br>_EN | BUF<br>_WR<br>ITE_<br>RDY<br>_EN            | DMA<br>_INT<br>_EN             | BLK<br>_GA<br>P_E<br>VNT<br>_EN        | TR_<br>CO<br>MPL<br>ETE<br>_EN | CM<br>D_C<br>OM<br>PLE<br>TE_<br>EN   |  |  |
| Туре   |      |         |       | RO                                   |    |          |         | R/W                                   | R                              | 0                                       | R/W                             | R/W                                         | 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                                     |  |  |

| Field Name          | Bit     | Type | Reset<br>Value | Description                                               |
|---------------------|---------|------|----------------|-----------------------------------------------------------|
| VNDR_ERR_ST_EN      | [31:29] | R/W  | 3'h0           | Vender specified error signal enable 0: masked 1: enabled |
| TRGT_RESP_ERR_EN    | [28]    | R/W  | 1'h0           | Target response error signal enable 0: masked 1: enabled  |
|                     | [27:25] | RO   | 3'h0           | Reserved                                                  |
| AUTO_CMD12_ERR_EN   | [24]    | R/W  | 1'h0           | Auto CMD12 error signal enable 0: masked 1: enabled       |
| CUR_LMT_ERR_EN      | [23]    | R/W  | 1'h0           | Current limit error signal enable 0: masked 1: enabled    |
| DATA_END_BIT_ERR_EN | [22]    | R/W  | 1'h0           | Data end bit error signal enable 0: masked 1: enabled     |
| DATA_CRC_ERR_EN     | [21]    | R/W  | 1'h0           | Data CRC error signal enable 0: masked 1: enabled         |
| DATA_TIMEOUT_ERR_EN | [20]    | R/W  | 1'h0           | Data timeout error signal enable 0: masked 1: enabled     |
| CMD_IND_ERR_EN      | [19]    | R/W  | 1'h0           | Command index error signal enable 0: masked               |



|                    |        |     |      | 1: enabled                                               |
|--------------------|--------|-----|------|----------------------------------------------------------|
| CMD_END_BIT_ERR_EN | [18]   | R/W | 1'h0 | Command end bit error signal enable 0: masked 1: enabled |
| CMD_CRC_ERROR_EN   | [17]   | R/W | 1'h0 | Command CRC error signal enable 0: masked 1: enabled     |
| CMD_TIMEOUT_ERR_EN | [16]   | R/W | 1'h0 | Command timeout error signal enable 0: masked 1: enabled |
|                    | [15:9] | RO  | 7'h0 | Reserved                                                 |
| CARD_INT_EN        | [8]    | R/W | 1'h0 | Card interrupt signal enable 0: masked 1: enabled        |
|                    | [7:6]  | RO  | 2'h0 | Reserved                                                 |
| BUF_READ_RDY_EN    | [5]    | R/W | 1'h0 | Buffer read ready signal enable 0: masked 1: enabled     |
| BUF_WRITE_RDY_EN   | [4]    | R/W | 1'h0 | Buffer write ready signal enable 0: masked 1: enabled    |
| DMA_INT_EN         | [3]    | R/W | 1'h0 | DMA interrupt signal enable 0: masked 1: enabled         |
| BLK_GAP_EVENT_EN   | [2]    | R/W | 1'h0 | Block gap event signal enable 0: masked 1: enabled       |
| TR_COMPLETE_EN     | [1]    | R/W | 1'h0 | Transfer complete signal enable 0: masked 1: enabled     |
| CMD_COMPLETE_EN    | [0]    | R/W | 1'h0 | Command complete signal enable 0: masked 1: enabled      |

# 6.13.5.2.12 CMD12\_ST

Description: Auto CMD12 error status



| 0x003C |    |    | Auto                    | CMD1 | 2 erro | r statu | s (res | et 0x0( | 00_00                   | 00)  |       |                 |                         |                 | CMD1                    | 2_ST             |
|--------|----|----|-------------------------|------|--------|---------|--------|---------|-------------------------|------|-------|-----------------|-------------------------|-----------------|-------------------------|------------------|
| Bit    | 31 | 30 | 29                      | 28   | 27     | 26      | 25     | 24      | 22                      | 21   | 20    | 19              | 18                      | 17              | 16                      |                  |
| Name   |    |    | Reserved                |      |        |         |        |         |                         |      |       |                 |                         |                 |                         |                  |
| Туре   |    |    | RO                      |      |        |         |        |         |                         |      |       |                 |                         |                 |                         |                  |
| 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   |    |    |                         | Rese | erved  |         |        |         | CM<br>D_N<br>OT_<br>ERR | Rese | erved | IND<br>_ER<br>R | END<br>_BIT<br>_ER<br>R | CRC<br>_ER<br>R | TIM<br>EOU<br>T_E<br>RR | Res<br>erve<br>d |
| Туре   |    |    |                         | R    | 0      |         |        |         | RO                      | R    | .0    | RO              | RO                      | RO              | RO                      | RO               |
| Reset  | 0  | 0  | 0                       | 0    | 0      | 0       | 0      | 0       | 0                       | 0    | 0     | 0               | 0                       | 0               | 0                       | 0                |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                        |
|-------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | [31:8] | RO   | 24'h0          | Reserved                                                                                                                                                                                                                           |
| CMD_NOT_ERR | [7]    | RO   | 1'h0           | Command not issued error. Setting this bit to 1 means CMD_wo_DAT is not executed due to an Auto CMD12 error ([4:1]) in this register. 0: no error 1: not issued                                                                    |
|             | [6:5]  | RO   | 2'h0           | Reserved                                                                                                                                                                                                                           |
| IND_ERR     | [4]    | RO   | 1'h0           | Auto CMD12 index error. This occurs if the Command Index error occurs in response to a command.  0: no error 1: error                                                                                                              |
| END_BIT_ERR | [3]    | RO   | 1'h0           | Auto CMD12 end bit error. This occurs when detecting that the end bit of command response is 0.  0: no error  1: end bit error generated                                                                                           |
| CRC_ERR     | [2]    | RO   | 1'h0           | Auto CMD12 CRC error. This occurs when detecting a CRC error in the command response.  0: no error  1: CRC error generated                                                                                                         |
| TIMEOUT_ERR | [1]    | RO   | 1'h0           | Auto CMD12 timeout error. This occurs if the no response is returned within 64 SDCLK cycles from the end bit of the command. If this bit is set to 1, the other error status bits ([4:2]) are meaningless.  0: no error 1: timeout |
|             | [0]    | RO   | 1'h0           | Reserved                                                                                                                                                                                                                           |



#### 6.13.5.2.13 CAP

Description: Capabilities

| 0x0040 |      |       | Capa     | bilities | s (rese | t 0x02  | e1_00 | 80) |                                      |                  |                        |    |         |         |    | CAP        |
|--------|------|-------|----------|----------|---------|---------|-------|-----|--------------------------------------|------------------|------------------------|----|---------|---------|----|------------|
| Bit    | 31   | 30    | 29       | 28       | 27      | 26      | 25    | 24  | 23                                   | 22               | 21                     | 20 | 19      | 18      | 17 | 16         |
| Name   |      | ı     | Reserved | i        |         | V18     | V30   | V33 | SUS<br>P_R<br>ES                     | DMA              | HIG<br>H_S<br>PEE<br>D | 1  | Reserve | d       |    | BLK_S<br>Æ |
| Туре   |      |       | RO       |          |         | RO      | RO    | RO  | RO                                   | RO               | RO                     |    | RO      |         |    | 0          |
| Reset  | 0    | 0     | 0        | 0        | 0       | 0       | 1     | 0   | 1                                    | 1                | 1                      | 0  | 0       | 0       | 1  |            |
| Bit    | 15   | 14    | 13       | 12       | 11      | 10      | 9     | 8   | 7                                    | 6                | 5                      | 4  | 3       | 2       | 1  | 0          |
| Name   | Rese | erved |          |          | BASE_C  | CLK_FRC | )     |     | TIM<br>EOU<br>T_C<br>LK_<br>UNI<br>T | Res<br>erve<br>d |                        | TI | MEOUT_  | _CLK_FF | 80 |            |
| Туре   | R    | 0     |          |          | R       | :0      |       |     | RO                                   | RO               |                        | RO |         |         |    |            |
| Reset  | 0    | 0     | 0        | 0        | 0       | 0       | 0     | 0   | 1                                    | 0                | 0                      | 0  | 0       | 0       | 0  | 0          |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                               |
|------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:27] | RO   | 5'h0           | Reserved                                                                                                                                                                                                                                                  |
| V18        | [26]    | RO   | 1'h0           | Voltage support 1.8 V. 0: 1.8 V not supported 1: 1.8 V supported                                                                                                                                                                                          |
| V30        | [25]    | RO   | 1'h1           | Voltage support 3.0 V. 0: 3.0 V not supported 1: 3.0 V supported                                                                                                                                                                                          |
| V33        | [24]    | RO   | 1'h0           | Voltage support 3.3 V. 0: 3.3 V not supported 1: 3.3 V supported                                                                                                                                                                                          |
| SUSP_RES   | [23]    | RO   | 1'h1           | Suspend/resume support. This bit indicates whether the HC supports Suspend/Resume function. If this bit is 0, the Suspend and Resume mechanism is not supported and the HD shall not issue either Suspend/Resume command.  0: not supported  1: supported |
| DMA        | [22]    | RO   | 1'h1           | DMA support. This bit indicates whether the HC is capable of using DMA to transfer data between system memory and the HC directly.  0: DMA not supported  1: DMA supported                                                                                |
| HIGH_SPEED | [21]    | RO   | 1'h1           | High speed support. This bit indicates whether the HC and the Host System support High Speed mode and they can supply SD Clock frequency from 25 MHz to 50 MHz.                                                                                           |



|                  |         |    |       | 0: high speed not supported     1: high speed supported                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|---------|----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | [20:18] | RO | 3'h0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| MAX_BLK_SIZE     | [17:16] | RO | 2'h01 | This value indicates the maximum block size that the HD can read and write to the buffer in the HC. The buffer shall transfer this block size without wait cycles.  00: 512 bytes  01: 1024 bytes  10: 2048 bytes  11: 4096 bytes                                                                                                                                                                                                                                                                                                         |
|                  | [15:14] | RO | 2'h0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| BASE_CLK_FRQ     | [13:8]  | RO | 6'h0  | This value indicates the base (maximum) clock frequency for the SD clock. The unit is MHz. If the real frequency is 16.5 MHz, a larger value shall be set, i.e., 010001b (17 MHz) because the HD uses this value to calculate the clock divider value and it shall not exceed the upper limit of the SD clock frequency. The supported range is 10 to 63 MHz. If these bits are all 0, the Host System has to get information via another method.  0: get information via another method (Registry Entry)  1: 1 MHz  2: 2 MHz  63: 63 MHz |
| TIMEOUT_CLK_UNIT | [7]     | RO | 1'h1  | This bit shows the unit of base clock frequency used to detect Data Timeout Error.  0: kHz  1: MHz                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                  | [6]     | RO | 1'h0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| TIMEOUT_CLK_FRQ  | [5:0]   | RO | 6'h0  | This bit shows the base clock frequency used to detect Data Timeout Error.  0: get information via another method  1: 1 MHz  2: 2 MHz   63: 63 MHz                                                                                                                                                                                                                                                                                                                                                                                        |

6.13.5.2.14 MAX\_CUR\_CAP

Description: Maximum current capabilities



| 0x0048 |               |    | Maxi | mum c  | urrent | capal | oilities | (reset | 0x000       | 0_000 | 0) |       | MAX_CUR_CAP |    |    |    |  |
|--------|---------------|----|------|--------|--------|-------|----------|--------|-------------|-------|----|-------|-------------|----|----|----|--|
| Bit    | 31            | 30 | 29   | 28     | 27     | 26    | 25       | 24     | 23          | 22    | 21 | 20    | 19          | 18 | 17 | 16 |  |
| Name   |               |    |      | Rese   | erved  |       |          |        | MAX_CUR_V18 |       |    |       |             |    |    |    |  |
| Туре   |               |    |      | R      | 0      |       |          |        |             |       |    | R     | 0           |    |    |    |  |
| 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   |               |    |      | MAX_CI | UR_V30 |       |          |        |             |       |    | MAX_C | UR_V33      |    |    |    |  |
| Туре   |               |    |      | R      | 0      |       |          |        |             |       |    | R     | 0           |    |    |    |  |
| Reset  | 0 0 0 0 0 0 0 |    |      |        |        |       |          |        | 0           | 0     | 0  | 0     | 0           | 0  | 0  | 0  |  |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                                      |
|-------------|---------|------|----------------|------------------------------------------------------------------|
|             | [31:24] | RO   | 8'h0           | Reserved                                                         |
| MAX_CUR_V18 | [23:16] | RO   | 8'h0           | Maximum current for 1.8 V. 0: get information via another method |
| MAX_CUR_V30 | [15:8]  | RO   | 8'h0           | Maximum current for 3.0 V. 0: get information via another method |
| MAX_CUR_V33 | [7:0]   | RO   | 8'h0           | Maximum current for 3.3 V. 0: get information via another method |

## 6.13.5.2.15 SLT\_INT\_ST

Description: Slot interrupt status and version number

| 0x00FC |    |    |    | nterru<br>00_00 |        | us and | d versi | ion nui | mber (                                | reset |    |    |    | S  | LT_IN | T_ST |  |
|--------|----|----|----|-----------------|--------|--------|---------|---------|---------------------------------------|-------|----|----|----|----|-------|------|--|
| Bit    | 31 | 30 | 29 | 28              | 27     | 26     | 25      | 24      | 23                                    | 22    | 21 | 20 | 19 | 18 | 17    | 16   |  |
| Name   |    |    |    | VNDR_\          | /ER_NO |        |         |         | 23   22   21   20   19   18   17   16 |       |    |    |    |    |       |      |  |
| Туре   |    |    |    | R               | 0      |        |         |         | 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   |    |    |    | Rese            | erved  |        |         |         | SLT_INT                               |       |    |    |    |    |       |      |  |
| Туре   |    |    |    | R               | 0      |        |         |         | RO                                    |       |    |    |    |    |       |      |  |
| Reset  | 0  | 0  | 0  | 0               | 0      | 0      | 0       | 0       | 0                                     | 0     | 0  | 0  | 0  | 0  | 0     | 0    |  |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                                                                                                                    |
|-------------|---------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| VNDR_VER_NO | [31:24] | RO   | 8'h0           | This status is reserved for the vendor version number. The HD should not use this status.                                                      |
| SPEC_VER_NO | [23:16] | RO   | 8'h0           | This status indicates the Host Controller Spec Version. The upper and lower 4 bits indicate the version.  0: SD Host Specification version 1.0 |



|         |        |    |      | Others: reserved                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|--------|----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | [15:8] | RO | 8'h0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SLT_INT | [7:0]  | RO | 8'h0 | These status bits indicate the logical OR of Interrupt signal and Wakeup signal for each slot. A maximum of 8 slots can be defined. If one interrupt signal is associated with multiple slots, the HD can know which interrupt is generated by reading these status bits. By a power-on reset or by Software Reset for All, the Interrupt signal shall be deasserted and this status shall read 0.  [0]: slot 1  [1]: slot 2 |

#### 6.14 SDIO slave Controller

#### 6.14.1 Overview

SDIO: SD Input/Output

The SDIO (SD Input/Output) slave model is based on and compatible with the SD memory card. The intent of SDIO module used in SPRD design is to transfer data from/to data card. It has the AHB master and slave interface to commute with the main AHB bus.

#### 6.14.2 Features

- I Targeted for high speed data transfer applications (as slave).
- I Compatible with SD physical layer specification ver2.0
- I Compatible with SDIO specification ver2.0
- Allows card to interrupt host
- I SDIO card only
- I Support only function 1 (function 0 default support)
- I Support SD 4/1 bit mode
- I Support read wait
- I Support suspend/resume
- Support direct commands during data transfer
- I Support multi-block
- Support infinite transfer
- Support interrupt between blocks of data in 4-bit SD mode
- Support f0 max block size 1 bytes
- Support f1 max block size 1024bytes
- I Support full speed card 25MHz
- I Support high speed card 50MHz
- No support master power control
- I No support code storage area
- No support SPI mode of this module (it reused with the outside independent SPI module)
- I Initialization IO voltage: 3.3V
- I Operational IO voltage range: (4 level adjustable outside this module)



#### 6.14.3 Signal Description

There are 6 signals to interface with external chip of SDIO host. CLK pad is used to provide the working clock for internal register, CMD pad is to receive SDIO host command or send response, and the DAT3~ 0 lines is used to transfer data.

Table 6-12 SDIO interface

| PIN Name | Description  |
|----------|--------------|
| CLK      | Clock        |
| CMD      | Command line |
| DAT0     | Data 0 line  |
| DAT1     | Data 1 line  |
| DAT2     | Data 2 line  |
| DAT3     | Data 3 line  |

The external connection of SDIO host and SDIO slave can be refer to the following figure.



Figure 6-58 SDIO Connection

## 6.14.4 Function Description

The preliminary idea of this module is to interconnect AP to our BB module and interchange data using the popular interface of SDIO port.

The SDIO slave module is used to transfer data using the SDIO protocol which compatible with the "SD Specifications Part E1 SDIO Specification Version 2.00 January 30, 2007" and "SD Specifications Part 1 Physical Layer Specification Version 2.00" except for the omitted SPI protocol which divided to an individual module.

#### 6.14.4.1 Block Diagram





Figure 6-59 System Block Diagram

This SDIO slave have there main interfaces. The first is the SD bus which act as the SDIO slave interface to receive the host command and transfer data to/from internal data FIFO. The other two interfaces are AHB master and target interface which act as the porter that transit data between AHB bus and internal data FIFO.

As the figure shows, the control flow and data flow are draw with different type of arrows

The CIA register is configured through the SD bus interface, AHB control register is configured through AHB target interface.

The internal FIFO is operated in Ping-Pang mode, and the data can be take away by CPU read/write through AHB target interface of directly read/write through AHB master by DMA.

#### 6.14.4.2 SDIO Slave Initial Sequence

After reset or power-up, I/O function 1 on the card is disabled and shall not execute any operation except CMD5. At first the host sends CMD5 with no argument to ask the card for the OCR, and the card responses with its supported OCR and supported functions (in this card, only function 1 is support). After this, host set an appropriate voltage according to the card's replied OCR and wait for the card is ready to operate. After the card is ready, host send CMD3 to ask card for the RCA which used to distinguish the different slave card if there are more than one card existed. All the initialized of the I/O card is completed after card replayed with right RCA.

This I/O only card will not respond to the CMD0, CMD1 and CMD55/ACMD41 command, so any of the following except cases are no response and the card will be set to inactive state which has no affect to the card.

- I if the host is non-I/O aware host
- if the host wants to initialize the card to SD or MMC memory card
- I if the host wants to initialize the card to SPI mode

To select this card, the host shall send CMD7 with the given RCA before all the following operations. After the host has initialized the I/O portion of the card, it then reads the Common Information Area (CIA) of the card. This is done by issuing a read command, starting with the byte at address 0x00, of I/O function 0. The CIA contains the Card Common Control Registers (CCCR) and the Function Basic Registers (FBR). Also included in the CIA are pointers to the card's common Card Information Structure (CIS) and each individual function's CIS. The CIS includes information on power, function, manufacturer and other things the host needs to determine if the I/O function(s) is appropriate to power-up. If the host determines that the card should be activated, a register in the CCCR area enables the card and each individual function.



At this time, all functions of the I/O card are fully available. In addition, the host can enable/disable interrupts on a function-by-function basis.



Figure 6-60 SDIO Initial Sequence

#### 6.14.4.3 Supported Command and Response

In our design, there are just 6 command supported. CMD5 is used to get card's support voltage and set new appreciate voltage; CMD3 is used to get card's relative card address. CMD5 and CMD3 command are acted as initial command. CMD7 is used to select the right card base on previously get RCA or to unselect the card. CMD52 is an IO direct read/write command, it is the fastest means to read or write single I/O register, also act to read or write the control registers. CMD53 is an IO extended read/write command; it is used to transfer a large number of data in one time. CMD15 is not a common used command; it is used to send card into an inactive state which just can be active by power reset.

Table 6-13 Support CMD and RSP

| Command | Command Name                 | Response | Description                                                                                                        |
|---------|------------------------------|----------|--------------------------------------------------------------------------------------------------------------------|
| CMD3    | SEND_RELATIV<br>E_ADDR       | R6       | Ask the card to publish a new relative address (RCA)                                                               |
| CMD5    | IO_SEND_OP_C<br>OND          | R4       | It is used to inquire about the voltage range needed by the I/O card.                                              |
| CMD7    | SELECT/<br>DESELECT_CAR<br>D | R1b      | Command toggles a card between the stand-by and transfer states or between the programming and disconnects states. |
| CMD15   | GO_INACTIVE_S                | N/A      | Sends an addressed card into the Inactive State.                                                                   |



|       | TATE               |    |                                                                                                                                |
|-------|--------------------|----|--------------------------------------------------------------------------------------------------------------------------------|
| CMD52 | IO_RW_DIRECT       | R5 | This command is the fastest means to read or write single I/O registers, as it requires only a single command / response pair. |
| CMD53 | IO_RW_EXTEND<br>ED | R5 | This command allows the reading or writing of a large number of I/O registers with a single command.                           |

## 6.14.4.3.1 CMD3

| Bit         | 47 | 46 | 45:40     | 39:8          | 7:1  | 0 |
|-------------|----|----|-----------|---------------|------|---|
| Width       | 1  | 1  | 6         | 32            | 7    | 1 |
| Value       | 0  | 1  | 6'b000011 | 32'h0000_0000 | х    | 1 |
| Description | S  | D  | CMD Index | Stuff bits    | CRC7 | E |

Note:

The gray color background table are don't care registers and reserved to fix value.

#### 6.14.4.3.2 CMD5

| Bit         | 47 | 46 | 45:40     |       | 7:1          | 0    |   |
|-------------|----|----|-----------|-------|--------------|------|---|
| Width       | 1  | 1  | 6         | 8     | 24           | 7    | 1 |
| Value       | 0  | 1  | 6'b000101 | 8'h0  | X            | х    | 1 |
| Description | S  | D  | CMD Index | Stuff | I/O OCR (*1) | CRC7 | Е |

#### 6.14.4.3.3 CMD7

| Bit         | 47 | 46 | 45:40     | 39  | 9:8        | 7:1  | 0 |
|-------------|----|----|-----------|-----|------------|------|---|
| Width       | 1  | 1  | 6         | 16  | 16         | 7    | 1 |
| Value       | 0  | 1  | 6'b000111 | х   | 16'h0      | Х    | 1 |
| Description | S  | D  | CMD Index | RCA | Stuff bits | CRC7 | Е |

## 6.14.4.3.4 CMD15

| Bit         | 47 | 46 | 45:40     | 39:8 | 7:1        | 0    |   |
|-------------|----|----|-----------|------|------------|------|---|
| Width       | 1  | 1  | 6         | 16   | 16         | 7    | 1 |
| Value       | 0  | 1  | 6'b001111 | х    | 16'h0      | х    | 1 |
| Description | S  | D  | CMD Index | RCA  | Stuff bits | CRC7 | Е |

## 6.14.4.3.5 CMD52

| Bit   | 47 | 4 | 45:40         |            |                      |             | 39:   | 8            |       |               | 7:1  | 0 |
|-------|----|---|---------------|------------|----------------------|-------------|-------|--------------|-------|---------------|------|---|
| Width | 1  | 1 | 6             | 1          | 3                    | 1           | 1     | 17           | 1     | 8             | 7    | 1 |
| Value | 0  | 1 | 6'b11010<br>0 | Х          | х                    | Х           | 0     | Х            | 0     | Х             | 7'h0 | 1 |
| Des.  | S  | D | CMD<br>Index  | RW<br>Flag | Fun<br>c.<br>Nu<br>m | RAW<br>Flag | Stuff | Reg.<br>Addr | Stuff | Write<br>Data | CRC7 | E |

## 6.14.4.3.6 CMD53



| Bit   | 47 | 4<br>6 | 45:40         |            | 39:8                 |               |            |              |                     |      | 0 |
|-------|----|--------|---------------|------------|----------------------|---------------|------------|--------------|---------------------|------|---|
| Width | 1  | 1      | 6             | 1          | 3                    | 1             | 1          | 17           | 9                   | 7    | 1 |
| Value | 0  | 1      | 6'b11010<br>1 | х          | х                    | Х             | х          | Х            | х                   | 7'h0 | 1 |
| Des.  | S  | D      | CMD<br>Index  | RW<br>Flag | Fun<br>c.<br>Nu<br>m | Block<br>Mode | OP<br>Code | Reg.<br>Addr | Byte/Block<br>Count | CRC7 | E |

#### 6.14.4.3.7 R6

| Bit         | 47 | 46 | 45:40     | 39:8              | 7:1             | 0    |   |
|-------------|----|----|-----------|-------------------|-----------------|------|---|
| Width       | 1  | 1  | 6         | 16                | 16              | 7    | 1 |
| Value       | 0  | 0  | 6'b000011 | х                 | х               | х    | 1 |
| Description | S  | D  | CMD Index | New published RCA | Card Status(*2) | CRC7 | Е |

## 6.14.4.3.8 R4

| Bit         | 47 | 46 | 45:40     |   | 39:8                 |             |               | 7:1     | 0    |   |
|-------------|----|----|-----------|---|----------------------|-------------|---------------|---------|------|---|
| Width       | 1  | 1  | 6         | 1 | 3                    | 1           | 3             | 24      | 7    | 1 |
| Value       | 0  | 0  | 6'b111111 |   | 1                    | 0           | 3'b0          | х       | 7'h0 | 1 |
| Description | S  | D  | Rsv       | С | Nu<br>m<br>of<br>I/O | Mem<br>Pres | Stuff<br>Bits | I/O OCR | Rsv  | E |

#### 6.14.4.3.9 R1b

| Bit         | 47 | 46 | 45:40     | 39:8            | 7:1  | 0 |
|-------------|----|----|-----------|-----------------|------|---|
| Width       | 1  | 1  | 6         | 32              | 7    | 1 |
| Value       | 0  | 0  | 6'b000111 | x               | х    | 1 |
| Description | S  | D  | CMD Index | Card status(*3) | CRC7 | Е |

## 6.14.4.3.10 R5

| Bit         | 47 | 46 | 45:40     | 39:8  |                        |                      | 7:1  | 0 |
|-------------|----|----|-----------|-------|------------------------|----------------------|------|---|
| Width       | 1  | 1  | 6         | 16    | 8                      | 8                    | 7    | 1 |
| Value       | 0  | 0  | 6'b110101 | х     | Х                      | x                    | х    | 1 |
| Description | S  | D  | CMD Index | Stuff | Response<br>Flags (*4) | Read / Write<br>Data | CRC7 | E |

# 6.14.4.3.11 Note

\*1, OCR

## Table 6-14 OCR map

| I/O OCR bit position | VDD voltage window ( in volts) |
|----------------------|--------------------------------|
| 0 ~ 7                | Reserved                       |
| 8                    | 2.0 ~ 2.1                      |



| 9  | 2.1 ~ 2.2 |
|----|-----------|
| 10 | 2.2 ~ 2.3 |
| 11 | 2.3 ~ 2.4 |
| 12 | 2.4 ~ 2.5 |
| 13 | 2.5 ~ 2.6 |
| 14 | 2.6 ~ 2.7 |
| 15 | 2.7 ~ 2.8 |
| 16 | 2.8 ~ 2.9 |
| 17 | 2.9 ~ 3.0 |
| 18 | 3.0 ~ 3.1 |
| 19 | 3.1 ~ 3.2 |
| 20 | 3.2 ~ 3.3 |
| 21 | 3.3 ~ 3.4 |
| 22 | 3.4 ~ 3.5 |
| 23 | 3.5 ~ 3.6 |
|    |           |

## \*2, Card Status 1 (16 bits)

| Bits | Identifier          | Туре | Value                   | Description                                                  | Clear<br>Condition |
|------|---------------------|------|-------------------------|--------------------------------------------------------------|--------------------|
| 15   | COM_CRC_ERROR       | ER   | 0, no error<br>1, error | The CRC check of the previous command failed.                | В                  |
| 14   | ILLEGAL_COMMAN<br>D | ER   | 0, no error<br>1, error | Command not legal for the card state                         | В                  |
| 13   | ERROR               | ERX  | 0, no error<br>1, error | A general or an unknown error occurred during the operation. | С                  |
| 12:0 | Reserved            |      | 0                       |                                                              |                    |

# \*3, Card Status 2 (32 bits)

| Bits  | Identifier          | Туре | Value                   | Description                                                  | Clear<br>Condition |
|-------|---------------------|------|-------------------------|--------------------------------------------------------------|--------------------|
|       |                     |      |                         |                                                              |                    |
| 23    | COM_CRC_ERRO        | ER   | 0, no error<br>1, error | The CRC check of the previous command failed.                | В                  |
| 22    | ILLEGAL_COMMAN<br>D | ER   | 0, no error<br>1, error | Command not legal for the card state                         | В                  |
| 21:20 | Reserved            |      | 0                       |                                                              |                    |
| 19    | ERROR               | ERX  | 0, no error<br>1, error | A general or an unknown error occurred during the operation. | С                  |
| 18:0  | Reserved            |      | 0                       |                                                              |                    |

## \*4, Response Flags



| Bits | Identifier           | Туре                               | Value                                    | Description                                                        | Clear<br>Condition |
|------|----------------------|------------------------------------|------------------------------------------|--------------------------------------------------------------------|--------------------|
| 7    | COM_CRC_ERRO<br>R    | ER                                 | 0, no error<br>1, error                  | The CRC check of the previous command failed.                      | В                  |
| 6    | ILLEGAL_COMMA<br>ND  | ER                                 | 0, no error<br>1, error                  | Command not legal for the card state                               | В                  |
| 5:4  | IO_CURRENT_ST<br>ATE | S                                  | 00, DIS<br>01, CMD<br>02, TRN<br>03, RFU | DIS: Disabled: CMD: Data line free. TRN: Data transferring         | В                  |
| 3    | ERROR                | E R<br>(CMD52)<br>E R X<br>(CMD53) | 0, no error<br>1, error                  | A general or an unknown error occurred during the operation.       | С                  |
| 2    | Reserved             |                                    | 0                                        |                                                                    |                    |
| 1    | FUNCTION_NUMB<br>ER  | ER                                 | 0, no error<br>1, error                  | An invalid function number was requested                           | С                  |
| 0    | OUT_OF_RANGE         | ER                                 | 0, no error<br>1, error                  | The command's argument was out of the allowed range for this card. | С                  |

| Type:    |                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------|
| E:       | Error bit.                                                                                                         |
| R:       | Detected and set for the actual command response.                                                                  |
| S:       | Status bit.                                                                                                        |
| X:       | Detected and set during command execution.  The host can get the status by issuing a command with R1 response      |
| Clear Co | ndition:                                                                                                           |
| C:       | Clear by read.                                                                                                     |
| B:       | Always related to the previous command.  Reception of a valid command will clear it (with a delay of one command). |



#### 6.14.4.4 Bus State Diagram for SDIO card



Figure 6-61

**Bus State Diagram** 

# 6.14.5 Control Registers

The SDIO register has divided into two parts, the SD domain and AHB domain.

#### 6.14.5.1 AHB Domain Memory map

ARM base address: 0x2050\_0200 (SC6820)

Table 6-15 AHB Domain Registers

| Offset<br>Address | Name         | Description                            |
|-------------------|--------------|----------------------------------------|
| 0x0000            | SYS_ADDR     | DMA system address                     |
| 0x0004            | RST_DMASET   | DMA setting and software reset         |
| 0x0008            |              | Reserved                               |
| 0x000C            | BLK_CNT_SIZE | Block size and block count information |
| 0x0010            | TRANS_MODE   | Transfer mode information              |
| 0x0014            | CURT_STATUS  | Current operation status               |
| 0x0018            | CMD_ARG      | Current command argument               |
| 0x001C            | RSP_ARG      | Current response argument              |
| 0x0020            | DAT_PORT     | Read or write buffer data port         |
| 0x0024            |              | Reserved                               |
| 0x0028            |              | Reserved                               |
| 0x002C            |              | Reserved                               |
| 0x0030            | INT_EN       | Interrupt enable signal                |
| 0x0034            | INT_CLR      | Interrupt clear signal                 |
| 0x0038            | INT_RAW      | Interrupt raw status                   |
| 0x003C            | INT_STA      | Interrupt masked status                |



| Offset<br>Address | Name     | Description     |
|-------------------|----------|-----------------|
| 0x0040            | SUPT_OCR | Supported OCR   |
| 0x0044            | CURT_OCR | Set current OCR |

#### 6.14.5.2 AHB Domain Register Descriptions

#### 6.14.5.2.1 SYS\_ADDR Registers

Description: System memory address for DMA transfer

This register indicates the DMA where to read or write data. To use DMA transfer, this register should be set first.

| 0x0000 |    |                           | DMA | syste | m add | ress (F | Reset ( | 0x0000 | _0000   | )  |    |    |    |    | SYS_A | ADDR |
|--------|----|---------------------------|-----|-------|-------|---------|---------|--------|---------|----|----|----|----|----|-------|------|
| Bit    | 31 | 30                        | 29  | 28    | 27    | 26      | 25      | 24     | 23      | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
| Name   |    |                           |     |       |       |         |         | SYS_A  | DDR (H) |    |    |    |    |    |       |      |
| Туре   |    | R/W                       |     |       |       |         |         |        |         |    |    |    |    |    |       |      |
| 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   |    |                           |     |       |       |         |         | SYS_A  | DDR (L) |    |    |    |    |    |       |      |
| Туре   |    | RW                        |     |       |       |         |         |        |         |    |    |    |    |    |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |     |       |       |         |         |        |         |    |    |    |    |    |       |      |

Note:

You can write the system address registers bytes by bytes, half-word by half-word or word by word.

(H) Indicate the high end of this register, (L) indicate the low end of this register.

| Field Name | Bit    | Туре | Reset Value | Description                                                                                                                                                                            |
|------------|--------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SYS_ADDR   | [31:0] | R/W  | 32'h0       | This register indicates the DMA where to read or write data. To use DMA transfer, this register should be set first. Note, once the DMA transfer is processing, modifying is forbidden |

### 6.14.5.2.2 RST\_DMASET Registers

Description: Write 1 to the relative register can reset the AHB or SDIO domain registers; Before using DMA, the DMA buffer size and DMA enable register should be set first;



| 0x0004 |    |                                     | DMA | settin | g and | soft re | set re | gister ( | Reset | 0x000 | 0_000 | 0) |                   | RS                            | T_DM                     | ASET                     |
|--------|----|-------------------------------------|-----|--------|-------|---------|--------|----------|-------|-------|-------|----|-------------------|-------------------------------|--------------------------|--------------------------|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 |     |        |       |         |        |          |       |       |       | 20 | 19                | 18                            | 17                       | 16                       |
| Name   |    | Reserved                            |     |        |       |         |        |          |       |       |       |    | DMA               | DMA<br>_EN                    |                          |                          |
| Туре   |    |                                     |     |        |       | R       | 0      |          |       |       |       |    |                   | R/W                           |                          | R/W                      |
| 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   |    |                                     |     |        |       | Rese    | erved  |          |       |       |       |    | FUN<br>C1_I<br>NT | SOF<br>T_R<br>ST_<br>SDI<br>O | SOF<br>T_R<br>ST_<br>AHB | SOF<br>T_R<br>ST_<br>ALL |
| Туре   |    | RO                                  |     |        |       |         |        |          |       |       |       | wo | wo                | WO                            | wo                       |                          |
| Reset  | 0  | 0                                   | 0   | 0      | 0     | 0       | 0      | 0        | 0     | 0     | 0     | 0  | 0                 | 0                             | 0                        | 0                        |

| Field Name    | Bit     | Туре | Reset Value | Description                                                                                                                                                                       |
|---------------|---------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [31:20] | RO   | 12'h0       | Reserved                                                                                                                                                                          |
| DMA_BUF_SIZE  | [19:17] | R/W  | 3'h0        | Specify the DMA buffer size when use DMA methods to transfer data. Once the DMA has transfer the size amount data, it then sent a DMA interrupt to notice software to fetch data. |
| DMA_EN        | [16]    | R/W  | 1'h0        | DMA enable signal. 0: Disable 1: Enable                                                                                                                                           |
|               | [15:4]  | RO   | 12'h0       | Reserved                                                                                                                                                                          |
| FUNC1_INT     | [3]     | WO   | 1'h0        | Set this bit to 1 to manual generate a function 1 interrupt. Auto clear to 0 after write 1                                                                                        |
| SOFT_RST_SDIO | [2]     | wo   | 1'h0        | Set this bit to 1 to soft reset SDIO domain registers. Auto clear to 0 after write 1                                                                                              |
| SOFT_RST_AHB  | [1]     | WO   | 1'h0        | Set this bit to 1 to soft reset<br>AHB domain registers.<br>Auto clear to 0 after write 1                                                                                         |
| SOFT_RST_ALL  | [0]     | WO   | 1'h0        | Set this bit to 1 to soft reset<br>SDIO and AHB domain<br>registers.<br>Auto clear to 0 after write 1.                                                                            |

# 6.14.5.2.3 BLK\_CNT\_SIZE Registers

Description: This register give the SDIO host set block size and block counter.



| 0x000C |    |          | Bloc  | k Size | and C | and Counter (Reset 0x0000_0000) |    |         |    |      |      | BLK_CNT_SIZE |    |    |    |    |
|--------|----|----------|-------|--------|-------|---------------------------------|----|---------|----|------|------|--------------|----|----|----|----|
| Bit    | 31 | 30       | 29    | 28     | 27    | 26                              | 25 | 24      | 23 | 22   | 21   | 20           | 19 | 18 | 17 | 16 |
| Name   |    | Reserved |       |        |       |                                 |    | BLK_CNT |    |      |      |              |    |    |    |    |
| Туре   |    |          |       | RO     |       |                                 |    |         | 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   |    | Rese     | erved |        |       |                                 |    |         |    | BLK_ | SIZE |              |    |    |    |    |
| Туре   |    | R        | .0    |        | RO    |                                 |    |         |    |      |      |              |    |    |    |    |
| Reset  | 0  | 0        | 0     | 0      | 0     | 0                               | 0  | 0       | 0  | 0    | 0    | 0            | 0  | 0  | 0  | 0  |

| Field Name | Bit     | Туре | Reset Value | Description                                            |
|------------|---------|------|-------------|--------------------------------------------------------|
|            | [31:25] | RO   | 7'h0        | Reserved                                               |
| BLK_CNT    | [24:16] | RO   | 9'h0        | Transfer Block Count. Set by SDIO host through SD bus. |
|            | [15:12] | RO   | 4'h0        | Reserved                                               |
| BLK_SIZE   | [11:0]  | RO   | 5'h0        | Transfer Block Size. Set by SDIO host through SD bus.  |

# 6.14.5.2.4 TRANS\_MODE Registers

Description: Specify some read only register that SDIO host set transferring mode.

| 0x0010 |    |                                              | Trans | sfer m | ode re | gister | (Reset | 0x000 | 00_000 | 0)               |                        |       |       | TRA               | ANS_N             | ODE              |
|--------|----|----------------------------------------------|-------|--------|--------|--------|--------|-------|--------|------------------|------------------------|-------|-------|-------------------|-------------------|------------------|
| Bit    | 31 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |       |        |        |        |        |       |        |                  |                        |       |       |                   |                   |                  |
| Name   |    |                                              |       |        |        |        |        | Rese  | erved  |                  |                        |       |       |                   |                   |                  |
| Туре   |    |                                              |       |        |        |        |        | R     | 0      |                  |                        |       |       |                   |                   |                  |
| 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   |    | Reserved N_M _                               |       |        |        |        |        |       |        | SIG<br>_MU<br>LT | HIG<br>H_S<br>PEE<br>D | BUS_\ | WIDTH | TRA<br>NS_<br>DIR | OPE<br>R_M<br>ODE | BLK<br>_MO<br>DE |
| Туре   |    | RO RO RO RO                                  |       |        |        |        |        |       |        |                  | 0                      | RO    | RO    | RO                |                   |                  |
| Reset  | 0  | 0                                            | 0     | 0      | 0      | 0      | 0      | 0     | 0      | 0                | 0                      | 0     | 0     | 0                 | 0                 | 0                |

| Field Name | Bit    | Туре | Reset Value | Description                                                                                       |
|------------|--------|------|-------------|---------------------------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0       | Reserved                                                                                          |
| INFIN_MODE | [7]    | RO   | 1'h0        | Indicate whether the transfer is infinite or not  0: Infinite transfer  1: Finite transfer        |
| SIG_MULT   | [6]    | RO   | 1'h0        | Indicate whether the transfer is signal or multiply transfer.  0: Signal block  1: Multiply block |



| HIGH_SPEED | [5]   | RO | 1'h0 | Indicate whether the transfer is high speed or not.  0: Normal transfer (<=25MHz)  1: High Speed transfer (50MHz) |
|------------|-------|----|------|-------------------------------------------------------------------------------------------------------------------|
| BUS_WIDTH  | [4:3] | RO | 2'h0 | Indicate whether the transfer bus width is 1 bit or 4 bits. 2'b00: 1 bit width 2'b10: 4 bit width                 |
| TRANS_DIR  | [2]   | RO | 1'h0 | Indicate whether the transfer is read or write.  0: Read  1: Write                                                |
| OPER_MODE  | [1]   | RO | 1'h0 | Indicate whether the transfer mode is increasing or fixing address.  0: Fixing address  1: Increasing address     |
| BLK_MODE   | [0]   | RO | 1'h0 | Indicate whether the transfer is block mode or byte mode.  0: Byte mode transfer.  1: Block mode transfer.        |

### 6.14.5.2.5 CURT\_STATUS Registers

Description: Specify some read only register that SDIO host transferring status.

| 0x0014 |    |                                                      | Curre    | ent Sta | itus Re | egister          | (Reset                 | 0x000 | 000_000 | 0) |   |          | CURT_STATUS |          |          |         |
|--------|----|------------------------------------------------------|----------|---------|---------|------------------|------------------------|-------|---------|----|---|----------|-------------|----------|----------|---------|
| Bit    | 31 | 31   30   29   28   27   26   25   24   23   22   21 |          |         |         |                  |                        |       |         |    |   | 20       | 19          | 18       | 17       | 16      |
| Name   |    | Reserved                                             |          |         |         |                  |                        |       |         |    |   | DAT<br>3 | DAT<br>2    | DAT<br>1 | DAT<br>0 | CM<br>D |
| Туре   |    |                                                      |          |         |         | RO               |                        |       |         |    |   | RO       | RO          | RO       | RO       | RO      |
| 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   |    | F                                                    | Reserved | I       |         | SUS<br>P_S<br>TA | RD_<br>WAI<br>T_S<br>T | E     | BUS_ST/ | A  |   | CMD_IDX  |             |          |          |         |
| Туре   |    |                                                      | RO       |         |         | RO RO RO         |                        |       |         |    |   |          | R           | .0       |          |         |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0                                  |          |         |         |                  |                        |       |         | 0  | 0 | 0        | 0           | 0        | 0        |         |

Note:

These registers are just used for debug only.

| Field Name | Bit     | Туре | Reset Value | Description         |
|------------|---------|------|-------------|---------------------|
|            | [31:21] | RO   | 11'h0       | Reserved            |
| DAT3       | [20]    | RO   | 1'h0        | Data 3 line latched |
| DAT2       | [19]    | RO   | 1'h0        | Data 2 line latched |
| DAT1       | [18]    | RO   | 1'h0        | Data 1 line latched |



| DAT0        | [17]    | RO | 1'h0 | Data 0 line latched                                                                                                               |
|-------------|---------|----|------|-----------------------------------------------------------------------------------------------------------------------------------|
| CMD         | [16]    | RO | 1'h0 | Command line latched                                                                                                              |
|             | [15:11] | RO | 5'h0 | Reserved                                                                                                                          |
| SUSP_STA    | [10]    | RO | 1'h0 | Indicate whether the transfer is suspending or not.  0: Normal  1: Suspending.                                                    |
| RD_WAIT_STA | [9]     | RO | 1'h0 | Indicate whether the transfer is in read wait state or not.  0: Normal  1: Read wait state                                        |
| BUS_STA     | [8:6]   | RO | 3'h0 | Specify the current bus state. 3'b000: Bus idle 3'b001: Bus standby 3'b010: Bus command 3'b011: Bus transfer 3'b100: Bus inactive |
| CMD_IDX     | [5:0]   | RO | 6'h0 | Specify the current command index                                                                                                 |

# 6.14.5.2.6 CMD\_ARG Registers

Description: Specify read only register that SDIO host transferring command argument.

| 0x0018 |    |                                 | Com | mand | Argum | nent(Re  | eset 0 | (0000_ | 0000)  |   |   |    |    |    | CMD_ | ARG |
|--------|----|---------------------------------|-----|------|-------|----------|--------|--------|--------|---|---|----|----|----|------|-----|
| Bit    | 31 | 30 29 28 27 26 25 24 23 22 21 2 |     |      |       |          |        |        |        |   |   | 20 | 19 | 18 | 17   | 16  |
| Name   |    |                                 |     |      |       | <b>A</b> |        | CMD_A  | RG (H) |   |   |    |    |    |      |     |
| Туре   |    |                                 |     |      |       |          |        | R      | 0      |   |   |    |    |    |      |     |
| 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   |    | <b>—</b>                        |     |      |       |          |        | CMD_A  | RG (L) |   |   |    |    |    |      |     |
| Туре   |    | RO                              |     |      |       |          |        |        |        |   |   |    |    |    |      |     |
| Reset  | 0  |                                 |     |      |       |          |        |        |        |   | 0 |    |    |    |      |     |

Note:

This register is just used for debug only.

| Field Name | Bit    | Туре | Reset Value | Description                                                       |
|------------|--------|------|-------------|-------------------------------------------------------------------|
| CMD_ARG    | [31:0] | RO   | 32'h0       | This register indicates the current transmitted command argument. |

# 6.14.5.2.7 RSP\_ARG Registers

Description: Specify read only register that SDIO host received response argument.



| 0x001C |    |    | Resp                                      | onse / | Argum | ent(Re | eset 0x | 0000_ | 0000)  |   |   |   |   |   | RSP_ | _ARG |
|--------|----|----|-------------------------------------------|--------|-------|--------|---------|-------|--------|---|---|---|---|---|------|------|
| Bit    | 31 | 30 | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |       |        |         |       |        |   |   |   |   |   |      |      |
| Name   |    |    |                                           |        |       |        |         | RSP_A | RG (H) |   |   |   |   |   |      |      |
| Туре   |    |    |                                           |        |       |        |         | R     | 0      |   |   |   |   |   |      |      |
| 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   |    |    |                                           |        |       |        |         | RSP_A | RG (L) |   |   |   |   |   |      |      |
| Туре   |    |    | RO                                        |        |       |        |         |       |        |   |   |   |   |   |      |      |
| Reset  | 0  |    |                                           |        |       |        |         |       |        |   |   |   |   |   |      |      |

Note:

This register is just used for debug only.

| Field Name | Bit    | Туре | Reset Value | Description                                                        |
|------------|--------|------|-------------|--------------------------------------------------------------------|
| RSP_ARG    | [31:0] | RO   | 32'h0       | This register indicates the current transmitted response argument. |

### 6.14.5.2.8 DAT\_PORT Registers

Description: This register is used to read or write data when using NON-DMA transferring mode.

| 0x0020 |    |                                    | Buffe | er Data | Port I | Registe | er (Res | set 0x0 | 0000_0  | 000) |   |   |    |    | DAT_F | PORT |
|--------|----|------------------------------------|-------|---------|--------|---------|---------|---------|---------|------|---|---|----|----|-------|------|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 2 |       |         |        |         |         |         |         |      |   |   | 19 | 18 | 17    | 16   |
| Name   |    |                                    |       |         |        |         |         | DAT_P   | ORT (H) |      |   |   |    |    |       |      |
| Туре   |    |                                    |       |         |        |         |         | R       | W       |      |   |   |    |    |       |      |
| 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   |    |                                    |       |         |        |         |         | DAT_P   | ORT (L) |      |   |   |    |    |       |      |
| Туре   |    | R/W                                |       |         |        |         |         |         |         |      |   |   |    |    |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0        |       |         |        |         |         |         |         |      |   |   |    |    |       |      |

Note:

This registers should be accessed word by word.

| Field Name | Bit    | Туре | Reset Value | Description                                                                       |
|------------|--------|------|-------------|-----------------------------------------------------------------------------------|
| DAT_PORT   | [31:0] | R/W  | 32'h0       | This register is used to read or write data when using non-DMA transferring mode. |

6.14.5.2.9 INT\_EN Registers

Description: Interrupt enable signals



| 0x0030 |    |                       | Interi | upt er | nable s | ignals | (Rese | et 0x00 | 00_00              | 00)               |                   |                         |                                |                               | IN.                    | T_EN                           |
|--------|----|-----------------------|--------|--------|---------|--------|-------|---------|--------------------|-------------------|-------------------|-------------------------|--------------------------------|-------------------------------|------------------------|--------------------------------|
| Bit    | 31 | 30                    | 29     | 28     | 27      | 26     | 25    | 24      | 23                 | 22                | 21                | 20                      | 19                             | 18                            | 17                     | 16                             |
| Name   |    |                       |        |        |         | Rese   | erved |         |                    |                   |                   |                         | AHB<br>_TR<br>N_E<br>RR_<br>EN | WD_<br>CRC<br>_ER<br>R_E<br>N | CM<br>D_IL<br>L_E<br>N | CM<br>D_C<br>RC_<br>ERR<br>_EN |
| Туре   |    |                       |        |        |         | R      | 0     |         |                    |                   |                   |                         | 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    | 15 | 14                    | 13     | 12     | 11      | 10     | 9     | 8       | 7                  | 6                 | 5                 | 4                       | 3                              | 2                             | 1                      | 0                              |
| Name   |    |                       |        | Rese   | erved   |        |       |         | OCR<br>_INT<br>_EN | SLV<br>_RD<br>_EN | SLV<br>_WR<br>_EN | AHB<br>_WR<br>DY_<br>EN | AHB<br>_RR<br>DY_<br>EN        | DMA<br>_INT<br>_EN            | RD_<br>CMP<br>_EN      | WR_<br>CMP<br>_EN              |
| Туре   |    | RO RW RW RW RW        |        |        |         |        |       |         |                    |                   | R/W               | 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                             | 0                      |                                |

| Field Name     | Bit     | Туре | Reset Value | Description                             |
|----------------|---------|------|-------------|-----------------------------------------|
|                | [31:20] | RO   | 12'h0       | Reserved                                |
| AHB_TRN_ERR_EN | [19]    | R/W  | 1'h0        | AHB transfer error enable               |
| WD_CRC_ERR_EN  | [18]    | R/W  | 1'h0        | Write data crc err interrupt enable     |
| CMD_ILL_EN     | [17]    | R/W  | 1'h0        | Command illegal interrupt enable        |
| CMD_CRC_ERR_EN | [16]    | R/W  | 1'h0        | Command crc error interrupt enable      |
|                | [15:8]  | RO   | 8'h0        | Reserved                                |
| OCR_INT_EN     | [7]     | R/W  | 1'h0        | SDIO host CMD5 set OCR interrupt enable |
| SLV_RD_EN      | [6]     | R/W  | 1'h0        | Slave read begin enable                 |
| SLV_WR_EN      | [5]     | R/W  | 1'h0        | Slave write begin enable                |
| AHB_WRDY_EN    | [4]     | R/W  | 1'h0        | No-dma mode write buffer ready enable   |
| AHB_RRDY_EN    | [3]     | R/W  | 1'h0        | No-dma mode read buffer ready enable    |
| DMA_INT_EN     | [2]     | R/W  | 1'h0        | DMA transfer data complete enable       |
| RD_CMP_EN      | [1]     | R/W  | 1'h0        | Read transfer data complete enable      |
| WR_CMP_EN      | [0]     | R/W  | 1'h0        | Write transfer data complete enable     |

6.14.5.2.10 INT\_CLR Registers

Description: Interrupt status clear signals



| 0x0034 |    |    | Inter | rupt st | atus c | lear si | gnals | (Reset | 0x000                  | 0_000              | 0)                 |                          |                                 |                                | INT                     | CLR                     |
|--------|----|----|-------|---------|--------|---------|-------|--------|------------------------|--------------------|--------------------|--------------------------|---------------------------------|--------------------------------|-------------------------|-------------------------|
| Bit    | 31 | 30 | 29    | 28      | 27     | 26      | 25    | 24     | 23                     | 22                 | 21                 | 20                       | 19                              | 18                             | 17                      | 16                      |
| Name   | _  |    |       |         |        | Rese    | erved |        |                        |                    |                    |                          | AHB<br>_TR<br>N_E<br>RR_<br>CLR | WD_<br>CRC<br>_ER<br>R_<br>CLR | CM<br>D_IL<br>L_<br>CLR | CM<br>D_C<br>RC_<br>ERR |
| Туре   |    |    |       |         |        | R       | 0     |        |                        |                    |                    |                          | 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    | 15 | 14 | 13    | 12      | 11     | 10      | 9     | 8      | 7                      | 6                  | 5                  | 4                        | 3                               | 2                              | 1                       | 0                       |
| Name   |    |    |       | Rese    | erved  |         |       |        | OCR<br>_INT<br><br>CLR | SLV<br>_RD<br>_CLR | SLV<br>_WR<br>_CLR | AHB<br>_WR<br>DY_<br>CLR | AHB<br>_RR<br>DY_<br>CLR        | DMA<br>_INT<br>CLR             | RD_<br>CMP              | WR_<br>CMP              |
| Туре   |    | RO |       |         |        |         |       |        | 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                  | 0                        | 0                               | 0                              | 0                       | 0                       |

| Field Name      | Bit     | Туре | Reset Value | Description                            |
|-----------------|---------|------|-------------|----------------------------------------|
|                 | [31:20] | RO   | 12'h0       | Reserved                               |
| AHB_TRN_ERR_CLR | [19]    | R/W  | 1'h0        | AHB transfer error clear               |
| WD_CRC_ERR_CLR  | [18]    | R/W  | 1'h0        | Write data crc err interrupt clear     |
| CMD_ILL_CLR     | [17]    | R/W  | 1'h0        | Command illegal interrupt clear        |
| CMD_CRC_ERR_CLR | [16]    | R/W  | 1'h0        | Command crc error interrupt clear      |
|                 | [15:8]  | RO   | 8'h0        | Reserved                               |
| OCR_INT_CLR     | [7]     | R/W  | 1'h0        | SDIO host CMD5 set OCR interrupt clear |
| SLV_RD_CLR      | [6]     | R/W  | 1'h0        | Slave read begin clear                 |
| SLV_WR_CLR      | [5]     | R/W  | 1'h0        | Slave write begin clear                |
| AHB_WRDY_CLR    | [4]     | R/W  | 1'h0        | No-dma mode write buffer ready clear   |
| AHB_RRDY_CLR    | [3]     | R/W  | 1'h0        | No-dma mode read buffer ready clear    |
| DMA_INT_CLR     | [2]     | R/W  | 1'h0        | DMA transfer data complete clear       |
| RD_CMP_CLR      | [1]     | R/W  | 1'h0        | Read transfer data complete clear      |
| WR_CMP_CLR      | [0]     | R/W  | 1'h0        | Write transfer data complete clear     |

# 6.14.5.2.11 INT\_RAW Registers

Description: Interrupt raw status signals



| 0x0038 |    |          | Inter | rupt ra | w stat | us sig | nals (F | Reset ( | )x0000 | _0000                      | )                          |                              |                                     |                                    | INT_                        | RAW                                |
|--------|----|----------|-------|---------|--------|--------|---------|---------|--------|----------------------------|----------------------------|------------------------------|-------------------------------------|------------------------------------|-----------------------------|------------------------------------|
| Bit    | 31 | 30       | 29    | 28      | 27     | 26     | 25      | 24      | 23     | 22                         | 21                         | 20                           | 19                                  | 18                                 | 17                          | 16                                 |
| Name   |    |          |       |         |        | Rese   | erved   |         |        |                            |                            |                              | AHB<br>_TR<br>N_E<br>RR_<br>RA<br>W | WD_<br>CRC<br>_ER<br>R_<br>RA<br>W | CM<br>D_IL<br>L_<br>RA<br>W | CM<br>D_C<br>RC_<br>ERR<br>RA<br>W |
| Туре   |    |          |       |         |        | R      | 0       |         |        |                            |                            |                              | RO                                  | RO                                 | RO                          | 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   |    | Reserved |       |         |        |        |         |         |        | SLV<br>_RD<br>_<br>RA<br>W | SLV<br>_WR<br>_<br>RA<br>W | AHB<br>_WR<br>DY_<br>RA<br>W | AHB<br>_RR<br>DY_<br>RA<br>W        | DMA<br>_INT<br>_<br>RA<br>W        | RD_<br>CMP<br>-<br>RA<br>W  | WR_<br>CMP<br>RA<br>W              |
| Туре   |    | RO       |       |         |        |        |         |         | RO     | RO                         | RO                         | RO                           | RO                                  | RO                                 | RO                          | RO                                 |
| Reset  | 0  | 0        | 0     | 0       | 0      | 0      | 0       | 0       | 0      | 0                          | 0                          | 0                            | 0                                   | 0                                  | 0                           | 0                                  |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                 |
|-----------------|---------|------|----------------|---------------------------------------------|
|                 | [31:20] | RO   | 12'h0          | Reserved                                    |
| AHB_TRN_ERR_RAW | [19]    | RO   | 1'h0           | AHB transfer error raw status               |
| WD_CRC_ERR_RAW  | [18]    | RO   | 1'h0           | Write data crc err interrupt raw status     |
| CMD_ILL_RAW     | [17]    | RO   | 1'h0           | Command illegal interrupt raw status        |
| CMD_CRC_ERR_RAW | [16]    | RO   | 1'h0           | Command crc error interrupt raw status      |
|                 | [15:8]  | RO   | 8'h0           | Reserved                                    |
| OCR_INT_RAW     | [7]     | RO   | 1'h0           | SDIO host CMD5 set OCR interrupt raw status |
| SLV_RD_RAW      | [6]     | RO   | 1'h0           | Slave read begin raw status                 |
| SLV_WR_RAW      | [5]     | RO   | 1'h0           | Slave write begin raw status                |
| AHB_WRDY_RAW    | [4]     | RO   | 1'h0           | No-dma mode write buffer ready raw status   |
| AHB_RRDY_RAW    | [3]     | RO   | 1'h0           | No-dma mode read buffer ready raw status    |
| DMA_INT_RAW     | [2]     | RO   | 1'h0           | DMA transfer data complete raw status       |
| RD_CMP_RAW      | [1]     | RO   | 1'h0           | Read transfer data complete raw status      |
| WR_CMP_RAW      | [0]     | RO   | 1'h0           | Write transfer data complete raw status     |

# 6.14.5.2.12 INT\_STA Registers

Description: Interrupt masked status signals



| 0x003C |    |    | Inter | rupt m | asked | status | signa | ıls (Re | set 0x                 | 0000_0                | 0000)             |                          |                                 |                                | INT                     | _STA                    |
|--------|----|----|-------|--------|-------|--------|-------|---------|------------------------|-----------------------|-------------------|--------------------------|---------------------------------|--------------------------------|-------------------------|-------------------------|
| Bit    | 31 | 30 | 29    | 28     | 27    | 26     | 25    | 24      | 23                     | 22                    | 21                | 20                       | 19                              | 18                             | 17                      | 16                      |
| Name   | _  |    |       |        |       | Rese   | erved |         |                        |                       |                   |                          | AHB<br>_TR<br>N_E<br>RR_<br>STA | WD_<br>CRC<br>_ER<br>R_<br>STA | CM<br>D_IL<br>L_<br>STA | CM<br>D_C<br>RC_<br>ERR |
| Туре   |    |    |       |        |       | R      | 0     |         |                        |                       |                   |                          | RO                              | RO                             | RO                      | 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   |    |    |       | Rese   | erved |        |       |         | OCR<br>_INT<br><br>STA | SLV<br>_RD<br><br>STA | SLV<br>_WR<br>STA | AHB<br>_WR<br>DY_<br>STA | AHB<br>_RR<br>DY_<br>STA        | DMA<br>_INT<br>STA             | RD_<br>CMP              | WR_<br>CMP              |
| Туре   |    | RO |       |        |       |        |       |         | RO                     | RO                    | RO                | RO                       | RO                              | RO                             | RO                      | RO                      |
| Reset  | 0  | 0  | 0     | 0      | 0     | 0      | 0     | 0       | 0                      | 0                     | 0                 | 0                        | 0                               | 0                              | 0                       | 0                       |

| Field Name      | Bit     | Туре | Reset Value | Description                                    |
|-----------------|---------|------|-------------|------------------------------------------------|
|                 | [31:20] | RO   | 12'h0       | Reserved                                       |
| AHB_TRN_ERR_STA | [19]    | RO   | 1'h0        | AHB transfer error masked status               |
| WD_CRC_ERR_STA  | [18]    | RO   | 1'h0        | Write data crc err interrupt masked status     |
| CMD_ILL_STA     | [17]    | RO   | 1'h0        | Command illegal interrupt masked status        |
| CMD_CRC_ERR_STA | [16]    | RO   | 1'h0        | Command crc error interrupt masked status      |
|                 | [15:8]  | RO   | 8'h0        | Reserved                                       |
| OCR_INT_STA     | [7]     | RO   | 1'h0        | SDIO host CMD5 set OCR interrupt masked status |
| SLV_RD_STA      | [6]     | RO   | 1'h0        | Slave read begin masked status                 |
| SLV_WR_STA      | [5]     | RO   | 1'h0        | Slave write begin masked status                |
| AHB_WRDY_STA    | [4]     | RO   | 1'h0        | No-dma mode write buffer ready masked status   |
| AHB_RRDY_STA    | [3]     | RO   | 1'h0        | No-dma mode read buffer ready masked status    |
| DMA_INT_STA     | [2]     | RO   | 1'h0        | DMA transfer data complete masked status       |
| RD_CMP_STA      | [1]     | RO   | 1'h0        | Read transfer data complete masked status      |
| WR_CMP_STA      | [0]     | RO   | 1'h0        | Write transfer data complete masked status     |

6.14.5.2.13 SUPT\_OCR Registers

Description: Support OCR register.



| 0x0040 |    |    | Supp | ort O    | CR reg | ister (F | Reset | 0x0000          | _0000     | )  |    |        |         |    | SUPT | OCR |
|--------|----|----|------|----------|--------|----------|-------|-----------------|-----------|----|----|--------|---------|----|------|-----|
| Bit    | 31 | 30 | 29   | 28       | 27     | 26       | 25    | 24              | 23        | 22 | 21 | 20     | 19      | 18 | 17   | 16  |
| Name   |    |    | ſ    | Reserved | d      |          |       | LDO<br>_RD<br>Y |           |    |    | SUPT_0 | OCR (H) |    |      |     |
| Туре   |    |    |      | RO R/W   |        |          |       |                 |           |    | R  | W      |         |    | >    |     |
| 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   |    |    |      |          |        |          |       | SUPT_0          | OCR (L)   |    |    |        |         |    |      |     |
| Type   |    |    |      |          |        |          |       | R/              | W         |    |    |        |         |    | A    |     |
| Reset  | 0  | 0  | 0    | 0        | 0      | 0        | 0     | 0               | 0         | 0  | 0  | 0      | 0       | 0  | 0    | 0   |

| Field Name | Bit     | Туре | Reset Value | Description                                                                                                                                                                                                       |
|------------|---------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:25] | RO   | 7'h0        | Reserved                                                                                                                                                                                                          |
| LDO_RDY    | [24]    | R/W  | 1'h0        | When set new OCR, the AHB should adjust the LDO to adapt the new voltage, after the LDO is stable, AHB set this bit to notice the SDIO host that the IO is ready, and then the initialization can be in progress. |
| SUPT_OCR   | [23:0]  | R/W  | 24'h0       | This register is set by AHB to tell the host the voltage round of this slave supported.                                                                                                                           |

#### Note:

Before the initial state, software should set SUPT\_OCR register with the supported OCR value first, then the SDIO initial process can be proceed.

In the initial process, the R4 will response to host with the SUPT\_OCR value, if it matched host's OCR, then the host will send a new OCR value to slave (reflect to the following register of CURT\_OCR). At the same time, an interrupt of OCR\_INT\_STA will occurred to ask slave to set the LDO using the new set OCR.

After the LDO is stable, the software set LDO\_RDY bit to indicate it is ready to process the following initial process.

#### 6.14.5.2.14 CURT\_OCR Registers

Description: Current OCR register.



| 0x0044 |               |    | Curre | ent OC | R regi | pister (Reset 0x0000_0000) CURT_O |    |       |              |    |    | OCR |    |    |    |    |
|--------|---------------|----|-------|--------|--------|-----------------------------------|----|-------|--------------|----|----|-----|----|----|----|----|
| Bit    | 31            | 30 | 29    | 28     | 27     | 26                                | 25 | 24    | 23           | 22 | 21 | 20  | 19 | 18 | 17 | 16 |
| Name   |               |    |       | Rese   | erved  |                                   |    |       | CURT_OCR (H) |    |    |     |    |    |    |    |
| Туре   |               |    |       | R      | 0      |                                   |    |       | 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   |               |    |       |        |        |                                   |    | CURT_ | RT_OCR (L)   |    |    |     |    |    |    |    |
| Туре   |               |    |       |        |        |                                   |    |       |              |    |    |     |    |    |    |    |
| Reset  | 0 0 0 0 0 0 0 |    |       |        |        |                                   |    | 0     | 0            | 0  | 0  | 0   | 0  | 0  | 0  | 0  |

| Field Name | Bit     | Туре | Reset Value | Description                                                                                                            |
|------------|---------|------|-------------|------------------------------------------------------------------------------------------------------------------------|
|            | [31:24] | RO   | 8'h0        | Reserved                                                                                                               |
| CURT_OCR   | [23:0]  | RO   | 24'h0       | This register is set by SDIO host to tell the AHB what the new set voltage is, and then the AHB should adjust the LDO. |

Note:

Refer to the before interpretation of SUPT\_OCR for the detail information.

For the SD domain, only the SDIO host can access it and it is not visible for ARM or DSP. The SD domain register are call Common I/O Area register (CIA). The CIA shall be implemented on all SDIO cards. The CIA is accessed by the host via I/O reads and writes to function 0. The registers within the CIA are provided to enable/disable the operation of the I/O function(s), control the generation of interrupts and optionally load software to support the I/O functions. The registers in the CIA also provide information about the function(s) abilities and requirements. There are three distinct register structures supported within the CIA. They are:

- I Card Common Control Registers (CCCR)
- I Function Basic Registers (FBR)
- I Card Information Structure (CIS)

#### 6.14.5.3 SD Domain Memory map (CCCR)

The Card Common Control Registers allow for quick host checking and control of an I/O card's enable and interrupts on function basis. The bits in the CCCR are mixed Read/Write and read only. If the functions are not provided on an SDIO card, the bits corresponding to unused functions shall all be read-only and read as 0. All reserved for future use bits (RFU) shall be read-only and return a value of 0. All writeable bits are set to 0 after power-up or reset. Access to the CCCR is possible even after initialization when the I/O functions are disabled. Access is performed using the I/O read and write commands. This allows the host to enable functions after initialization. This abstract SDIO slave CCCR is as follows:



### Table 6-16 Card Common Control Registers (CCCR)

|               |              |                       | Card C | ommon C    | ontrol Re       | gisters (C   | CCR)            |                |             |       |
|---------------|--------------|-----------------------|--------|------------|-----------------|--------------|-----------------|----------------|-------------|-------|
| Offset        | Reset        | Name                  | 7      | 6          | 5               | 4            | 3               | 2              | 1           | 0     |
| 0x00          | 8'h32        | CCCR / SDIO<br>Rev    |        | SDIO Speci | fication Rev    |              |                 | CCCR Forr      | mat Version |       |
| 0x01          | 8'h02        | SD Rev                |        | RI         | FU              |              |                 | SD Form        | nat Version | •     |
| 0x02          | 8'h00        | I/O Enable            | IOE7   | IOE6       | IOE5            | IOE4         | IOE3            | IOE2           | IOE1        | RFU   |
| 0x03          | 8'h00        | I/O Ready             | IOR7   | IOR6       | IOR5            | IOR4         | IOR3            | IOR2           | IOR1        | RFU   |
| 0x04          | 8'h00        | Int Enable            | IEN7   | IEN6       | IEN5            | IEN4         | IEN3            | IEN2           | IEN1        | IENM  |
| 0x05          | 8'h00        | Int Pending           | INT7   | INT6       | INT5            | INT4         | INT3            | INT2           | INT1        | RFU   |
| 0x06          | 8'h00        | I/O Abort             |        | RI         | FU              |              | RES             |                | AS[2:0]     |       |
| 0x07          | 8'h00        | Bus Intf<br>Control   | CD dis | SCSI       | ECSI            |              | RFU             |                | Bus         | Width |
| 0x08          | 8'h1F        | Card Capability       | 4BLS   | LSC        | E4MI            | S4MI         | SBS             | SRW            | SMB         | SDC   |
| 0x09-<br>0x0B | 24'h<br>1000 | Common CIS<br>Pointer |        | Po         | inter to card's | common Ca    | ard Information | n Structure (C | CIS)        |       |
| 0x0C          | 8'h00        | Bus Suspend           |        |            | RI              | Ū            |                 |                | BR          | BS    |
| 0x0D          | 8'h00        | Function<br>Select    | DF     |            | RFU             |              |                 | FS             | [3:0]       | 1     |
| 0x0E          | 8'h00        | Exec Flags            | EX7    | EX6        | EX5             | EX4          | EX3             | EX2            | EX1         | EXM   |
| 0x0F          | 8'h02        | Ready Flags           | RF7    | RF6        | RF5             | RF4          | RF3             | RF2            | RF1         | RFM   |
| 0x10-<br>0x11 | 16'h0        | FN0 Block Size        |        |            | 1               | O Block Size | e for Function  | 0              |             |       |
| 0x12          | 8'h00        | RFU                   |        |            | RI              | U            |                 |                | EMPC        | SMPC  |
| 0x13          | 8'h01        | High-Speed            |        |            | RI              | U            |                 |                | EHS         | SHS   |
| 0x14-<br>0xEF |              | RFU                   |        |            |                 | R            | FU              |                |             |       |
| 0xF0-<br>0xF3 | 32'h0        | Free<br>Read/Write    |        |            |                 | Free Read    | or Write Area   |                |             |       |
| 0xF4<br>0xFF  |              | Vendors Area          |        |            |                 | R            | FU              |                |             |       |

Note:

The gray back color table are don't care registers and reserved to 0.

# 6.14.5.4 SD Domain Register Descriptions (CCCR)

### 6.14.5.4.1 CCCR/SDIO Rev Registers

Description: The version of CCCR and SDIO



| 0x0000 |   | CCCR/SDIC | version (Re | eset 0x32) |   |        | CCCF   | R/SDIO Rev |
|--------|---|-----------|-------------|------------|---|--------|--------|------------|
| Bit    | 7 | 6         | 5           | 4          | 3 | 2      | 1      | 0          |
| Name   |   | SDIO_SI   | PC_VER      |            |   | CCCR_F | MT_VER |            |
| Туре   |   | R         | 0           |            |   | R      | .0     |            |
| Reset  | 0 | 0         | 1           | 1          | 0 | 0      | 1      | 0          |

| Field Name   | Bit   | R/W | Reset Value | Description                                                                                                                                          |
|--------------|-------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| SDIO_SPC_VER | [7:4] | RO  | 4'h3        | SDIO Specification Version  Value SDIO Specification  0x00 Version 1.00  0x01 Version 1.10  0x02 Version 1.20  0x03 Version 2.00  0x04-0x0F Reserved |
| CCCR_FMT_VER | [3:0] | RO  | 4'h2        | CCCR Format Version.  Value CCCR/FBR  0x00 Version 1.00  0x01 Version 1.10  0x02 Version 1.20  0x03-0x0F Reserved                                    |

# 6.14.5.4.2 SD Version Registers

Description: SD Version, Read Only.

| 0x0001 | SD version (Reset 0x02) |      |       |   |        |   | SD Rev |   |
|--------|-------------------------|------|-------|---|--------|---|--------|---|
| Bit    | 7                       | 6    | 5     | 4 | 3      | 2 | 1      | 0 |
| Name   |                         | Rese | erved |   | SD_VER |   |        |   |
| Туре   | RO                      |      |       |   | RO     |   |        |   |
| Reset  | 0                       | 0    | 0     | 0 | 0      | 0 | 1      | 0 |

| Field Name | Bit   | R/W | Reset Value | Description                                                                                                                     |  |  |
|------------|-------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|
|            | [7:4] | RO  | 4'h0        | Reserved                                                                                                                        |  |  |
| SD_VER     | [3:0] | RO  | 4'h2        | SD Format Version number.  Value SD Physical Spec.  0x00 Version 1.01  0x01 Version 1.10  0x02 Version 2.00  0x03-0x0F Reserved |  |  |



#### 6.14.5.4.3 I/O Enable Registers

Description: I/O Enable registers. It is used to enable, initial or reset functions.

| 0x0002 |    | I/O Enable Registers (Reset 0x00) |          |   |   |   |   | I/O Enable |  |  |
|--------|----|-----------------------------------|----------|---|---|---|---|------------|--|--|
| Bit    | 7  | 6                                 | 1        | 0 |   |   |   |            |  |  |
| Name   |    | IOE1                              | Reserved |   |   |   |   |            |  |  |
| Туре   | RO |                                   |          |   |   |   |   | RO         |  |  |
| Reset  | 0  | 0                                 | 0        | 0 | 0 | 0 | 0 | 0          |  |  |

| Field Name | Bit   | R/W | Reset Value | Description                                                                                    |
|------------|-------|-----|-------------|------------------------------------------------------------------------------------------------|
|            | [7:2] | RO  | 6'h0        | Reserved                                                                                       |
| IOE1       | [1]   | R/W | 1'h0        | Enable Function  0: Function 1 is disabled;  1: Function 1 is enabled to start initialization. |
|            | [0]   | RO  | 1'h0        | Reserved                                                                                       |

Note:

The host can use IOE1 as function 1 reset for error recovery. The host sequence to reset IOE1 to 0, wait until IOR1 becomes 0 and then set IOE1 to 1 again.

### 6.14.5.4.4 I/O Ready Registers

Description: I/O Ready registers. It is used to enable, initial or reset functions.

| 0x0003 |          | I/O Ready Registers (Reset 0x00) |   |    |    |   |   | I/O Ready |  |  |
|--------|----------|----------------------------------|---|----|----|---|---|-----------|--|--|
| Bit    | 7        | 6                                | 1 | 0  |    |   |   |           |  |  |
| Name   | Reserved |                                  |   |    |    |   |   | Reserved  |  |  |
| Туре   |          |                                  |   | RO | RO |   |   |           |  |  |
| Reset  | 0        | 0                                | 0 | 0  | 0  | 0 | 0 | 0         |  |  |

| Field Name | Bit   | R/W | Reset Value | Description                                                                       |
|------------|-------|-----|-------------|-----------------------------------------------------------------------------------|
|            | [7:2] | RO  | 6'h0        | Reserved                                                                          |
| IOR1       | [1]   | RO  | 1'h0        | I/O Function Ready 0: Func1 is not ready to operate 1: Func1 is ready to operate. |
|            | [0]   | RO  | 1'h0        | Reserved                                                                          |

Note:



When software set the LDO\_RDY register in AHB domain, this register will set to 1 automatically, and then the R4 will response to SDIO host that the SDIO slave is ready to operate, and initial sequence will be processed.

### 6.14.5.4.5 Int Enable Registers

Description: Int Enable registers. It is used to enable function's interrupt.

| 0x0004 | Int Enable Registers (Reset 0x00) |           |   |   |   |   | Int Enable |      |  |
|--------|-----------------------------------|-----------|---|---|---|---|------------|------|--|
| Bit    | 7                                 | 6 5 4 3 2 |   |   |   |   |            | 0    |  |
| Name   | Reserved                          |           |   |   |   |   |            | IENM |  |
| Туре   |                                   | RO        |   |   |   |   |            | R/W  |  |
| Reset  | 0                                 | 0         | 0 | 0 | 0 | 0 | 0          | 0    |  |

| Field Name | Bit   | R/W | Reset Value | Description                                                                                                                             |
|------------|-------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
|            | [7:2] | RO  | 6'h0        | Reserved                                                                                                                                |
| IEN1       | [1]   | R/W | 1'h0        | Interrupt Enable for function 1. 0: Disable function 1 interrupt; 1: Enable function 1 interrupt. At the precondition of IENM set to 1. |
| IENM       | [0]   | R/W | 1'h0        | Interrupt Enable Master.  0: Disable all interrupt of functions.  1: Enable all interrupt of functions.                                 |

### 6.14.5.4.6 Int Pending Registers

Description: Int Pending registers. It is used to display which function is pending interrupt.

| 0x0005 |          | Int Pending Registers (Reset 0x00) |   |   |   |   | Int Pending |          |  |
|--------|----------|------------------------------------|---|---|---|---|-------------|----------|--|
| Bit    | 7        | 6                                  | 1 | 0 |   |   |             |          |  |
| Name   | Reserved |                                    |   |   |   |   |             | Reserved |  |
| Туре   |          | RO                                 |   |   |   |   |             | RO       |  |
| Reset  | 0        | 0                                  | 0 | 0 | 0 | 0 | 0           | 0        |  |

| Field Name | Bit   | R/W | Reset Value | Description                                                                                                                                          |
|------------|-------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [7:2] | RO  | 6'h0        | Reserved                                                                                                                                             |
| INT1       | [1]   | RO  | 1'h0        | Interrupt pending for function 1. 0:Func1 interrupt is not pending 1: Func1 interrupt is pending. At the precondition of IENM and IEN1 are set to 1. |
|            | [0]   | RO  | 1'h0        | Reserved                                                                                                                                             |



#### 6.14.5.4.7 I/O Abort Registers

Description: I/O Abort registers. It is used to abort the data transfer of reset all the registers.

| 0x0006 |   | I/O Abort Registers (Reset 0x00) |       |   |     |     |   | I/O Abort |  |  |
|--------|---|----------------------------------|-------|---|-----|-----|---|-----------|--|--|
| Bit    | 7 | 6                                | 5     | 4 | 3   | 2   | 1 | 0         |  |  |
| Name   |   | Rese                             | erved |   | RES | ASx |   |           |  |  |
| Туре   |   | R                                | 0     |   | WO  | wo  |   |           |  |  |
| Reset  | 0 | 0                                | 0     | 0 | 0   | 0   | 0 | 0         |  |  |

| Field Name | Bit   | R/W | Reset Value | Description                                                                                                                                                                                                                                                                    |
|------------|-------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [7:4] | RO  | 4'h0        | Reserved                                                                                                                                                                                                                                                                       |
| RES        | [3]   | WO  | 1'h0        | I/O CARD RESET.                                                                                                                                                                                                                                                                |
| ASx        | [2:0] | WO  | 3'h0        | Abort Select.  To abort an I/O read or write and free the SD bus. For this design just has function 1 inside, to abort the function 1 transferring, the 0x01 should be set to stop it.  0x01: Abort function 1 data transferring;  0x00, 0x02~0x07: Not support and no action. |

Note:

Setting the RES to 1 shall cause all I/O functions in an SDIO to perform a soft reset.

Setting the RES to 1 does not affect the CD Disable.

Setting of the RES bit shall only be performed using CMD52.

When RES=1, the values of AS2-0 are don't-cares.

The RES bit is auto cleared, so there is no need to rewrite a value of 0.

### 6.14.5.4.8 Bus Intf Control Registers

Description: Bus interface control registers.

| 0x0007 |        | Bus intf co | Bus intf control (Reset 0x00) |          |   |   |           | BUS_CTRL |  |
|--------|--------|-------------|-------------------------------|----------|---|---|-----------|----------|--|
| Bit    | 7      | 6           | 6 5 4 3 2                     |          |   |   |           | 0        |  |
| Name   | CD_DIS |             |                               | Reserved |   |   | BUS_WIDTH |          |  |
| Type   | R/W    |             | RO                            |          |   |   |           | W        |  |
| Reset  | 0      | 0           | 0                             | 0        | 0 | 0 | 0         | 0        |  |

| Field Name | Bit | R/W | Reset Value | Description                                                                                                                                                 |
|------------|-----|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CD Disable | [7] | R/W | 1'h0        | Connect/Disconnect the 10K-90K ohm pull-up resistor on CD / DAT3 of the card which is used for card detection.  0x00: Connect (default).  0x01: Disconnect. |



|           |       |     |      | On power-on, this bit is cleared to 0. On soft-reset, this bit is not affected.                                     |
|-----------|-------|-----|------|---------------------------------------------------------------------------------------------------------------------|
|           | [6:2] | RO  | 5'h0 | Reserved                                                                                                            |
| Bus Width | [1:0] | R/W | 2'h0 | Data bus width.  0x00: 1-bit data width  0x02: 4-bit data width  On reset or power-on, these bits are cleared to 0. |

# 6.14.5.4.9 Card Capability Registers

Description: Card Capability registers.

| 0x0008 | Card Capability Registers (Reset 0x1F) |          |     |      |     |     |     | CARD_CAP |
|--------|----------------------------------------|----------|-----|------|-----|-----|-----|----------|
| Bit    | 7                                      | 6        | 5   | 4    | 3   | 2   | 1   | 0        |
| Name   | Rese                                   | Reserved |     | S4MI | SBS | SRW | SMB | SDC      |
| Туре   | RO                                     |          | R/W | RO   | RO  | RO  | RO  | RO       |
| Reset  | 0                                      | 0        | 0   | 1    | 1   | 1   | 1   | 1        |

| Field Name | Bit   | R/W | Reset Value | Description                                                                                   |
|------------|-------|-----|-------------|-----------------------------------------------------------------------------------------------|
|            | [7:6] | RO  | 2'h0        | Reserved                                                                                      |
| E4MI       | [5]   | R/W | 1'h0        | Enable interrupt between blocks of data in 4-bit SD mode.  0x00: Disable  0x01: Enable        |
| S4MI       | [4]   | RO  | 1'h1        | Supports interrupt between blocks of data in 4-bit SD mode.  0x00: Not Support  0x01: Support |
| SBS        | [3]   | RO  | 1'h1        | Card supports Suspend / Resume.  0x00: Not Support  0x01: Support                             |
| SRW        | [2]   | RO  | 1'h1        | Card Supports Read Wait.  0x00: Not Support  0x01: Support                                    |
| SMB        | [1]   | RO  | 1'h1        | Card Supports Multi-Block. 0x00: Not Support 0x01: Support                                    |
| SDC        | [0]   | RO  | 1'h1        | Card Supports Direct Commands during data transfer. 0x00: Not Support 0x01: Support           |



# 6.14.5.4.10 Common CIS Pointer Registers

Description: Common CIS Pointer registers.

| 0x0009 | ~0x000B | Card Capal | oility Registe    | rs (Reset 0x | 1000)  |    | C   | OM_CIS_PT |  |  |
|--------|---------|------------|-------------------|--------------|--------|----|-----|-----------|--|--|
| Bit    | 23      | 22         | 22 21 20 19 18 17 |              |        |    |     |           |  |  |
| Name   |         | COM_CIS_PT |                   |              |        |    |     |           |  |  |
| Туре   |         |            |                   | R            | .0     |    |     |           |  |  |
| Reset  | 0       | 0          | 0                 | 0            | 0      | 0  | 0   | 0         |  |  |
| Bit    | 15      | 14         | 13                | 12           | 11     | 10 | 9   | 8         |  |  |
| Name   |         |            |                   | COM_0        | CIS_PT |    |     |           |  |  |
| Туре   |         |            |                   | R            | .0     |    | . ( |           |  |  |
| Reset  | 0       | 0          | 0                 | 1            | 0      | 0  | 0   | 0         |  |  |
| Bit    | 7       | 6          | 5                 | 4            | 3      | 2  | 1   | 0         |  |  |
| Name   |         |            |                   | COM_0        | CIS_PT |    |     |           |  |  |
| Туре   |         | RO         |                   |              |        |    |     |           |  |  |
| Reset  | 0       | 0          | 0                 | 0            | 0      | 0  | 0   | 0         |  |  |

Note:

There are 24 bits, not 8 bits.

| Field Name | Bit    | R/W | Reset Value | Description                                                                                                                                                                                                       |
|------------|--------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| COM_CIS_PT | [23:0] | RO  | 24'h1000    | This 3-byte pointer points to the start of the card's common CIS. The common CIS contains information relation to the entire card.  This card's common CIS located within the CIS space of function 0 (0x001000). |

# 6.14.5.4.11 Bus Suspend Registers

Description: Bus Suspend registers.

| 0x000C |   | Bus Suspend Registers (Reset 0x00) |   |    |    |   | BUS_SUSP |    |  |
|--------|---|------------------------------------|---|----|----|---|----------|----|--|
| Bit    | 7 | 6                                  | 1 | 0  |    |   |          |    |  |
| Name   |   |                                    |   | BR | BS |   |          |    |  |
| Туре   |   | RO                                 |   |    |    |   |          | RO |  |
| Reset  | 0 | 0                                  | 0 | 0  | 0  | 0 | 0        | 0  |  |

| Field Name | Bit   | R/W | Reset Value | Description                                                                                                                                                        |
|------------|-------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [7:2] | RO  | 6'h0        | Reserved                                                                                                                                                           |
| BR         | [1]   | R/W | 1'h0        | Bus Release Request/Status: This bit is used to request that the addressed function release the data lines and suspend operation.  0x00: No bus release request is |



|    |     |    |      | processing.  0x01: Host sends a bus release request.  Once the host sets this bit to 1, the addressed function shall temporarily halt data transfer on the DAT[x] lines and suspend the command that is in process. The BR bit shall remain set to 1 until the release is complete.  This bit can be cleared either by card when after the bus release is complete or by host writes it to 0 initiatives. |
|----|-----|----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BS | [0] | RO | 1'h0 | Bus status.  This bit indicates if the currently addressed function is currently executing a command which transfers data on the DAT lines. For this design, there is just function 1 inside; the only support function number is 1.  0x00: No data is transferring.  0x01: Data is transferring.                                                                                                         |

# 6.14.5.4.12 Function Select Registers

Description: Function Select registers.

| 0x000D |    | Function Select Registers (Reset 0x00) |       |  |   | FUNC_SEL |   |   |  |
|--------|----|----------------------------------------|-------|--|---|----------|---|---|--|
| Bit    | 7  | 6 5 4                                  |       |  | 3 | 2        | 1 | 0 |  |
| Name   | DF | Reserved                               |       |  |   | FS       |   |   |  |
| Туре   | RO | RO                                     |       |  |   | R/W      |   |   |  |
| Reset  | 0  | 0                                      | 0 0 0 |  |   | 0        | 0 | 0 |  |

| Field Name | Bit   | R/W | Reset Value | Description                                                                                                                             |
|------------|-------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| DF         | [7]   | RO  | 1'h0        | Resume Data Flag.                                                                                                                       |
| -9         |       |     |             | Once the transaction is resumed, the DF indicates if more data will be transferred.                                                     |
| (0)        |       |     |             | 0x00: No additional data will be transferred after the function is resumed.                                                             |
|            |       |     |             | 0x01: There is more data to transfer that will begin after the function in resumed.                                                     |
|            | [6:4] | RO  | 3'h0        | Reserved                                                                                                                                |
| FS         | [3:0] | R/W | 4'h0        | Select Function bits. If a function is currently suspended, the writing of it's number to FSx shall re-start (resume) the data transfer |



|  |  | operation                                                                                     |
|--|--|-----------------------------------------------------------------------------------------------|
|  |  | When reading FSx, the value returned shall be the number of the currently addressed function. |
|  |  | FSx Current Transaction                                                                       |
|  |  | 0000 Transaction of function 0                                                                |
|  |  | 0001 Transaction to functions 1 0002-1111 Not defined.                                        |

# 6.14.5.4.13 Exec Flag Registers

Description: Execute flag registers.

| 0x000E |   | Execute Fla |   | EXEC_FLG |  |  |  |    |
|--------|---|-------------|---|----------|--|--|--|----|
| Bit    | 7 | 6           | 1 | 0        |  |  |  |    |
| Name   |   | Reserved    |   |          |  |  |  |    |
| Туре   |   | RO          |   |          |  |  |  | RO |
| Reset  | 0 | 0           | 0 | 0        |  |  |  |    |

| Field Name | Bit   | R/W | Reset Value | Description                                                                                                                                                                                                                                  |
|------------|-------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [7:2] | RO  | 6'h0        | Reserved                                                                                                                                                                                                                                     |
| EX1        | [1]   | RO  | 1'h0        | Execution Flag bits These bits are used by the host to determine the current execution status of function 1 either currently executing or suspended.  0x00: Function 1 is not currently execution.  0x01: Function 1 is currently execution. |
|            | [0]   | RO  | 1'h0        | Reserved                                                                                                                                                                                                                                     |

# 6.14.5.4.14 Ready Flag Registers

Description: Functions Ready flag registers.

| 0x000F |          | Functions Ready Flag Registers (Reset 0x02) |   |   |   |  |    | RDY_FLG  |
|--------|----------|---------------------------------------------|---|---|---|--|----|----------|
| Bit    | 7        | 7 6 5 4 3 2                                 |   |   |   |  |    | 0        |
| Name   | Reserved |                                             |   |   |   |  |    | Reserved |
| Туре   | RO       |                                             |   |   |   |  | RO | RO       |
| Reset  | 0        | 0                                           | 0 | 1 | 0 |  |    |          |

| Field Name | Bit   | R/W | Reset Value | Description                                                                           |
|------------|-------|-----|-------------|---------------------------------------------------------------------------------------|
|            | [7:2] | RO  | 6'h0        | Reserved                                                                              |
| RF1        | [1]   | RO  | 1'h1        | Ready Flag bits. This bit tells the host the reads or writes busy status for function |



|     |    |      | 1. 0x00: Function 1 is busy reading or writing. 0x01: Function 1 is ready to be transferred. |
|-----|----|------|----------------------------------------------------------------------------------------------|
| [0] | RO | 1'h0 | Reserved                                                                                     |

# 6.14.5.4.15 FN0 Block Size Registers

Description: Function 0 Block size registers

| 0x0010 | ~0x0011 | Function 0 Block Size Registers (Reset 0x0000) FN0_SIZ |    |          |            |    |   |   |  |
|--------|---------|--------------------------------------------------------|----|----------|------------|----|---|---|--|
| Bit    | 15      | 14                                                     | 13 | 12       | 11         | 10 | 9 | 8 |  |
| Name   |         | FN0 Block Size (H)                                     |    |          |            |    |   |   |  |
| Туре   |         | RW                                                     |    |          |            |    |   |   |  |
| Reset  | 0       | 0                                                      | 0  | 0        | 0          | 0  | 0 | 0 |  |
| Bit    | 7       | 6                                                      | 5  | 4        | 3          | 2  | 1 | 0 |  |
| Name   |         |                                                        |    | FN0 Bloc | k Size (L) |    |   |   |  |
| Туре   |         | RW                                                     |    |          |            |    |   |   |  |
| Reset  | 0       | 0                                                      | 0  | 0        | 0          | 0  | 0 | 0 |  |

Note:

There are 16 bits, not 8 bits.

| Field Name     | Bit    | R/W | Reset Value | Description                                                                                                                                                                                                                                                            |
|----------------|--------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FN0 Block Size | [15:0] | R/W | 16'h0       | This 16-bit register sets the block size for I/O block operations for function 0. Just support 0x0001 (1byte).  The host is responsible for setting the appropriate value for the block size supported by function 0.  This pointer is stored in little-endian format. |

# 6.14.5.4.16 High Speed Control Registers

Description: High Speed Control registers.

| 0x0013 | 70 | High Speed | l Control Rec | HIGH_SPEED |     |  |  |    |
|--------|----|------------|---------------|------------|-----|--|--|----|
| Bit    | 7  | 6          | 1             | 0          |     |  |  |    |
| Name   |    |            |               | EHS        | SHS |  |  |    |
| Type   |    | RO         |               |            |     |  |  | RO |
| Reset  | 0  | 0          | 0             | 1          |     |  |  |    |

| Field Name | Bit   | R/W | Reset Value | Description                |
|------------|-------|-----|-------------|----------------------------|
|            | [7:2] | RO  | 6'h0        | Reserved                   |
| EHS        | [1]   | R/W | 1'h0        | Enable High-Speed.         |
|            |       |     |             | 0x00: The card operates in |



|     |     |    |      | default timing mode with a clock rate up to 25MHz 0x01: The card work in high speed mode of 50MHz                                                                              |
|-----|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SHS | [0] | RO | 1'h1 | Support High-Speed. This bit reports the card's ability to operate in High-Speed mode. 0x00: The card does not support high speed mode 0x01: The card support high speed mode. |

### 6.14.5.4.17 Free Read/Write Registers

Description: Free Read and write registers.

| 0x00F0 | ~0x00F3 | Free Read | and Write Re | gisters (Res | et 0x0000) |     |     | FRER_RW |
|--------|---------|-----------|--------------|--------------|------------|-----|-----|---------|
| Bit    | 31      | 30        | 29           | 28           | 27         | 26  | 25  | 24      |
| Name   | FRW     | FRW       | FRW          | FRW          | FRW        | FRW | FRW | FRW     |
| Туре   | 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       |
| Bit    | 23      | 22        | 21           | 20           | 19         | 18  | 17  | 16      |
| Name   | FRW     | FRW       | FRW          | FRW          | FRW        | FRW | FRW | FRW     |
| Туре   | 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       |
| Bit    | 15      | 14        | 13           | 12           | 11         | 10  | 9   | 8       |
| Name   | FRW     | FRW       | FRW          | FRW          | FRW        | FRW | FRW | FRW     |
| Туре   | 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       |
| Bit    | 7       | 6         | 5            | 4            | 3          | 2   | 1   | 0       |
| Name   | FRW     | FRW       | FRW          | FRW          | FRW        | FRW | FRW | FRW     |
| Туре   | 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       |

Note:

There are 32 bits, not 8 bits.

| Field Name          | Bit    | R/W | Reset Value | Description                                      |
|---------------------|--------|-----|-------------|--------------------------------------------------|
| Free Read/<br>Write | [31:0] | R/W | 32'h0       | This 32-bit register can be freely read or write |

# 6.14.5.5 SD Domain Memory map (FBR)

In addition to the CCCR, function 1 I/O has a 256-byte area used to allow the host to quickly determine the abilities and requirements or enable power selection and to enable software loading. The address of this area is from 0x00100 to 0x001FF. This function 1 area is structured as follows:



Table 6-17 Function Basic Register (FBR)

|                 | Function Basic Register (FBR)                          |                                                                                               |  |    |   |  |  |  |  |
|-----------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------|--|----|---|--|--|--|--|
| Offset          | Register Name                                          | Register Name         7         6         5         4         3         2         1         0 |  |    |   |  |  |  |  |
| 0x100-<br>0x108 | RFU                                                    |                                                                                               |  |    |   |  |  |  |  |
| 0x109-<br>0x10B | Pointer to Function 1 Card Information Structure (CIS) |                                                                                               |  |    |   |  |  |  |  |
| 0x10C-<br>0x10F |                                                        | RFU                                                                                           |  |    |   |  |  |  |  |
| 0x110-<br>0x111 |                                                        | I/O block size for Function 1                                                                 |  |    |   |  |  |  |  |
| 0x112-<br>0xFFF |                                                        |                                                                                               |  | RF | J |  |  |  |  |

# 6.14.5.6 SD Domain Register Descriptions (FBR)

# 6.14.5.6.1 Pointer to Card Information Structure Registers

Description: Pointer to function 1 Card Information Structure.

| 0x0109 | -0x010B   | Pointer to F | unc1 CIS Re | egisters (Res | et 0x2000) |    | F1_CIS_PT |   |  |  |
|--------|-----------|--------------|-------------|---------------|------------|----|-----------|---|--|--|
| Bit    | 23        | 22           | 21          | 17            | 16         |    |           |   |  |  |
| Name   | F1_CIS_PT |              |             |               |            |    |           |   |  |  |
| Туре   |           |              |             | R             | 0          |    |           |   |  |  |
| Reset  | 0         | 0            | 0           | 0             | 0          | 0  | 0         | 0 |  |  |
| Bit    | 15        | 14           | 13          | 12            | 11         | 10 | 9         | 8 |  |  |
| Name   | F1_CIS_PT |              |             |               |            |    |           |   |  |  |
| Туре   |           |              |             | R             | 0          |    |           |   |  |  |
| Reset  | 0         | 0            | 1           | 0             | 0          | 0  | 0         | 0 |  |  |
| Bit    | 7         | 6            | 5           | 4             | 3          | 2  | 1         | 0 |  |  |
| Name   |           | F1_CIS_PT    |             |               |            |    |           |   |  |  |
| Туре   |           | RO           |             |               |            |    |           |   |  |  |
| Reset  | 0         | 0            | 0           | 0             | 0          | 0  | 0         | 0 |  |  |

Note:

There are 24 bits, not 8 bits.

| Field Name                              | Bit    | R/W | Reset Value | Description                                                                                                                                                                                                                                          |
|-----------------------------------------|--------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address<br>pointer to<br>Function 1 CIS | [23:0] | RO  | 24'h2000    | These three bytes make up a 24-bit pointer to the start of the Card Information Structure (CIS) that is associated with function 1. This pointer is stored in little-endian format (LSB first). Note:  The function 0 CIS pointer address is 0x01000 |



|  |  | The function 1 CIS pointer address is 0x02000 |
|--|--|-----------------------------------------------|
|  |  |                                               |

#### 6.14.5.6.2 Pointer to Card Information Structure Registers

Description: Function 1 blocks size registers.

| 0x0110 | ~0x0111 | Function 1     | Function 1 Block Size Registers (Reset 0x0000) FUNC1_SIZE |   |   |   |   |   |  |  |
|--------|---------|----------------|-----------------------------------------------------------|---|---|---|---|---|--|--|
| Bit    | 15      | 14             | 13                                                        | 9 | 8 |   |   |   |  |  |
| Name   |         | FUNC1_SIZE (H) |                                                           |   |   |   |   |   |  |  |
| Туре   |         | R/W            |                                                           |   |   |   |   |   |  |  |
| Reset  | 0       | 0              | 0                                                         | 0 | 0 | 0 | 0 | 0 |  |  |
| Bit    | 7       | 6              | 5                                                         | 4 | 3 | 2 | 1 | 0 |  |  |
| Name   |         | FUNC1_SIZE (L) |                                                           |   |   |   |   |   |  |  |
| Туре   |         | R/W            |                                                           |   |   |   |   |   |  |  |
| Reset  | 0       | 0              | 0                                                         | 0 | 0 | 0 | 0 | 0 |  |  |

Note:

There are 16 bits, not 8 bits.

| Field Name               | Bit    | R/W | Reset Value | Description                                                                                                                                            |
|--------------------------|--------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function 1<br>Block Size | [15:0] | R/W | 16'h0       | This 16-bit register sets the block size for I/O block operations for function 1. Support range:  0x0001 (1byte) ~ 0x0200 (512bytes).                  |
|                          |        |     |             | The host is responsible for setting the appropriate value for the block size supported by function 1.  This pointer is stored in little-endian format. |

### 6.14.5.7 SD Domain Memory map (CIS)

The Card Information Structure provides more complete information about the card and the individual functions. The CIS is the common area to read information about all I/O functions that exist in a card. The design is based on the PC Card16 design standardized by PCMCIA. The CIS is accessed by reads to a fixed area as shown in Table 17 This one area serves the card as a Common CIS and also as the storage area for function 1. The common area and function 1 have a pointer to the start of its CIS within this memory space.

Table 6-18 Function 0 CIS

|        | Function 0 CIS Structure |   |                         |  |  |  |  |  |   |
|--------|--------------------------|---|-------------------------|--|--|--|--|--|---|
| Offset | Value                    | 7 | 7 6 5 4 3 2 1 0         |  |  |  |  |  | 0 |
| 0x1000 | 0x20                     |   | TPL_CODE: CISTPL_MANFID |  |  |  |  |  |   |
| 0x1001 | 0x04                     |   | TPL_LINK                |  |  |  |  |  |   |
| 0x1002 | 0x00                     |   | TPLMID_MANF (L) 0000    |  |  |  |  |  |   |



| 0x1003 | 0x00 | TPLMID_MANF(H) 0000             |
|--------|------|---------------------------------|
| 0x1004 | 0x60 | TPLMID_CARD (L) 8800            |
| 0x1005 | 0x22 | TPLMID_CARD (H) 8800            |
| 0x1006 | 0x21 | TPL_CODE: CISTPL_FUNCID         |
| 0x1007 | 0x02 | TPL_LINK                        |
| 0x1008 | 0x0C | TPLFID_FUNCTION                 |
| 0x1009 | 0x00 | TPLFID_SYSINIT                  |
| 0x100A | 0x22 | TPL_CODE: TPL_CODE CISTPL_FUNCE |
| 0x100B | 0x04 | TPL_LINK                        |
| 0x100C | 0x00 | TPLFE_TYPE (00)                 |
| 0x100D | 0x01 | TPLFE_FN0_BLK_SIZE (L)          |
| 0x100E | 0x00 | TPLFE_FN0_BLK_SIZE (H)          |
| 0x100F | 0x5A | TPLFE_MAX_TRAN_SPEED (50MHz)    |
| 0x1010 | 0xFF | CISTPL_END                      |
|        |      |                                 |

#### Note:

For function 0, the tuple code of CISTPL\_MANFID, CISTPL\_FUNCID,

CISTPL\_FUNCE and CISTPL\_END are listed.

TPLMID\_MANF: The manufacture id of SPRD is not defined and reserved to 0x0000;

TPLMID\_CARD: The chip is defined to 8800(decimal) to adapt the SPRD "G" chip;

TPLFID\_FUNCTION: is default 0x0c;

TPLFID\_SYSINIT: is not used and reserved to 0x00;

TPLFE\_FN0\_BLK\_SIZE: function 0 max block size is 0x01

TPLFE\_MAX\_TRAN\_SPEED: support high speed of 50MHz.

Table 6-19 Function 1 CIS

|        | Function 1 CIS Structure |                |                                 |       |          |          |       |  |  |  |
|--------|--------------------------|----------------|---------------------------------|-------|----------|----------|-------|--|--|--|
| Offset | Value                    | 7              | 7 6 5 4 3 2 1 0                 |       |          |          |       |  |  |  |
| 0x2000 | 0x21                     |                |                                 | TPL_0 | CODE: CI | STPL_FL  | JNCID |  |  |  |
| 0x2001 | 0x02                     |                |                                 |       | TPL_     | LINK     |       |  |  |  |
| 0x2002 | 0x0C                     |                |                                 | Т     | PLFID_F  | UNCTIO   | N     |  |  |  |
| 0x2003 | 0x00                     |                |                                 |       | TPLFID_  | SYSINIT  |       |  |  |  |
| 0x2004 | 0x22                     |                | TPL_CODE: TPL_CODE CISTPL_FUNCE |       |          |          |       |  |  |  |
| 0x2005 | 0x2A                     |                |                                 |       | TPL_     | LINK     |       |  |  |  |
| 0x2006 | 0x01                     |                |                                 |       | TPLFE_T  | YPE (01) | )     |  |  |  |
| 0x2007 | 0x00                     |                |                                 | TPL   | FE_FUN   | CTION_II | NFO   |  |  |  |
| 0x2008 | 0x00                     |                |                                 | TI    | PLFE_ST  | D_IO_RE  | V     |  |  |  |
| 0x2009 | 0x00                     | TPLFE_CARD_PSN |                                 |       |          |          |       |  |  |  |
| 0x200A | 0x00                     |                |                                 |       |          |          |       |  |  |  |
| 0x200B | 0x00                     |                |                                 |       |          |          |       |  |  |  |
| 0x200C | 0x00                     |                |                                 |       |          |          |       |  |  |  |



| 0x200D | 0x00 | TPLFE_CSA_SIZE                           |
|--------|------|------------------------------------------|
| 0x200E | 0x00 |                                          |
| 0x200F | 0x00 |                                          |
| 0x2010 | 0x00 |                                          |
| 0x2011 | 0x00 | TPLFE_CSA_PROPERTY                       |
| 0x2012 | 0x00 | TPLFE_MAX_BLK_SIZE                       |
| 0x2013 | 0x40 | ( 1024 bytes )                           |
| 0x2014 | 0x00 | TPLFE_OCR                                |
| 0x2015 | 0xFF | (2.0 ~ 3.6)                              |
| 0x2016 | 0xFF |                                          |
| 0x2017 | 0x00 |                                          |
| 0x2018 | 0x00 | TPLFE_OP_MIN_PWR                         |
| 0x2019 | 0x00 | TPLFE_OP_AVG_PWR                         |
| 0x201A | 0x00 | TPLFE_OP_MAX_PWR                         |
| 0x201B | 0x00 | TPLFE_SB_MIN_PWR                         |
| 0x201C | 0x00 | TPLFE_SB_AVG_PWR                         |
| 0x201D | 0x00 | TPLFE_SB_MAX_PWR                         |
| 0x201E | 0x00 | TPLFE_MIN_BW                             |
| 0x201F | 0x00 |                                          |
| 0x2020 | 0x00 | TPLFE_OPT_BW                             |
| 0x2021 | 0x00 |                                          |
| 0x2022 | 0x64 | TPLFE_ENABLE_TIMEOUT_VAL (1s = 100*10ms) |
| 0x2023 | 0x00 |                                          |
| 0x2024 | 0x00 | TPLFE_SP_AVG_PWR_3.3V                    |
| 0x2025 | 0x00 |                                          |
| 0x2026 | 0x00 | TPLFE_SP_MAX_PWR_3.3V                    |
| 0x2027 | 0x00 |                                          |
| 0x2028 | 0x00 | TPLFE_HP_AVG_PWR_3.3V                    |
| 0x2029 | 0x00 |                                          |
| 0x202A | 0x00 | TPLFE_HP_MAX_PWR_3.3V                    |
| 0x202B | 0x00 |                                          |
| 0x202C | 0x00 | TPLFE_LP_AVG_PWR_3.3V                    |
| 0x202D | 0x00 |                                          |
| 0x202E | 0x00 | TPLFE_LP_MAX_PWR_3.3V                    |
| 0x202F | 0x00 |                                          |
| 0x2030 | 0xFF | CISTPL_END                               |

Note:

TPLFE\_MAX\_BLK\_SIZE: Function 1 max block size is 1024 bytes.

TPLFE\_OCR: Support voltage range is 2.0v ~ 3.6v.

TPLFE\_ENABLE\_TIMEOUT\_VAL: Timeout value is 1s = 100 \* 10ms (unit is 10ms)



### 6.14.6 Application Notes

#### 6.14.6.1 Initial sequence programming guide

To adapt our usage, there are some adjustments of the normal initial sequence which need MCU to configure some registers inside the flow. The light blue in the following figure are the added operation. The following are three methods to descript the programming flow.

#### **DESCRIPTION:**

- MCU set AHB domain register SUPT\_OCR with the supported OCR value. (e.g. 24'hFF00)
- SDIO host sends CMD5 with OCR value 24'h0000
- 3. **SDIO host** sends **CMD5** with support OCR value. (e.g. 24'h0100)
- MCU adjust the LDO to a appropriate value, and wait LDO is stable, then set AHB
  domain register LDO\_RDY to 1 to indicate it is ready.
- SDIO host wait card\_rdy (or IO\_RDY, it is other description of LDO\_RDY) by repeat send CMD5 and check the response flag.
- 6. SDIO host send CMD3 to get RCA.
- 7. SDIO host send CMD7 to select the card (not show in the figure).
- SDIO host send some CMD52 commands to configure the CCCR/FBR registers.(not show in the figure)

#### **PSEUDOCODE:**

- ahb\_write (slave\_base\_addr+8'h40, { Ido\_rdy=0, support\_ocr})
- 2. sendcmd5 (0)
- 3. sendcmd5 (24'h100)
- 4. ahb\_write (slave\_ldo\_addr, new\_ldo\_valud)
- ahb\_write (slave\_base\_addr+8'h40, {Ido\_rdy=1, support\_ocr})
- 6. while(!card rdy) sendcmd5 (24'h100)
- 7. sendcmd3
- 8. sendcmd7( new rca)
- sendcmd52(write,func0,raw\_yes,17'h2,8'h2,"enable func1 IO")
- 10. sendcmd52(write,func0,raw\_yes,17'h4,8'h3,"enable func1 int")
- 11. sendcmd52(write,func0,raw\_yes,17'h8,8'h3f,"enable int between blocks")

#### FIGURE:





Figure 6-62 Software Initial Control Flow

#### 6.14.6.2 Non-DMA read programming guide

- Initial SDIO slave card
- 2. Enable AHB domain interrupt register SLV\_RD\_EN, AHB\_WRDY\_EN, RD\_CMP\_EN.
- 3. SDIO host send CMD53 to read function 1
- 4. Once the SLV\_RD\_STA interrupt occurred, then software read BLK\_CNT and BLK\_SIZE to prepare for reading data.
- 5. Once the AHB\_WRDY\_STA interrupt occurred, then software should send BLK\_SIZE data to buffer data port DAT\_PORT
- 6. Once he RD CMP STA interrupt occurred, then all the data is transferred over.

#### 6.14.6.3 DMA read programming guide

- 1. Initial SDIO slave card
- 2. Enable AHB domain interrupt register DMA\_INT\_EN, RD\_CMP\_EN
- 3. Set SYS ADDR, DMA BUF SIZE, and enable DMA EN.
- 4. SDIO host send CMD53 to read function 1



- 5. Once the DMA\_INT\_EN, it means that the DMA have transfer DMA\_BUF\_SIZE data, then software should change a new SYS\_ADDR to receive more data.
- 6. Once the RD\_CMP\_STA interrupt occurred, then all the data is transferred over

## 6.14.6.4 Non-DMA write programming guide

- Initial SDIO slave card
- Enable AHB domain interrupt register SLV\_WR\_EN, AHB\_RRDY\_EN, WR CMP EN.
- 3. SDIO host send CMD53 to write function 1
- Once the SLV\_WR\_STA interrupt occurred, then software read BLK\_CNT and BLK\_SIZE to prepare for writing data.
- Once the AHB\_RRDY\_STA interrupt occurred, then software should get BLK\_SIZE data from buffer data port DAT\_PORT
- 6. Once he WR\_CMP\_STA interrupt occurred, then all the data is transferred over.

#### 6.14.6.5 DMA write programming guide

- Initial SDIO slave card
- 2. Enable AHB domain interrupt register DMA\_INT\_EN, WR\_CMP\_EN
- 3. Set SYS ADDR, DMA BUF SIZE, and enable DMA EN.
- 4. SDIO host send CMD53 to write function 1
- 5. Once the DMA\_INT\_EN, it means that the DMA have transfer DMA\_BUF\_SIZE data, then software should change a new SYS\_ADDR to transfer more data.
- 6. Once the WR\_CMP\_STA interrupt occurred, then all the data is transferred over

### 6.14.6.6 Suspend/resume programming guide

- 1. Initial SDIO slave card
- 2. Set relative registers based on DMA or NO-DMA transfer mode.
- SDIO host send CMD53 to read/write function 1
- 4. During the data block transferred, send a CMD52 write CCCR address 8'h0C with data 8'h02 to request bus release, the R5 response flag will tell the host whether the bus is released and data suspended or not. If the BS bit is set to 1, then the transfer is suspending.
- 5. There are two way to resume the data transfer. One way is to send a CMD52 write CCCR address 8'h0D with data 8'h01(function 1); the second way is to send a CMD53 with the same configuration as it set previously.

## 6.15 Efuse

#### 6.15.1 Overview

The electrical fuse is a type of non-volatile memory fabricated in standard CMOS logic process. This electrical fuse macro is widely used in chip ID, memory redundancy, security code, configuration setting, and feature selection, etc.

The efuse controller generates necessary timing and relative control interface to software.

This efuse controller is specially designed for TSMC product of TEF40LP32X8HD, which is a 8\*32 bits electrical fuses.



#### 6.15.2 Features

- I Meet TEF40LP32X8HD timing requirement
- I SW-friendly programming interface, each time 32 bits can be programmed or read
- I Build-in programming protect logic, each time before programming controller will first read current efuse memory value and then decide whether programming is needed
- Build-in programming check logic, can read and check the memory data after each programming
- I Build-in self-test logic(bist), can be triggered by SW or tester

### 6.15.3 Signal Description

# 6.15.4 Function Description

### 6.15.4.1 Block Diagram



Figure 6-63 Efuse controller block diagram

#### 6.15.4.2 Efuse connection





Figure 6-64 multi-efuse macro connection

### 6.15.4.3 Memory, Clock and Reset

Clk\_efuse is the controller clock and it's directly from PCLK or divided into one half from PCLK, There is only one async reset PRESETn in this module.

# 6.15.5 Control Registers

# 6.15.5.1 Memory map

| 45541            | 0 0000 | ~~~  |
|------------------|--------|------|
| ARM base address | 0x8900 | 0000 |

| Offset<br>Address | Name              | Description                                |
|-------------------|-------------------|--------------------------------------------|
| 0x0000            | EFUSE_DATA_RD     | Data read from efuse memory                |
| 0x0004            | EFUSE_DATA_WR     | Data to be write to efuse memory           |
| 0x0008            | EFUSE_BLOCK_INDEX | block index for read, program or bist.     |
| 0x000C            | EFUSE_MODE_CTRL   | Mode control of efuse memory               |
| 0x0010            | EFUSE_PGM_PARA    | Timing parameters in PGM and other control |



| Offset<br>Address | Name               | Description                                                     |
|-------------------|--------------------|-----------------------------------------------------------------|
| 0x0014            | EFUSE_STATUS       | Efuse controller internal status                                |
| 0x0018            | EFUSE_BLK_FLAGS    | Flags for each block                                            |
| 0x001C            | EFUSE_BLK_CLR      | To clear EFUSE_BLK_FLAGS                                        |
| 0x0020            | EFUSE_MAGIC_NUMBER | Magic number to protect efuse from un-intentionally programming |

### 6.15.5.1.1 EFUSE\_DATA\_RD

Description: Data read from efuse memory

| 0x0000 | Data read from efuse memory(Reset 0x0000_0000) |               |    |    |    |    |    |        |         |    | A_RD |    |    |    |    |    |
|--------|------------------------------------------------|---------------|----|----|----|----|----|--------|---------|----|------|----|----|----|----|----|
| Bit    | 31                                             | 30            | 29 | 28 | 27 | 26 | 25 | 24     | 23      | 22 | 21   | 20 | 19 | 18 | 17 | 16 |
| Name   |                                                | EFUSE_DATA_RD |    |    |    |    |    |        |         |    |      |    |    |    |    |    |
| Туре   |                                                | 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   |                                                |               |    |    |    |    | Е  | FUSE_D | DATA_RI |    |      |    |    |    |    |    |
| Туре   |                                                | RO            |    |    |    |    |    |        |         |    |      |    |    |    |    |    |
| Reset  | 0                                              | 0             | 0  | 0  | 0  | 0  | 0  | 0      | 0       | 0  | 0    | 0  | 0  | 0  | 0  | 0  |

| Field Name    | Bit    | Type | Reset<br>Value | Description                                                                                                      |
|---------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------|
| EFUSE_DATA_RD | [31:0] | RO   | 32'h0          | Efuse data, If SW use efuse controller to send a read command to efuse memory, the return value will store here. |

# 6.15.5.1.2 **EFUSE\_DATA\_WR**

Description: Data to be write to efuse memory



| 0x0004 |    | Data to be write to efuse memory(Reset 0x0000_0000) |    |                         |    |    |    |        |        |    |    |    | _WR |    |    |    |
|--------|----|-----------------------------------------------------|----|-------------------------|----|----|----|--------|--------|----|----|----|-----|----|----|----|
| Bit    | 31 | 30                                                  | 29 | 28                      | 27 | 26 | 25 | 24     | 23     | 22 | 21 | 20 | 19  | 18 | 17 | 16 |
| Name   |    | EFUSE_DATA_WR                                       |    |                         |    |    |    |        |        |    |    |    |     |    |    |    |
| Туре   |    | 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   |    |                                                     |    |                         |    |    | Е  | FUSE_D | DATA_W | R  |    |    |     |    |    |    |
| Туре   |    | R/W                                                 |    |                         |    |    |    |        |        |    |    |    |     |    |    |    |
| Reset  | 0  | 0                                                   | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |        |        |    |    |    | 0   |    |    |    |

| Field Name    | Bit    | Туре | Reset<br>Value | Description                                                                                                                                          |
|---------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| EFUSE_DATA_WR | [31:0] | R/W  | 32'h0          | Efuse data to be write.  If SW want to program the efuse memory, the data to be programmed will write to this register before SW issue a PGM command |

# 6.15.5.1.3 EFUSE\_BLOCK\_INDEX

Description: block index for read, program or bist.

| 0x0008 |    |          | block | block index for read, program or bist. (Reset 0x0000_0000) |     |    |     |             |    | EFUSE_BLOCK_INDE X |            |    |     |       |           |    |  |  |
|--------|----|----------|-------|------------------------------------------------------------|-----|----|-----|-------------|----|--------------------|------------|----|-----|-------|-----------|----|--|--|
| Bit    | 31 | 30       | 29    | 28                                                         | 27  | 26 | 25  | 24          | 23 | 22                 | 21         | 20 | 19  | 18    | 17        | 16 |  |  |
| Name   | В  | SIST_SIZ | E     | BIST_START_INDEX                                           |     |    |     | Reserved    |    |                    |            |    |     |       | PGM_INDEX |    |  |  |
| Туре   |    | 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    | 15 | 14       | 13    | 12                                                         | 11  | 10 | 9   | 9 8 7 6 5 4 |    |                    |            |    | 3   | 2 1 0 |           |    |  |  |
| Name   |    |          |       | Reserved                                                   |     |    |     |             |    |                    | READ_INDEX |    |     |       |           |    |  |  |
| Туре   |    |          |       |                                                            |     |    | R/W | R/W         |    |                    |            |    | R/W |       |           |    |  |  |
| Reset  | 0  | 0        | 0     | 0 0 0 0 0 0 0 0 0 0                                        |     |    |     |             |    | 0                  | 0          | 0  |     |       |           |    |  |  |

| Field Name | Bit   | Туре | Reset<br>Value | Description                                                                                                                       |
|------------|-------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------|
| READ_INDEX | [2:0] | R/W  | 3'h0           | The efuse memory block index to be read, when efuse controller read done next time ,the read data is in regiser "EFUSE_DATA_RD ". |



|                  |         |     |       | Attention: if Efuse is in PGM_MODE, since the efuse controller will first read the efuse memory, so in this case SW must makesure that read_index equal to pgm_index. |
|------------------|---------|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | [15:3]  | R/W | 13'h0 | Reserved                                                                                                                                                              |
| PGM_INDEX        | [18:16] | R/W | 3'h0  | The efuse memory block index to be programmed, when issue a PGM command ,efuse controller will write regiser value of "efuse_data_wr" into efuse data block n.        |
|                  | [25:19] | R/W | 7'h0  | Reserved                                                                                                                                                              |
| BIST_START_INDEX | [28:26] | R/W | 3'h0  | In efuse memory bist test mode, this field indicate the start word index                                                                                              |
| BIST_SIZE        | [31:29] | R/W | 3'h0  | In efuse memory bist test mode, this field indicate how many words will be checked by bist logic from start index.                                                    |

### 6.15.5.1.4 EFUSE\_MODE\_CTRL

Description: Mode control of efuse memory

| 0x000C |                    |          | Mode        | conti                                     | ol of e | fuse n | nemor | y (Res | et 0x0 | 000_00 | 000)                                        |                                | EFU                            | ISE_M | ODE_0 | CTRL |
|--------|--------------------|----------|-------------|-------------------------------------------|---------|--------|-------|--------|--------|--------|---------------------------------------------|--------------------------------|--------------------------------|-------|-------|------|
| Bit    | 31                 | 30       | 29          | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |        |       |        |        |        |                                             |                                |                                |       |       |      |
| Name   | BIST<br>_ST<br>ART |          |             | Reserved                                  |         |        |       |        |        |        |                                             |                                |                                |       |       |      |
| Туре   | R/W                |          |             |                                           |         |        |       |        | R/w    |        |                                             |                                |                                |       |       |      |
| 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   |                    | Reserved |             |                                           |         |        |       |        |        |        | EFU<br>SE_<br>STA<br>NDB<br>Y_S<br>TAR<br>T | EFU<br>SE_<br>RD_<br>STA<br>RT | EFU<br>SE_<br>PG_<br>STA<br>RT |       |       |      |
| Туре   |                    |          | 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    |

| Field Name     | Bit | Туре | Reset<br>Value | Description                                                                      |
|----------------|-----|------|----------------|----------------------------------------------------------------------------------|
| EFUSE_PG_START | [0] | R/W  | 1'h0           | Write 1 to this bit start efuse program process. Read this bit will always get 0 |
| EFUSE_RD_START | [1] | R/W  | 1'h0           | Write 1 to this bit start efuse read process,                                    |



|                     |        |     |       | Read this bit will always get 0                                                                                                                                                                                     |
|---------------------|--------|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EFUSE_STANDBY_START | [2]    | R/W | 1'h0  | Write 1 to this bit will make efuse went to standby mode, Read this bit will always get 0                                                                                                                           |
|                     | [30:3] | R/W | 28'h0 | Reserved                                                                                                                                                                                                            |
| BIST_START          | [31]   | R/W | 1'h0  | When BIST_SW_EN=1, write 1 to this bit will start efuse memory bist test process. this work mode is designed for efuse memory function test when mass production. DON'T active this process in normal working flow. |

### 6.15.5.1.5 EFUSE\_PGM\_PARA

Description: Timing parameters in PGM and other control

| 0x0010 |                |                         |                        | Timing parameters in PGM and other control (Reset 0x1000_0107) |                    |          |          |               |                                       |                                       |                                       |                                       | EFUSE_PGM_PARA                        |                                       |                                       |                                       |  |
|--------|----------------|-------------------------|------------------------|----------------------------------------------------------------|--------------------|----------|----------|---------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|--|
| Bit    | 31             | 30                      | 29                     | 28                                                             | 27                 | 26       | 26 25 24 |               |                                       | 22                                    | 21                                    | 20                                    | 19                                    | 18                                    | 17                                    | 16                                    |  |
| Name   | PG<br>M_E<br>N | PCL<br>K_DI<br>V_E<br>N | EFS<br>_VD<br>D_O<br>N | CLK<br>_EF<br>S_E<br>N                                         | BIST<br>_SW<br>_EN | Reserved |          |               | BLK<br>7_A<br>UTO<br>_TE<br>ST_<br>EN | BLK<br>6_A<br>UTO<br>_TE<br>ST_<br>EN | BLK<br>5_A<br>UTO<br>_TE<br>ST_<br>EN | BLK<br>4_A<br>UTO<br>_TE<br>ST_<br>EN | BLK<br>3_A<br>UTO<br>_TE<br>ST_<br>EN | BLK<br>2_A<br>UTO<br>_TE<br>ST_<br>EN | BLK<br>1_A<br>UTO<br>_TE<br>ST_<br>EN | BLK<br>0_A<br>UTO<br>_TE<br>ST_<br>EN |  |
| Туре   | R/W            | R/W                     | R/W                    | R/W                                                            | R/W                |          | R/W      |               | R/W                                   |  |
| Reset  | 0              | 0                       | 0                      | 1                                                              | 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   |                |                         | í                      | Reserve                                                        | t                  |          |          | TPGM_TIME_CNT |                                       |                                       |                                       |                                       |                                       |                                       |                                       |                                       |  |
| Туре   |                |                         |                        | R/W                                                            |                    |          |          |               | R/W                                   |                                       |                                       |                                       |                                       |                                       |                                       |                                       |  |
| Reset  | 0              | 0                       | 0                      | 0                                                              | 0                  | 0        | 0        | 1             | 0                                     | 0                                     | 0                                     | 0                                     | 0                                     | 1                                     | 1                                     | 1                                     |  |

| Field Name        | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                               |
|-------------------|--------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TPGM_TIME_CNT     | [8:0]  | R/W  | 9'h107         | Clk_efuse Cycle counter, if set n, the Tpgm time will last for (n+1) clk_efuse cycle, only when PGM_EN=1 can write this field, in general case, DON'T change this field value.                            |
|                   | [15:9] | R/W  | 7'h0           | Reserved                                                                                                                                                                                                  |
| BLK0_AUTO_TEST_EN | [16]   | R/W  | 1'h0           | If set this bit, when each time SW program efuse memory block0, the controller will automatically read its value and compare with write value. If not match, the flag bit of "MEM_BLK0_ERR_FLAG" will set |
| BLK1_AUTO_TEST_EN | [17]   | R/W  | 1'h0           | If set this bit, when each time SW program efuse memory block1, the controller will                                                                                                                       |



|                   |         |     |      | automatically read its value and compare with write value. If not match, the flag bit                                                                                                                                                      |
|-------------------|---------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BLK2_AUTO_TEST_EN | [18]    | R/W | 1'h0 | of "MEM_BLK1_ERR_FLAG" will set  If set this bit, when each time SW program efuse memory block2, the controller will automatically read its value and compare with write value. If not match, the flag bit of "MEM_BLK2_ERR_FLAG" will set |
| BLK3_AUTO_TEST_EN | [19]    | R/W | 1'h0 | If set this bit, when each time SW program efuse memory block3, the controller will automatically read its value and compare with write value. If not match, the flag bit of "MEM_BLK3_ERR_FLAG" will set                                  |
| BLK4_AUTO_TEST_EN | [20]    | R/W | 1'h0 | If set this bit, when each time SW program efuse memory block4, the controller will automatically read its value and compare with write value. If not match, the flag bit of "MEM_BLK4_ERR_FLAG" will set                                  |
| BLK5_AUTO_TEST_EN | [21]    | R/W | 1'h0 | If set this bit, when each time SW program efuse memory block5, the controller will automatically read its value and compare with write value. If not match, the flag bit of "MEM_BLK5_ERR_FLAG" will set                                  |
| BLK6_AUTO_TEST_EN | [22]    | R/W | 1'h0 | If set this bit, when each time SW program efuse memory block6, the controller will automatically read its value and compare with write value. If not match, the flag bit of "MEM_BLK6_ERR_FLAG" will set                                  |
| BLK7_AUTO_TEST_EN | [23]    | R/W | 1'h0 | If set this bit, when each time SW program efuse memory block7, the controller will automatically read its value and compare with write value. If not match, the flag bit of "MEM_BLK7_ERR_FLAG" will set                                  |
|                   | [26:24] | R/W | 3'h0 | Reserved                                                                                                                                                                                                                                   |
| BIST_SW_EN        | [27]    | R/W | 1'h0 | Write 1 to this bit will enable bist test mode. This mode is for mass production function test, DON'T set this bit in normal working mode.                                                                                                 |
| CLK_EFS_EN        | [28]    | R/W | 1'h1 | Set to 1 will open clk_efs This bit must set before efuse controller is in use                                                                                                                                                             |
| EFUSE_VDD_ON      | [29]    | R/W | 1'h0 | Set this bit will open 1.1v power supply for efuse memory, before any operation towards to efuse memory this bit have to set to 1.                                                                                                         |
| PCLK_DIV_EN       | [30]    | R/W | 1'h0 | When set, the clk_efuse will equal to a half of PCLK, otherwise will equal to PCLK. This bit is for timing adjust and debug use, in most case no need and don"t change its default value                                                   |
| PGM_EN            | [31]    | R/W | 1'h0 | Only set this bit can SW write register field of "TPGM_TIME_CNT" and start PGM                                                                                                                                                             |



|  |  | mode                                                                     |
|--|--|--------------------------------------------------------------------------|
|  |  | (this bit used to protect software unexpectedly programmed efuse memory) |

### 6.15.5.1.6 EFUSE\_STATUS

Description: Efuse controller internal status

| 0x0014 |    |                                              | Efus     | se con | troller | intern | al stat | us(Re | set 0x0 | 0000_0 | 000)              |                   |                  | EFUS                     | E_ST              | ATUS             |
|--------|----|----------------------------------------------|----------|--------|---------|--------|---------|-------|---------|--------|-------------------|-------------------|------------------|--------------------------|-------------------|------------------|
| Bit    | 31 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |          |        |         |        |         |       |         |        |                   |                   |                  |                          |                   |                  |
| Name   |    |                                              | Reserved |        |         |        |         |       |         |        |                   |                   |                  |                          |                   |                  |
| Туре   |    | 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   |    |                                              |          |        | Rese    | erved  |         |       |         |        | BIST<br>_BU<br>SY | BIST<br>_FAI<br>L | Res<br>erve<br>d | STA<br>NDB<br>Y_B<br>USY | REA<br>D_B<br>USY | PG<br>M_B<br>USY |
| Туре   |    |                                              | RW RO RO |        |         |        |         |       |         |        | RO                | RO                | RO               | RO                       | RO                |                  |
| Reset  | 0  | 0                                            | 0        | 0      | 0       | 0      | 0       | 0     | 0       | 0      | 0                 | 0                 | 0                | 0                        | 0                 | 0                |

| Field Name   | Bit    | Type | Reset<br>Value | Description                                    |
|--------------|--------|------|----------------|------------------------------------------------|
| PGM_BUSY     | [0]    | R0   | 1'h0           | "1" indicate efuse memory in programming mode  |
| READ_BUSY    | [1]    | R0   | 1'h0           | "1" indicate efuse memory in read mode         |
| STANDBY_BUSY | [2]    | R0   | 1'h0           | "1" indicate efuse memory in standby mode      |
|              | [3]    | R0   | 1'h0           | Reserved                                       |
| BIST_FAIL    | [4]    | R0   | 1'h0           | "1" will indicate that bist test failed        |
| BIST_BUSY    | [5]    | R0   | 1'h0           | "1" will indicate that bist test is in process |
|              | [31:6] | R/W  | 26'h0          | Reserved                                       |

# 6.15.5.1.7 EFUSE\_BLK\_FLAGS

Description: Flags for each block



| 0x0018 |                               |                               | Flags                         | for ea                        | ach blo                       | ock (Re                       | eset 0                        | <0000_                        | 0000)                          |                                |                                |                                | EFU                            | JSE_B                          | LK_FL                          | AGS                            |
|--------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|
| Bit    | 31                            | 30                            | 29                            | 28                            | 27                            | 26                            | 25                            | 24                            | 23                             | 22                             | 21                             | 20                             | 19                             | 18                             | 17                             | 16                             |
| Name   |                               |                               |                               |                               |                               |                               |                               | Rese                          | erved                          |                                |                                |                                |                                |                                |                                |                                |
| Туре   |                               |                               |                               |                               |                               |                               |                               | R/                            | W                              |                                |                                |                                |                                |                                |                                |                                |
| 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   | BLK<br>7_E<br>RR_<br>FLA<br>G | BLK<br>6_E<br>RR_<br>FLA<br>G | BLK<br>5_E<br>RR_<br>FLA<br>G | BLK<br>4_E<br>RR_<br>FLA<br>G | BLK<br>3_E<br>RR_<br>FLA<br>G | BLK<br>2_E<br>RR_<br>FLA<br>G | BLK<br>1_E<br>RR_<br>FLA<br>G | BLK<br>0_E<br>RR_<br>FLA<br>G | BLK<br>7_P<br>ROT<br>_FL<br>AG | BLK<br>6_P<br>ROT<br>_FL<br>AG | BLK<br>5_P<br>ROT<br>_FL<br>AG | BLK<br>4_P<br>ROT<br>_FL<br>AG | BLK<br>3_P<br>ROT<br>_FL<br>AG | BLK<br>2_P<br>ROT<br>_FL<br>AG | BLK<br>1_P<br>ROT<br>_FL<br>AG | BLK<br>0_P<br>ROT<br>_FL<br>AG |
| Туре   | RO                             | RO                             | RO                             | RO                             | RO                             | RO                             | RO                             | RO                             |
| Reset  | 0                             | 0                             | 0                             | 0                             | 0                             | 0                             | 0                             | 0                             | 0                              | 0                              | 0                              | 0                              | 0                              | 0                              | 0                              | 0                              |

| Field Name     | Bit | Туре | Reset<br>Value | Description                                                                                                                                                              |
|----------------|-----|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BLK0_PROT_FLAG | [0] | R0   | 1'h0           | If the SW send a PGM command to memory block0, and the controller found this memory block need to be protected(which means the highest bit is 1), this bit will set to 1 |
| BLK1_PROT_FLAG | [1] | R0   | 1'h0           | If the SW send a PGM command to memory block1, and the controller found this memory block need to be protected(which means the highest bit is 1), this bit will set to 1 |
| BLK2_PROT_FLAG | [2] | R0   | 1'h0           | If the SW send a PGM command to memory block2, and the controller found this memory block need to be protected(which means the highest bit is 1), this bit will set to 1 |
| BLK3_PROT_FLAG | [3] | R0   | 1'h0           | If the SW send a PGM command to memory block3, and the controller found this memory block need to be protected(which means the highest bit is 1), this bit will set to 1 |
| BLK4_PROT_FLAG | [4] | R0   | 1'h0           | If the SW send a PGM command to memory block4, and the controller found this memory block need to be protected(which means the highest bit is 1), this bit will set to 1 |
| BLK5_PROT_FLAG | [5] | R0   | 1'h0           | If the SW send a PGM command to memory block5, and the controller found this memory block need to be protected(which means the highest bit is 1), this bit will set to 1 |
| BLK6_PROT_FLAG | [6] | R0   | 1'h0           | If the SW send a PGM command to memory block6, and the controller found this memory block need to be protected(which means the highest bit is 1), this bit will set to 1 |



| BLK7_PROT_FLAG  [7]  R0  1'h0  If the SW send a PGM comman memory block7, and the control this memory block need to be                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
| protected(which means the hig<br>1), this bit will set to 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                        |
| BLK0_ERR_FLAG  [8]  R0  1'h0  If BLK0_AUTO_TEST_EN is set controller compared the value in PGM from the same block, and two value not match, this bit will error flag. But if this block is properly PGM command in-fact not reall this bit will not set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | read after<br>found the<br>set as an<br>otected, the   |
| BLK1_ERR_FLAG  [9]  R0  1'h0  If BLK1_AUTO_TEST_EN is set controller compared the value in PGM from the same block, and two value not match, this bit will error flag. But if this block is properly PGM command in-fact not reall this bit will not set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | read after<br>found the<br>I set as an<br>otected, the |
| BLK2_ERR_FLAG  [10]  R0  1'h0  If BLK2_AUTO_TEST_EN is secontroller compared the value of PGM from the same block, and two value not match, this bit will error flag. But if this block is properly pGM command in-fact not reall this bit will not set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | read after<br>found the<br>set as an<br>otected, the   |
| BLK3_ERR_FLAG  [11]  R0  1'h0  If BLK3_AUTO_TEST_EN is secontroller compared the value representation of two value not match, this bit will error flag. But if this block is properly performed to the properties of the properties | read after<br>found the<br>I set as an<br>otected, the |
| BLK4_ERR_FLAG  [12] R0 1'h0 If BLK4_AUTO_TEST_EN is se controller compared the value r PGM from the same block, and two value not match, this bit will error flag. But if this block is property PGM command in-fact not reall this bit will not set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | read after<br>found the<br>I set as an<br>otected, the |
| BLK5_ERR_FLAG  [13]  R0  1'h0  If BLK5_AUTO_TEST_EN is secontroller compared the value in PGM from the same block, and two value not match, this bit will error flag. But if this block is properly PGM command in-fact not reall this bit will not set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | read after<br>found the<br>set as an<br>otected, the   |
| BLK6_ERR_FLAG  [14]  R0  1'h0  If BLK6_AUTO_TEST_EN is secontroller compared the value in PGM from the same block, and two value not match, this bit will error flag. But if this block is pro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | read after<br>found the<br>I set as an<br>otected, the |
| PGM command in-fact not reall this bit will not set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | y send, so                                             |



|         |     |       | controller compared the value read after PGM from the same block, and found the two value not match, this bit will set as an error flag. But if this block is protected, the PGM command in-fact not really send, so this bit will not set. |
|---------|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | R/W | 16'h0 | Reserved                                                                                                                                                                                                                                    |

### 6.15.5.1.8 EFUSE\_BLK\_FLAGS\_CLR

Description: To clear EFUSE\_BLK\_FLAGS

| 0x001C | To clear EFUSE_BLK_FLAGS (Reset 0x0000_0000) |                                       |                                       |                                       |                                       |                                       | EFU:                                  | SE_BL                                 | K_FL/                                  | AGS_<br>CLR                            |                                        |                                        |                                        |                                        |                                        |                                        |
|--------|----------------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|
| Bit    | 31                                           | 30                                    | 29                                    | 28                                    | 27                                    | 26                                    | 25                                    | 24                                    | 23                                     | 22                                     | 21                                     | 20                                     | 19                                     | 18                                     | 17                                     | 16                                     |
| Name   |                                              |                                       |                                       |                                       |                                       |                                       |                                       | Rese                                  | erved                                  |                                        |                                        |                                        |                                        |                                        |                                        |                                        |
| Туре   |                                              |                                       |                                       |                                       |                                       |                                       |                                       | R/                                    | W                                      |                                        |                                        |                                        |                                        |                                        |                                        |                                        |
| 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   | BLK<br>7_E<br>RR_<br>FLA<br>G_C<br>LR        | BLK<br>6_E<br>RR_<br>FLA<br>G_C<br>LR | BLK<br>5_E<br>RR_<br>FLA<br>G_C<br>LR | BLK<br>4_E<br>RR_<br>FLA<br>G_C<br>LR | BLK<br>3_E<br>RR_<br>FLA<br>G_C<br>LR | BLK<br>2_E<br>RR_<br>FLA<br>G_C<br>LR | BLK<br>1_E<br>RR_<br>FLA<br>G_C<br>LR | BLK<br>0_E<br>RR_<br>FLA<br>G_C<br>LR | BLK<br>7_P<br>ROT<br>_FL<br>AG_<br>CLR | BLK<br>6_P<br>ROT<br>_FL<br>AG_<br>CLR | BLK<br>5_P<br>ROT<br>_FL<br>AG_<br>CLR | BLK<br>4_P<br>ROT<br>_FL<br>AG_<br>CLR | BLK<br>3_P<br>ROT<br>_FL<br>AG_<br>CLR | BLK<br>2_P<br>ROT<br>_FL<br>AG_<br>CLR | BLK<br>1_P<br>ROT<br>_FL<br>AG_<br>CLR | BLK<br>0_P<br>ROT<br>_FL<br>AG_<br>CLR |
| Туре   | R/W                                          | R/W                                   | R/W                                   | R/W                                   | R/W                                   | 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                                      | 0                                      | 0                                      | 0                                      | 0                                      | 0                                      |

| Field Name         | Bit | Туре | Reset<br>Value | Description                                                                                    |
|--------------------|-----|------|----------------|------------------------------------------------------------------------------------------------|
| BLK0_PROT_FLAG_CLR | [0] | R0   | 1'h0           | Write this bit "1" will clear flag bit "BLK0_PROT_FLAG", read this bit will always get 0       |
| BLK1_PROT_FLAG_CLR | [1] | R0   | 1'h0           | Write this bit "1" will clear flag bit "BLK1_PROT_FLAG", read this bit will always get 0       |
| BLK2_PROT_FLAG_CLR | [2] | R0   | 1'h0           | Write this bit "1" will clear flag bit<br>"BLK2_PROT_FLAG", read this bit will<br>always get 0 |
| BLK3_PROT_FLAG_CLR | [3] | R0   | 1'h0           | Write this bit "1" will clear flag bit<br>"BLK3_PROT_FLAG", read this bit will<br>always get 0 |
| BLK4_PROT_FLAG_CLR | [4] | R0   | 1'h0           | Write this bit "1" will clear flag bit<br>"BLK4_PROT_FLAG", read this bit will<br>always get 0 |
| BLK5_PROT_FLAG_CLR | [5] | R0   | 1'h0           | Write this bit "1" will clear flag bit "BLK5_PROT_FLAG", read this bit will always get 0       |
| BLK6_PROT_FLAG_CLR | [6] | R0   | 1'h0           | Write this bit "1" will clear flag bit                                                         |



|                    |         |     |       | "BLK6_PROT_FLAG", read this bit will always get 0                                              |
|--------------------|---------|-----|-------|------------------------------------------------------------------------------------------------|
| BLK7_PROT_FLAG_CLR | [7]     | R0  | 1'h0  | Write this bit "1" will clear flag bit<br>"BLK7_PROT_FLAG", read this bit will<br>always get 0 |
| BLK0_ERR_FLAG_CLR  | [8]     | R0  | 1'h0  | Write this bit "1" will clear flag bit<br>"BLK0_ERR_FLAG", read this bit will<br>always get 0  |
| BLK1_ERR_FLAG_CLR  | [9]     | R0  | 1'h0  | Write this bit "1" will clear flag bit<br>"BLK1_ERR_FLAG", read this bit will<br>always get 0  |
| BLK2_ERR_FLAG_CLR  | [10]    | R0  | 1'h0  | Write this bit "1" will clear flag bit<br>"BLK2_ERR_FLAG", read this bit will<br>always get 0  |
| BLK3_ERR_FLAG_CLR  | [11]    | R0  | 1'h0  | Write this bit "1" will clear flag bit "BLK3_ERR_FLAG", read this bit will always get 0        |
| BLK4_ERR_FLAG_CLR  | [12]    | R0  | 1'h0  | Write this bit "1" will clear flag bit  "BLK4_ERR_FLAG", read this bit will  always get 0      |
| BLK5_ERR_FLAG_CLR  | [13]    | R0  | 1'h0  | Write this bit "1" will clear flag bit  "BLK5_ERR_FLAG", read this bit will  always get 0      |
| BLK6_ERR_FLAG_CLR  | [14]    | R0  | 1'h0  | Write this bit "1" will clear flag bit<br>"BLK6_ERR_FLAG", read this bit will<br>always get 0  |
| BLK7_ERR_FLAG_CLR  | [15]    | R0  | 1'h0  | Write this bit "1" will clear flag bit "BLK7_ERR_FLAG", read this bit will always get 0        |
|                    | [31:16] | R/W | 16'h0 | Reserved                                                                                       |

### 6.15.5.1.9 EFUSE\_MAGIC\_NUMBER

Description: magic number to protect efuse from un-intentionally programming



| 0x0020 | magic number to protect efuse from un-intentionally programming (Reset 0x0000_0000) |          |    |    |    |    |      | EFU    | JSE_M  | AGIC_ | NUM<br>BER |    |    |    |    |    |
|--------|-------------------------------------------------------------------------------------|----------|----|----|----|----|------|--------|--------|-------|------------|----|----|----|----|----|
| Bit    | 31                                                                                  | 30       | 29 | 28 | 27 | 26 | 25   | 24     | 23     | 22    | 21         | 20 | 19 | 18 | 17 | 16 |
| Name   |                                                                                     | Reserved |    |    |    |    |      |        |        |       |            |    |    |    |    |    |
| Туре   |                                                                                     | 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   |                                                                                     |          |    |    |    |    | EFU: | SE_MAG | IC_NUM | 1BER  |            |    |    |    |    |    |
| Туре   | RW                                                                                  |          |    |    |    |    |      |        |        |       |            |    |    |    |    |    |
| Reset  | 0                                                                                   | 0        | 0  | 0  | 0  | 0  | 0    | 0      | 0      | 0     | 0          | 0  | 0  | 0  | 0  | 0  |

| Field Name         | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                      |
|--------------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EFUSE_MAGIC_NUMBER | [15:0]  | R/W  | 16'h0          | Magic number, only when this field is 0x8810, the Efuse programming command can be handle.  So if SW want to program efuse memory, except open clocks and power, 2 other conditions must be met:  (1) PGM_EN =1; (2) EFUSE_MAGIC_NUMBER = 0x8810 |
|                    | [31:16] | R/W  | 16'h0          | Reserved                                                                                                                                                                                                                                         |

# 6.15.6 Application Notes

### 6.15.6.1 Clock structure

Before any operation towards efuse macro through efuse controller, you need set "efs\_eb" to open efuse controller clock, and then set "CLK\_EFS\_EN" to open accelerator clock.





Figure 6-65 clock structure for efuse controller

### 6.15.6.2 Efuse memory power supply

As specification requires, efuse memory need two power supply: VDDQ @ 2.5V+/- 10% and VDD @ 1.1V+/- 10%, In SC6820, VDDQ use the 2.5V PLL power supply and VDD use 1.1v digital core (40nm technology) power supply.

When EFUSE\_VDD\_ON is set , the VDD power will open and efuse memory can be ready for programming or read

#### 6.15.6.3 Read mode timing sequence

In physical view, The TEF40LP32X8HD is a 32 rows and 8 columns memory array, each time only one rows can be read at the same time, but this efuse controller re-grouped the memory array and from sofware's perspective, 4 rows are together and each time they can be accessed for read, which are 32bits





Figure 6-66 efuse memory read timing

### 6.15.6.4 Programming mode(PGM) timing sequence

In physical, each time only one bit is allowed to be programmed, which is in-fact an irreversible erase process from 1 to 0, efuse controller packaged such process and each time one work, that is 32 bits, can be programmed as your will.

Attention: before efuse controller program a word to relative memory, it will previously read this memory value and if found the highest bit of this memory is 0, then the efuse PGM will abort and no data will write to this memory, this function is the system department's requirement.





Figure 6-67 efuse memory program timing

#### 6.15.6.5 Standby mode

When CSB = 1, PENB =1 and VDDQ is floating or equal to 0v, the Efuse memory is in standby mode, the power consumption is the smallest in this mode.

#### 6.15.6.6 Program in-active mode

When CSB=1, PENB=0 and VDDQ is 2.5v+/-10%, the efuse memory is in program inactive mode.

#### 6.15.6.7 Programming notes

#### 6.15.6.7.1 Power on & Power off

Before using efuse controller to send any command to efuse memory , SW need to open efuse power according to following steps :

- (1) set global control bit of "efs\_eb", that is bit 7 in 0x8b00\_0007;
- (2) set "EFUSE\_VDD\_ON" in 0x8900\_0010 bit 29, to open power supply for VDD

after finished all operation to efuse memory , then "EFUSE\_VDD\_ON" and "efs\_eb" should be cleared for power saving



#### 6.15.6.7.2 PGM flow

- (1) Write "PGM\_EN" and "CLK\_EFUSE\_EN" in "EFUSE\_PGM\_PARA" register to enable PGM mode. (0x8900\_0010 bit 28 & 31)
- (2) Write "EFUSE\_MAGIC\_NUMBER" as 0x8810 (0x8900\_0020)
- (3) write the value to be programmed to register "Efuse\_data\_wr" (0x8900\_0004)
- (4) write the memory index to be programmed to register "PGM\_INDEX" (0x8900\_0008 bits 16 to 18)
- (5) write bit of "EFUSE\_PG\_START" in register "EFUSE\_MODE\_CTRL" to 1 to start programming efuse memory (0x8900\_000C bit 0)
- (6) SW then polling the status of "PGM\_BUSY" in "EFUSE\_STATUS" register (0x8900\_0014 bit 0), if this bit cleared, the programming process finished
- (7) After PGM finished, SW can read "BLKX\_PROT\_FLAG" to know whether the previous programming succeed or not (X equal to the PGM\_INDEX value)
- (8) clear "PGM\_EN" in "EFUSE\_PGM\_PARA" register to prohibit un-expected programming command

In most case, there is no need to change the TPGM\_TIME\_CNT and the default value will be OK

#### 6.15.6.7.3 Read flow

After PGM , SW can read the efuse memory value according to the following steps:

- (1) Wite "CLK\_EFS\_EN" in "EFUSE\_PGM\_PARA" register to pen efuse clock. (0x8900\_0010 bit 28)
- (2) write "EFUSE\_RD\_START" in register "EFUSE\_MODE\_CTRL" to 1 to start reading process from efuse memory(0x8900\_000C bit 1)
- (3) polling bit of "READ\_BUSY" in "EFUSE\_STATUS" register(0x8900\_0014 bit 1), after it cleared to zero, the read flow is finished and the return value is in "EFUSE\_DATA\_RD" (0x8900\_0000)

### 6.15.6.7.4 Standby flow

SW can set "EFUSE\_STANDBY\_START" (0x8900\_000C bit 2)to let efuse macro go to standby status. After read/write done, the efuse controller can also control efuse macro go to this mode automatically.

#### 6.15.6.7.5 Software trigger bist process



Software can enable bist test process, to check some content of efuse memory is programmed or not.

- (1) SW write register field "BIST\_START\_INDEX" and "BIST\_END\_INDEX"
- (2) SW wite "BIST\_SW\_EN" and "CLK\_EFS\_EN" to 1
- (3) SW write "BIST\_START" 1 to start bist check

The bist test process will read the memory value from "BIST\_START\_INDEX" to "BIST\_END\_INDEX"

" and if find its value are not zero, then an "BIST\_FAIL" flag will set after "BIST\_BUSY" return to zero.



# 7 Multi-Media Subsystem

#### 7.1 Dcam

#### 7.1.1 Overview

The DCAM integrates several multimedia hardware accelerator include camera interface, image resizing and videophone path. Both YCbCr and JPEG data can be captured by camera interface. The image signal process such as decimation, trimming, scaling, RGB data conversion and etc functions can be transacted in review module.

#### Change list:

- I New CAP module to support SPI, CCIR 656 1 bit, 2 bit and 4 bit.
- I Modify the endian adjustment.
- I Support output data YUV420 YUV422 and RGB565 in capture path1.
- I Modify the frm addr from 18 bits to 32 bits.
- I Add rotation function in review path.

#### 7.1.2 Features

Camera capture path:

- I ITU\_R 601/ITU\_R 656 format input support. 8 bit YCbCr is supported.
- I Support up to 5M pixel CMOS sensor's JPEG compression mode;
- Support SPI Camera Interface.
- Support 601/656 1bit, 2bit, 4bit and 8bit Camera Interface.
- Programmable polarity of Vsync and Href signals.
- I Support scaling down/up function, scaling factor from 1/4 to 4;
- I The scaling hardware support for output resolutions up to 960 pixel;
- I Support image crop and down sample in camera interface;
- I Support frame decimation in camera interface;
- I Sensor line and frame data error auto detect;
- I Support two separate capture path. one for preview another for capture;if the second camera path is active, the review path must be disabled. If both two capture path is active, trimming of two path must be active, and scaling of them can't be bypassed.



- I Support trimming and down sample in both capture path; if enable subsample, trimming must be enabled too.
- I Support YUV422 ,RGB565 and YUV420 format data out in both capture path ;

#### Image resizing path:

- I Support two scaling mode: normal and slice;
- I Support scaling down/up function, scaling factor from 1/4 to 4;
- I in normal mode, restricted to output width less than 960 pixel for display;
- I If using slice review mode, support output horizontal size up to 4092;
- I Support different YUV input format, include: YUV422, YUV420, YUV400;
- I Support Y,U,V 3 frame data format input scaling;
- I Support different output data format, YUV422 and RGB565, and support YUV420 output format in normal scaling mode;
- I Support image trimming and down sample in review mode. 1/2, 1/4,1/8,1/16 down sample in X and Y direction;
- I Support RGB2YUV and YUV2RGB conversion;
- I Support different RGB format input, RGB888, RGB565;
- I Support rotation function in resizing path.

#### Rotation function:

- I Support 90 270 180 and horizontal mirror rotation mode;
- I Support rotation image width up to 960 pixel;
- I The rotation function can only be active in resizing path or capture path 2;

### 7.1.3 Signal Description



### 7.1.3.1 Diagram of Camera Interface:



Figure 7.1-1 interface of CAM\_IF

### 7.1.3.2 Signal description

| Signal name | I/O | Width | Description                                  |  |
|-------------|-----|-------|----------------------------------------------|--|
| CCIRCK      | I   | 1     | Pixel Clock, driven by the Camera Module     |  |
| CCIRVS      | I   | 1     | Frame Sync, driven by the Camera Module      |  |
| CCIRHS      | I   | 1     | Horizontal Sync, driven by the Camera Module |  |
| CCIRD       | I   | [7:0] | Pixel Data driven by the Camera Module       |  |
| CCIRMCK     | 0   | 1     | Clock to external Camera                     |  |
| CAM_PD      | 0   | [1:0] | Software Power Down for the Camera Module    |  |
| CAM_RSTN    | 0   | 1     | Software Reset for the Camera Module         |  |

Camera I/F connections with different mode sensor:

| Г |          |      |                 |                 |                 |
|---|----------|------|-----------------|-----------------|-----------------|
|   |          | SPI  | CCIR656(4 bits) | CCIR656(2 bits) | CCIR656(1 bits) |
|   | CCIRCK   | PCLK | PCLK            | PCLK            | PCLK            |
|   | CCIRVS   | CS   |                 |                 |                 |
|   | CCIRHS   |      |                 |                 |                 |
|   | CCIRD[0] | SPID | CCIRD[0]        | CCIRD[0]        | CCIRD[0]        |
|   | CCIRD[1] |      | CCIRD[1]        | CCIRD[1]        |                 |
| Ī | CCIRD[2] |      | CCIRD[2]        |                 |                 |



| CCIRD[3] |     | CCIRD[3] |     |     |
|----------|-----|----------|-----|-----|
| CCIRD[4] |     |          |     |     |
| CCIRD[5] |     |          |     |     |
| CCIRD[6] |     |          |     |     |
| CCIRD[7] |     |          |     |     |
| SCL      | SCL | SCL      | SCL | SCL |
| SDA      | SDA | SDA      | SDA | SDA |

#### 7.1.3.3 Clock of Camera Interface



Figure 1.1-2 clock of CAM\_IF

Camera Interface includes three clock domains. The AHB bus clock: HCLK; CCIR Clock from sensor: CCIRCK and clock to dcam\_top; clk\_dcam. The AHB bus clock must be faster than dcam clock. The dcam clock should be faster than Sensor clock.

The AHB slave works in AHB domain. Most DCAM component except some logic in CAP works in DCAM clock domain. The DCAM clock can work at 48M, 64M and 96M.

The MCLK of sensor can be supplied from Chip or external oscillator. A extra CLK DLY cell have been inserted on CCIRCK path, which can adjust the CCIRCK phase.

#### Note:

• The frequency of sensor clock must slower than dcam clock;



### 7.1.3.4 Timing Diagram of Camera IF



Figure 7.1-3 timing diagram of Sync signal

CCIR601 YUV mode timing diagram:

Vsync/Href (register Sync\_polarity =01)



Figure 7.1-4 timing diagram of CAM\_IF 601

JPEG data timing diagram is similar with YUV data mode.

Following is an example of Vsynv/Hsync(register Sync\_polarity =01):





Figure 7.1-5 JPG timing diagram of CAM\_IF

### SPI mode:



Figure 7.1-6 timing diagram of CAM\_IF SPI mode

#### CCIR 656 mode:





### 7.1.4 Function Description

### 7.1.4.1 Diagram of DCAM\_TOP



Figure 7.1-8 diagram of DCAM\_TOP

#### CAP\_TOP:

This module was in charge of transacting YUV or JPEG data from sensor. It support down-sampling ,image-trimming, frame decimation and etc;

- 1. Interface timing
- 1.1. Support YUV4:2:2 and JPEG compression formats;
- 1.2. Support Vref/Vsync and Href/Hsync.
- 1.3. Support CCIR656 interface 1bit,2bit and4bit in YUV4:2:2 format.
- 1.4. Support SPI sensor.
- 1.5. Support sensor's output clock polarity inversion.
- 1.6. Sensor's input clock is configurable by ARM.
- 2. Frame control
- 2.1. Support decimation on frames. The decimation factors can be configured by ARM.
- 2.2. Which frame is captured could be configured by ARM.
- 3. Image Size
- 3.1. Support YUV4:2:2 format sensors up to 4092x4092.
- 3.2. Support various image sizes smaller than 4092x4092, which is configured by ARM.



- 3.3. Support decimation on line and column in YUV4:2:2. The decimation unit on the horizontal and vertical direction are 1. The decimation factors can be configured independently by ARM.
- 3.4. Support trimming images from the sensor in YUV4:2:2. The start point and the end point are configured by ARM.
- 4. Whole module could be disabled by ARM based on DCAM working mode.

#### **SCALING:**

- Support unsigned YUV422 input, The input data can be from two source, YUYV
   DATA from CAP, Y frame and UV frame from AHB Master.
- Support trimming function before scaling. And the timing size can be programmed by ARM
- 3. Scaling factor from 1/4 to 4.
- 4. In slice mode, output horizontal size is up to 4092.
- Normal mode scaling output horizontal size up to 960.
- 6. the 2D scalar has such work parameters:
- (1) Horizontal scaling

For Y component, using fixed 8-tap and 8-phase filter;

For U/V component, using fixed 4-tap and 8-phase filter;

(2) Vertical scaling down

For Y component, using variable tap and 8-phase filter,  $2 \le K_Y \le 4M/N \le 8$ ;

For U/V component, using variable tap and 8-phase filter,  $2 \le K_C = K_Y \le 8$ ;

(3) Vertical scaling up

For Y component, using 4-tap and 8-phase filter;

For U/V component, using 4-tap and 8-phase filter;

7. Whole module could be disabled bypassed by ARM based on DCAM working mode.

#### NOTE:

The input and output width of scaling module must be multiple of 4.

The trimming function only be active in review mode. And it the trimming start and trimming size must be 4 aligned.

### Color space conversion:

in charge of data format conversion between YUV and RGB.

YUV2RGB: Convert YUV444 to RGB565

Ø Support YUV422 to RGB565 conversion. The input data format to this module should be YUV 422. The conversion coefficients is fixed .

The algorithm for YUVTORGB is shown below:



$$\begin{bmatrix} R \\ G \\ B \end{bmatrix} = \begin{bmatrix} 1 & 0 & \frac{359}{256} \\ 1 & -\frac{88}{256} & -\frac{183}{256} \\ 1 & \frac{454}{256} & 0 \end{bmatrix} \begin{bmatrix} Y \\ U \\ V \end{bmatrix} + \begin{bmatrix} -180 \\ 136 \\ -227 \end{bmatrix}$$

Ø Support dithering function and it can be enable or disable by software.

RGB2YUV: Convert RGB888 or RGB565 to YUV422, we use fixed conversion coefficient.

The formula as below shows:

$$\begin{bmatrix} Y \\ U \\ V \end{bmatrix} = \begin{bmatrix} \frac{77}{256} & \frac{150}{256} & \frac{29}{256} \\ \frac{43}{256} & -\frac{85}{256} & \frac{128}{256} \\ \frac{128}{256} & -\frac{107}{256} & -\frac{21}{256} \end{bmatrix} \begin{bmatrix} R \\ G \\ B \end{bmatrix} + \begin{bmatrix} 0 \\ 128 \\ 128 \end{bmatrix}$$

### DCAM\_AHB\_MASTER:

- 1. There are two output ports and one input port in DCAM AHB Master Interface, only one port can be active at one time.
- 2. Support an arbiter between Port CAM, Port REV and Port YUV2RGB. The priority of Port CAM is highest.
- 3. The interval between two burst can be configured by register.
- 4. The AHB interface, DCAM VDB port and AHB part works in clk\_dcam domain,





Figure 7.1-9 diagram of AHB master

### 7.1.4.2 Camera capture path:



Figure 7.1-10 camera data path

Two separate camera capture path is supported in DCAM module, which can be active simultaneously. Both YUV422 YUV420 RGB565 and JPEG data can be capture by camera path 1.The output data from path1 can be YUV422 YUV420 and RGB565.

## 7.1.4.3 Image resizing path





#### Figure 7.1-11 resizing data path

In image resizing path, support different input data format scaling, include YUV422, YUV420, YUV400, YUV420(3 frame), RGB565 and RGB888. And support different output data format, include YUV422, YUV420 and RGB565. Limited by the size of line buffer, the output width must less than 960 in normal scaling mode. In slice mode, the output data width can be up to 4092.

Image resizing path can't be active if enable camera path 2.

### 7.1.4.4 Video phone path



Figure 7.1-12 video phone data path

In Video phone mode, work flow as following figures shows:





Figure 7.1-13 video phone mode sequence.

# 7.1.5 Control Registers

### 7.1.5.1 **Memory map**

ARM base address: 0x2020\_0000

| Offset<br>Address | Name            | Description               |
|-------------------|-----------------|---------------------------|
| 0x0000            | DCAM_CFG        | DCAM control              |
| 0x0004            | CAMERA_PATH_CFG | CAMERA PATH control       |
| 0x0008            | CAM_SRC_SIZE    | Camera Source size        |
| 0x000C            | CAM_DES_SIZE    | Camera Destination size   |
| 0x0010            | CAM1_TRIM_START | CAM1 Trimming start       |
| 0x0014            | CAM1_TRIM_SIZE  | CAM1 Trimming size        |
| 0x0018            | REVIEW_PATH_CFG | Review control register   |
| 0x001C            | REV_SRC_SIZE    | Review Source size;       |
| 0x0020            | REV_DES_SIZE    | Review Destination size   |
| 0x0024            | REV_TRIM_START  | Review Trimming start     |
| 0x0028            | REV_TRIM_SIZE   | Review Trimming size      |
| 0x002C            | SLICE_VER_CNT   | Slice Vertical line count |
| 0x0030            | DCAM_INT_STS    | DCAM interrupt status     |
| 0x0034            | DCAM_INT_MASK   | DCAM interrupt mask       |
| 0x0038            | DCAM_INT_CLR    | DCAM interrupt clear      |



|                   |                  | Ţ .                                   |  |  |  |  |
|-------------------|------------------|---------------------------------------|--|--|--|--|
| Offset<br>Address | Name             | Description                           |  |  |  |  |
| 0x003C            | DCAM_INT_RAW     | DCAM interrupt raw                    |  |  |  |  |
| 0x0040            | FRM_ADDR_0       | Frame address 0                       |  |  |  |  |
| 0x0044            | FRM_ADDR_1       | Frame address 1                       |  |  |  |  |
| 0x0048            | FRM_ADDR_2       | Frame address 2                       |  |  |  |  |
| 0x004C            | FRM_ADDR_3       | Frame address 3                       |  |  |  |  |
| 0x0050            | FRM_ADDR_4       | Frame address 4                       |  |  |  |  |
| 0x0054            | FRM_ADDR_5       | Frame address 5                       |  |  |  |  |
| 0x0058            | FRM_ADDR_6       | Frame address 6                       |  |  |  |  |
| 0x005c            |                  | X                                     |  |  |  |  |
| 0x0060            | BURST_GAP        | GAP between two burst                 |  |  |  |  |
| 0x0064            | ENDIAN_SEL       | Endian adjustment                     |  |  |  |  |
| 0x0068            | AHBM_STS         | AHB master status                     |  |  |  |  |
| 0x006C            | FRM_ADDR_7       | Frame address 7                       |  |  |  |  |
| 0x0070            | FRM_ADDR_8       | Frame address 8                       |  |  |  |  |
| 0x0074            |                  | reserved                              |  |  |  |  |
| ~<br>0x00FC       |                  |                                       |  |  |  |  |
| 0x0100            | CAP_CTRL         | Camera interface control              |  |  |  |  |
| 0x0104            | CAP FRM CTRL     | CAP Frame CTRL                        |  |  |  |  |
| 0x0108            | CAP START        | CAP Start position                    |  |  |  |  |
| 0x010C            | CAP_END          | CAP End position                      |  |  |  |  |
| 0x0110            | CAP_IMG_DECI     | CAP image decimation parameter        |  |  |  |  |
| 0x0114            | ATV_MODE_FIX     |                                       |  |  |  |  |
| 0x0118            | CAP OBSERVE      | CAP Observing register                |  |  |  |  |
| 0x011C            | CAP_JPEG_CTRL    | 3 3 3                                 |  |  |  |  |
| 0x0120            | CAP FRM SIZE     | Current capture size from JPEG or spi |  |  |  |  |
| 0,0120            | 0/11 _1 11W_0122 | sensor                                |  |  |  |  |
| 0x0124            | CAP_SPI_WIDTH    | SPI sensor control                    |  |  |  |  |
| 0x0128            |                  | reserved                              |  |  |  |  |



| Offset<br>Address     | Name           | Description                           |  |  |  |  |  |  |
|-----------------------|----------------|---------------------------------------|--|--|--|--|--|--|
| ~<br>0x01FC           |                |                                       |  |  |  |  |  |  |
| 0x0200<br>~<br>0x027C | LUMA_HCOEF_1   | Luma horizontal coefficient table 1   |  |  |  |  |  |  |
| 0x0280<br>~<br>0x02BC | CHROMA_HCOEF_1 | Chroma horizontal coefficient table 1 |  |  |  |  |  |  |
| 0x02F0<br>~<br>0x03FC | VCOEFF_1       | Vertical coefficient table 1          |  |  |  |  |  |  |
| 0x0400<br>~<br>0x047C | LUMA_HCOEF_2   | Luma horizontal coefficient table 2   |  |  |  |  |  |  |
| 0x0480<br>~<br>0x04BC | CHROMA_HCOEF_2 | Chroma horizontal coefficient table 2 |  |  |  |  |  |  |
| 0x04F0<br>~<br>0x05FC | VCOEFF_2       | Vertical coefficient table 2          |  |  |  |  |  |  |
| 0x2000<br>~<br>0x23FF | Dcam_mem0      | Cap buffer of DCAM                    |  |  |  |  |  |  |
| 0x2400<br>~<br>0x25FF | Dcam_mem1      | Data buffer of camera path            |  |  |  |  |  |  |
| 0x2600<br>~<br>0x27FF | Dcam_mem2      | Data buffer of review path            |  |  |  |  |  |  |

### 7.1.5.2 Register Descriptions

### 7.1.5.2.1 DCAM\_CFG Registers

Description: DCAM configuration register



| 0x0000 |    |                       | DCA | M conf | igurat   | ion reç | gister( | Reset | 0x0000 | 0_000 | ))  |     |     | DCAM_ | CFG |     |
|--------|----|-----------------------|-----|--------|----------|---------|---------|-------|--------|-------|-----|-----|-----|-------|-----|-----|
| Bit    | 31 | 30                    | 29  | 28     | 27       | 26      | 25      | 24    | 23     | 22    | 21  | 20  | 19  | 18    | 17  | 16  |
| Name   |    | Reserved              |     |        |          |         |         |       |        |       |     |     |     |       |     |     |
| Туре   |    | 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   |
|        |    |                       |     |        |          |         |         |       |        | CLK   | CLK | CLK | CLK | REV   | CAM | CAM |
| Name   |    |                       |     |        | Reserved | i       |         |       |        | _ST   | _ST | _SW | _SW | _PA   | _PA | _PA |
| 110    |    |                       |     |        |          |         |         |       |        | ATU   | ATU | ITC | ITC | TH_   | TH2 | TH1 |
|        |    |                       |     |        |          |         |         |       |        | S2    | S   | H2  | Н   | EB    | _EB | _EB |
| Туре   | RO |                       |     |        |          |         |         |       |        | RO    | RO  | R/W | R/W | R/W   | R/W | R/W |
| Reset  | 0  | 0 0 0 0 0 0 0         |     |        |          |         |         |       |        |       | 0   | 0   | 0   | 0     | 0   | 0   |

| Field Name   | Bit    | R/W | Reset<br>Value | Description                                                 |
|--------------|--------|-----|----------------|-------------------------------------------------------------|
|              | [31:7] | RO  | 25'h0          | Reserved                                                    |
| CLK_STATUS2  | [6]    | RO  | 1'h0           | Current status of review path                               |
| CLK_STATUS   | [5]    | RO  | 1'h0           | Current status of camera path 1                             |
| CLK_SWITCH2  | [4]    | R/W | 1'h0           | Review path or cam path2 clock switch : 1:HCLK; 0:clk_dcam; |
| CLK_SWITCH   | [3]    | R/W | 1'h0           | Camera path 1 clock domain switch; 1:HCLK;0:clk_dcam;       |
| REV_PATH_EB  | [2]    | R/W | 1'h0           | Review path enable; 1: enable; 0:disable;                   |
| CAM_PATH2_EB | [1]    | R/W | 1'h0           | Camera path 1 enable; 1: enable; 0:disable;                 |
| CAM_PATH1_EB | [0]    | R/W | 1'h0           | Camera path 1 enable;<br>1: enable; 0:disable;              |



### 7.1.5.2.2 CAM\_PATH\_CFG Registers

Description: Camera path configuration register

| 0x0004 |                        |                   | Cam                      | era pa             | th con | figurat           | tion re                  | gister(                  | Reset | 0x000   | 0_000  | ))    |                               | CAM_                     | PATH             | CFG        |
|--------|------------------------|-------------------|--------------------------|--------------------|--------|-------------------|--------------------------|--------------------------|-------|---------|--------|-------|-------------------------------|--------------------------|------------------|------------|
| Bit    | 31                     | 30                | 29                       | 28                 | 27     | 26                | 25                       | 24                       | 23    | 22      | 21     | 20    | 19                            | 18                       | 17               | 16         |
| Name   |                        |                   |                          |                    |        |                   |                          | Rese                     | erved |         |        |       |                               |                          |                  |            |
| Туре   |                        | 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   | CAM 1_U V42 0_A VG_ EN | AUT O_C OPY _CA P | FRC<br>_CO<br>PY_<br>CAP | CAM 1_DI THE R_E N |        | _ODA<br>ORMA<br>T | CAM<br>2_D<br>ECI_<br>EB | CAM<br>1_T<br>RIM<br>_EB | CAM   | M_SC_VI | ER_TAP | [3:0] | CAP<br>_SC<br>_BY<br>PAS<br>S | CAM<br>1_D<br>ECI_<br>EB | CAP<br>_MO<br>DE | CAP<br>_EB |
| Туре   | R/W                    | wo                | wo                       | 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      | 0     | 0                             | 0                        | 0                | 0          |

| Field Name        | Bit     | R/W | Reset<br>Value | Description                                                                            |
|-------------------|---------|-----|----------------|----------------------------------------------------------------------------------------|
|                   | [31:16] | RO  | 20'h0          | Reserved                                                                               |
| CAM1_UV420_AVG_EN | [15]    | R/W | 1'b0           | Enable UV average when vertical down sample to YUV420 . only can be set in YUV420 mode |
| AUTO_COPY_CAP     | [14]    | WO  | 1'h0           |                                                                                        |
| FRC_COPY_CAP      | [13]    | WO  | 1'h0           |                                                                                        |
| CAM1_DITHER_EN    | [12]    | R/W | 1'b0           | 1: enable path1 dithering                                                              |
| CAM1_ODATA_FORMAT | [11:10] | R/W | 2'b0           | Output data format of cam path 1: 00:YUV422 01:YUV420; 10:YUV2RGB 11:reserved          |



| CAM2_DECI_EB   | [9]   | R/W | 1'h0 | 1:enable path2 1/2 subsample                        |
|----------------|-------|-----|------|-----------------------------------------------------|
| CAM1_TRIM_EB   | [8]   | R/W | 1'h0 | 1:enable path1 trimming                             |
| CAM_SC_VER_TAP | [7:4] | R/W | 4'h0 | Vertical tap of scaling                             |
| CAM_SC_BYPASS  | [3]   | R/W | 1'h0 | 1:bypass camera path scaling                        |
| CAM1_DECI_EB   | [2]   | R/W | 1'h0 | 1:enable path1 1/2 subsample                        |
| CAP_MODE       | [1]   | R/W | 1'h0 | 1:capture multi frame; 0: only capture single frame |
| CAP_EB         | [0]   | R/W | 1'h0 | CAP module enable; 1: enable; 0:disable;            |

### 7.1.5.2.3 CAM\_SRC\_SIZE Registers

Description: Camera source image size register.

| 0x0008 |    |      | Cam   | era so | urce si        | ze (Re                | set:0x | 0000_ | 0000) |       |         |    |    | CAM | _SRC_ | SIZE |  |
|--------|----|------|-------|--------|----------------|-----------------------|--------|-------|-------|-------|---------|----|----|-----|-------|------|--|
| Bit    | 31 | 30   | 29    | 28     | 27             | 26                    | 25     | 24    | 23    | 22    | 21      | 20 | 19 | 18  | 17    | 16   |  |
| Name   |    | Rese | erved |        | CAM_SRC_SIZE_Y |                       |        |       |       |       |         |    |    |     |       |      |  |
| Туре   |    | R    | .0    |        |                | W/R                   |        |       |       |       |         |    |    |     |       |      |  |
| 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   |    | Rese | erved |        |                |                       |        |       | С     | AM_SR | C_SIZE_ | Х  |    |     |       |      |  |
| Туре   |    | R    | .0    |        | W/R            |                       |        |       |       |       |         |    |    |     |       |      |  |
| Reset  | 0  | 0    | 0     | 0      | 0              | 0                     | 0      | 0     | 0     | 0     | 0       | 0  | 0  | 0   | 0     | 0    |  |

| Field Name     | Bit     | R/W | Reset<br>Value | Description             |
|----------------|---------|-----|----------------|-------------------------|
|                | [31:28] | RO  | 4'h0           | Reserved                |
| CAM_SRC_SIZE_Y | [27:16] | R/W | 12'h0          | Height of camera source |
|                | [15:12] | RO  | 4'h0           | Reserved                |



### 7.1.5.2.4 CAM\_DES\_SIZE Registers

Description: Camera destination image size register.

| 0x000C |    |      | Came  | era de | stinatio              | on size | (Rese | et:0x00 | 00_00 | 000)   |        |     | CAM_DES_SIZE |    |    |     |  |  |  |  |  |
|--------|----|------|-------|--------|-----------------------|---------|-------|---------|-------|--------|--------|-----|--------------|----|----|-----|--|--|--|--|--|
| Bit    | 31 | 30   | 29    | 28     | 27                    | 26      | 25    | 24      | 23    | 22     | 21     | 20  | 19           | 18 | 17 | 16  |  |  |  |  |  |
| Name   |    | Rese | erved |        | CAM_DES_SIZE_Y        |         |       |         |       |        |        |     |              |    |    |     |  |  |  |  |  |
| Туре   |    | R    | .0    |        | W/R                   |         |       |         |       |        |        |     |              |    |    |     |  |  |  |  |  |
| 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   |    | Rese | erved |        |                       |         |       |         | CAI   | M_DESS | RC_SIZ | E_X |              |    |    |     |  |  |  |  |  |
| Туре   |    | R    | .0    |        | W/R                   |         |       |         |       |        |        |     |              |    |    | W/R |  |  |  |  |  |
| Reset  | 0  | 0    | 0     | 0      | 0                     | 0       | 0     | 0       | 0     | 0      | 0      | 0   | 0            | 0  | 0  | 0   |  |  |  |  |  |

| Field Name     | Bit     | R/W | Reset<br>Value | Description                  |
|----------------|---------|-----|----------------|------------------------------|
|                | [31:28] | RO  | 4'h0           | Reserved                     |
| CAM_DES_SIZE_Y | [27:16] | R/W | 11'h0          | Height of camera destination |
|                | [15:12] | RO  | 4'h0           | Reserved                     |
| CAM_DES_SIZE_X | [11:0]  | R/W | 11'h0          | Width of camera destination  |

### 7.1.5.2.5 CAM\_TRIM\_START Registers

Description: Camera trimming start position register



| 0x0010 |    |      | Cam   | era trir | n start          | n start (Reset:0x0FFF_0FFF) |    |    |    |        |         |    |          | CAM_TRIM_START |    |    |  |  |
|--------|----|------|-------|----------|------------------|-----------------------------|----|----|----|--------|---------|----|----------|----------------|----|----|--|--|
| Bit    | 31 | 30   | 29    | 28       | 27               | 26                          | 25 | 24 | 23 | 22     | 21      | 20 | 19       | 18             | 17 | 16 |  |  |
| Name   |    | Rese | erved |          | CAM_TRIM_START_Y |                             |    |    |    |        |         |    |          |                |    |    |  |  |
| Туре   |    | R    | 0     |          | W/R              |                             |    |    |    |        |         |    | <b>\</b> |                |    |    |  |  |
| Reset  | 0  | 0    | 0     | 0        | 1                | 1                           | 1  | 1  | 1  | 1      | 1       | 1  | 1        | 1              | 1  | 1  |  |  |
| Bit    | 15 | 14   | 13    | 12       | 11               | 10                          | 9  | 8  | 7  | 6      | 5       | 4  | 3        | 2              | 1  | 0  |  |  |
| Name   |    | Rese | erved |          |                  |                             |    |    | CA | M_TRIM | I_START | _X |          |                |    |    |  |  |
| Туре   |    | R    | 0     |          | W/R              |                             |    |    |    |        |         |    |          |                |    |    |  |  |
| Reset  | 0  | 0    | 0     | 0        | 1                | 1                           | 1  | 1  | 1  | 1      | 1       | 1  | 1        | 1              | 1  | 1  |  |  |

| Field Name       | Bit     | R/W | Reset<br>Value | Description                                         |
|------------------|---------|-----|----------------|-----------------------------------------------------|
|                  | [31:28] | RO  | 4'h0           | Reserved                                            |
| CAM_TRIM_START_Y | [27:16] | R/W | 12'hFFF        | Vertical start position of camera path 1 trimming   |
|                  | [15:12] | RO  | 4'h0           | Reserved                                            |
| CAM_TRIM_START_X | [11:0]  | R/W | 12'hFFF        | Horizontal start position of camera path 1 trimming |

### 7.1.5.2.6 CAM\_TRIM\_SIZE Registers

Description: Camera trimming size register



| 0x0014 |    |      | Cam   | era trir | n start         | n start (Reset:0x0000_0000) CAM_TRIM_SIZ |    |    |    |    |          |    |    | SIZE |    |    |
|--------|----|------|-------|----------|-----------------|------------------------------------------|----|----|----|----|----------|----|----|------|----|----|
| Bit    | 31 | 30   | 29    | 28       | 27              | 26                                       | 25 | 24 | 23 | 22 | 21       | 20 | 19 | 18   | 17 | 16 |
| Name   |    | Rese | erved |          |                 | CAM_TRIM_SIZE_Y                          |    |    |    |    |          |    |    |      |    |    |
| Туре   |    | R    | 0     |          | W/R             |                                          |    |    |    |    | <b>\</b> |    |    |      |    |    |
| 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   |    | Rese | erved |          | CAM_TRIM_SIZE_X |                                          |    |    |    |    |          |    |    |      |    |    |
| Туре   | RO |      |       | W/R      |                 |                                          |    |    |    |    |          |    |    |      |    |    |
| Reset  | 0  | 0    | 0     | 0        | 0               | 0                                        | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0    | 0  | 0  |

| Field Name      | Bit     | R/W | Reset<br>Value | Description                      |
|-----------------|---------|-----|----------------|----------------------------------|
|                 | [31:28] | RO  | 4'h0           | Reserved                         |
| CAM_TRIM_SIZE_Y | [27:16] | R/W | 12'h0          | Height of camera path 1 trimming |
|                 | [15:12] | RO  | 4'h0           | Reserved                         |
| CAM_TRIM_SIZE_X | [11:0]  | R/W | 12'h0          | Width of camera path 1 trimming  |

# 7.1.5.2.7 REV\_PATH\_CFG Registers

Description: Review path configuration register



| 0x0018 |       |    | Review path configuration (Reset 0x0000_0000) |               |     |              |      |                          |    |             |                        | REV_PATH_CFG             |                                |                                  |                         |                          |
|--------|-------|----|-----------------------------------------------|---------------|-----|--------------|------|--------------------------|----|-------------|------------------------|--------------------------|--------------------------------|----------------------------------|-------------------------|--------------------------|
| Bit    | 31    | 30 | 29                                            | 28            | 27  | 26           | 25   | 24                       | 23 | 22          | 21                     | 20                       | 19                             | 18                               | 17                      | 16                       |
| Name   |       | F  | Reserved                                      | I             |     | ROT_l        | MODE | ROT<br>_EB               |    | ı           | Reserve                | d                        |                                | REV<br>_UV<br>420_<br>AVG<br>_EN |                         | ≣R_TA                    |
| Туре   |       |    | RO                                            |               |     | R/           | W    | R/W                      |    |             | RO                     |                          |                                | R/W                              | R                       | W                        |
| 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   | SC_VE |    | RGB<br>_INP<br>UT_<br>FOR<br>MAT              | YUV_I<br>_FOR |     | SUB_S<br>E_M |      | DIT<br>HER<br>ING<br>_EN |    | PUT_M<br>DE | INP<br>UT_<br>MO<br>DE | SCA<br>LIN<br>G_M<br>ODE | SCA<br>LIN<br>G_B<br>YPA<br>SS | SUB<br>_SA<br>MPL<br>E_E<br>B    | REV<br>_TRI<br>M_E<br>B | REV<br>IEW<br>_ST<br>ART |
| Туре   | R/    | W  | R/W                                           | R/W           | R/W | R/           | w    | R/W                      | R/ | w           | R/W                    | R/W                      | R/W                            | R/W                              | R/W                     | wo                       |
| Reset  | 0     | 0  | 0                                             | 0             | 0   | 0            | 0    | 0                        | 0  | 0           | 0                      | 0                        | 0                              | 0                                | 0                       | 0                        |

| Field Name       | Bit     | R/W | Reset<br>Value | Description                                                                                               |
|------------------|---------|-----|----------------|-----------------------------------------------------------------------------------------------------------|
|                  | [31:27] | RO  | 14'h0          | Reserved                                                                                                  |
| ROT_MODE         | [26:25] | R/W | 2'b0           | Rotation direction: 00: 90 01: 270 10: 180 11: horizon mirror                                             |
| ROT_EB           | [24]    | R/W | 1'b0           | 1:enable rotation                                                                                         |
|                  | [23:19] | RO  |                | Reserved                                                                                                  |
| REV_UV420_AVG_EN | [18]    | R/W | 1'b0           | Enable UV average when vertical down sample to YUV420 . Can be set, when output YUV420 or rotation 90/270 |
| SC_VER_TAP       | [17:14] | R/W | 4'h0           | Vertical tap of review                                                                                    |



|                  |         |     |      | scaling                                          |
|------------------|---------|-----|------|--------------------------------------------------|
| RGB_INPUT_FORMAT | [13]    | RO  | 1'h0 | 1: RGB565; 0:RGB888                              |
| YUV_INPUT_FORMAT | [12:11] | R/W | 2'h0 | 00:YUV422                                        |
|                  |         |     |      | 01:YUV420 ( Y, UV 2 frame)                       |
|                  |         |     |      | 10:YUV400                                        |
|                  |         |     |      | 11:YUV420 (Y, U, V 3                             |
|                  |         |     |      | frame)                                           |
| SUB_SAMPLE_MODE  | [10:9]  | R/W | 2'h0 | 00:1/2;01:1/4;10:1/8;11:1/16                     |
| DITHERING_EN     | [8]     | R/W | 1'h0 | 1:ebable dithering                               |
| OUTPUT_MODE      | [7:6]   | R/W | 2'h0 | 00:YUV422                                        |
|                  |         |     |      | 01:YUV420                                        |
|                  |         |     |      | 10:RGB565                                        |
|                  |         |     |      | 11:reserved                                      |
| INPUT_MODE       | [5]     | R/W | 1'h0 | 1:RGB 0:YUV;                                     |
| SCALING_MODE     | [4]     | R/W | 1'h0 | 1:slice mode; 0:normal                           |
|                  |         |     |      | mode;                                            |
| SCALING_BYPASS   | [3]     | R/W | 1'h0 | 1: bypass scaling;                               |
| SUB_SAMPLE_EB    | [2]     | R/W | 1'h0 | 1: enable sub sample                             |
| REV_TRIM_EB      | [1]     | R/W | 1'h0 | Trimming enable of review path or camera path 2; |
| REVIEW_START     | [0]     | wo  | 1'h0 | 1: start review;                                 |

### 7.1.5.2.8 REV\_SRC\_SIZE Registers

Description: Review source image size register of review path. In capture path2 mode, it indicate

the input size of path2 scaling.



| 0x001C |    |      | Revie | ew sou | ırce si | ze (Re         | set:0x | 0000_0 | 0000) |         |         |    | REV_SRC_SIZE |    |      |    |
|--------|----|------|-------|--------|---------|----------------|--------|--------|-------|---------|---------|----|--------------|----|------|----|
| Bit    | 31 | 30   | 29    | 28     | 27      | 26             | 25     | 24     | 23    | 22      | 21      | 20 | 19           | 18 | 17   | 16 |
| Name   |    | Rese | erved |        |         | REV_SRC_SIZE_Y |        |        |       |         |         |    |              |    |      |    |
| Туре   |    | R    | 0     |        |         | W/R            |        |        |       |         |         |    | •            |    |      |    |
| 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   |    | Rese | erved |        |         |                |        |        | F     | REV_SRO | C_SIZE_ | X  |              |    | abla |    |
| Туре   |    | R    | 0     |        | W/R     |                |        |        |       |         |         |    |              |    |      |    |
| Reset  | 0  | 0    | 0     | 0      |         |                |        |        |       |         |         | 0  |              |    |      |    |

| Field Name     | Bit     | R/W | Reset<br>Value | Description                                                            |
|----------------|---------|-----|----------------|------------------------------------------------------------------------|
|                | [31:28] | RO  | 4'h0           | Reserved                                                               |
| REV_SRC_SIZE_Y | [27:16] | R/W | 12'h0          | Source height of review path; Or scaling input height of camera path 2 |
|                | [15:12] | RO  | 4'h0           | Reserved                                                               |
| REV_SRC_SIZE_X | [11:0]  | R/W | 12'h0          | Source width of review path; or scaling input width of camera path 2   |

# 7.1.5.2.9 REV\_DES\_SIZE Registers

Description: Review destination image size register. In capture path2 mode, it indicate the output

size of path2 scaling.



| 0x0020 |    |      | Revie | ew des | stinatio              | n size         | (Rese | t:0x00 | 00_00 | 00)     |         |    | REV_DES_SIZE |          |      |    |  |
|--------|----|------|-------|--------|-----------------------|----------------|-------|--------|-------|---------|---------|----|--------------|----------|------|----|--|
| Bit    | 31 | 30   | 29    | 28     | 27                    | 26             | 25    | 24     | 23    | 22      | 21      | 20 | 19           | 18       | 17   | 16 |  |
| Name   |    | Rese | erved |        |                       | REV_DES_SIZE_Y |       |        |       |         |         |    |              |          |      |    |  |
| Туре   |    | R    | 0     |        |                       |                |       |        |       | W       | /R      |    |              | <b>*</b> |      |    |  |
| 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   |    | Rese | erved |        |                       |                |       |        | F     | REV_DES | S_SIZE_ | X  |              |          | abla |    |  |
| Туре   |    | R    | 0     |        | W/R                   |                |       |        |       |         |         |    |              |          |      |    |  |
| Reset  | 0  | 0    | 0     | 0      | 0 0 0 0 0 0 0 0 0 0 0 |                |       |        |       |         |         | 0  |              |          |      |    |  |

| Field Name     | Bit     | R/W | Reset<br>Value | Description                                   |
|----------------|---------|-----|----------------|-----------------------------------------------|
|                | [31:28] | RO  | 4'h0           | Reserved                                      |
| REV_DES_SIZE_Y | [27:16] | R/W | 12'h0          | Source height of review path or camera path 2 |
|                | [15:12] | RO  | 4'h0           | Reserved                                      |
| REV_DES_SIZE_X | [11:0]  | R/W | 12'h0          | Source width of review path or camera path 2  |

# 7.1.5.2.10 REV\_TRIM\_START Registers

Description: Review trimming start position register



| 0x0024 |    |      | Revie | ew trin | n start                 | (Rese            | t:0x0F | FF_0F | FF) |        |        |    | R  | EV_TF | RIM_S | TART |
|--------|----|------|-------|---------|-------------------------|------------------|--------|-------|-----|--------|--------|----|----|-------|-------|------|
| Bit    | 31 | 30   | 29    | 28      | 27                      | 26               | 25     | 24    | 23  | 22     | 21     | 20 | 19 | 18    | 17    | 16   |
| Name   |    | Rese | erved |         |                         | REV_TRIM_START_Y |        |       |     |        |        |    |    |       |       |      |
| Туре   |    | R    | 0     |         |                         | W/R 🔷            |        |       |     |        |        |    | •  |       |       |      |
| Reset  | 0  | 0    | 0     | 0       | 1                       | 1                | 1      | 1     | 1   | 1      | 1      | 1  | 1  | 1     | 1     | 1    |
| Bit    | 15 | 14   | 13    | 12      | 11                      | 10               | 9      | 8     | 7   | 6      | 5      | 4  | 3  | 2     | 1     | 0    |
| Name   |    | Rese | erved |         |                         |                  |        |       | RE  | V_TRIM | _START | _X |    |       |       |      |
| Туре   |    | R    | 0     |         | W/R                     |                  |        |       |     |        |        |    |    |       |       |      |
| Reset  | 0  | 0    | 0     | 0       | 1 1 1 1 1 1 1 1 1 1 1 1 |                  |        |       |     |        |        | 1  |    |       |       |      |

| Field Name       | Bit     | R/W | Reset<br>Value | Description                                                        |
|------------------|---------|-----|----------------|--------------------------------------------------------------------|
|                  | [31:28] | RO  | 4'h0           | Reserved                                                           |
| REV_TRIM_START_Y | [27:16] | R/W | 12'hFFF        | Vertical trimming start position of review path or camera path 2   |
|                  | [15:12] | RO  | 4'h0           | Reserved                                                           |
| REV_TRIM_START_X | [11:0]  | R/W | 12'hFFF        | Horizontal trimming start position of review path or camera path 2 |

# 7.1.5.2.11 REV\_TRIM\_SIZE Registers

Description: Review trimming size register



| 0x0028 |    |      | Revie | ew trin | n start               | (Rese           | t:0x00 | 00_000 | 00) |        |         |    |    | REV_TRIM_SIZE |      |    |  |
|--------|----|------|-------|---------|-----------------------|-----------------|--------|--------|-----|--------|---------|----|----|---------------|------|----|--|
| Bit    | 31 | 30   | 29    | 28      | 27                    | 26              | 25     | 24     | 23  | 22     | 21      | 20 | 19 | 18            | 17   | 16 |  |
| Name   |    | Rese | erved |         |                       | REV_TRIM_SIZE_Y |        |        |     |        |         |    |    |               |      |    |  |
| Туре   |    | R    | 0     |         |                       | W/R             |        |        |     |        |         |    | •  |               |      |    |  |
| 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   |    | Rese | erved |         |                       |                 |        |        | R   | EV_TRI | M_SIZE_ | _X |    |               | abla |    |  |
| Туре   |    | R    | 0     |         | W/R                   |                 |        |        |     |        |         |    |    |               |      |    |  |
| Reset  | 0  | 0    | 0     | 0       | 0 0 0 0 0 0 0 0 0 0 0 |                 |        |        |     |        |         | 0  |    |               |      |    |  |

| Field Name      | Bit     | R/W | Reset<br>Value | Description                                     |
|-----------------|---------|-----|----------------|-------------------------------------------------|
|                 | [31:28] | RO  | 4'h0           | Reserved                                        |
| REV_TRIM_SIZE_Y | [27:16] | R/W | 12'h0          | Trimming height of review path or camera path 2 |
|                 | [15:12] | RO  | 4'h0           | Reserved                                        |
| REV_TRIM_SIZE_X | [11:0]  | R/W | 12'h0          | Trimming width of review path or camera path 1  |

# 7.1.5.2.12 SLICE\_VER\_CNT Registers

Description: Slice vertical count register.



| 0x002C |    |          | Slice | vertic            | al cou                | nt (Re | set:0x | 0000_0 | 0000) |         |        |    |    | SLICE | _VER | CNT      |
|--------|----|----------|-------|-------------------|-----------------------|--------|--------|--------|-------|---------|--------|----|----|-------|------|----------|
| Bit    | 31 | 30       | 29    | 28                | 27                    | 26     | 25     | 24     | 23    | 22      | 21     | 20 | 19 | 18    | 17   | 16       |
| Name   |    | Rese     | erved |                   |                       |        |        |        |       | SLICE_0 | D_VCNT |    |    |       |      |          |
| Туре   |    | R        | 0     |                   |                       |        |        |        |       | R       | 0      |    |    |       |      | <b>\</b> |
| 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   |    | Reserved | d     | LAS<br>T_B<br>LK_ |                       |        |        |        |       | SLICE_  | I_VCNT |    |    | 2     |      |          |
|        |    |          |       | EN                |                       |        |        |        |       |         |        |    |    |       |      |          |
| Туре   |    | RO       |       | R/W               | N R/W                 |        |        |        |       |         |        |    |    |       |      |          |
| Reset  | 0  | 0        | 0     | 0                 | 0 0 0 0 0 0 0 0 0 0 0 |        |        |        |       |         |        |    |    |       |      |          |

| Field Name   | Bit     | R/W | Reset<br>Value | Description                                                                    |
|--------------|---------|-----|----------------|--------------------------------------------------------------------------------|
|              | [31:28] | RO  | 4'h0           | Reserved                                                                       |
| SLICE_O_VCNT | [27:16] | RO  | 12'h0          | Current vertical line number of output when current slice mode scaling is done |
|              | [15:13] | RO  | 3'h0           | Reserved                                                                       |
| LAST_BLK_EN  | [12]    | R/W | 1'h0           | 1: indicate current slice is last one                                          |
| SLICE_I_VCNT | [11:0]  | R/W | 12'h0          | Line number of current slice                                                   |

# 7.1.5.2.13 DCAM\_INT\_STS Registers

Description: DCAM interrupt status register.



| 0x0030 |    |                            | DCA      | M inte | rrupt s | tatus ( | Reset | 0x000 | 0_000 | 0)   |     |     |     | DCA | M_INT | _STS |
|--------|----|----------------------------|----------|--------|---------|---------|-------|-------|-------|------|-----|-----|-----|-----|-------|------|
| Bit    | 31 | 30                         | 29       | 28     | 27      | 26      | 25    | 24    | 23    | 22   | 21  | 20  | 19  | 18  | 17    | 16   |
| Name   |    |                            | Reserved |        |         |         |       |       |       |      |     |     |     |     |       |      |
| Туре   |    |                            | 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    |
|        |    |                            |          |        |         |         | REV   | JPG   | CAM   | CAM  | CAP | CAM | CAP | CAP | SEN   | SEN  |
| Name   |    |                            | Rese     | anvod  |         |         | _TX   | _BU   | _FR   | _LIN | _BU | _TX | _EO | _SO | SOR   | SOR  |
| Name   |    |                            | Nesc     | ei veu |         |         | _DO   | F_O   | M_E   | E_E  | F_O | _DO | _LO | F   | _EO   | _so  |
|        |    | NE VF RR RR VF NE F F      |          |        |         |         |       |       |       |      |     |     |     |     |       |      |
| Туре   |    | RO RO RO RO RO RO RO RO RO |          |        |         |         |       |       |       |      |     |     |     |     |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0  |          |        |         |         |       |       |       |      |     |     |     |     |       |      |

| Field Name   | Bit     | R/W | Reset<br>Value | Description                                                     |
|--------------|---------|-----|----------------|-----------------------------------------------------------------|
|              | [31:10] | RO  | 22h0           | Reserved                                                        |
| REV_TX_DONE  | [9]     | RO  | 1'h0           | Transfer done of review path or camera path 2                   |
| JPG_BUF_OVF  | [8]     | RO  | 1'h0           | JPEG data size exceeded the allocated buffer on SDRAM.          |
| CAM_FRM_ERR  | [7]     | RO  | 1'h0           | Error is found in current frame                                 |
| CAM_LINE_ERR | [6]     | RO  | 1'h0           | Line error is found in current frame.                           |
| CAP_BUF_OVF  | [5]     | RO  | 1'h0           | Camera Buffer overflow                                          |
| CAP_TX_DONE  | [4]     | RO  | 1'h0           | Data transfer done of camera path1                              |
| CAP_EOF      | [3]     | RO  | 1'h0           | Camera Interface's end of frame indication to the next module   |
| CAP_SOF      | [2]     | RO  | 1'h0           | Camera Interface's start of frame indication to the next module |



| SENSOR_EOF | [1] | RO | 1'h0 | Sensor's end of frame indication to Camera Interface module   |
|------------|-----|----|------|---------------------------------------------------------------|
| SENSOR_SOF | [0] | RO | 1'h0 | Sensor's start of frame indication to Camera Interface module |

### 7.1.5.2.14 DCAM\_INT\_MASK Registers

Description: DCAM interrupt mask register.

| 0x0034 |    |    | DCA  | M inte                  | rrupt n | nask (F | Reset ( | 0x0000 | _0000 | )  |        |         | ı  | DCAM_ | _INT_N | IASK |
|--------|----|----|------|-------------------------|---------|---------|---------|--------|-------|----|--------|---------|----|-------|--------|------|
| Bit    | 31 | 30 | 29   | 28                      | 27      | 26      | 25      | 24     | 23    | 22 | 21     | 20      | 19 | 18    | 17     | 16   |
| Name   |    |    |      |                         |         |         |         | Rese   | erved |    |        |         |    |       |        |      |
| Туре   |    |    |      | RO                      |         |         |         |        |       |    |        |         |    |       |        |      |
| 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   |    |    | Rese | erved                   |         |         |         |        |       | Г  | CAM_IN | IT_MASI | K  |       |        |      |
| Туре   |    |    | R    | RO R/W                  |         |         |         |        |       |    |        | W       |    |       |        |      |
| Reset  | 0  | 0  | 0    | 0                       | 0       | 0       | 0       | 0      | 0     | 0  | 0      | 0       | 0  | 0     | 0      | 0    |

| Field Name    | Bit     | R/W | Reset<br>Value | Description                                                                                                     |
|---------------|---------|-----|----------------|-----------------------------------------------------------------------------------------------------------------|
|               | [31:10] | RO  | 22h0           | Reserved                                                                                                        |
| DCAM_INT_MASK | [9:0]   | R/W | 10'h0          | Bit[i] = 1: DCAM interrupt is<br>enabled for source i<br>Bit[i] = 0: DCAM interrupt is<br>disabled for source i |

# 7.1.5.2.15 DCAM\_INT\_CLR Registers

Description: DCAM interrupt clear register.



| 0x0038 |    |    | DCA  | M inte            | rupt c | lear (R | leset 0 | x0000 | _0000) | )  |        |        |    | DCA | M_INT | _CLR |
|--------|----|----|------|-------------------|--------|---------|---------|-------|--------|----|--------|--------|----|-----|-------|------|
| Bit    | 31 | 30 | 29   | 28                | 27     | 26      | 25      | 24    | 23     | 22 | 21     | 20     | 19 | 18  | 17    | 16   |
| Name   |    |    |      |                   |        |         |         | Rese  | erved  |    |        |        |    |     |       |      |
| Туре   |    |    |      | RO                |        |         |         |       |        |    |        |        |    |     |       |      |
| 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   |    |    | Rese | erved             |        |         |         |       |        |    | DCAM_I | NT_CLR |    |     |       |      |
| Туре   |    |    | R    | 0                 |        |         |         | R/W   |        |    |        |        |    |     |       |      |
| Reset  | 0  | 0  | 0    | 0                 | 0      | 0       | 0       | 0     | 0      | 0  | 0      | 0      | 0  | 0   | 0     | 0    |

| Field Name   | Bit     | R/W | Reset<br>Value | Description                                                  |
|--------------|---------|-----|----------------|--------------------------------------------------------------|
|              | [31:10] | RO  | 22h0           | Reserved                                                     |
| DCAM_INT_CLR | [9:0]   | R/W | 10'h0          | Write 1 into Bit[i] to clear bit[i] of ISP_INT_RAW register. |

# 7.1.5.2.16 DCAM\_INT\_RAW Registers

Description: DCAM interrupt raw register.

| 0x003C |    |          | DCA  | M inte                    | rrupt ra | aw (Re | set 0x | 0000_0 | 0000) |    |         |        |    | DCAN | I_INT_ | RAW |
|--------|----|----------|------|---------------------------|----------|--------|--------|--------|-------|----|---------|--------|----|------|--------|-----|
| Bit    | 31 | 30       | 29   | 28                        | 27       | 26     | 25     | 24     | 23    | 22 | 21      | 20     | 19 | 18   | 17     | 16  |
| Name   |    | Reserved |      |                           |          |        |        |        |       |    |         |        |    |      |        |     |
| Туре   |    |          |      | 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   |    |          | Rese | erved                     |          |        |        |        |       | ı  | DCAM_II | NT_RAW | 1  |      |        |     |
| Туре   |    |          | R    | 0                         |          |        |        | R/W    |       |    |         |        |    |      |        |     |
| Reset  | 0  | 0        | 0    | 0                         | 0        | 0      | 0      | 0      | 0     | 0  | 0       | 0      | 0  | 0    | 0      | 0   |

| Field Name | Bit | R/W | Reset | Description |
|------------|-----|-----|-------|-------------|
|            |     |     |       | _           |



|              |         |     | Value |                                |
|--------------|---------|-----|-------|--------------------------------|
|              | [31:10] | RO  | 22h0  | Reserved                       |
| DCAM_INT_RAW | [9:0]   | R/W | 10'h0 | DCAM interrupt source raw bits |

# 7.1.5.2.17 FRM\_ADDR\_0 Registers

Description: Frame address 0 register.

| 0x0040 |    |    | Fram                    | e addı                                 | ress 0 | (Reset | 0x000 | 00_000 | 0)    |   |   |   |   | FR | M_AD | DR_0 |
|--------|----|----|-------------------------|----------------------------------------|--------|--------|-------|--------|-------|---|---|---|---|----|------|------|
| Bit    | 31 | 30 | 29                      | 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |        |       |        |       |   |   |   |   |    | 16   |      |
| Name   |    |    |                         | FRM_ADDR_0                             |        |        |       |        |       |   |   |   |   |    |      |      |
| Туре   |    |    |                         |                                        |        |        |       | R      | W     |   |   |   |   |    |      |      |
| 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   |    |    |                         |                                        |        |        |       | FRM_A  | DDR_0 |   |   |   |   |    |      |      |
| Туре   |    |    |                         | R/W                                    |        |        |       |        |       |   |   |   |   |    |      |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 |                                        |        |        |       |        |       |   |   |   |   |    |      |      |

| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
| FRM_ADDR_0 | [31:0] | R/W | 32'h0       | BYTE        |

# 7.1.5.2.18 FRM\_ADDR\_1 Registers

Description: Frame address 1 register.



| 0x0044 |    |    | Fram | e addı                | ress 1 | (Reset | 0x000 | 00_00 | 0)     |    |    |    |    | FR | M_AD | DR_1 |
|--------|----|----|------|-----------------------|--------|--------|-------|-------|--------|----|----|----|----|----|------|------|
| Bit    | 31 | 30 | 29   | 28                    | 27     | 26     | 25    | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    |    |      | FRM_ADDR_1            |        |        |       |       |        |    |    |    |    |    |      |      |
| Туре   |    |    |      | R/W                   |        |        |       |       |        |    |    |    |    |    |      |      |
| 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   |    |    |      |                       |        |        |       | FRM_A | .DDR_1 |    |    |    |    |    |      |      |
| Туре   |    |    |      | R/W                   |        |        |       |       |        |    |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0    | 0 0 0 0 0 0 0 0 0 0 0 |        |        |       |       |        |    |    |    | 0  |    |      |      |

| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
| FRM_ADDR_1 | [31:0] | R/W | 32'h0       | ВУТЕ        |

## 7.1.5.2.19 FRM\_ADDR\_2 Registers

Description: Frame address 2 register.

| 0x0048 |    | Frame address 2 (Reset 0x0000_0000) FRM_ADDR_2 |    |    |    |    |    |       |       |    |    |    |    |    |    |    |
|--------|----|------------------------------------------------|----|----|----|----|----|-------|-------|----|----|----|----|----|----|----|
| Bit    | 31 | 30                                             | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |    |                                                |    |    |    |    |    | FRM_A | DDR_2 |    |    |    |    |    |    |    |
| Туре   |    | R/W                                            |    |    |    |    |    |       |       |    |    |    |    |    |    |    |
| 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   |    | FRM_ADDR_2                                     |    |    |    |    |    |       |       |    |    |    |    |    |    |    |
| Туре   | 7  | R/W                                            |    |    |    |    |    |       |       |    |    |    |    |    |    |    |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0                    |    |    |    |    |    |       |       |    |    |    |    |    |    |    |

| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
| FRM_ADDR_2 | [31:0] | R/W | 32'h0       |             |

## 7.1.5.2.20 FRM\_ADDR\_3 Registers



Description: Frame address 3 register.

| 0x004C |    |    | Fram | e addı                  | ress 3 | (Reset | 0x000 | 000_000 | 0)    |    |    |    |    | FR | M_AD | DR_3     |
|--------|----|----|------|-------------------------|--------|--------|-------|---------|-------|----|----|----|----|----|------|----------|
| Bit    | 31 | 30 | 29   | 28                      | 27     | 26     | 25    | 24      | 23    | 22 | 21 | 20 | 19 | 18 | 17   | 16       |
| Name   |    |    |      |                         |        |        |       | FRM_A   | DDR_3 |    |    |    |    |    |      | <b>•</b> |
| Туре   |    |    |      | R/W                     |        |        |       |         |       |    |    |    |    |    |      |          |
| 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   |    |    |      | FRM_ADDR_3              |        |        |       |         |       |    |    |    |    |    |      |          |
| Туре   |    |    |      | R/W                     |        |        |       |         |       |    |    |    |    |    |      |          |
| Reset  | 0  | 0  | 0    | 0                       | 0      | 0      | 0     | 0       | 0     | 0  | 0  | 0  | 0  | 0  | 0    | 0        |

| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
| FRM_ADDR_3 | [31:0] | R/W | 32'h0       |             |

### 7.1.5.2.21 FRM\_ADDR\_4 Registers

Description: Frame address 4 register.

| 0x0050 |    | Frame address 4 (Reset 0x0000_0000) FRM_ADDR_4 |    |    |    |    |    |       |       |    |    |    |    | DR_4 |    |    |
|--------|----|------------------------------------------------|----|----|----|----|----|-------|-------|----|----|----|----|------|----|----|
| Bit    | 31 | 30                                             | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18   | 17 | 16 |
| Name   |    |                                                |    |    |    |    |    | FRM_A | DDR_4 |    |    |    |    |      |    |    |
| Туре   |    | R/W                                            |    |    |    |    |    |       |       |    |    |    |    |      |    |    |
| Reset  | 0  |                                                |    |    |    |    |    |       |       |    |    |    |    |      |    |    |
| Bit    | 15 | 14                                             | 13 | 12 | 11 | 10 | 9  | 8     | 7     | 6  | 5  | 4  | 3  | 2    | 1  | 0  |
| Name   |    | FRM_ADDR_4                                     |    |    |    |    |    |       |       |    |    |    |    |      |    |    |
| Туре   |    | R/W                                            |    |    |    |    |    |       |       |    |    |    |    |      |    |    |
| Reset  | 0  |                                                |    |    |    |    |    |       |       |    |    |    |    |      |    |    |

| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
| FRM_ADDR_4 | [31:0] | R/W | 32'h0       |             |



### 7.1.5.2.22 FRM\_ADDR\_5 Registers

Description: Frame address 5 register.

| 0x0054 |    |    | Fram | e addı     | ress 5 | (Rese | t 0x000 | 000_000 | 0)    |    |    |    |    | FR | M_AD | DR_5 |
|--------|----|----|------|------------|--------|-------|---------|---------|-------|----|----|----|----|----|------|------|
| Bit    | 31 | 30 | 29   | 28         | 27     | 26    | 25      | 24      | 23    | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    |    |      |            |        |       |         | FRM_A   | DDR_5 |    |    |    |    |    |      |      |
| Туре   |    |    |      | R/W        |        |       |         |         |       |    |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0    |            |        |       |         |         |       |    |    |    |    |    |      |      |
| Bit    | 15 | 14 | 13   | 12         | 11     | 10    | 9       | 8       | 7     | 6  | 5  | 4  | 3  | 2  | 1    | 0    |
| Name   |    |    |      | FRM_ADDR_5 |        |       |         |         |       |    |    |    |    |    |      |      |
| Туре   |    |    |      | R/W        |        |       |         |         |       |    |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0    | 0          | 0      | 0     | 0       | 0       | 0     | 0  | 0  | 0  | 0  | 0  | 0    | 0    |

| Field Name | Bit    | R/W | Reset Value Description |
|------------|--------|-----|-------------------------|
| FRM_ADDR_5 | [31:0] | R/W | 32'h0                   |

# 7.1.5.2.23 FRM\_ADDR\_6 Registers

Description: Frame address 6 register.

| 0x0058 |    |    | Fram                        | e addı     | ress 6 | (Reset | 0x000 | 00_000 | 0)    |    |    |    |    | FR | M_AD | DR_6 |
|--------|----|----|-----------------------------|------------|--------|--------|-------|--------|-------|----|----|----|----|----|------|------|
| Bit    | 31 | 30 | 29                          | 28         | 27     | 26     | 25    | 24     | 23    | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    |    |                             |            |        |        |       | FRM_A  | DDR_6 |    |    |    |    |    |      |      |
| Туре   |    |    |                             |            |        |        |       | R/     | W     |    |    |    |    |    |      |      |
| 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   |    |    |                             | FRM_ADDR_6 |        |        |       |        |       |    |    |    |    |    |      |      |
| Туре   |    |    | R/W                         |            |        |        |       |        |       |    |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |            |        |        |       |        |       |    |    |    |    |    |      |      |

| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
| FRM_ADDR_6 | [31:0] | R/W | 32'h0       |             |



### 7.1.5.2.24 BURST\_GAP Registers

Description: Burst gap register.

| 0x0060 |    |                       | Burs | t gap ( | Reset | 0x000 | 0_000 | 0)   |       |    |    |    |    | В  | URST_ | _GAP |
|--------|----|-----------------------|------|---------|-------|-------|-------|------|-------|----|----|----|----|----|-------|------|
| Bit    | 31 | 30                    | 29   | 28      | 27    | 26    | 25    | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
| Name   |    |                       |      |         |       |       |       | Rese | erved |    |    |    |    |    |       |      |
| Туре   |    | 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   |    | ReservedHOBURST_GAPLD |      |         |       |       |       |      |       |    |    |    |    |    |       |      |
| Туре   |    | RO R/W R/W            |      |         |       |       |       |      |       |    |    |    |    |    |       |      |
| Reset  | 0  | 0                     | 0    | 0       | 0     | 0     | 0     | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0     | 0    |

| Field Name | Bit    | R/W | Reset Value | Description                                              |
|------------|--------|-----|-------------|----------------------------------------------------------|
|            | [31:6] | RO  | 26'h0       | Reserved                                                 |
| AHBM_HOLD  | [5]    | R/W | 1'b0        | 1: HOLD DCAM master                                      |
| BURST_GAP  | [4:0]  | R/W | 5'h0        | The interval cycles inserted between two block transfer. |

## 7.1.5.2.25 ENDIAN\_SEL Registers

Description: Endian select register.



| 0x0064 |          |          | Endia | an sel | (Reset | 0x000     | 000_000 | 0) |    |    |    |               | ENDAIN_SEL |       |    |              |
|--------|----------|----------|-------|--------|--------|-----------|---------|----|----|----|----|---------------|------------|-------|----|--------------|
| Bit    | 31       | 30       | 29    | 28     | 27     | 26        | 25      | 24 | 23 | 22 | 21 | 20            | 19         | 18    | 17 | 16           |
| Name   |          | Reserved |       |        |        |           |         |    |    |    |    |               |            |       |    |              |
| Туре   |          | 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   | Reserved |          |       |        | _END   | _ENDIAN_U |         |    |    |    |    | OUT_E<br>AN_Y |            | IN_EN |    | IN_EN<br>N_y |
| Туре   | RO       |          |       |        | R/     | W         | R/      | W  | 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            |

| Field Name         | Bit     | R/W | Reset<br>Value | Description                                                                                                                                    |
|--------------------|---------|-----|----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | [31:12] | RO  | 20'h0          | Reserved                                                                                                                                       |
| DCAM_OUT_ENDIAN_UV | [11:10] | R/W | 2'h0           | UV data endian adjust for camera path 1;                                                                                                       |
| DCAM_OUT_ENDIAN_Y  | [9:8]   | R/W | 2'h0           | Y or JPEG or RGB565<br>data endian adjust for<br>camera path 1;                                                                                |
| REV_OUT_ENDIAN_UV  | [7:6]   | R/W | 2'h0           | UV data endian adjust for rev output path; when write data out: 00: original:{B0,B1,B2,B3} 01:{B3,B2,B1,B0} 10:{B2,B3,B0,B1} 11: {B1,B0,B3,B2} |
| REV_OUT_ENDIAN_Y   | [5:4]   | R/W | 2'h0           | Y or RGB data endian adjust for rev output path; when write data out:  00: original:{B0,B1,B2,B3}  01:{B3,B2,B1,B0}  10:{B2,B3,B0,B1}          |



|                  |       |     |      | 11: {B1,B0,B3,B2}                                                                                                                                  |
|------------------|-------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| REV_IN_ENDIAN_UV | [3:2] | R/W | 2'h0 | UV or U or V data Endian adjust for rev input path; when read data: 00: original:{B0,B1,B2,B3} 01:{B3,B2,B1,B0} 10:{B2,B3,B0,B1} 11: {B1,B0,B3,B2} |
| REV_IN_ENDIAN_Y  | [1:0] | R/W | 2'h0 | Y or RGB data Endian adjust for rev input path; when read data:  00: original:{B0,B1,B2,B3}  01:{B3,B2,B1,B0}  10:{B2,B3,B0,B1}  11: {B1,B0,B3,B2} |

# 7.1.5.2.26 AHBM\_STS Registers

Description: AHB master status registers.

| 0x0068 |    |    | АНВ | maste                 | er statu | s (Res | et 0x0 | 0000_0   | 000)  |    |    |    |    | ,  | АНВМ | _STS |
|--------|----|----|-----|-----------------------|----------|--------|--------|----------|-------|----|----|----|----|----|------|------|
| Bit    | 31 | 30 | 29  | 28                    | 27       | 26     | 25     | 24       | 23    | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| Name   |    |    |     |                       |          |        |        | Rese     | erved |    |    |    |    |    |      |      |
| Туре   |    | RO |     |                       |          |        |        |          |       |    |    |    |    |    |      |      |
| 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    |
|        |    |    |     |                       |          |        |        |          |       |    |    |    |    |    |      | AHB  |
| Name   |    |    |     |                       |          |        | I      | Reserved | ł     |    |    |    |    |    |      | M_B  |
|        |    |    |     |                       |          |        |        |          |       |    |    |    |    |    |      | USY  |
| Туре   |    | RO |     |                       |          |        |        |          |       | RO |    |    |    |    |      |      |
| Reset  | 0  | 0  | 0   | 0                     | 0        | 0      | 0      | 0        | 0     | 0  | 0  | 0  | 0  | 0  | 0    | 0    |

| Field Name | Bit    | R/W | Reset<br>Value | Description |
|------------|--------|-----|----------------|-------------|
|            | [31:1] | RO  | 31'h0          | Reserved    |



## 7.1.5.2.27 FRM\_ADDR\_7 Registers

Description: Frame address 7 register.

| 0x006C | Frame address 7 (Reset 0x0000_0000) |                             |    |    |    |    |    |       |       |    |    |    | FR | M_AD | DR_7 |    |
|--------|-------------------------------------|-----------------------------|----|----|----|----|----|-------|-------|----|----|----|----|------|------|----|
| Bit    | 31                                  | 30                          | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18   | 17   | 16 |
| Name   |                                     | FRM_ADDR_7                  |    |    |    |    |    |       |       |    |    |    |    |      |      |    |
| Туре   |                                     | R/W                         |    |    |    |    |    |       |       |    |    |    |    |      |      |    |
| 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   |                                     |                             |    |    |    |    |    | FRM_A | DDR_7 |    |    |    |    |      |      |    |
| Туре   | R/W                                 |                             |    |    |    |    |    |       |       |    |    |    |    |      |      |    |
| Reset  | 0                                   | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |       |       |    |    |    |    |      |      |    |

| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
| FRM_ADDR_7 | [31:0] | R/W | 32'h0       |             |

# 7.1.5.2.28 FRM\_ADDR\_8 Registers

Description: Frame address 8 register.

| 0x0070 |    |                                                                                                                                        | Fram | e addı | address 8 (Reset 0x0000_0000) FRM_ADDR_8 |    |   |       |       |   |   |   | DR_8 |    |   |   |
|--------|----|----------------------------------------------------------------------------------------------------------------------------------------|------|--------|------------------------------------------|----|---|-------|-------|---|---|---|------|----|---|---|
| Bit    | 31 | 30         29         28         27         26         25         24         23         22         21         20         19         18 |      |        |                                          |    |   |       |       |   |   |   | 17   | 16 |   |   |
| Name   |    | FRM_ADDR_8                                                                                                                             |      |        |                                          |    |   |       |       |   |   |   |      |    |   |   |
| Туре   | 76 | <b>&gt;</b>                                                                                                                            |      |        |                                          |    |   | R     | W     |   |   |   |      |    |   |   |
| 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   |    |                                                                                                                                        |      |        |                                          |    |   | FRM_A | DDR_8 |   |   |   |      |    |   |   |
| Туре   |    | R/W                                                                                                                                    |      |        |                                          |    |   |       |       |   |   |   |      |    |   |   |
| Reset  | 0  | 0                                                                                                                                      | 0    | 0      | 0                                        | 0  | 0 | 0     | 0     | 0 | 0 | 0 | 0    | 0  | 0 | 0 |



| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
| FRM_ADDR_8 | [31:0] | R/W | 32'h0       |             |

## Frame address mapping:

In different work mode, we need

| Addre Reg<br>Name | Capture path                     | Capture path               | Review<br>&YUV input                      | Large size slice mode | Review &YUV<br>(3FRAME) |
|-------------------|----------------------------------|----------------------------|-------------------------------------------|-----------------------|-------------------------|
| Frm_addr0         |                                  | Captured Y0 frame buffer   | Source Y0<br>frame buffer<br>(Source RGB) | Source Y              | Source Y frame buffer   |
| Frm_addr1         |                                  | Captured U0V0 frame buffer | Source U0V0 frame buffer                  | Source U              | Source U frame buffer   |
| Frm_addr2         |                                  |                            |                                           | Temp data Y           | Source V frame buffer   |
| Frm_addr3         |                                  |                            |                                           | Temp data U           |                         |
| Frm_addr4         |                                  |                            | Destination Y or<br>Destination<br>RGB    | Dest Y                | Destination Y addr      |
| Frm_addr5         |                                  |                            | Destination<br>U0V0                       | Dest U                | Destination<br>U0V0     |
| Frm_addr6         |                                  |                            |                                           | Linebufer             |                         |
| Frm_addr7         | Captured Y0 or JPEG frame        |                            |                                           |                       |                         |
| Frm_addr8         | Captured<br>U0V0 frame<br>buffer |                            |                                           |                       |                         |

# 7.1.5.2.29 CAP\_CTRL

Description: CAP control register.



| 0x0100 |    |          | САР   | contro | ol regis                 | ter(re | set 0x( | 0000_0 | 000) |                  |                           |                   |                   |            | CAP_0      | CTRL             |
|--------|----|----------|-------|--------|--------------------------|--------|---------|--------|------|------------------|---------------------------|-------------------|-------------------|------------|------------|------------------|
| Bit    | 31 | 30       | 29    | 28     | 27                       | 26     | 25      | 24     | 23   | 22               | 21                        | 20                | 19                | 18         | 17         | 16               |
| Name   |    | Reserved |       |        |                          |        |         |        |      |                  |                           |                   |                   |            |            |                  |
| Туре   |    | 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   |    |          | CAP_( |        | CAP<br>_CC<br>IR_<br>RST | CAP_I  |         | YUV_   | TYPE | Res<br>erve<br>d | Cap<br>_IF_<br>END<br>IAN | VSY<br>NC_<br>POL | HSY<br>NC_<br>POL | SENS<br>OI | OR_M<br>DE | CCI<br>R_6<br>56 |
| Туре   | R  | 0        | R/    | W      | R/W                      | R/     | W       | R/     | W    | RO               | R/W                       | R/W               | R/W               | R/         | W          | R/W              |
| Reset  | 0  | 0        | Х     | Х      | х                        | 0      | 0       | 0      | 0    | 0                | 0                         | 0                 | 0                 | 0          | 0          | 0                |

| Field Name    | Bit     | R/W | Reset<br>Value | Description                                                                                                         |
|---------------|---------|-----|----------------|---------------------------------------------------------------------------------------------------------------------|
|               | [31:14] | RO  | 18'h0          | Reserved                                                                                                            |
| CAP_CCIR_PD   | [13:12] | R/W | 2'hX           | Power down signal to sensor                                                                                         |
| CAP_CCIR_RST  | [11]    | R/W | 1'hX           | Reset to sensor.                                                                                                    |
| CAP_IF_MODE   | [10:9]  | R/W | 2'h0           | 00:8bit interface mode 01:4bit interface mode 10:2bit interface mode 11:1bit interface mode For CCIR656 or CCIR 601 |
| YUV_TYPE      | [8:7]   | R/W | 2'h0           | YUV sequence of sensor: 0:Y0U0Y1V1 1:Y0V0Y1U0 2:U0Y0V0Y1 3:V0Y0U0Y1                                                 |
|               | [6]     | RO  | 1'h0           | Reserved                                                                                                            |
| CAP_IF_ENDIAN | [5]     | R/W | 1'h0           | 0:big-endian: 1: little endian Only active for 4 bit 2 bit or 1 bit YUV sensor                                      |



| VSYNC_POL    | [4]   | R/W | 1'h0 | Polarity of Vsync 0: active low 1: active high                                                          |
|--------------|-------|-----|------|---------------------------------------------------------------------------------------------------------|
| HSYNC_POL    | [3]   | R/W | 1'h0 | Polarity of Hsync 0: active low 1: active high                                                          |
| SENSOR_MODE  | [2:1] | R/W | 2'h0 | 00:YUV, force copy is suggested. 01:SPI :auto copy 10:JPEG autocopy 11:RAW RGB force copy is suggested. |
| CCIR_656_sel | [0]   | R/W | 1'h0 | 1: ccir656 mode<br>In CCIR656, only force copy<br>can be use.<br>0:ccir601                              |

### 7.1.5.2.30 CAP\_FRM\_CTRL

Description: CAP frame count register.



| 0x0104 |                                 |    | САР | frame | contro    | ol (Res | et 0x0 | 000_0  | 00F)    |     |         |    |          | CAP_     | FRM_ | CTRL |
|--------|---------------------------------|----|-----|-------|-----------|---------|--------|--------|---------|-----|---------|----|----------|----------|------|------|
| Bit    | 31                              | 30 | 29  | 28    | 27        | 26      | 25     | 24     | 23      | 22  | 21      | 20 | 19       | 18       | 17   | 16   |
|        |                                 |    |     |       |           |         |        |        |         | CAP |         |    |          |          |      |      |
| Name   |                                 |    |     |       | Reserved  | 1       |        |        |         | _FR |         |    | CAP_FR   | M CNT    |      |      |
| Name   |                                 |    |     |       | i veserve | 4       |        |        |         | M_C |         |    | CAI _I I | dvi_Civi |      |      |
|        |                                 |    |     |       |           |         |        |        | LR      | X   |         |    |          |          |      |      |
| Туре   |                                 |    |     |       | RO        |         |        |        |         | wo  | 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   | Reserved CAP_F                  |    |     |       |           | RM_D    |        | PRE_Sh | (IP_CNT |     |         |    |          |          |      |      |
| Туре   |                                 | RO |     |       |           |         |        |        |         |     | R/W R/W |    |          | W        |      |      |
| Reset  | 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 |    |     |       |           |         |        |        | 1       |     |         |    |          |          |      |      |

| Field Name   | Bit     | R/W | Reset<br>Value | Description                                                                                                       |
|--------------|---------|-----|----------------|-------------------------------------------------------------------------------------------------------------------|
|              |         |     |                |                                                                                                                   |
|              | [31:23] | RO  | 9'h0           | Reserved                                                                                                          |
| CAP_FRM_CLR  | [22]    | WO  | 1'h0           | If this bit is 1, the frame-counter will be "0" at the next frame start, and then this bit is self-cleared by HW. |
| CAP_FRM_CNT  | [21:16] | RO  | 6'h0           | The counter is for the frames, which CAP issues to the next modules.                                              |
|              | [15:6]  | RO  | 10'h0          | Reserved                                                                                                          |
| CAP_FRM_DECI | [5:4]   | R/W | 2'h0           | 00:no deci<br>01:1/2                                                                                              |
|              |         |     |                | 10:1/3<br>11:1/4                                                                                                  |
| PRE_SKIP_CNT | [3:0]   | R/W | 4'hF           | The frame counter to skip sensor's frames.                                                                        |

Note:



 When switch to capture mode, skip a few frame is suggested after configuring sensor, so set the PRE\_SKIP\_CNT to neglect the frame we not interested.

#### 7.1.5.2.31 CAP\_START

Description: CAP start register.

| 0x0108 |          |      | САР   | start (       | Reset                 | 0x0080 | 0_0080 | )) |    |       |        |     |        | C   | AP_S | ΓART |  |  |  |
|--------|----------|------|-------|---------------|-----------------------|--------|--------|----|----|-------|--------|-----|--------|-----|------|------|--|--|--|
| Bit    | 31       | 30   | 29    | 28            | 27                    | 26     | 25     | 24 | 23 | 22    | 21     | 20  | 19     | 18  | 17   | 16   |  |  |  |
| Name   |          | Rese | erved |               |                       |        |        |    |    | CAP_S | TART_Y |     |        |     |      |      |  |  |  |
| Туре   |          | R    | RO    |               | R/W                   |        |        |    |    |       |        |     |        |     |      |      |  |  |  |
| Reset  | 0        | 0    | 0     | 0             | 0                     | 0      | 0      | 0  | 1  | 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   | Reserved |      |       | Name Reserved |                       |        |        |    |    |       |        | CAI | P_STAR | T_X |      |      |  |  |  |
| Туре   |          | RO   |       |               | RW                    |        |        |    |    |       |        |     |        |     |      |      |  |  |  |
| Reset  | 0        | 0    | 0     | 0             | 0 0 0 0 1 0 0 0 0 0 0 |        |        |    |    |       |        |     |        |     |      |      |  |  |  |

| Field Name  | Bit     | R/W | Reset Value | Description      |
|-------------|---------|-----|-------------|------------------|
|             | [31:28] | RO  | 4'h0        | Reserved         |
| CAP_START_Y | [27:16] | R/W | 12'h80      | Start Y position |
|             | [15:13] | RO  | 3'h0        | Reserved         |
| CAP_START_X | [12:0]  | R/W | 13'h80      | Start X position |

### 7.1.5.2.32 CAP\_END

Description: CAP end register.



| 0x010C |          |      | САР   | end (R | Reset 0             | x00FF | _00FF | )  |    |         |       |    |    |    | CAP | END |
|--------|----------|------|-------|--------|---------------------|-------|-------|----|----|---------|-------|----|----|----|-----|-----|
| Bit    | 31       | 30   | 29    | 28     | 27                  | 26    | 25    | 24 | 23 | 22      | 21    | 20 | 19 | 18 | 17  | 16  |
| Name   |          | Rese | erved |        |                     |       |       |    |    | CAP_E   | END_Y |    |    |    |     |     |
| Туре   | RO       |      |       |        |                     | R/W • |       |    |    |         |       |    | •  |    |     |     |
| Reset  | 0        | 0    | 0     | 0      | 0                   | 0     | 0     | 0  | 1  | 1       | 1     | 1  | 1  | 1  | 1   | 1   |
| Bit    | 15       | 14   | 13    | 12     | 11                  | 10    | 9     | 8  | 7  | 6       | 5     | 4  | 3  | 2  | 1   | 0   |
| Name   | Reserved |      |       |        |                     |       |       |    | CA | AP_END. | _X    |    |    |    |     |     |
| Туре   | RO       |      |       | R/W    |                     |       |       |    |    |         |       |    |    |    |     |     |
| Reset  | 0        | 0    | 0     | 0      | 0 0 0 1 1 1 1 1 1 1 |       |       |    |    |         | 1     |    |    |    |     |     |

| Field Name | Bit     | R/W | Reset Value | Description      |
|------------|---------|-----|-------------|------------------|
|            | [31:28] | RO  | 4'h0        | Reserved         |
| CAP_END_Y  | [27:16] | R/W | 12'hFF      | Start Y position |
|            | [15:13] | RO  | 3'h0        | Reserved         |
| CAP_END_X  | [12:0]  | R/W | 13'hFF      | Start X position |

# 7.1.5.2.33 CAP\_IMG\_DECI

Description: CAP image decimation register.

| 0x0110 |    |                         | САР | image | decim | ation | (Reset | 0x000 | 0_001 | 1) |    |    | CAP_IMG_I |       |      | DECI |
|--------|----|-------------------------|-----|-------|-------|-------|--------|-------|-------|----|----|----|-----------|-------|------|------|
| Bit    | 31 | 30                      | 29  | 28    | 27    | 26    | 25     | 24    | 23    | 22 | 21 | 20 | 19        | 18    | 17   | 16   |
| Name   |    | Reserved                |     |       |       |       |        |       |       |    |    |    |           |       |      |      |
| Туре   |    | 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   |    |                         |     |       |       | Rese  | erved  |       |       |    |    |    | CAP_      | DECI_ | CAP_ |      |
| Туре   |    | RO RW RW                |     |       |       |       |        |       |       |    |    |    |           |       |      |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 |     |       |       |       |        |       |       |    |    |    |           |       |      |      |



| Field Name | Bit    | R/W | Reset Value | Description                                                    |
|------------|--------|-----|-------------|----------------------------------------------------------------|
|            | [31:4] | RO  | 28'h0       | Reserved                                                       |
| CAP_DECI_Y | [3:2]  | R/W | 2'h0        | Y direction decimation factor 0: Disable 1: 1/ 2 2: 1/4 3: 1/8 |
| CAP_DECI_X | [1:0]  | R/W | 2'h0        | X direction decimation factor 0: Disable 1: 1/ 2 2: 1/4 3: 1/8 |

### 7.1.5.2.34 ATV\_MODE\_FIX

# 7.1.5.2.35 CAP\_OBSERVE

Description: CAP observe register.

| 0x00118 | 3  |          | САР                       | obser | ve regi | ster (F | Reset ( | 0x0000   | _0000 | )  |     |    |    | CAP | OBSE | RVE |
|---------|----|----------|---------------------------|-------|---------|---------|---------|----------|-------|----|-----|----|----|-----|------|-----|
| Bit     | 31 | 30       | 29                        | 28    | 27      | 26      | 25      | 24       | 23    | 22 | 21  | 20 | 19 | 18  | 17   | 16  |
| Name    |    | Reserved |                           |       |         |         |         |          |       |    |     |    |    |     |      |     |
| Туре    |    | 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   |
|         |    |          |                           |       |         |         |         |          |       |    |     |    |    |     |      | CAP |
|         |    |          |                           |       |         |         |         |          |       |    |     |    |    |     |      | _OB |
| Name    |    |          |                           |       |         |         | 1       | Reserved | i     |    |     |    |    |     |      | SER |
|         |    |          |                           |       |         |         |         |          |       |    |     |    |    |     |      | VE_ |
| V       |    |          |                           |       |         |         |         |          |       |    |     | EB |    |     |      |     |
| Туре    |    | RO       |                           |       |         |         |         |          |       |    | R/W |    |    |     |      |     |
| Reset   | 0  | 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 |       |         |         |         |          |       |    |     |    | 0  |     |      |     |

| Field Name | Bit    | R/W | Reset Value | Description |
|------------|--------|-----|-------------|-------------|
|            | [31:1] | RO  | 31'h0       | Reserved    |



| CAP_OBSERVE [0] | R/W | 1'h0 | Enable signal for observing |
|-----------------|-----|------|-----------------------------|
|-----------------|-----|------|-----------------------------|

### 7.1.5.2.36 CAP\_JPG\_CTL

Description: CAP JPEG control register.

| 0x011c |    |    | САР    | JPEG                | buffer | contro              | ol (Res | et 0x0 | 000_0 | 020) |        |        |    | CAF | P_JPG | CTL |
|--------|----|----|--------|---------------------|--------|---------------------|---------|--------|-------|------|--------|--------|----|-----|-------|-----|
| Bit    | 31 | 30 | 29     | 28                  | 27     | 26                  | 25      | 24     | 23    | 22   | 21     | 20     | 19 | 18  | 17    | 16  |
| Name   |    |    |        |                     |        |                     |         | Rese   | erved |      |        |        |    |     |       |     |
| Туре   |    |    |        | RO                  |        |                     |         |        |       |      |        |        |    |     |       |     |
| Reset  | 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   |    |    | Rese   | erved               |        |                     |         |        |       |      | JPG_ME | M_SIZE |    |     |       |     |
| Туре   |    |    | RO R/W |                     |        |                     |         |        |       |      |        |        |    |     |       |     |
| Reset  | 0  | 0  | 0      | 0                   | 0      | 0 0 0 0 0 0 0 0 0 0 |         |        |       |      |        |        |    |     |       |     |

| Field Name   | Bit     | R/W | Reset<br>Value | Description                                                                                                                     |
|--------------|---------|-----|----------------|---------------------------------------------------------------------------------------------------------------------------------|
|              | [31:10] | RO  | 22'h0          | Reserved                                                                                                                        |
| JPG_buf_SIZE | [9:0]   | R/W | 10'h0          | The JPEG buffer size in external memory, which was prepared by software. (unit:32K BYTE)  0: No limit  1: 23K BYTE   N: N * 32K |

### 7.1.5.2.37 CAP\_FRM\_SIZE

Description: CAP frame size register.



| 0x0120 |    |    | CAP frame size (Reset 0x0000_0000) |      |       |    |    |        |        |    |    | CAP_FRM_SIZE |         |    |      |    |
|--------|----|----|------------------------------------|------|-------|----|----|--------|--------|----|----|--------------|---------|----|------|----|
| Bit    | 31 | 30 | 29                                 | 28   | 27    | 26 | 25 | 24     | 23     | 22 | 21 | 20           | 19      | 18 | 17   | 16 |
| Name   |    |    |                                    | Rese | erved |    |    |        |        |    |    | CAP_FR       | RM_SIZE |    |      |    |
| Туре   |    |    | RO                                 |      |       |    |    |        |        |    |    |              | 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   |    |    |                                    |      |       |    |    | CAP_FF | M_SIZE |    |    |              |         |    | abla |    |
| Туре   |    |    | RO                                 |      |       |    |    |        |        |    |    |              |         |    |      |    |
| Reset  | 0  | 0  | 0                                  | 0    | 0     | 0  | 0  | 0      | 0      | 0  | 0  | 0            | 0       | 0  | 0    | 0  |

| Field Name   | Bit     | R/W | Reset<br>Value | Description                                                              |
|--------------|---------|-----|----------------|--------------------------------------------------------------------------|
|              | [31:24] | RO  | 8'h0           | Reserved                                                                 |
| CAP_FRM_SIZE | [23:0]  | RO  | 24'h0          | Size of current frame, the unit is BYTE, only active in spi or jpeg mode |

# 7.1.5.2.38 CAP\_SPI\_CFG

Description: SPI original width register.

| 0x0124 |    |          | CAP | SPI co                | onfig re              | egister | (reset | 0x000 | 0_000 | 0)     |      |    |    | CA | P_SPI | CFG |
|--------|----|----------|-----|-----------------------|-----------------------|---------|--------|-------|-------|--------|------|----|----|----|-------|-----|
| Bit    | 31 | 30       | 29  | 28                    | 27                    | 26      | 25     | 24    | 23    | 22     | 21   | 20 | 19 | 18 | 17    | 16  |
| Name   |    |          |     |                       | Reserved              |         |        |       |       |        |      |    |    |    |       |     |
| Туре   |    |          |     |                       | RO                    |         |        |       |       |        |      |    |    |    |       |     |
| 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   |    | Reserved | t   |                       |                       |         |        |       | SPI_0 | ORIG_W | IDTH |    |    |    |       |     |
| Туре   |    | RO       |     | R/W                   |                       |         |        |       |       |        |      |    |    |    |       |     |
| Reset  | 0  | 0        | 0   | 0 0 0 0 0 0 0 0 0 0 0 |                       |         |        |       |       |        |      |    |    |    |       |     |

| Field Name Bit | R/W | Reset | Description |
|----------------|-----|-------|-------------|
|----------------|-----|-------|-------------|



|                |         |     | Value |                                               |
|----------------|---------|-----|-------|-----------------------------------------------|
|                | [31:13] | RO  | 19'h0 | Reserved                                      |
| SPI_ORIG_WIDTH | [12:0]  | R/W | 13'h0 | Width of SPI sensor original image. n-1 BYTE. |

# 7.1.5.2.39 SCALING COEF TABLE

The scaling coefficient fixed-point precision is 9-bit, range from [-2.0, 1.9921875] COEF table 1:

Luma horizontal coeffient table: 8X72

| 0x0200 |    |                       | Lum                 | na hori | izontal | coeffi | cient 1 | [0] (R | eset 0 | x0000 | _0000) |    | LU | JMA_H | ICOEF                     | _1[0] |  |
|--------|----|-----------------------|---------------------|---------|---------|--------|---------|--------|--------|-------|--------|----|----|-------|---------------------------|-------|--|
| Bit    | 31 | 30                    | 29                  | 28      | 27      | 26     | 25      | 24     | 23     | 22    | 21     | 20 | 19 | 18    | 17                        | 16    |  |
| Name   |    |                       |                     |         |         |        | Rese    | erved  |        |       |        |    |    |       | LUMA_HCO<br>EF_1[0][17:0] |       |  |
| Туре   |    | RO RW                 |                     |         |         |        |         |        |        |       |        |    |    |       | W                         |       |  |
| 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   |    | LUMA_HCOEF_1[0][17:0] |                     |         |         |        |         |        |        |       |        |    |    |       |                           |       |  |
| Туре   |    | R/W                   |                     |         |         |        |         |        |        |       |        |    |    |       |                           |       |  |
| Reset  | 0  | 0                     | 0 0 0 0 0 0 0 0 0 0 |         |         |        |         |        |        |       |        |    |    | 0     | 0                         | 0     |  |



| 0x0204 |    |    | Lun | na hori                | izontal | coeffi | cient 1 | [0] (R | eset 0 | x0000 | _0000) |    | LU | JMA_H | ICOEF    | _1[0]   |  |  |
|--------|----|----|-----|------------------------|---------|--------|---------|--------|--------|-------|--------|----|----|-------|----------|---------|--|--|
| Bit    | 31 | 30 | 29  | 28                     | 27      | 26     | 25      | 24     | 23     | 22    | 21     | 20 | 19 | 18    | 17       | 16      |  |  |
|        |    |    |     |                        |         |        |         |        |        |       |        |    |    |       | LUMA_HCO |         |  |  |
| Name   |    |    |     |                        |         |        | Rese    | erved  |        |       |        |    |    |       |          | 0][35:1 |  |  |
|        |    |    |     | 8)                     |         |        |         |        |        |       |        |    |    |       |          |         |  |  |
| Туре   |    |    |     | RO R/W                 |         |        |         |        |        |       |        |    |    |       |          |         |  |  |
| 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   |    |    |     | LUMA_HCOEF_1[0][35:18] |         |        |         |        |        |       |        |    |    |       |          |         |  |  |
| Туре   |    |    | R/W |                        |         |        |         |        |        |       |        |    |    |       |          |         |  |  |
| Reset  | 0  | 0  | 0   |                        |         |        |         |        |        |       |        |    |    |       | 0        | 0       |  |  |

| 0x0208 |    |    | Lun                    | na hori | zontal | coeffi | cient 1 | [0] (R | eset 0 | ×0000_ | 0000) |    | LU | JMA_H | HCOEF_1[0]                     |    |  |
|--------|----|----|------------------------|---------|--------|--------|---------|--------|--------|--------|-------|----|----|-------|--------------------------------|----|--|
| Bit    | 31 | 30 | 29                     | 28      | 27     | 26     | 25      | 24     | 23     | 22     | 21    | 20 | 19 | 18    | 17                             | 16 |  |
| Name   |    |    |                        |         |        |        | Rese    | erved  |        |        |       |    |    |       | LUMA_HCO<br>EF_1[0][53:3<br>6] |    |  |
| Туре   |    |    |                        | RO R/M  |        |        |         |        |        |        |       |    |    |       |                                |    |  |
| 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   |    |    | LUMA_HCOEF_1[0][53:36] |         |        |        |         |        |        |        |       |    |    |       |                                |    |  |
| Туре   |    |    | R/W                    |         |        |        |         |        |        |        |       |    |    |       |                                |    |  |
| Reset  | 0  | 0  | 0                      |         |        |        |         |        |        |        |       |    |    |       |                                | 0  |  |



| 0x020C |    |    | Lun                    | na hori | izontal | coeffi | cient 1 | [0] (R | eset 0 | x0000 | _0000) |    | LU | JMA_H | ICOEF | _1[0]    |  |  |
|--------|----|----|------------------------|---------|---------|--------|---------|--------|--------|-------|--------|----|----|-------|-------|----------|--|--|
| Bit    | 31 | 30 | 29                     | 28      | 27      | 26     | 25      | 24     | 23     | 22    | 21     | 20 | 19 | 18    | 17    | 16       |  |  |
|        |    |    |                        |         |         |        |         |        |        |       |        |    |    |       | LUMA  | LUMA_HCO |  |  |
| Name   |    |    |                        |         |         |        | Rese    | erved  |        |       |        |    |    |       | -     | 0][71:5  |  |  |
|        |    |    |                        | 4] PAM  |         |        |         |        |        |       |        |    |    |       |       |          |  |  |
| Туре   |    |    |                        | RO 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   |    |    | LUMA_HCOEF_1[0][71:54] |         |         |        |         |        |        |       |        |    |    |       |       |          |  |  |
| Туре   |    |    | R/W                    |         |         |        |         |        |        |       |        |    |    |       |       |          |  |  |
| Reset  | 0  | 0  | 0 0 0 0 0 0 0 0 0 0 0  |         |         |        |         |        |        |       |        |    | 0  | 0     |       |          |  |  |

. . .

Chroma horizontal coefficient table: 8X36

| 0x0280 |    |          | Chro                    | Chroma horizontal coefficient 1 [0] (Reset 0x0000_0000) |    |    |    |    |    |    |    |    |                                 |    | HCOE | F_1[0<br>] |
|--------|----|----------|-------------------------|---------------------------------------------------------|----|----|----|----|----|----|----|----|---------------------------------|----|------|------------|
| Bit    | 31 | 30       | 29                      | 28                                                      | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                              | 18 | 17   | 16         |
| Name   |    | Reserved |                         |                                                         |    |    |    |    |    |    |    |    | CHROMA_H<br>COEF_1[0][1<br>7:0] |    |      |            |
| Туре   |    |          |                         | RO                                                      |    |    |    |    |    |    |    |    | R/W                             |    |      |            |
| 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   |    |          | CHROMA_HCOEF_1[0][17:0] |                                                         |    |    |    |    |    |    |    |    |                                 |    |      |            |
| Туре   |    | R/W      |                         |                                                         |    |    |    |    |    |    |    |    |                                 |    |      |            |
| Reset  | 0  | 0        | 0                       | 0                                                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                               | 0  | 0    | 0          |



| 0x0284 |    | Chroma horizontal coefficient 1 [0] (Reset 0x0000_0000) |    |    |    |    |    |    |    |    |    |    | OMA_                             | HCOE | F_1[0<br>] |    |
|--------|----|---------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----------------------------------|------|------------|----|
| Bit    | 31 | 30                                                      | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                               | 18   | 17         | 16 |
| Name   |    | Reserved                                                |    |    |    |    |    |    |    |    |    |    | CHROMA_H<br>COEF_1[0][3<br>5:18] |      |            |    |
| Туре   |    |                                                         | RO |    |    |    |    |    |    |    |    |    | R                                | W    |            |    |
| 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   |    | CHROMA_HCOEF_1[0][35:18]                                |    |    |    |    |    |    |    |    |    |    |                                  |      |            |    |
| Туре   |    | R/W                                                     |    |    |    |    |    |    |    |    |    |    |                                  |      |            |    |
| Reset  | 0  | 0                                                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                | 0    | 0          | 0  |

. . .

Vertical coefficient table: 68X8

| 0x02F0 |                   |          | Verti | cal co | efficier | nt (Res | et 0x0 | 000_0 | 000) |      |       |                       |    | ١                 | /COEF | _1[0] |  |  |
|--------|-------------------|----------|-------|--------|----------|---------|--------|-------|------|------|-------|-----------------------|----|-------------------|-------|-------|--|--|
| Bit    | 31                | 30       | 29    | 28     | 27       | 26      | 25     | 24    | 23   | 22   | 21    | 20                    | 19 | 18                | 17    | 16    |  |  |
| Name   |                   | Reserved |       |        |          |         |        |       |      |      |       | CHROMA_V<br>COEF_1[0] |    |                   |       |       |  |  |
| Туре   |                   | RO       |       |        |          |         |        |       |      |      | R/    | R/W                   |    |                   |       |       |  |  |
| 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   | CHROMA_VCOEF_1[0] |          |       |        |          |         |        |       |      | LUMA | _VCOE | 1[0]                  |    | R/W 0 0 1 0 1 0 0 |       |       |  |  |
| Туре   |                   |          |       |        |          |         |        |       |      |      |       |                       |    |                   |       |       |  |  |
| Reset  | 0                 | 0        | 0     | 0      | 0        | 0       | 0      | 0     | 0    | 0    | 0     | 0                     | 0  | 0                 | 0     | 0     |  |  |

. . .

| <b>-</b> | Address | Register | Signal | Bits | R/W | Defau | Description |
|----------|---------|----------|--------|------|-----|-------|-------------|
|          |         | Name     | Name   |      |     | lt    |             |



| Address | Register<br>Name         | Signal<br>Name             | Bits   | R/W | Defau<br>It | Description                              |
|---------|--------------------------|----------------------------|--------|-----|-------------|------------------------------------------|
| 0x0200  | LUMA_HCOE<br>FF[0]_1     | Video_luma<br>_horizontal_ | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[17:0]  |
| 0x0204  | LUMA_HCOE<br>FF[0]_2     | coeff[0]                   | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[35:18] |
| 0x0208  | LUMA_HCOE<br>FF[0]_3     |                            | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[53:36] |
| 0x020c  | LUMA_HCOE<br>FF[0]_4     |                            | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[71:54] |
|         |                          |                            |        |     |             | * ( ) ·                                  |
| 0x0210  | LUMA_HCOE<br>FF[1]_1     | Video_luma<br>_horizontal_ | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[17:0]  |
| 0x0214  | LUMA_HCOE<br>FF[1]_2     | coeff[1]                   | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[35:18] |
| 0x0218  | LUMA_HCOE<br>FF[1]_3     |                            | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[53:36] |
| 0x021C  | LUMA_HCOE<br>FF[1]_4     |                            | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[71:54] |
|         |                          |                            |        |     |             |                                          |
| 0x0220  | LUMA_HCOE<br>FF[2]_1     | Video_luma<br>_horizontal_ | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[17:0]  |
| 0x0224  | LUMA_HCOE<br>FF[2]_2     | coeff[2]                   | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[35:18] |
| 0x0228  | LUMA_HCOE<br>FF[2]_3     |                            | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[53:36] |
| 0x022C  | LUMA_HCOE<br>FF[2]_4     |                            | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[71:54] |
| O       |                          |                            |        |     |             |                                          |
|         |                          |                            |        |     |             |                                          |
|         |                          |                            |        |     |             |                                          |
| 0x0270  | VID_LUMA_H<br>COEFF[7]_1 | Video_luma<br>_horizontal_ | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[17:0]  |



| Address | Register<br>Name                  | Signal<br>Name                                    | Bits   | R/W | Defau<br>It | Description                               |
|---------|-----------------------------------|---------------------------------------------------|--------|-----|-------------|-------------------------------------------|
| 0x0274  | VID_LUMA_H<br>COEFF[7]_2          | coeff[7]                                          | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[35:18]  |
| 0x0278  | VID_LUMA_H<br>COEFF[7]_3          |                                                   | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[53:36]  |
| 0x027C  | VID_LUMA_H<br>COEFF[7]_4          |                                                   | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[71:54]  |
| 0x0280  | VID_CHROMA<br>_HCOEFF_LO<br>W[0]  | Video_chro<br>ma_horizont<br>al_coeff_low<br>[0]  | [17:0] | R/W | 18'h0       | Video Chroma horizontal coefficient[17:0] |
| 0x0284  | VID_CHROMA<br>_HCOEFF_HI<br>GH[0] | Video_chro<br>ma_horizont<br>al_coeff_hig<br>h[0] | [17:0] | R/W | 18'h0       | Video chroma horizontal coefficient[17:0] |
| 0x0288  | VID_CHROMA<br>_HCOEFF_LO<br>W[1]  | Video_chro<br>ma_horizont<br>al_coeff_low<br>[7]  | [17:0] | R/W | 18'h0       | Video Chroma horizontal coefficient[17:0] |
| 0x028C  | VID_CHROMA<br>_HCOEFF_HI<br>GH[1] | Video_chro<br>ma_horizont<br>al_coeff_hig<br>h[7] | [17:0] | R/W | 18'h0       | Video chroma horizontal coefficient[17:0] |
|         |                                   | •••                                               |        |     |             |                                           |
|         |                                   |                                                   |        |     |             |                                           |
| 0x02B8  | VID_CHROMA<br>_HCOEFF_LO<br>W[7]  | Video_chro<br>ma_horizont<br>al_coeff_low         | [17:0] | R/W | 18'h0       | Video Chroma horizontal coefficient[17:0] |
| 0x02BC  | VID_CHROMA<br>_HCOEFF_HI<br>GH[7] | Video_chro<br>ma_horizont<br>al_coeff_hig<br>h    | [17:0] | R/W | 18'h0       | Video chroma horizontal coefficient[17:0] |



| Address | Register<br>Name  | Signal<br>Name                          | Bits        | R/W | Defau<br>It | Description                            |
|---------|-------------------|-----------------------------------------|-------------|-----|-------------|----------------------------------------|
|         |                   |                                         |             |     |             |                                        |
| 0x02F0  | VID_VCOEFF[<br>0] | Video_luma<br>_vertical_co<br>eff[0]    | [8:0]       | R/W | 9'h0        | Video luma Vertical coefficient[8:0]   |
|         |                   | Video_chro<br>ma_vertical_<br>coeff[0]  | [17:9]      | R/W | 9'h0        | Video Chroma vertical coefficient[8:0] |
|         |                   | Reserved                                | [31:1<br>8] |     |             | Reserved                               |
| 0x02F4  | VID_VCOEFF[<br>1] | Video_luma<br>_vertical_co<br>eff[1]    | [8:0]       | R/W | 9'h0        | Video luma Vertical coefficient[8:0]   |
|         |                   | Video_chro<br>ma_vertical_<br>coeff[1]  | [17:9]      | R/W | 9'h0        | Video Chroma vertical coefficient[8:0] |
|         |                   | Reserved                                | [31:1<br>8] |     |             | Reserved                               |
|         |                   |                                         |             |     |             |                                        |
|         |                   |                                         |             |     |             |                                        |
|         |                   |                                         |             |     |             |                                        |
| 0x03FC  | VID_VCOEFF[ 35]   | Video_luma<br>_vertical_co<br>eff[67]   | [8:0]       | R/W | 9'h0        | Video luma Vertical coefficient[8:0]   |
|         |                   | Video_chro<br>ma_vertical_<br>coeff[67] | [17:9]      | R/W | 9'h0        | Video Chroma vertical coefficient      |
|         |                   | Reserved                                | [31:1<br>8] |     |             | Reserved                               |

# COEF table 2:

| Address | Register | Signal | Bits | R/W | Defau | Description |
|---------|----------|--------|------|-----|-------|-------------|
|         | Name     | Name   |      |     | It    |             |



| Address | Register                 | Signal                     | Bits   | R/W | Defau | Description                              |
|---------|--------------------------|----------------------------|--------|-----|-------|------------------------------------------|
|         | Name                     | Name                       |        |     | It    |                                          |
| 0x0400  | LUMA_HCOE<br>FF[0]_1     | Video_luma<br>_horizontal_ | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[17:0]  |
| 0x0404  | LUMA_HCOE<br>FF[0]_2     | coeff[0]                   | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[35:18] |
| 0x0408  | LUMA_HCOE<br>FF[0]_3     |                            | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[53:36] |
| 0x040c  | LUMA_HCOE<br>FF[0]_4     |                            | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[71:54] |
|         |                          |                            |        |     |       | <b>*</b> . ( )                           |
| 0x0410  | LUMA_HCOE<br>FF[1]_1     | Video_luma<br>_horizontal_ | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[17:0]  |
| 0x0414  | LUMA_HCOE<br>FF[1]_2     | coeff[1]                   | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[35:18] |
| 0x0418  | LUMA_HCOE<br>FF[1]_3     |                            | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[53:36] |
| 0x041C  | LUMA_HCOE<br>FF[1]_4     |                            | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[71:54] |
|         |                          |                            |        |     |       |                                          |
| 0x0420  | LUMA_HCOE<br>FF[2]_1     | Video_luma<br>_horizontal_ | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[17:0]  |
| 0x0424  | LUMA_HCOE<br>FF[2]_2     | coeff[2]                   | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[35:18] |
| 0x0428  | LUMA_HCOE<br>FF[2]_3     |                            | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[53:36] |
| 0x042C  | LUMA_HCOE<br>FF[2]_4     |                            | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[71:54] |
|         |                          |                            |        |     |       |                                          |
|         |                          |                            |        |     |       |                                          |
|         |                          |                            |        |     |       |                                          |
| 0x0470  | VID_LUMA_H<br>COEFF[7]_1 | Video_luma<br>_horizontal_ | [17:0] | R/W | 18'h0 | Video luma horizontal coefficient[17:0]  |



| Address | Register<br>Name                  | Signal<br>Name                                    | Bits   | R/W | Defau<br>It | Description                               |
|---------|-----------------------------------|---------------------------------------------------|--------|-----|-------------|-------------------------------------------|
| 0x0474  | VID_LUMA_H<br>COEFF[7]_2          | coeff[7]                                          | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[35:18]  |
| 0x0478  | VID_LUMA_H<br>COEFF[7]_3          |                                                   | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[53:36]  |
| 0x047C  | VID_LUMA_H<br>COEFF[7]_4          |                                                   | [17:0] | R/W | 18'h0       | Video luma horizontal coefficient[71:54]  |
| 0x0480  | VID_CHROMA<br>_HCOEFF_LO<br>W[0]  | Video_chro<br>ma_horizont<br>al_coeff_low<br>[0]  | [17:0] | R/W | 18'h0       | Video Chroma horizontal coefficient[17:0] |
| 0x0484  | VID_CHROMA<br>_HCOEFF_HI<br>GH[0] | Video_chro<br>ma_horizont<br>al_coeff_hig<br>h[0] | [17:0] | R/W | 18'h0       | Video chroma horizontal coefficient[17:0] |
| 0x0488  | VID_CHROMA<br>_HCOEFF_LO<br>W[1]  | Video_chro<br>ma_horizont<br>al_coeff_low<br>[7]  | [17:0] | R/W | 18'h0       | Video Chroma horizontal coefficient[17:0] |
| 0x048C  | VID_CHROMA<br>_HCOEFF_HI<br>GH[1] | Video_chro<br>ma_horizont<br>al_coeff_hig<br>h[7] | [17:0] | R/W | 18'h0       | Video chroma horizontal coefficient[17:0] |
|         |                                   |                                                   |        |     |             |                                           |
| 0x04B8  | VID_CHROMA<br>_HCOEFF_LO<br>W[7]  | Video_chro ma_horizont al_coeff_low               | [17:0] | R/W | 18'h0       | Video Chroma horizontal coefficient[17:0] |
| 0x04BC  | VID_CHROMA<br>_HCOEFF_HI<br>GH[7] | Video_chro<br>ma_horizont<br>al_coeff_hig<br>h    | [17:0] | R/W | 18'h0       | Video chroma horizontal coefficient[17:0] |



| Address | Register<br>Name   | Signal<br>Name                          | Bits        | R/W | Defau<br>It | Description                            |
|---------|--------------------|-----------------------------------------|-------------|-----|-------------|----------------------------------------|
|         |                    |                                         |             |     |             |                                        |
| 0x04F0  | VID_VCOEFF[<br>0]  | Video_luma<br>_vertical_co<br>eff[0]    | [8:0]       | R/W | 9'h0        | Video luma Vertical coefficient[8:0]   |
|         |                    | Video_chro<br>ma_vertical_<br>coeff[0]  | [17:9]      | R/W | 9'h0        | Video Chroma vertical coefficient[8:0] |
|         |                    | Reserved                                | [31:1<br>8] |     |             | Reserved                               |
| 0x04F4  | VID_VCOEFF[<br>1]  | Video_luma<br>_vertical_co<br>eff[1]    | [8:0]       | R/W | 9'h0        | Video luma Vertical coefficient[8:0]   |
|         |                    | Video_chro<br>ma_vertical_<br>coeff[1]  | [17:9]      | R/W | 9'h0        | Video Chroma vertical coefficient[8:0] |
|         |                    | Reserved                                | [31:1<br>8] |     |             | Reserved                               |
|         |                    |                                         |             |     |             |                                        |
|         |                    |                                         |             |     |             |                                        |
|         |                    |                                         |             |     |             |                                        |
| 0x04FC  | VID_VCOEFF[<br>35] | Video_luma<br>_vertical_co<br>eff[67]   | [8:0]       | R/W | 9'h0        | Video luma Vertical coefficient[8:0]   |
|         |                    | Video_chro<br>ma_vertical_<br>coeff[67] | [17:9]      | R/W | 9'h0        | Video Chroma vertical coefficient      |
|         |                    | Reserved                                | [31:1<br>8] |     |             | Reserved                               |

# 7.1.6 Application Notes

# 7.1.6.1 Camera capture path

Software operation suggestion:

YUV data format capture:



- a. Configure sensor via I2C,
- b. Enable DCAM module, and clear interrupt and set relative interrupt mask.
- c. Configure DCAM global control register and AHB master register. Include DCAM\_CFG, CAMER\_CFG, CAM\_SRC\_SIZE, AHB frame address register and CAM\_DST\_SIZE if enable scaling.
- d. If enable scale&trimming in YUV capture mode. Scaling coefficient table 1 is needed.
- e. Filled in relative cap registers. Set shadow register, auto copy is suggested.
- f. Set cap\_eb to start capture.
- g. Wait CAP\_TX\_DONE interrupt.
- h. If camera path2 is enabled, wait REV\_TX\_DONE.

#### Data store method:

#### Camera path1:



#### JPEG capture data memory store:



### Camera path 2:





#### 7.1.6.2 Image resizing path

#### Software operation suggestion:

#### Normal mode:

- a. Enable DCAM module and clear interrupt and set relative interrupt mask.
- b. Configure DCAM global control register. Include DCAM\_CFG, REVIEW\_CFG, REV\_SRC\_SIZE, REV\_DST\_SIZE and AHB frame address registers,
- c. If enable scaling module. Fill in scaling coefficient table 2.
- d. Set review start.
- e. Wait REV\_TX\_DONE interrupt.

#### Slice mode operation:

- Enable DCAM CLK and clear interrupt and set relative interrupt mask.
- Configure DCAM global control register. Include DCAM\_CFG, REV\_SRC\_SIZE, REV\_DST\_SIZE and AHB frame address registers,
- c. Set frm\_addr2, frm\_addr3,frm\_addr6, If the destination width exceed 960.
- d. Fill in scaling coefficient table 2.
- Enable slice mode and Fill in SLICE\_VCNT\_INPUT. The standard vertical number 64,128 and 256 is suggested.

#### Caution: The trim\_start\_y must be 0, if current slice is not first slice block.

- f. Wait REV\_TX\_DONE interrupt, And check AHBM\_STS ,make sure it is IDLE;
- So, one slice mode review process completed. Read SLICE\_O\_VCNT can get the total line numbers hardware have send out.
- g. After VSP operation, begin the new slice mode review.
- h. Repeat step d, e, f. until the left vertical line is less than standard vertical number.
- i. Fill in the left line number to SLIC\_VCNT\_INPUT.
- j. Start review.
- k. Wait REV\_TX\_DONE;



#### Data store method:

Normal review mode:

Input data: YUV422/YUV420/YUV400;

output data:YUV422



Figure 7.1-13 data store scheme of review mode(a)

Input data: YUV420(3 Frame);

output data YUV. (with Scaling enable)

In YUV 3 frame, the input horizontal size must be multiple of 8.



Figure 7.1-14 data store scheme of review mode(b)

Input data: YUV420(3 Frame);

output data YUV. (with Scaling bypass).



In YUV 3 frame, the input horizontal size must be multiple of 8.

Caution: in current mode, the yuv2rgb shouldn't be enabled.



Figure 7.1-15 data store scheme of review mode(c)

Input data YUV; output data: RGB565.



Figure 7.1-16 data store scheme of review mode(d)

Input data: RGB565; Output data: RGB565





Figure 7.1-17 data store scheme of review mode(e)

Input data:RGB888; output data RGB565:



Figure 7.1-18 data store scheme of review mode(f)

RGB888 data format:

| [31:24]  | [23:16] | [15:8] | [7:0] |
|----------|---------|--------|-------|
| reserved | R       | G      | В     |

Large size(dst\_hor\_size>640) slice mode review:

Input data: YUV
Output data: YUV422





Figure 7.1-19 data store scheme of slice mode(g)

Temp Y size: (dst\_size\_X \* slice\_i\_vcnt) BYTE;

Temp UV size: (dst\_size\_X \* slice\_i\_vcnt) BYTE;

Line buffer data size:

Dst\_size\_y \* 8 BYTE;

Input data: RGB565/RGB888

Output data: RGB565



Figure 7.1-20 data store scheme of slice mode(f)



## 7.2 Rotation

#### 7.2.1 Overview

The module works as accelerator to help software processing image rotation operation.

#### Change list:

- I Add trimming function
- I Modify the macro block size to 16X16 to improve the performance.

#### 7.2.2 Features

- I Support byte, half word and word format image rotation.
- I Support UV 422 data mode rotation.
- I Support 90, 270, 180 and mirror rotation.
- Support image size up to 4092X4092.
- I Support image trimming before rotation.

# 7.2.3 Signal Description



# 7.2.4 Function Description



Figure 7.2-1 Diagram of rot\_top

The above figure depicts the diagram of ROTATION module. This module contains of 2 units except one 64X32 memory, rot\_intf and unit\_rot.

# 7.2.4.1 Rot\_intf&unit\_rot

This two module is in charge of coordinate rotation.





Figure 7.2-2 rotation coordinate

The whole image will be divided into several blocks according to the image size and rotation unit. First, we rotate the block position. Secondly we rotate every pixel in one block.

Byte\_addr = pixel\_addr << PixelFormat ();



For the pixel with 4bytes, we only need to change its memory position. If one pixel with the following coordinate (a, b) enters the rotation module, it will have another coordinate(x, y). X=8-b; (Suppose that Rotation Unit is 8)

Y=a.

As the result, the memory address will be 8(a+1) -b; (a[2:0], b[2:0])

```
After rotation: (a+b^*i) * i = -b + a^*i;
Coordination shift 8 left: 8-b+a*i;
Index in memory (64X32): 8*a + (8 - b) = 8(a+1) -b.
```

For the pixel with 2bytes, firstly, we should rotate it, and align the half-word. Suppose pixel position is (a, b), after rotation, the position will be (16-b, a), and the pixel position in memory will be (8(a+1) -b)/2.(a[2:0], b[2:0])

```
After rotation: (a+b^*i)^*i = -b + a^*i;
Coordination shift 8 left: 8-b+a*i;
Index in memory (64X32): 8^*a + (8 - b) = 8(a+1) - b.
```

For the pixel with only one byte, suppose pixel position is (a, b), the finial position will be 16(a+1) -b, and the memory address will be ((16(a+1) -b)/4); (a[3:0], b[3:0])

```
After rotation: (a+b*i)*i = -b+a*i;
Coordination shift 16 left: 16-b+a*i;
Index in memory (64X32): 16*a + (16 - b) = 16(a+1) -b.
```

### 7.2.4.2 Rotation mode

Support four rotation modes:



original





Figure 7.2-3 rotation mode

# 7.2.5 Control Registers

## **7.2.5.1** Memory map

ARM base address: 0x2080\_0000

| Offset<br>Address | Name             | Description                       |
|-------------------|------------------|-----------------------------------|
| 0x0400            | SrcDataStartAddr | Start address of source           |
| 0x0404            | DesDataStartAddr | Start address of destination      |
| 0x0408            | IMGSIZE          | Image size                        |
| 0x040C            | ROTCTRL          | Rotation control                  |
| 0x0410            | ORIGWIDTH        | Original image width              |
| 0x0414            | ORIGOFFSET       | Offset position in original image |



| Offset<br>Address | Name          | Description                     |
|-------------------|---------------|---------------------------------|
| 0x0420            | DMACHnCFG0    | DMA channel configuration 0     |
| 0x0424            | DMACHnCFG1    | DMA channel configuration 1     |
| 0x0428            | DMACHnSrcAddr | DMA channel source address      |
| 0x042C            | DMACHnDesAddr | DMA channel Destination address |
| 0x0430            | DMACHnLLPtr   | DMA channel link list pointer   |
| 0x0434            | DMACHnSDI     | DMA channel SDI                 |
| 0x0438            | DMACHnSBP     | DMA channel SBD                 |
| 0x043C            | DMACHnDBP     | DMA channel DBP                 |

## 7.2.5.2 Register Descriptions

### 7.2.5.2.1 SrcDataStartAddr Registers

Description: Source data start address

| 0x0400 |    | Source data start address(Reset 0x0000_0000) |                               |    |    |    |   |   |   |   |   |   |    | DataSt | artAdo | dress |
|--------|----|----------------------------------------------|-------------------------------|----|----|----|---|---|---|---|---|---|----|--------|--------|-------|
| Bit    | 31 | 30                                           | 29 28 27 26 25 24 23 22 21 20 |    |    |    |   |   |   |   |   |   | 19 | 18     | 17     | 16    |
| Name   |    | SrcDataStartAddress                          |                               |    |    |    |   |   |   |   |   |   |    |        |        |       |
| Туре   |    | R/W                                          |                               |    |    |    |   |   |   |   |   |   |    |        |        |       |
| 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   |    | SrcDataStartAddress                          |                               |    |    |    |   |   |   |   |   |   |    |        |        |       |
| Туре   |    | R/W                                          |                               |    |    |    |   |   |   |   |   |   |    |        |        |       |
| Reset  | 0  | 0                                            | 0                             | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0      | 0      | 0     |

| Field Name       | Bit    | Туре | Reset<br>Value | Description                                   |
|------------------|--------|------|----------------|-----------------------------------------------|
| SrcDataStartAddr | [31:0] | R/W  | 32'h0          | Start address for raw data in external memory |

## 7.2.5.2.2 DesDataStartAddr Registers

Description: Destination data start address



| 0x0404 |    |                     | Desti | ination             | data | start a | ddress | (Rese                 | t 0x00 | 00_000 | 00) |    | Des | DataSt | artAdo | dress |
|--------|----|---------------------|-------|---------------------|------|---------|--------|-----------------------|--------|--------|-----|----|-----|--------|--------|-------|
| Bit    | 31 | 30                  | 29    | 28                  | 27   | 26      | 25     | 24                    | 23     | 22     | 21  | 20 | 19  | 18     | 17     | 16    |
| Name   |    | DesDataStartAddress |       |                     |      |         |        |                       |        |        |     |    |     |        |        |       |
| Туре   |    | R/W                 |       |                     |      |         |        |                       |        |        |     |    |     |        |        |       |
| 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   |    |                     |       | DesDataStartAddress |      |         |        |                       |        |        |     |    |     |        |        |       |
| Туре   |    |                     | R/W   |                     |      |         |        |                       |        |        |     |    |     |        |        |       |
| Reset  | 0  | 0                   | 0     | 0                   | 0    | 0       | 0      | 0 0 0 0 0 0 0 0 0 0 0 |        |        |     |    |     |        |        |       |

| Field Name       | Bit    | Туре | Reset<br>Value | Description                            |
|------------------|--------|------|----------------|----------------------------------------|
| SrcDataStartAddr | [31:0] | R/W  | 32'h0          | destination address in external memory |

## 7.2.5.2.3 IMGSIZE Registers

Description: Source image size register;

| 0x0408 |          |      | Sour  | ce Ima | ige siz | e (re     | set 0x0   | 0000_0 | 000) |    |    |    |    |    | IMG | SIZE |
|--------|----------|------|-------|--------|---------|-----------|-----------|--------|------|----|----|----|----|----|-----|------|
| Bit    | 31       | 30   | 29    | 28     | 27      | 26        | 25        | 24     | 23   | 22 | 21 | 20 | 19 | 18 | 17  | 16   |
| Name   | Reserved |      |       |        |         |           | FORM<br>T |        |      |    |    |    |    |    |     |      |
| Туре   |          |      | R     | W      |         |           | R         | W      |      |    |    | R/ | W  |    |     |      |
| 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   |          | IMGW | /IDTH |        |         | IMGHEIGHT |           |        |      |    |    |    |    |    |     |      |
| Туре   |          | R    | /W    |        | R/W     |           |           |        |      |    |    |    |    |    |     |      |
| Reset  | 0        | 0    | 0     | 0      | 0       | 0         | 0         | 0      | 0    | 0  | 0  | 0  | 0  | 0  | 0   | 0    |

| Field Name | Bit     | R/W | Reset Value | Description |
|------------|---------|-----|-------------|-------------|
|            | [31:26] | RO  | 6'h0        | Reserved    |



| PIXELFORMAT | [25:24] | R/W | 2'h0  | Pixel format:          |
|-------------|---------|-----|-------|------------------------|
|             |         |     |       | 2'h0: 1Byte/Pixel      |
|             |         |     |       | 2'h1: 2Byte/Pixle      |
|             |         |     |       | 2'h2: 4Byte/Pixel      |
| IMGWIDTH    | [23:12] | R/W | 12'h0 | Image width of source  |
| IMGHEIGHT   | [11:0]  | R/W | 12'h0 | Image height of source |

## 7.2.5.2.4 ROTCTRL Registers

Description: Rotation control registers.

| 0x040C |    |          | Rota                      | tion co                         | ontrol ( | Reset | 0x000 | 0_000 | 0) |   |   |            |     |      | ROT              | CTRL |
|--------|----|----------|---------------------------|---------------------------------|----------|-------|-------|-------|----|---|---|------------|-----|------|------------------|------|
| Bit    | 31 | 30       | 29                        | 29 28 27 26 25 24 23 22 21 20 1 |          |       |       |       |    |   |   |            |     | 18   | 17               | 16   |
| Name   |    | Reserved |                           |                                 |          |       |       |       |    |   |   |            |     |      |                  |      |
| Туре   |    |          |                           |                                 |          |       |       | R     | 0  |   |   |            |     |      |                  |      |
| 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   |    | Reserved |                           |                                 |          |       |       |       |    |   |   | ROT<br>_EN | ROT | _DIR | ROT<br>_MO<br>DE |      |
| Туре   |    | RO RW RA |                           |                                 |          |       |       |       |    |   |   | W          | R/W |      |                  |      |
| Reset  | 0  | 0        | 0                         | 0                               | 0        | 0     | 0     | 0     | 0  | 0 | 0 | 0          | 0   | 0    | 0                | 0    |

| Field Name | Bit    | R/W | Reset Value | Description                                                            |
|------------|--------|-----|-------------|------------------------------------------------------------------------|
|            | [31:4] | RO  | 28'h0       | Reserved                                                               |
| ROT_EN     | [3]    | R/W | 1'h0        | Rotation Enable, This bit will be auto cleared after rotation is done. |
| ROT_DIR    | [2:1]  | R/W | 2'h0        | Rotation direction: 00: 90 01: 270 10: 180 11: horizon mirror          |
| ROT_MODE   | [0]    | R/W | 1'h0        | Rotation mode:                                                         |



|  | 1:uv422 mode  |
|--|---------------|
|  | 0:normal mode |

### 7.2.5.2.5 ORIGWIDTH Registers

Description: Original image width register;

| 0x0410 |    |      | Origi | nal im | age wi              | dth s | size ( | reset ( | )x0000 | _0000 | )     |    |    | C  | ORIGW | IDTH |
|--------|----|------|-------|--------|---------------------|-------|--------|---------|--------|-------|-------|----|----|----|-------|------|
| Bit    | 31 | 30   | 29    | 28     | 27                  | 26    | 25     | 24      | 23     | 22    | 21    | 20 | 19 | 18 | 17    | 16   |
| Name   |    |      |       |        |                     |       |        | Rese    | erved  |       |       |    |    |    |       |      |
| Туре   |    |      |       |        |                     |       |        | R       | 0      |       |       |    |    |    |       |      |
| 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   |    | Rese | erved |        |                     |       |        |         |        | ORIGN | VIDTH |    |    |    |       |      |
| Туре   |    | R    | .0    |        | R/W                 |       |        |         |        |       |       |    |    |    |       |      |
| Reset  | 0  | 0    | 0     | 0      | 0 0 0 0 0 0 0 0 0 0 |       |        |         |        |       |       |    |    |    |       |      |

| Field Name | Bit     | R/W | Reset Value | Description             |
|------------|---------|-----|-------------|-------------------------|
|            | [31:12] | RO  | 6'h0        | Reserved                |
| ORIGWIDTH  | [11:0]  | R/W | 12'h0       | Width of original image |

# 7.2.5.2.6 ORIGOFFSET Registers

Description: offset position of original iamge register;



| 0x041C |        |        | Offse  | et posi  | tion of | origir    | al pos | ition | (reset | 0x000        | 00_000 | 0) | ORIGOFFSET |    |    |          |
|--------|--------|--------|--------|----------|---------|-----------|--------|-------|--------|--------------|--------|----|------------|----|----|----------|
| Bit    | 31     | 30     | 29     | 28       | 27      | 26        | 25     | 24    | 23     | 22           | 21     | 20 | 19         | 18 | 17 | 16       |
| Name   |        |        |        | Reserved |         |           |        |       |        | ORIG_START_Y |        |    |            |    |    |          |
| Туре   |        |        |        | R        | 0       |           |        |       |        |              |        | R  | W          |    |    | <b>\</b> |
| 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   |        | ORIG_S | TART_Y |          |         |           |        |       |        | ORIG_S       | TART_X |    |            |    |    |          |
| Туре   | De R/W |        |        |          | R/W     |           |        |       |        |              |        |    |            |    |    |          |
| Reset  | 0      | 0      | 0      | 0        | 0       | 0 0 0 0 0 |        |       |        |              | 0      | 0  | 0          | 0  | 0  | 0        |

| Field Name   | Bit     | R/W | Reset Value | Description                        |
|--------------|---------|-----|-------------|------------------------------------|
|              | [31:26] | RO  | 6'h0        | Reserved                           |
| ORIG_START_Y | [23:12] | R/W | 12'h0       | Start Y position in original iamge |
| ORIG_START_X | [11:0]  | R/W | 12'h0       | Start X position in original iamge |

### 7.2.5.2.7 DMACHnCFG0 Registers

Description: DMA channel configuration 0 register.

| 0x0420 |           |    | DMA      | chanr                | el con     | figura      | tion 0 | (Reset            | 0x004 | 12_000 | 0)                |                    | DMAChnCFG0 |       |                     |                  |  |
|--------|-----------|----|----------|----------------------|------------|-------------|--------|-------------------|-------|--------|-------------------|--------------------|------------|-------|---------------------|------------------|--|
| Bit    | 31        | 30 | 29       | 28                   | 27         | 26          | 25     | 24                | 23    | 22     | 21                | 20                 | 19         | 18    | 17                  | 16               |  |
| Name   | LLen<br>d |    | Reserved | i                    | SrcDa<br>ł | taWidt<br>n |        | DestDataWid<br>th |       | odeSel | Src<br>Wra<br>pEn | Dest<br>Wra<br>pEn | Rese       | erved | NoA<br>utoC<br>lose | Res<br>erve<br>d |  |
| Туре   | RO        |    | RO       | RO RO RO RO RO RO RO |            |             |        |                   |       |        |                   |                    |            |       |                     |                  |  |
| Reset  | 0         | 0  | 0        | 0                    | 0          | 0           | 0      | 0                 | 0     | 1      | 0                 | 0                  | 0          | 0     | 1                   | 0                |  |
| Bit    | 15        | 14 | 13       | 12                   | 11         | 10          | 9      | 8                 | 7     | 6      | 5                 | 4                  | 3          | 2     | 1                   | 0                |  |
| Name   |           |    |          | BurstLength          |            |             |        |                   |       |        |                   |                    |            |       |                     |                  |  |
| Туре   |           |    |          | RO                   |            |             |        |                   |       |        |                   |                    |            |       |                     |                  |  |
| Reset  | 0         | 0  |          |                      |            |             |        |                   |       |        |                   |                    |            |       |                     |                  |  |



| Field Name    | Bit     | R/W | Reset Value | Description                                                                                                                                  |
|---------------|---------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| LLend         | [31]    | RO  | 1'h0        | Link list end flag.                                                                                                                          |
|               | [30:28] | RO  | 3'h0        | Reserved                                                                                                                                     |
| SrcDataWidth  | [27:26] | RO  | 2'h0        | Source data width. 00: byte. 01: half-word. 10: word.                                                                                        |
| DestDataWidth | [25:24] | RO  | 2'h0        | Destination data width. 00: byte. 01: half-word. 10: word.                                                                                   |
| ReqModeSel    | [23:22] | RO  | 2'h1        | 2'b01: Transaction mode,<br>one request for one<br>transaction.                                                                              |
| SrcWrapEn     | [21]    | RO  | 1'h0        | Source Address Wrapping<br>Enable. 1'b0: disable                                                                                             |
| DestWrapEn    | [20]    | RO  | 1'h0        | Destination Address<br>Wrapping Enable. 1'b0:<br>disable                                                                                     |
|               | [19:18] | RO  | 2'h0        | Reserved                                                                                                                                     |
| NoAutoclose   | [17]    | RO  | 1'h1        | Channel No Auto-Close  0: ChnEn is set by ARM and cleared automatically after a request completed.  1: ChnEn is set and cleared only by ARM. |
|               | [16]    | RO  | 1'h0        | Reserved                                                                                                                                     |
| Burst_Length  | [15:0]  | RO  | 16'h0       | Burst Length The unit is BYTE. MUST be ChnSrcDataWidth boundary.                                                                             |

## 7.2.5.2.8 DMACHnCFG1 Registers

Description: DMA channel configuration 1 register.



| 0x0424 |    |    | DMA      | chann | nel con | figura | tion 1 | (Reset | 0x000         | 000_000 | 0) |    |    | DMACHnCFG1 |      |            |  |
|--------|----|----|----------|-------|---------|--------|--------|--------|---------------|---------|----|----|----|------------|------|------------|--|
| Bit    | 31 | 30 | 29       | 28    | 27      | 26     | 25     | 24     | 23            | 22      | 21 | 20 | 19 | 18         | 17   | 16         |  |
| Name   |    |    | Reserved |       |         |        |        |        | TotalTransact |         |    |    |    | th         |      |            |  |
| Туре   |    |    |          | RO    |         |        |        |        | RO            |         |    |    |    |            |      | <b>•</b> ( |  |
| 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   |    |    |          |       |         |        | Total  | Transa | ctionL        | ength   |    |    |    |            | abla |            |  |
| Туре   |    |    |          | RO    |         |        |        |        |               |         |    |    |    |            |      |            |  |
| Reset  | 0  | 0  | 0        | 0     | 0       | 0      | 0      | 0      | 0             | 0       | 0  | 0  | 0  | 0          | 0    | 0          |  |

| Field Name             | Bit     | R/W | Reset<br>Value | Description                            |
|------------------------|---------|-----|----------------|----------------------------------------|
|                        | [31:25] | RO  | 7'h0           | Reserved                               |
| TotalTransactionLength | [24:0]  | RO  | 25'h0          | Total Transaction length. Unit is BYTE |

## 7.2.5.2.9 DMACHnSrcAddr Registers

Description: DMA channel source address register.

| 0x0428 |    |                           | DMA           | chanr | nel sou | rce ac | Idress | (Rese | t 0x00  | 00_000 | 00) |    |    | DMAC | HnSrc | Addr |
|--------|----|---------------------------|---------------|-------|---------|--------|--------|-------|---------|--------|-----|----|----|------|-------|------|
| Bit    | 31 | 30                        | 29            | 28    | 27      | 26     | 25     | 24    | 23      | 22     | 21  | 20 | 19 | 18   | 17    | 16   |
| Name   |    |                           |               |       |         |        |        | DMACH | SrcAddı | r      |     |    |    |      |       |      |
| Туре   |    |                           | <b>)</b>      |       |         |        |        | R     | 0       |        |     |    |    |      |       |      |
| 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   |    |                           | DMACHnSrcAddr |       |         |        |        |       |         |        |     |    |    |      |       |      |
| Туре   |    | RO                        |               |       |         |        |        |       |         |        |     |    |    |      |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |               |       |         |        |        |       |         |        |     |    |    |      |       |      |

| Field Name | Bit | R/W | Reset | Description |
|------------|-----|-----|-------|-------------|
|            |     |     | Value |             |



| DMACHnSrcAddr | [31:0] | RO | 32'h0 | DMA channel Source |
|---------------|--------|----|-------|--------------------|
|               |        |    |       | address            |
|               |        |    |       |                    |

### 7.2.5.2.10 DMACHnDesAddr Registers

Description: DMA channel Destination address register.

| 0x042C |    | DMA channel destination address (Reset0x0000_0000) DMACHnDesAddr |    |    |    |    |   |        |         |   |   |   |   |   |   |   |
|--------|----|------------------------------------------------------------------|----|----|----|----|---|--------|---------|---|---|---|---|---|---|---|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16                  |    |    |    |    |   |        |         |   |   |   |   |   |   |   |
| Name   |    |                                                                  |    |    |    |    | ļ | DMACHr | nDesAdd | r |   |   |   |   |   |   |
| Туре   |    |                                                                  |    |    |    |    |   | R      | 0       |   |   |   |   |   |   |   |
| 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   |    |                                                                  |    |    |    |    | ļ | DMACHr | nDesAdd | r |   |   |   |   |   |   |
| Туре   |    | RO                                                               |    |    |    |    |   |        |         |   |   |   |   |   |   |   |
| Reset  | 0  | 0                                                                | 0  | 0  | 0  | 0  | 0 | 0      | 0       | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Field Name    | Bit    | R/W | Reset<br>Value | Description                     |
|---------------|--------|-----|----------------|---------------------------------|
| DMACHnDesAddr | [31:0] | RO  | 32'h0          | DMA channel destination address |

## 7.2.5.2.11 DMACHnLLPtr Registers

Description: DMA channel link list pointer register.



| 0x0430 |    |    | DMA | chann | el link | list po | ointer | (Reset | 0x000   | 0_000 | 0) |    |    | DM | ACHn | LLPtr    |
|--------|----|----|-----|-------|---------|---------|--------|--------|---------|-------|----|----|----|----|------|----------|
| Bit    | 31 | 30 | 29  | 28    | 27      | 26      | 25     | 24     | 23      | 22    | 21 | 20 | 19 | 18 | 17   | 16       |
| Name   |    |    |     |       |         |         |        | DMACI  | HnLLPtr |       |    |    |    |    |      |          |
| Туре   |    |    |     |       |         |         |        | R      | 0       |       |    |    |    |    |      | <b>\</b> |
| 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   |    |    |     |       |         |         |        | DMACI  | HnLLPtr |       |    |    |    |    | abla |          |
| Туре   |    |    |     | RO    |         |         |        |        |         |       |    |    |    |    |      |          |
| Reset  | 0  | 0  | 0   | 0     | 0       | 0       | 0      | 0      | 0       | 0     | 0  | 0  | 0  | 0  | 0    | 0        |

| Field Name  | Bit    | R/W | Reset<br>Value | Description                                                                                                                                                                                                                                 |
|-------------|--------|-----|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMACHnLLPtr | [31:0] | RO  | 32'h0          | Link list pointer to the next node address.MUST be on 8-word boundary.  So when writing, bit [4:0] is omitted; When reading, bit [4:0] is 0.  If LLEnd is set, indicating the current transaction is last one of the list, LLPtr is unused. |

## 7.2.5.2.12 DMACHnSDI Registers

Description: DMA channel source transfer Interval register.



| 0x0434 |                             |                  | DM | A chan | nel so | urce t | ransfe | r inter | val (Re | set va | lue) |          |    | D  | MACH | InSDI |
|--------|-----------------------------|------------------|----|--------|--------|--------|--------|---------|---------|--------|------|----------|----|----|------|-------|
| Bit    | 31                          | 30               | 29 | 28     | 27     | 26     | 25     | 24      | 23      | 22     | 21   | 20       | 19 | 18 | 17   | 16    |
| Name   | SrcT<br>ransf<br>erSe       | Res<br>erve<br>d |    |        |        |        |        | Src     | Transfe | erAddr | Step |          |    |    | •    |       |
| Туре   | RO                          | RO               |    |        |        |        |        |         | R       | 0      |      |          |    |    |      |       |
| 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   | Dest<br>Tran<br>sfer<br>Sel | Res<br>erve<br>d |    |        |        |        |        | Dest    | Transf  | erAddr | Step |          |    |    |      |       |
| Туре   | RO                          | RO               |    |        |        |        |        |         | R       | 0      |      | <u> </u> |    |    |      |       |
| Reset  | 0                           | 0                | 0  | 0      | 0      | 0      | 0      | 0       | 0       | 0      | 0    | 0        | 0  | 0  | 0    | 0     |

| Field Name           | Bit     | R/W | Reset<br>Value | Description                                              |
|----------------------|---------|-----|----------------|----------------------------------------------------------|
| srcTransferSel       | [31]    | RO  | 1'h0           | 0:increased;1:decreased;                                 |
|                      | [30]    | RO  | 1'h0           | Reserved.                                                |
| SrcTransferAddrStep  | [29:16] | RO  | 14'h0          | Source Transfer address step.The unit is BYTE            |
| DestTransferSel      | [15]    | RO  | 1'h0           | 0:increased;1:decreased;                                 |
|                      | [14]    | RO  | 1'h0           | Reserved.                                                |
| DestTransferAddrStep | [13:0]  | RO  | 14'h0          | Destination Transfer<br>address step.The unit is<br>BYTE |

## 7.2.5.2.13 DMACHnSBP Registers

Description: DMA channel source block post-modification register.



| 0x0438 |                  |      |        | chanr<br>00_000 |      | ırce bl | ock po | st-mo | dificat | ion (R | eset |       | DMACHnSB |    |    | nSBP |
|--------|------------------|------|--------|-----------------|------|---------|--------|-------|---------|--------|------|-------|----------|----|----|------|
| Bit    | 31               | 30   | 29     | 28              | 27   | 26      | 25     | 24    | 23      | 22     | 21   | 20    | 19       | 18 | 17 | 16   |
| Name   | Res<br>erve<br>d | Srcl | BurstM | ode             | rese | rved    |        |       |         |        | DMAC | HnSBP |          |    |    |      |
| Туре   | RO               |      | RO     |                 | R    | 0       |        |       |         |        | R    | 0     |          |    |    |      |
| Reset  | 0                | 0    | 0      | 1               | 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   |                  |      |        | DMACHnSBP       |      |         |        |       |         |        |      |       |          |    |    |      |
| Туре   |                  |      |        |                 |      |         |        | R     | 0       |        | 5    |       |          |    |    |      |
| Reset  | 0                | 0    | 0      | 0               | 0    | 0       | 0      | 0     | 0       | 0      | 0    | 0     | 0        | 0  | 0  | 0    |

| Field Name   | Bit     | R/W | Reset Value | Description                                                                                                                                                                                                                                                                                               |
|--------------|---------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | [31]    | RO  | 1'h0        | Reserved                                                                                                                                                                                                                                                                                                  |
| SrcBurstMode | [30:28] | RO  | 3'h1        | 000 – Single Transfer; NSEQ for each transfer; 001 – INCR for unspecified length 011 – INCR4; 101 – INCR8; 111 – INCR16;                                                                                                                                                                                  |
|              | [27:26] | RO  | 2'h0        | Reserved                                                                                                                                                                                                                                                                                                  |
| DMACHnSBP    | [25:0]  | RO  | 26'h0       | Sets the post-modification value of the source's current address, between the Read transfer of the last element in a source block to the first element of the next block during a cluster transfer. The value is in 2's complement, which means that both positive and negative values are supported. The |



|  | post-modification value is summed with the source current address following a block Read transfer.  Note: The value must be set to an integer multiple of the data width; setting it to a different value may yield |
|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | unexpected behavior.                                                                                                                                                                                                |

## 7.2.5.2.14 DMACHnDBP Registers

Description: DMA channel destination block post-modification register.

| 0x043C |                  |      | DMA<br>value |       | el des | tinatio | n bloc | n block post-modification (Reset |       |    |       |       |    | DMACHnDBP |    |    |  |
|--------|------------------|------|--------------|-------|--------|---------|--------|----------------------------------|-------|----|-------|-------|----|-----------|----|----|--|
| Bit    | 31               | 30   | 29           | 28    | 27     | 26      | 25     | 24                               | 23    | 22 | 21    | 20    | 19 | 18        | 17 | 16 |  |
| Name   | Res<br>erve<br>d | Dest | tBurstN      | ⁄lode | rese   | rved    |        |                                  |       |    | DMACI | HnDBP |    |           |    |    |  |
| Туре   | RO               |      | RO           |       | R      | 0       |        |                                  |       |    | R     | 0     |    |           |    |    |  |
| Reset  | 0                | 0    | 0            | 1     | 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   |                  |      |              |       |        |         |        | DMACI                            | HnDBP |    |       |       |    |           |    |    |  |
| Туре   |                  |      |              |       |        |         |        | R                                | 0     |    |       |       |    |           |    |    |  |
| Reset  | 0                | 0    | 0            | 0     | 0      | 0       | 0      | 0                                | 0     | 0  | 0     | 0     | 0  | 0         | 0  | 0  |  |

| Field Name    | Bit     | R/W | Reset Value | Description                                                                                                              |
|---------------|---------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------|
| OU            | [31]    | RO  | 1'h0        | Reserved                                                                                                                 |
| DestBurstMode | [30:28] | RO  | 3'h1        | 000 – Single Transfer; NSEQ for each transfer; 001 – INCR for unspecified length 011 – INCR4; 101 – INCR8; 111 – INCR16; |



|           | [27:26] | RO | 2'h0  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|---------|----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMACHnDBP | [25:0]  | RO | 26'h0 | Sets the post-modification value of the destination's current address, between the Read transfer of the last element in a source block to the first element of the next block during a cluster transfer. The value is in 2's complement, which means that both positive and negative values are supported. The post-modification value is summed with the source current address following a block Read transfer. |

## 7.2.6 Application Notes

# **7.3 LCDC**

# 7.3.1 Overview

LCD Controller (LCDC) is used to fetch image data and OSD data, blend these data, and output to LCD panel or write back to memory. There are 6 data sources, one for image source, and five for OSD source, these 6 source data can be blended with alpha simultaneously.

## 7.3.2 Features

Support 6 layer alpha blending, 5 for OSD and 1 for image, the image layer is the bottom one, the OSD1 is the more top one, and in turn, the OSD5 is the most top one;





Figure xx Layer Define

- I Support YUV422/YUV420/YUV400/RGB888/RGB565/RGB666/RGB555 data format in image layer;
- I Support RGB888/RGB565/RGB666/RGB555/GREY data format in OSD1 layer, when in RGB565, it can be with individual alpha data;
- I Support RGB888/RGB565/RGB666/RGB555/GREY data format in OSD2/3/4/5 layer, when in RGB565, only support block alpha;

#### Table xx Data Format

| Format | Code |                                                                     | Data Mapping |            |          |           |        |           |            |         |       |
|--------|------|---------------------------------------------------------------------|--------------|------------|----------|-----------|--------|-----------|------------|---------|-------|
| YUV422 | 0000 |                                                                     |              |            |          |           |        |           |            |         |       |
|        |      | Υ                                                                   | [31:24]      | [23:16]    | [15:8]   | [7:0]     | UV     | [31:24]   | [23:16]    | [15:8]  | [7:0] |
|        |      |                                                                     | Y0           | Y1         | Y2       | Y3        |        | U0        | V0         | U2      | V2    |
|        |      |                                                                     | Y4           | Y5         | Y6       | Y7        |        | U4        | V4         | U6      | V6    |
|        |      | The                                                                 | U/V data     | is half of | the Y da | ata in h  | orizor | ntal.     |            |         |       |
|        |      | Data                                                                | a address    | should b   | e half-w | ord-aliલ્ | gned,  | size shou | ld be 2x p | oixels. |       |
| YUV420 | 0001 |                                                                     |              |            |          |           |        |           |            |         |       |
|        |      | Υ                                                                   | [31:24]      | [23:16]    | [15:8]   | [7:0]     | UV     | [31:24]   | [23:16]    | [15:8]  | [7:0] |
|        |      |                                                                     | Y0           | Y1         | Y2       | Y3        |        | U0        | V0         | U2      | V2    |
|        |      |                                                                     | Y4           | Y5         | Y6       | Y7        |        | U4        | V4         | U6      | V6    |
|        |      | The U/V data is half of the Y data in horizontal and vertical.      |              |            |          |           |        |           |            |         |       |
|        |      | Data address should be half-word-aligned, size should be 2x pixels. |              |            |          |           |        |           |            |         |       |
| YUV400 | 0010 |                                                                     |              |            |          |           | _      |           |            |         |       |
|        |      | Υ                                                                   | [31:24]      | [23:16]    | [15:8]   | [7:0]     |        |           |            |         |       |



|        |      |                                                                          | Y0      | Y1      |           | Y2      | Y3               |           |        |          |         |       |      |  |
|--------|------|--------------------------------------------------------------------------|---------|---------|-----------|---------|------------------|-----------|--------|----------|---------|-------|------|--|
|        |      |                                                                          | Y4      | Y5      |           | Y6      | Y7               |           |        |          |         |       |      |  |
|        |      | No U/V source data in this format, but we replace them with constant 0x8 |         |         |           |         |                  |           | 0x80.  |          |         |       |      |  |
|        |      | Data                                                                     | addres  | s shou  | ld be     | half-   | word-alig        | ned, size | sho    | uld be   | 2x pixe | els.  |      |  |
| RGB888 | 0011 |                                                                          |         |         |           |         |                  |           |        |          |         |       |      |  |
|        |      | [31:                                                                     | :24]    |         | [23:      | [23:16] |                  |           | [15:8] |          |         | [7:0] |      |  |
|        |      | A0                                                                       |         |         | R0        |         |                  | G0        |        |          | В0      |       |      |  |
|        |      | A1                                                                       |         |         | R1        |         |                  | G1        |        |          | B1      |       |      |  |
|        |      | Ax is                                                                    | pixel a | lpha.   |           |         |                  | •         |        |          | X       | V     |      |  |
|        |      |                                                                          |         |         |           |         |                  |           |        | <b>\</b> |         |       |      |  |
| RGB666 | 0100 |                                                                          |         |         |           |         |                  |           |        |          |         |       |      |  |
|        |      | [31:                                                                     | :24]    |         |           | [2      | 21:16]           |           | [13    | :8]      |         | [5    | :0]  |  |
|        |      | A0                                                                       |         |         |           | F       | 20               |           | G0     |          |         | В     | )    |  |
|        |      | A1                                                                       |         |         |           | F       | 21               | -         | G1     |          |         | B     | 1    |  |
|        |      | Ax is                                                                    | pixel a | lpha.   |           |         |                  |           |        |          |         |       |      |  |
|        |      | RGB                                                                      | 666 to  | RGB88   | 88: R/0   | G/B[5   | 5:0] <b>à</b> {R | /G/B[5:0] | , 2{F  | R/G/B[0  | )]}}    |       |      |  |
| RGB565 | 0101 |                                                                          |         |         |           |         |                  |           |        |          |         |       |      |  |
|        |      | [31:                                                                     | :27]    | [26:2   | 21]       | [2      | 0:16]            | [15:11]   |        | [10:5]   | ]       | [4:0  | ]    |  |
|        |      | R0                                                                       |         | G0      |           | В       | )                | R1 G1     |        | G1       |         | В1    |      |  |
|        |      | R2                                                                       |         | G2      |           | B2      | 2                | R3        |        | G3       | B3      |       |      |  |
|        |      | Whe                                                                      | n in OS | D1 lay  | er, it ir | ncluc   | les the be       | elow alph | a da   | ta.      |         |       |      |  |
|        |      | [31:                                                                     | :24]    |         | [23:      | 16]     |                  | [15:8]    | 5:8]   |          | [7:0]   |       |      |  |
|        |      | A0                                                                       |         |         | A1        |         |                  | A2        |        |          | A3      |       |      |  |
|        |      | А3                                                                       |         |         | A2        |         |                  | A1        |        |          | A0      |       |      |  |
|        |      | Ax is pixel alpha, $Px = \{Ax, Rx, Gx, Bx\}.$                            |         |         |           |         |                  |           |        |          |         |       |      |  |
|        |      | RGB565 to RGB888: R/B[4:0] à {R/B[4:0], 3{R/B[0]}}, G[5:0] à {G[5:0],    |         |         |           |         |                  |           |        |          |         |       |      |  |
|        |      | 2{G[(                                                                    | U]}}    |         |           |         |                  |           |        |          |         |       |      |  |
| RGB555 | 0110 |                                                                          |         |         |           |         |                  | L         |        |          |         | 1     |      |  |
|        |      | [31]                                                                     |         | 30:26]  | [25:2     | 21]     | [20:16]          | [15]      |        | 4:10]    | [9:5]   |       | 4:0] |  |
|        |      | A0                                                                       |         | .0      | G0        |         | B0               | A1        | R′     | 1        | G1      | E     | 31   |  |
|        |      | Ax is                                                                    | pixel a | lpha, 0 | for 8'    | h00,    | 1 for 8'hf       | f.        |        |          |         |       |      |  |



|          |       | RGB555 to RGB888: R/G/B[4:0] à {R/G/B[4:0], 3{R/G/B[0]}} |                                                                                          |                                |            |           |       |  |  |  |
|----------|-------|----------------------------------------------------------|------------------------------------------------------------------------------------------|--------------------------------|------------|-----------|-------|--|--|--|
| GREY     | 0111  |                                                          |                                                                                          |                                |            |           |       |  |  |  |
|          |       | [31:24]                                                  | [23:16]                                                                                  |                                |            |           | [7:0] |  |  |  |
|          |       | G0                                                       | G1                                                                                       | G1 G2                          |            |           | G3    |  |  |  |
|          |       | Gx is pixel grey G, B}.                                  | Gx is pixel grey, with the constant R, G and B, become a pixel: $Px = \{Gx, R, G, B\}$ . |                                |            |           |       |  |  |  |
| reserved | 1001~ | For future.                                              | For future.                                                                              |                                |            |           |       |  |  |  |
|          | 1111  |                                                          |                                                                                          |                                |            |           |       |  |  |  |
|          |       | All data support 3 switch mode                           |                                                                                          |                                |            |           |       |  |  |  |
|          |       |                                                          | [31:24]                                                                                  | [31:24] [23:16]<br>Byte0 Byte1 |            | [15:8]    | [7:0] |  |  |  |
|          |       | switch mode                                              | Byte0                                                                                    |                                |            | Byte2     | Byte3 |  |  |  |
|          |       |                                                          | Half-word0                                                                               |                                |            | Half-word | 1     |  |  |  |
|          |       | 0                                                        | Byte0                                                                                    | Byte0 Byte1                    |            | Byte2     | Byte3 |  |  |  |
|          |       | 1                                                        | Byte3 Byte2                                                                              |                                | Byte1      | Byte0     |       |  |  |  |
|          |       | 2                                                        | Half-word1                                                                               |                                | Half-word0 |           |       |  |  |  |
|          |       | reserved                                                 |                                                                                          |                                |            |           |       |  |  |  |

- I Support color key, one layer with same color key value;
- I Support dithering, RGB888 to RGB666 or RGB888 to RGB565;
- I Support writing back to memory, data can be RGB888/RGB565/RGB666;
- I Support 2 panel, and one can be FMARK panel;
- I Support MCU I/F, data type can be RGB565/RGB666/RGB888, bus type can be 8bits/9bits/16bits/18bits/24bits;

# 7.3.3 Signal Description

### **Table LCDC Signal List**

| Signal Name | Directio<br>n | Widt<br>h | Description                                                |
|-------------|---------------|-----------|------------------------------------------------------------|
| LCD_CD      | 0             | 1         | Command or data indication, '0' for command, '1' for data. |
| LCD_CSN0    | 0             | 1         | Device select, active low.                                 |
| LCD_CSN1    | 0             | 1         | Device select, active low.                                 |



| LCD_RSTN  | 0   | 1  | Reset control, active low.              |
|-----------|-----|----|-----------------------------------------|
| LCD_RDN   | 0   | 1  | Read control, active low.               |
| LCD_WRN   | 0   | 1  | Write control, active low.              |
| LCD_D     | I/O | 18 | Input/output data.                      |
| LCD_FMARK | I   | 1  | External panel frame sync signal input. |

## 7.3.4 Function Description

The LCDC's application is as below.



Figure xx LCDC Application

As above diagram, it includes 3 paths, the first one is Memory->LCDC->Memory; the second one is Memory->LCDC->Main Panle; the last one is Memory->LCDC->Sub Panel.

The LCDC's module diagram is shown in Figure xx.





#### Figure xx LCDC Module Diagram

The LCDC mainly does alpha blending along multi layer data, it supports up to 6 layers simultaneously. As above diagram, the LCDC includes multi clients for AHB master request, so it has an arbiter for AHB master interface, the "OSDx fetch" gets the top layer data and prepares for blending, the "Image fetch" gets bottom layer data and prepares for blending. Because blending only for RGB format data, but image data may be YUV format data, so a YUV2RGB module applied for YUV data. When all data are ready, "alpha blending" fetches all source and formats these data to RGB888, then blends them, if no source in some position, "alpha blending" outputs background color. Blended image may be output to LCM or write back to memory, when write back, the "capture" module will finish this task. For most applications, output may be RGB565 or RGB666, so the 'dithering' transform the RGB888 data to RGB565 or RGB666. Before send to LCM, "output ctrl" synchronizes data to cross 2 clock domains (LCM is in AHB clock) and sends to LCM. The LCDC also includes some configure registers.

#### 7.3.4.1 YUV to RGB

The blending only support RGB888 data format, so the YUV image data must be conversed to RGB888 before blend. Before the YUV changed to RGB, YUV can be adjusted for special application, the adjustment as below,

```
Y_tmp = (Y - 128) * contrast / 64 + 128 + brightness;
Y' = CLIP(Y_tmp, 255, 0);
U_tmp = (U - 128) * saturation / 64 + 128;
U' = CLIP(U_tmp, 255, 0);
V_tmp = (V - 128) * saturation / 64 + 128;
V' = CLIP(V_tmp, 255, 0);
```

After this, the Y'U'V' will be changed to RGB, this conversion uses the constant coefficient matrix calculation, the calculation formula as below.

$$\begin{bmatrix} R \\ G \\ B \end{bmatrix} = \begin{bmatrix} 1 & 0 & 359/256 \\ 1 & -88/256 & -183/256 \\ 1 & 454/256 & 0 \end{bmatrix} \begin{bmatrix} Y' \\ U' \\ V' \end{bmatrix} + \begin{bmatrix} -180 \\ 136 \\ -227 \end{bmatrix}$$

As above formula, the input data is YUV444, so the fetched data must be up-sampled to YUV444 before converse.

When the input is YUV422, we need to up-sample UV in horizontal.



|                   |  | Υ | ′UV4 | 22 |            | YUV444                           |
|-------------------|--|---|------|----|------------|----------------------------------|
|                   |  |   |      |    |            | 0000000                          |
|                   |  |   |      |    |            | 0000000                          |
|                   |  |   |      |    | - <b>-</b> | 0000000                          |
| Original UV pixel |  |   |      |    |            | Interpolated/duplicated UV pixel |

Figure xx YUV422 to YUV444 Conversion

When the input is YUV420, we need to up-sample UV in horizontal, and duplicate UV in vertical.



Figure xx YUV420 to YUV444 Conversion

When the input is YUV400, we need to replace the UV with some constant vale, here is 0x80.



Figure xx YUV400 to YUV444 Conversion

#### 7.3.4.2 Alpha Blending

The main function of this sub-module is blending image and OSD, when no image or OSD, the background will be displayed, the blending is alpha weighed average, a color-key function also implemented in here, when pixel vale is equal to color-key value, the pixel will become zero alpha.

The LCDC supports up to 6 layers blending, so it will do 5 blending,

The first one is blending image and OSD1,



The second one is blending blend1 and OSD2,

The third one is blending blend2 and OSD3,

The fourth one is blending blend3 and OSD4,

The fifth one is blending blend4 and OSD5,

For less resource, all blending share the same blending logic, the alpha blending as below.



Figure xx Blending Architecture Diagram

#### Alpha selection is below,

```
if(pixel_dat == color_key)
    alpha = 8'h0;
else if(blk_alpha_sel == 1)
    alpha = block_alpha;
else
    alpha = pixel_alpha;
```

#### Blending calculation is below,

```
if(alpha == 8'hff)
  blend = top;
else if(alpha == 8'h00)
  blend = bottom;
else
```



```
blend = (top - bottom)*alpha + bottom;
```

Here the top is upper level pixel and the bottom is lower level pixel; alpha is from the upper layer.

The LCDC also supports a new blending mode, it only for 2 layer application, the top layer is a processed result by SW, as a normal layer, it includes RGB data and Alpha data, but the Alpha data is used for bottom layer, the new blending mode is shown below,

#### 7.3.4.3 Dithering

Here an threshold-matrix dithering algorithm is presented.



Figure xx Dithering Data Flow

Dithering data flow is shown as Figure xx. In the module which Ri[7:0] is converted to Ro[4:0], the dither matrix T can be a simple 4x4 matrix as follow.

$$\begin{bmatrix} 0 & 4 & 0 & 5 \\ 6 & 2 & 7 & 3 \\ 1 & 5 & 1 & 4 \\ 8 & 3 & 6 & 2 \end{bmatrix}$$

When conversing RGB888 to RGB565, Ri[7:0] is separated to two parts. The first part is the higher five bits Ri[7:3] and the second part is the low three bits Ri[2:0]. The low three bits Ri[2:0] is compared with the corresponding element in the threshold matrix. If Ri[2:0] is bigger than the corresponding element, the Ri[7:3] add 1. Otherwise, Ri[7:3] remains its initial value. The output result Ro[4:0] is equaled with Ri[7:3]. The next pixel does the same cycle processing. In the row direction of image pixel array, column exchange should be done after every four pixel processed. Also namely, the first row move to the fourth row, the rest three rows move forward one by one in order(1->4, 2->1, 3->2, 4->3). After finish four times column exchange, reverse the present threshold matrix, the do the column exchange. In the column direction of image pixel array, row exchange should be done after every four pixel line



processed. After finish four times row exchange, reverse the present threshold matrix, then do the row exchange. The method of row exchange is as same as column exchange which is described above.

When Gi[7:0] is converted to Go[5:0], we the threshold matrix dithering algorithm. The dither matrix T can be a simple 2x2 matrix at follow.

$$\begin{bmatrix} 0 & 2 \\ 3 & 1 \end{bmatrix}$$

Gi[7:0] is separated to two parts. The first part is the higher six bits Gi[7:2] and the second part is the lower two bits Gi[1:0]. The lower two bits Gi[1:0] is compared with the corresponding element in the threshold matrix. If Gi[1:0] is bigger than the corresponding element, the Gi[7:2] adds 1. Otherwise, Gi[7:2] remains it initial value. The output result Go[5:0] is equaled with Gi[7:2].

For Bi[7:0] is converted to Bo[4:0]. We apply the same threshold method for Ri[7:0] to Ro[4:0]. When conversing RGB888 to RGB666, the Ri[7:0], Gi[7:0] and Bi[7:0] all are same as Gi[7:0] at above.

Dithering includes 565 and 666 two modes, when in display mode, the mode decided by LCM's configure; when in capture mode, the mode is decided by capture format.

#### 7.3.4.4 LCM

LCM receives AHB data or LCDC data and transfers them with a specified panel interface. This sub-module's block diagram is shown in below.



Figure xx LCM Block Diagram

The panel interface is SRAM-like interface, also named MCU interface, it includes 2 types, one is M6800, and the other is I8080. The 8080 and 6800 read/write control is shown as below.





Figure xx 8080/6800 Read/Write Control

The timing of read or write can be configured, the timing parameters are defined below.



Figure xx LCM Read/Write Timing Parameter Defines



AHB transfer can be used to initialize the panel, test the panel, update few data, read back panel data; LCDC transfer is used for normal display. The AHB data is priority to LCDC data, when LCDC is refreshing, must not send AHB data randomly.

## 7.3.4.5 Data Flow

The LCDC includes 2 data flow, one is for display, and another is for capture. They are can not work at the same time. They are shown in Figure xx and Figure xx.



Figure xx Data Flow for Display



Figure xx Data Flow for Capture

These 2 data flow can separate several stages, following is their detail information.

#### Data fetch stage:

It includes image fetch and OSD fetch, the image or OSD data stored in memory is linear, this data maybe map to a big picture, but we can trim the picture to our interesting region by configuring a special base address and region size. We must note the next line address should



be added the pitch other than the region's horizontal size. The data view for this stage as below.



Figure xx Data View in Fetch Stage

#### Data blending stage:

All active layers data are blended at a work plane based on their owner display start position and size. In single layer region, display the active layer data; in multi layer region, display the blended data; in spare region, display the background. The start position is based the work plane's origin. The data status is shown in Figure xx.



Figure 3.17 Data View in Blending Stage

#### Data refreshing stage:

After blending, blended data in work plane will be sent to LCM for LCD display. Normally, we update the entire work plane, we also need to update part region for many applications. The LCM window start position and size can decide LCM refreshing region, of course, it can cover the entire plane. The data view as Figure xx.





Figure xx Data View in Refreshing Stage

#### Data capture stage:

In capture mode, the blended data will be wrote back to memory. Normally, we capture the entire picture, but we also need to write back part picture, the capture start position and size can decide our interesting region, the capture base address decide the memory storage position, when write back, the next line address should be added by capture pitch. The data view in capture stage as Figure xx.



Figure xx Data View in Capture Stage

## 7.3.5 Control Registers

#### 7.3.5.1 **Memory map**

ARM Base address: 0x20700000

#### **Table LCDC Control Register Address Map**

| Offset Address      | Name           | Description                        |  |  |
|---------------------|----------------|------------------------------------|--|--|
| LCDC Global Control |                |                                    |  |  |
| 0x0000              | LCDC_CTRL      | LCDC module control                |  |  |
| 0x0004              | LCDC_DISP_SIZE | LCDC work plane size               |  |  |
| 0x0008              | LCDC_LCM_START | LCDC display window start position |  |  |



|                     |                      | - Coord Boolgii Opooliicatii                                                                                |
|---------------------|----------------------|-------------------------------------------------------------------------------------------------------------|
| 0x000c              | LCDC_LCM_SIZE        | LCDC display window size                                                                                    |
| 0x0010              | LCDC_BG_COLOR        | LCDC background color                                                                                       |
| 0x0014              | LCDC_FIFO_STATUS     | LCDC internal FIFO status                                                                                   |
| Image Layer Control |                      | <b>♦</b>                                                                                                    |
| 0x0020              | IMG_CTRL             | Image layer configuration                                                                                   |
| 0x0024              | IMG_Y_BASE_ADDR      | Image layer Y component base address when in YUV format, or image layer base address when in others format. |
| 0x0028              | IMG_UV_BASE_ADDR     | Image layer UV component base address only when in YUV format.                                              |
| 0x002c              | IMG_SIZE_XY          | Image layer size                                                                                            |
| 0x0030              | IMG_PITCH            | Image layer pitch                                                                                           |
| 0x0034              | IMG_DISP_XY          | Image layer start position in work plane.                                                                   |
| OSD1 Layer Control  |                      |                                                                                                             |
| 0x0050              | OSD1_CTRL            | OSD1 layer configuration                                                                                    |
| 0x0054              | OSD1_BASE_ADDR       | OSD1 layer data base address                                                                                |
| 0x0058              | OSD1_ALPHA_BASE_ADDR | OSD1 layer alpha data based address only when OSD1 is RGB565 and uses pixel alpha.                          |
| 0x005c              | OSD1_SIZE_XY         | OSD1 layer size                                                                                             |
| 0x0060              | OSD1_PITCH           | OSD1 layer pitch                                                                                            |
| 0x0064              | OSD1_DISP_XY         | OSD1 layer start position in work plane                                                                     |
| 0x0068              | OSD1_ALPHA           | OSD1 layer alpha                                                                                            |
| 0x006c              | OSD1_GREY_RGB        | OSD1 layer RGB constant of GREY format                                                                      |
| 0x0070              | OSD1_CK              | OSD1 layer color-key                                                                                        |
| OSD2 Layer Control  |                      |                                                                                                             |
| 0x0080              | OSD2_CTRL            | OSD2 layer configuration                                                                                    |
| 0x0084              | OSD2_BASE_ADDR       | OSD2 layer data base address                                                                                |
|                     |                      |                                                                                                             |



|                    |                | <u> </u>                                |
|--------------------|----------------|-----------------------------------------|
| 0x0088             | dummy          |                                         |
| 0x008c             | OSD2_SIZE_XY   | OSD2 layer size                         |
| 0x0090             | OSD2_PITCH     | OSD2 layer pitch                        |
| 0x0094             | OSD2_DISP_XY   | OSD2 layer start position in work plane |
| 0x0098             | OSD2_ALPHA     | OSD2 layer alpha                        |
| 0x009c             | OSD2_GREY_RGB  | OSD2 layer RGB constant of GREY format  |
| 0x00a0             | OSD2_CK        | OSD2 layer color-key                    |
| OSD3 Layer Control |                |                                         |
| 0x00b0             | OSD3_CTRL      | OSD3 layer configuration                |
| 0x00b4             | OSD3_BASE_ADDR | OSD3 layer data base address            |
| 0x00b8             | dummy          |                                         |
| 0x00bc             | OSD3_SIZE_XY   | OSD3 layer size                         |
| 0x00c0             | OSD3_PITCH     | OSD3 layer pitch                        |
| 0x00c4             | OSD3_DISP_XY   | OSD3 layer start position in work plane |
| 0x00c8             | OSD3_ALPHA     | OSD3 layer alpha                        |
| 0x00cc             | OSD3_GREY_RGB  | OSD3 layer RGB constant of GREY format  |
| 0x00d0             | OSD3_CK        | OSD3 layer color-key                    |
| OSD4 Layer Control |                |                                         |
| 0x00e0             | OSD4_CTRL      | OSD4 layer configuration                |
| 0x00e4             | OSD4_BASE_ADDR | OSD4 layer data base address            |
| 0x00e8             | dummy          |                                         |
| 0x00ec             | OSD4_SIZE_XY   | OSD4 layer size                         |
| 0×00f0             | OSD4_PITCH     | OSD4 layer pitch                        |
| 0x00f4             | OSD4_DISP_XY   | OSD4 layer start position in work plane |
| 0x00f8             | OSD4_ALPHA     | OSD4 layer alpha                        |
| 0x00fc             | OSD4_GREY_RGB  | OSD4 layer RGB constant of              |
| •                  |                | •                                       |



|                    |                 | <u> </u>                                |
|--------------------|-----------------|-----------------------------------------|
|                    |                 | GREY format                             |
| 0x0100             | OSD4_CK         | OSD4 layer color-key                    |
| OSD5 Layer Control |                 |                                         |
| 0x0110             | OSD5_CTRL       | OSD5 layer configuration                |
| 0x0114             | OSD5_BASE_ADDR  | OSD5 layer data base address            |
| 0x0118             | dummy           |                                         |
| 0x011c             | OSD5_SIZE_XY    | OSD5 layer size                         |
| 0x0120             | OSD5_PITCH      | OSD5 layer pitch                        |
| 0x0124             | OSD5_DISP_XY    | OSD5 layer start position in work plane |
| 0x0128             | OSD5_ALPHA      | OSD5 layer alpha                        |
| 0x012c             | OSD5_GREY_RGB   | OSD5 layer RGB constant of GREY format  |
| 0x0130             | OSD5_CK         | OSD5 layer color-key                    |
| Capture Control    |                 |                                         |
| 0x0140             | CAP_CTRL        | Capture configuration                   |
| 0x0144             | CAP_BASE_ADDR   | Capture base address                    |
| 0x0148             | CAP_START_XY    | Capture start position in work plane    |
| 0x014c             | CAP_SIZE_XY     | Capture size                            |
| 0x0150             | CAP_PITCH       | Capture pitch                           |
| YUV2RGB Control    |                 |                                         |
| 0x0160             | Y2R_CTRL        | YUV to RGB configuration                |
| 0x0164             | Y2R_CONTRAST    | Adjustment value of contrast            |
| 0x0168             | Y2R_SATURATION  | Adjustment value of saturation          |
| 0x016c             | Y2R_BRIGHTNESS  | Adjustment value of brightness          |
| Interrupt Control  |                 |                                         |
| 0x0170             | LCDC_IRQ_EN     | LCDC interrupt enable                   |
| 0x0174             | LCDC_IRQ_CLR    | LCDC interrupt clear                    |
| 0x0178             | LCDC_IRQ_STATUS | LCDC masked interrupt                   |
| 0x017c             | LCDC_IRQ_RAW    | LCDC raw interrupt                      |
|                    | •               |                                         |



| LCM Control |             |                                |
|-------------|-------------|--------------------------------|
| 0x0180      | LCM_CTRL    | LCM device configuration       |
| 0x0184      | LCM_TIMING0 | Timing setting for CS0 device  |
| 0x0188      | LCM_TIMING1 | Timing setting for CS1 device  |
| 0x018c      | LCM_RDATA   | Read back data from LCM device |
| 0x0190      | LCM_RSTN    | LCM device reset control       |
| 0x01a0      | LCM_CMD     | AHB channel command            |
| 0x01a4      | LCM_DATA    | AHB channel data               |

## 7.3.5.2 Register Descriptions

#### 7.3.5.2.1 LCDC\_CTRL

Description: LCDC module control

| 0x0000 |         |    | LCD | C mod | ule co | ntrol (ı | reset 0 | x0)  |       |       |               |                   |                  | L                 | CDC_0                  | CTRL            |
|--------|---------|----|-----|-------|--------|----------|---------|------|-------|-------|---------------|-------------------|------------------|-------------------|------------------------|-----------------|
| Bit    | 31      | 30 | 29  | 28    | 27     | 26       | 25      | 24   | 23    | 22    | 21            | 20                | 19               | 18                | 17                     | 16              |
| Name   |         |    |     |       |        |          |         | Rese | erved |       |               |                   |                  |                   |                        |                 |
| Туре   |         | 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   | REQ_GAP |    |     |       |        |          |         |      |       | erved | BLE ND_ MO DE | DIT<br>HER<br>_EN | LCD<br>C_R<br>UN | FMA<br>RK_<br>POL | FMA<br>RK_<br>MO<br>DE | LCD<br>C_E<br>N |
| Туре   | 71      |    |     | R/    | W      |          |         |      | R     | 0     | R/W           | R/W               | WO               | R/W               | R/W                    | R/W             |
| Reset  | 0       | 0  | 0   | 0     | 0      | 0        | 0       | 0    | 0     | 0     | 0             | 0                 | 0                | 0                 | 0                      | 0               |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                 |
|------------|---------|------|----------------|---------------------------------------------|
|            | [31:16] | RO   | 16'h0          | Reserved                                    |
| REQ_GAP    | [15:8]  | R/W  | 8'h0           | The interval between 2 AHB master requests. |
|            | [7:6]   | RO   | 2'h0           | Reserved                                    |



| BLEND_MODE | [5] | R/W | 1'h0 | Blending mode                                                                                                                                                 |
|------------|-----|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |     |     |      | 0- L = L0*(1-alpha) + L1*alpha;                                                                                                                               |
|            |     |     |      | 1- L = L0*alpha + L1 (only for 2 layer application).                                                                                                          |
| DITHER_EN  | [4] | R/W | 1'h0 | dithering enable                                                                                                                                              |
|            |     |     |      | 0-disable;                                                                                                                                                    |
|            |     |     |      | 1-enable.                                                                                                                                                     |
|            |     |     |      | Dithering includes 565 and 666 two modes, when in display mode, the mode decided by LCM setting; when in capture mode, the mode is decided by capture format. |
| LCDC_RUN   | [3] | WO  | 1'h0 | LCDC run, write '1' to run the LCDC, it will be cleared by HW.                                                                                                |
| FMARK_POL  | [2] | R/W | 1'h0 | Fmark signal polarity control                                                                                                                                 |
|            |     |     |      | 0-fmark valid at '1';                                                                                                                                         |
|            |     |     |      | 1-fmark valid at '0'.                                                                                                                                         |
| FMARK_MODE | [1] | R/W | 1'h0 | External FMARK panel setting                                                                                                                                  |
|            |     |     |      | 0-FMARK device;                                                                                                                                               |
|            |     |     |      | 1-Non-FMARK device.                                                                                                                                           |
| LCDC_EN    | [0] | R/W | 1'h0 | LCDC enable control                                                                                                                                           |
|            |     |     | 4    | 0-LCDC Disable                                                                                                                                                |
|            |     |     |      | 1-LCDC Enable;                                                                                                                                                |

# 7.3.5.2.2 LCDC\_DISP\_SIZE

Description: LCDC work plane size.



| 0x0004 |    |      | LCD   | C work | plane | size (      | reset 0 | )x0) |    |        |        |    |    | LCDC_DISP_SIZE |          |    |  |  |
|--------|----|------|-------|--------|-------|-------------|---------|------|----|--------|--------|----|----|----------------|----------|----|--|--|
| Bit    | 31 | 30   | 29    | 28     | 27    | 26          | 25      | 24   | 23 | 22     | 21     | 20 | 19 | 18             | 17       | 16 |  |  |
| Name   |    | Rese | erved |        |       | DISP_SIZE_Y |         |      |    |        |        |    |    |                |          |    |  |  |
| Туре   |    | R    | .0    |        |       | R/W         |         |      |    |        |        |    |    |                | <b>\</b> |    |  |  |
| 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   |    | Rese | erved |        |       |             |         |      |    | DISP_S | SIZE_X |    |    |                | abla     |    |  |  |
| Туре   |    | R    | 0     |        | R/W   |             |         |      |    |        |        |    |    |                |          |    |  |  |
| Reset  | 0  | 0    | 0     | 0      | 0     | 0           | 0       | 0    | 0  | 0      | 0      | 0  | 0  | 0              | 0        | 0  |  |  |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                         |
|-------------|---------|------|----------------|-----------------------------------------------------|
|             | [31:28] | RO   | 4'h0           | Reserved                                            |
| DISP_SIZE_Y | [27:16] | R/W  | 12'h0          | Work plane vertical size, should be >0 and <1024.   |
|             | [15:12] | RO   | 4'h0           | Reserved                                            |
| DISP_SIZE_X | [11:0]  | R/W  | 12'h0          | Work plane horizontal size, should be >0 and <1024. |

## 7.3.5.2.3 LCDC\_LCM\_START

Description: LCDC display window start position.



| 0x0008 |    |      | LCD   | C displ | ay wir | ndow s      | tart po | sition | (reset | (0x0) |        |    | LC | LCDC_LCM_START |          |    |  |
|--------|----|------|-------|---------|--------|-------------|---------|--------|--------|-------|--------|----|----|----------------|----------|----|--|
| Bit    | 31 | 30   | 29    | 28      | 27     | 26          | 25      | 24     | 23     | 22    | 21     | 20 | 19 | 18             | 17       | 16 |  |
| Name   |    | Rese | erved |         |        | LCM_START_Y |         |        |        |       |        |    |    |                |          |    |  |
| Туре   |    | R    | .0    |         |        | R/W         |         |        |        |       |        |    |    |                | <b>\</b> |    |  |
| 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   |    | Rese | erved |         |        |             |         |        |        | LCM_S | TART_X |    |    |                | abla     |    |  |
| Туре   |    | R    | .0    |         | R/W    |             |         |        |        |       |        |    |    |                |          |    |  |
| Reset  | 0  | 0    | 0     | 0       | 0      | 0           | 0       | 0      | 0      | 0     | 0      | 0  | 0  | 0              | 0        | 0  |  |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                                                                                                   |
|-------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------|
|             | [31:28] | RO   | 4'h0           | Reserved                                                                                                                      |
| LCM_START_Y | [27:16] | R/W  | 14'h0          | Display window vertical start position, it is based on the top left point of work plane. Please ensure it is in work plane.   |
|             | [15:12] | RO   | 4'h0           | Reserved                                                                                                                      |
| LCM_START_X | [11:0]  | R/W  | 12'h0          | Display window horizontal start position, it is based on the top left point of work plane. Please ensure it is in work plane. |

# 7.3.5.2.4 LCDC\_LCM\_SIZE

Description: LCDC display window size



| 0x000c |    |      | LCD   | C disp | lay wir | ndow s     | ize (re | set 0x | 0) |       |        |    |    | LCDC_LCM_SIZE |       |          |  |
|--------|----|------|-------|--------|---------|------------|---------|--------|----|-------|--------|----|----|---------------|-------|----------|--|
| Bit    | 31 | 30   | 29    | 28     | 27      | 26         | 25      | 24     | 23 | 22    | 21     | 20 | 19 | 18            | 17    | 16       |  |
| Name   |    | Rese | erved |        |         | LCM_SIZE_Y |         |        |    |       |        |    |    |               |       |          |  |
| Туре   |    | R    | .0    |        |         | R/W        |         |        |    |       |        |    |    |               |       | <b>\</b> |  |
| 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   |    | Rese | erved |        |         |            |         |        |    | LCM_S | SIZE_X |    |    |               | abla  |          |  |
| Туре   |    | R    | 0     |        | R/W     |            |         |        |    |       |        |    |    |               |       |          |  |
| Reset  | 0  | 0    | 0     | 0      | 0       | 0          | 0       | 0      | 0  | 0     | 0      | 0  | 0  | 0             | 0     | 0        |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                         |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------|
|            | [31:28] | RO   | 4'h0           | Reserved                                                                                                            |
| LCM_SIZE_Y | [27:16] | R/W  | 12'h0          | Display window vertical size, it is based on the top left point of work plane. Please ensure it is in work plane.   |
|            | [15:12] | RO   | 4'h0           | Reserved                                                                                                            |
| LCM_SIZE_X | [11:0]  | R/W  | 12'h0          | Display window horizontal size, it is based on the top left point of work plane. Please ensure it is in work plane. |

# 7.3.5.2.5 LCDC\_BG\_COLOR

Description: LCDC background color.



| 0x0010 |    |                                           | LCD | C back | groun | d colo | r (rese | t 0x0) |      |   |    |   | LCDC_BG_COLOR |      |          |   |  |
|--------|----|-------------------------------------------|-----|--------|-------|--------|---------|--------|------|---|----|---|---------------|------|----------|---|--|
| Bit    | 31 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 |     |        |       |        |         |        |      |   | 16 |   |               |      |          |   |  |
| Name   |    |                                           |     | Rese   | erved |        |         |        | BG_R |   |    |   |               |      |          |   |  |
| Туре   |    |                                           |     | R      | 0     |        |         |        | R/W  |   |    |   |               |      | <b>•</b> |   |  |
| 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   |    |                                           |     | BG     | _G    |        |         |        | BG_B |   |    |   |               | abla |          |   |  |
| Туре   |    |                                           |     | R/     | W     |        |         |        | RW   |   |    |   |               |      |          |   |  |
| Reset  | 0  | 0                                         | 0   | 0      | 0     | 0      | 0       | 0      | 0    | 0 | 0  | 0 | 0             | 0    | 0        | 0 |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description      |
|------------|---------|------|----------------|------------------|
|            | [31:24] | RO   | 8'h0           | Reserved         |
| BG_R       | [23:16] | R/W  | 8'h0           | Background red   |
| BG_G       | [15:8]  | R/W  | 8'h0           | Background green |
| BG_B       | [7:0]   | R/W  | 8'h0           | Background blue  |

# 7.3.5.2.6 LCDC\_FIFO\_STATUS

Description: LCDC internal FIFO status.



| 0x0014 |      |       | LCD      | Cinter                                            | nal FIF        | O stat | us (re | set 0x                        | 155555 | 5)                  |    |                  | LCE   | C_FIF  | O_ST  | ATUS  |
|--------|------|-------|----------|---------------------------------------------------|----------------|--------|--------|-------------------------------|--------|---------------------|----|------------------|-------|--------|-------|-------|
| Bit    | 31   | 30    | 29       | 28                                                | 27             | 26     | 25     | 24                            | 23     | 22                  | 21 | 20               | 19    | 18     | 17    | 16    |
| Name   |      |       |          |                                                   | Rese           | erved  |        | OUTP<br>FO_                   | _      | DITHER_FIF<br>O_STS |    | Y2R_FIFO_S<br>TS |       |        |       |       |
| Туре   |      |       | RO RO RO |                                                   |                |        |        |                               |        |                     |    |                  | R     | 0      |       |       |
| Reset  | 0    | 0     | 0        | 0                                                 | 0              | 0      | 0      | 0                             | 0      | 0                   | 0  | 1                | 0 1 0 |        |       | 1     |
| Bit    | 15   | 14    | 13       | 12                                                | 11             | 10     | 9      | 8                             | 7      | 6                   | 5  | 4                | 3     | 2      | 1     | 0     |
| Name   | OSD5 | _FIFO | OSD4     | OSD4_FIFO OSD3_FIFO OSD2_FIFO OSD1_FIFO OSD1_ALPH |                |        |        | OSD3_FIFO OSD2_FIFO OSD1_FIFO |        |                     |    |                  |       | JV_FIF | IMG_Y | _FIFO |
| Name   | _S   | TS    | _S       | TS                                                | _STS _STS _STS |        |        |                               |        | A_FIFO_STS          |    | O_STS            |       | S _STS |       |       |
| Туре   | R    | 0     | R        | 0                                                 | R              | 0      | RO     |                               | RO     |                     | RO |                  | RO    |        | RO    |       |
| Reset  | 0    | 1     | 0        | 1                                                 | 0              | 1      | 0      | 1                             | 0      | 1                   | 0  | 1                | 0     | 1      | 0     | 1     |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                              |
|-----------------|---------|------|----------------|------------------------------------------|
|                 | [31:22] | RO   | 10'h0          | Reserved                                 |
| OUTPUT_FIFO_STS | [21:20] | RO   | 2'h01          | Cross domain FIFO info.                  |
|                 |         |      |                | [21] - FIFO full status, '1' for full;   |
|                 |         |      |                | [20] - FIFO empty status, '1' for empty. |
| DITHER_FIFO_STS | [19:18] | RO   | 2'h01          | Dithering output FIFO info.              |
|                 |         |      |                | [19] - FIFO full status, '1' for full;   |
|                 | 5       |      |                | [18] - FIFO empty status, '1' for empty. |
| Y2R_FIFO_STS    | [17:16] | RO   | 2'h01          | YUV to RGB work FIFO info.               |
|                 |         |      |                | [17] - FIFO full status, '1' for full;   |
|                 |         |      |                | [16] - FIFO empty status, '1' for empty  |
| OSD5_FIFO_STS   | [15:14] | RO   | 2'h01          | OSD5 layer FIFO info.                    |
| 0,0             |         |      |                | [15] - FIFO full status, '1' for full;   |
|                 |         |      |                | [14] - FIFO empty status, '1' for empty  |
| OSD4_FIFO_STS   | [13:12] | RO   | 2'h01          | OSD4 layer FIFO info.                    |
|                 |         |      |                | [13] - FIFO full status, '1' for full;   |
|                 |         |      |                | [12] - FIFO empty status, '1' for empty  |
| OSD3_FIFO_STS   | [11:10] | RO   | 2'h01          | OSD3 layer FIFO info.                    |
|                 |         |      |                | [11] - FIFO full status, '1' for full;   |



|                     |       |    |       | [10] - FIFO empty status, '1' for empty                                             |
|---------------------|-------|----|-------|-------------------------------------------------------------------------------------|
| OSD2_FIFO_STS       | [9:8] | RO | 2'h01 | OSD2 layer FIFO info.                                                               |
|                     |       |    |       | [9] - FIFO full status, '1' for full;                                               |
|                     |       |    |       | [8] - FIFO empty status, '1' for empty                                              |
| OSD1_FIFO_STS       | [7:6] | RO | 2'h01 | OSD1 layer FIFO info.                                                               |
|                     |       |    |       | [7] - FIFO full status, '1' for full;                                               |
|                     |       |    |       | [6] - FIFO empty status, '1' for empty                                              |
| OSD1_ALPHA_FIFO_STS | [5:4] | RO | 2'h01 | OSD1 layer alpha FIFO info, it is active when OSD1 is RGB565 with pixel alpha.      |
|                     |       |    |       | [5] - FIFO full status, '1' for full;                                               |
|                     |       |    |       | [4] - FIFO empty status, '1' for empty                                              |
| IMG_UV_FIFO_STS     | [3:2] | RO | 2'h01 | Image layer UV data FIFO info, it is active when image is YUV422 and YUV420 format. |
|                     |       |    |       | [3] - FIFO full status, '1' for full;                                               |
|                     |       |    |       | [2] - FIFO empty status, '1' for empty.                                             |
| IMG_Y_FIFO_STS      | [1:0] | RO | 2'h01 | Image layer Y data FIFO info.                                                       |
|                     |       |    |       | [1] - FIFO full status, '1' for full;                                               |
|                     |       |    |       | [0] - FIFO empty status, '1' for empty                                              |

## 7.3.5.2.7 IMG\_CTRL

Description: Image layer configuration.



| 0x0020 |    |          | Imag                          | e laye | r confi                                  | guratio | on (res | set 0x0 | )  |    |    |      |       |            | IMG_0 | CTRL |
|--------|----|----------|-------------------------------|--------|------------------------------------------|---------|---------|---------|----|----|----|------|-------|------------|-------|------|
| Bit    | 31 | 30       | 29                            | 28     | 27                                       | 26      | 25      | 24      | 23 | 22 | 21 | 20   | 19    | 18         | 17    | 16   |
| Name   |    | Reserved |                               |        |                                          |         |         |         |    |    |    |      |       |            |       |      |
| Туре   |    |          | 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   |    | Rese     | erved                         |        | IMG_UV_SW ITCH ITC  IMG_Y_SWI TCH ITC  H |         |         |         |    |    | 3  | Rese | erved | IMG<br>_EN |       |      |
| Туре   |    | R        | 0                             |        | R/W R/W R/W                              |         |         |         |    | R  | 0  | R/W  |       |            |       |      |
| Reset  | 0  | 0        | 0                             | 0      | 0                                        | 0       | 0       | 0       | 0  | 0  | 0  | 0    | 0     | 0          | 0     | 0    |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [31:12] | RO   | 20'h0          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                            |
| IMG_UV_SWITCH | [11:10] | R/W  | 2'h0           | When image data is RGB format, it is useless; when image data is YUV format, it is image layer UV data byte order in a 32bits word, the source is B <sub>0</sub> B <sub>1</sub> B <sub>2</sub> B <sub>3</sub> , the destination is: 0-B <sub>0</sub> B <sub>1</sub> B <sub>2</sub> B <sub>3</sub> ; 1-B <sub>3</sub> B <sub>2</sub> B <sub>1</sub> B <sub>0</sub> ; 2-B <sub>2</sub> B <sub>3</sub> B <sub>0</sub> B <sub>1</sub> ; |
| IMG_RB_SWITCH | [9]     | R/W  | 1'h0           | 3-reserved.  R/B order switch for RGB data  0- DONOT switch;  1- exchange R and B.  Active for RGB888/666/565/555 data.                                                                                                                                                                                                                                                                                                             |
| IMG_Y_SWITCH  | [8:7]   | R/W  | 2'h0           | Image layer Y/RGB data byte order in a 32bits word, the source is B <sub>0</sub> B <sub>1</sub> B <sub>2</sub> B <sub>3</sub> , the destination is:  0-B <sub>0</sub> B <sub>1</sub> B <sub>2</sub> B <sub>3</sub> ;  1-B <sub>3</sub> B <sub>2</sub> B <sub>1</sub> B <sub>0</sub> ;                                                                                                                                               |



|            |       |     |      | 2-B <sub>2</sub> B <sub>3</sub> B <sub>0</sub> B <sub>1</sub> ; |
|------------|-------|-----|------|-----------------------------------------------------------------|
|            |       |     |      | 3-reserved.                                                     |
| IMG_FORMAT | [6:3] | R/W | 4'h0 | Image layer data format, it supports following                  |
|            |       |     |      | ones:                                                           |
|            |       |     |      | 0000-YUV422;                                                    |
|            |       |     |      | 0001-YUV420;                                                    |
|            |       |     |      | 0010-YUV400;                                                    |
|            |       |     |      | 0011-RGB888;                                                    |
|            |       |     |      | 0100-RGB666;                                                    |
|            |       |     |      | 0101-RGB565;                                                    |
|            |       |     |      | 0110-RGB555;                                                    |
|            |       |     |      | Others are invalid.                                             |
|            | [2:1] | RO  | 2'h0 | Reserved                                                        |
| IMG_EN     | [0]   | R/W | 1'h0 | Image layer enable                                              |
|            |       |     |      | 0-disable;                                                      |
|            |       |     |      | 1-enable.                                                       |

## 7.3.5.2.8 IMG\_Y\_BASE\_ADDR

Description: Image Y component base address.

| 0x0024 |    |    | Imag            | е Ү со                              | mpone | ent bas | se add | ress (r | eset 0 | x0) |   |   | IMG_Y_BASE_ADDR |    |    |   |  |
|--------|----|----|-----------------|-------------------------------------|-------|---------|--------|---------|--------|-----|---|---|-----------------|----|----|---|--|
| Bit    | 31 | 30 | 29              | 29 28 27 26 25 24 23 22 21 20 19 18 |       |         |        |         |        |     |   |   | 18              | 17 | 16 |   |  |
| Name   |    |    | IMG_Y_BASE_ADDR |                                     |       |         |        |         |        |     |   |   |                 |    |    |   |  |
| Туре   |    | X  |                 | R/W                                 |       |         |        |         |        |     |   |   |                 |    |    |   |  |
| 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   |    |    |                 | IMG_Y_BASE_ADDR                     |       |         |        |         |        |     |   |   |                 |    |    |   |  |
| Туре   |    |    | R/W             |                                     |       |         |        |         |        |     |   |   |                 |    |    |   |  |
| Reset  | 0  | 0  | 0               | 0                                   | 0     | 0       | 0      | 0       | 0      | 0   | 0 | 0 | 0               | 0  | 0  | 0 |  |

| Field Name      | Bit    | Туре | Reset<br>Value | Description                                 |
|-----------------|--------|------|----------------|---------------------------------------------|
| IMG_Y_BASE_ADDR | [31:0] | R/W  | 32'h0          | When image is YUV format, it is Y data base |



|  | address; when image is RGB format, it is |
|--|------------------------------------------|
|  | RGB data base address.                   |

#### 7.3.5.2.9 IMG\_UV\_BASE\_ADDR

Description: Image UV component base address.

| 0x0028 |    |    | Imag | e UV d           | ompo | nent b | ase ad | ldress | (reset | 0x0) |    |    | IMC | <b>5_UV_</b> I | BASE_ | ADD<br>R |
|--------|----|----|------|------------------|------|--------|--------|--------|--------|------|----|----|-----|----------------|-------|----------|
| Bit    | 31 | 30 | 29   | 28               | 27   | 26     | 25     | 24     | 23     | 22   | 21 | 20 | 19  | 18             | 17    | 16       |
| Name   |    |    |      |                  |      |        | IMO    | G_UV_B | ASE_AD | DR   |    |    |     |                |       |          |
| Туре   |    |    |      |                  |      |        |        | R/     | W      |      | •  |    |     |                |       |          |
| 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   |    |    |      | IMG_UV_BASE_ADDR |      |        |        |        |        |      |    |    |     |                |       |          |
| Туре   |    |    |      | R/W              |      |        |        |        |        |      |    |    |     |                |       |          |
| Reset  | 0  | 0  | 0    | 0                | 0    | 0      | 0      | 0      | 0      | 0    | 0  | 0  | 0   | 0              | 0     | 0        |

| Field Name       | Bit    | Туре | Reset<br>Value | Description                                                                     |
|------------------|--------|------|----------------|---------------------------------------------------------------------------------|
| IMG_UV_BASE_ADDR | [31:0] | R/W  | 32'h0          | When image is YUV format, it is UV data base address; otherwise, it is useless. |

#### 7.3.5.2.10 IMG\_SIZE\_XY

Description: Image layer size.



| 0x002c |    |      | Imag  | e laye | r size ( | size (reset 0x0) |    |    |    |       |        |    |    | IMG_SIZE_XY |      |          |  |
|--------|----|------|-------|--------|----------|------------------|----|----|----|-------|--------|----|----|-------------|------|----------|--|
| Bit    | 31 | 30   | 29    | 28     | 27       | 26               | 25 | 24 | 23 | 22    | 21     | 20 | 19 | 18          | 17   | 16       |  |
| Name   |    | Rese | erved |        |          |                  |    |    |    | IMG_S | SIZE_Y |    |    |             |      |          |  |
| Туре   |    | R    | .0    |        |          |                  |    |    |    | R     | W      |    |    |             |      | <b>\</b> |  |
| 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   |    | Rese | erved |        |          |                  |    |    |    | IMG_S | SIZE_X |    |    |             | abla |          |  |
| Туре   |    | R    | 0     |        |          | R/W              |    |    |    |       |        |    |    |             |      |          |  |
| Reset  | 0  | 0    | 0     | 0      | 0        | 0                | 0  | 0  | 0  | 0     | 0      | 0  | 0  | 0           | 0    | 0        |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                      |
|------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:28] | RO   | 4'h0           | Reserved                                                                                                                                         |
| IMG_SIZE_Y | [27:16] | R/W  | 12'h0          | Image layer vertical size, it is based on the top left point of work plane. Please ensure it is in work plane.                                   |
|            | [15:12] | RO   | 4'h0           | Reserved                                                                                                                                         |
| IMG_SIZE_X | [11:0]  | R/W  | 12'h0          | Image layer horizontal size, it is based on the top left point of work plane. Please ensure it is in work plane, and image data is word aligned. |

## 7.3.5.2.11 IMG\_PITCH

Description: Image layer pitch.



| 0x0030 |    |      | Imag  | e laye | r pitch | (reset | 0x0) |      |       |       |       |    | IMG_PITCH |    |      |    |  |
|--------|----|------|-------|--------|---------|--------|------|------|-------|-------|-------|----|-----------|----|------|----|--|
| Bit    | 31 | 30   | 29    | 28     | 27      | 26     | 25   | 24   | 23    | 22    | 21    | 20 | 19        | 18 | 17   | 16 |  |
| Name   |    |      |       |        |         |        |      | Rese | erved |       |       |    |           |    |      |    |  |
| Туре   |    |      |       |        |         |        |      | R    | 0     |       |       |    |           |    |      |    |  |
| 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   |    | Rese | erved |        |         |        |      |      |       | IMG_I | PITCH |    |           |    | abla |    |  |
| Туре   |    | R    | 0     |        | R/W     |        |      |      |       |       |       |    |           |    |      |    |  |
| Reset  | 0  | 0    | 0     | 0      | 0       | 0      | 0    | 0    | 0     | 0     | 0     | 0  | 0         | 0  | 0    | 0  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description        |
|------------|---------|------|----------------|--------------------|
|            | [31:12] | RO   | 20'h0          | Reserved           |
| IMG_PITCH  | [11:0]  | R/W  | 12'h0          | Image layer pitch. |

## 7.3.5.2.12 IMG\_DISP\_XY

Description: Image layer start position.

| 0x0034 |    |      | Imag  | e laye | r start | positio | n (res | et 0x0 | )  |       |       |    | IMG_DISP_XY |    |    |    |
|--------|----|------|-------|--------|---------|---------|--------|--------|----|-------|-------|----|-------------|----|----|----|
| Bit    | 31 | 30   | 29    | 28     | 27      | 26      | 25     | 24     | 23 | 22    | 21    | 20 | 19          | 18 | 17 | 16 |
| Name   |    | Rese | erved |        |         |         |        |        |    | IMG_D | ISP_Y |    |             |    |    |    |
| Туре   |    | R    | 0     |        |         |         |        |        |    | R/    | W     |    |             |    |    |    |
| 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   |    | Rese | erved |        |         |         |        |        |    | IMG_D | ISP_X |    |             |    |    |    |
| Туре   |    | R    | .0    |        | R/W     |         |        |        |    |       |       |    |             |    |    |    |
| Reset  | 0  | 0    | 0     | 0      | 0       | 0       | 0      | 0      | 0  | 0     | 0     | 0  | 0           | 0  | 0  | 0  |

| Field Name | Bit     | Туре | Reset<br>Value | Description |
|------------|---------|------|----------------|-------------|
|            | [31:28] | RO   | 4'h0           | Reserved    |



| IMG_DISP_Y | [27:16] | R/W | 12'h0 | Image layer vertical start position, it is based on the top left point of work plane. Please ensure it is in work plane.    |
|------------|---------|-----|-------|-----------------------------------------------------------------------------------------------------------------------------|
|            | [15:12] | RO  | 4'h0  | Reserved                                                                                                                    |
| IMG_DISP_X | [11:0]  | R/W | 12'h0 | Image layer horizontal start position, it is based on the top left point of work plane.  Please ensure it is in work plane. |

#### 7.3.5.2.13 OSDx\_CTRL

Description: OSD layer configuration, x=1~5.

| 0x0050 |    |      | OSD.  | 1 layer                              | confi | guratio        | on (res                        | et 0x0)    | )          |    |        |       |           | C                              | SD1_0                  | CTRL            |  |  |
|--------|----|------|-------|--------------------------------------|-------|----------------|--------------------------------|------------|------------|----|--------|-------|-----------|--------------------------------|------------------------|-----------------|--|--|
| 0x0080 |    |      | OSD   | 2 layer                              | confi | guratio        | n (res                         | et 0x0)    | )          |    |        |       | OSD2_CTRL |                                |                        |                 |  |  |
| 0x00b0 |    |      | OSD:  | 3 layer                              | confi | guratio        | on (res                        | et 0x0)    | )          |    |        |       |           | OSD3_CTRL                      |                        |                 |  |  |
| 0x00e0 |    |      | OSD   | OSD4 layer configuration (reset 0x0) |       |                |                                |            |            |    |        |       |           | C                              | SD4_0                  | CTRL            |  |  |
| 0x0110 |    |      | OSD   | OSD5 layer configuration (reset 0x0) |       |                |                                |            |            |    |        |       |           | C                              | SD5_0                  | CTRL            |  |  |
| Bit    | 31 | 30   | 29    | 28                                   | 27    | 26             | 25                             | 24         | 23         | 22 | 21     | 20    | 19        | 18                             | 17                     | 16              |  |  |
| Name   |    |      |       |                                      |       |                |                                | Rese       | erved      |    |        |       |           |                                |                        |                 |  |  |
| Туре   |    |      |       | 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   |    | Rese | erved |                                      |       | _ALPH<br>VITCH | OSD<br>x_R<br>B_S<br>WIT<br>CH | OSDx_<br>C | _SWIT<br>H |    | OSDx_F | ORMAT |           | OSD<br>x_A<br>LPH<br>A_S<br>EL | OSD<br>x_C<br>K_E<br>N | OSD<br>x_E<br>N |  |  |
| Туре   |    | R    | .0    | 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     | 0         | 0                              | 0                      | 0               |  |  |
|        |    |      |       |                                      |       |                |                                |            |            |    |        |       |           |                                |                        |                 |  |  |

| Field Name        | Bit     | Туре | Reset<br>Value | Description                           |
|-------------------|---------|------|----------------|---------------------------------------|
|                   | [31:12] | RO   | 20'h0          | Reserved                              |
| OSD1_ALPHA_SWITCH | [11:10] | R/W  | 2'h0           | OSD1 layer alpha data byte order in a |



|                |       |     |      | 32bits word, the source is $B_0B_1B_2B_3$ , the destination is:     |
|----------------|-------|-----|------|---------------------------------------------------------------------|
|                |       |     |      |                                                                     |
|                |       |     |      | 0-B <sub>0</sub> B <sub>1</sub> B <sub>2</sub> B <sub>3</sub> ;     |
|                |       |     |      | $1-B_3B_2B_1B_0$ ;                                                  |
|                |       |     |      | 2-B <sub>2</sub> B <sub>3</sub> B <sub>0</sub> B <sub>1</sub> ;     |
|                |       |     |      | 3-reserved.                                                         |
|                |       |     |      | NOTE: only OSD1 layer has this field,                               |
|                |       |     |      | and it is active when OSD1 layer format is RGB565 with pixel alpha. |
|                |       |     |      |                                                                     |
| OSDx_RB_SWITCH | [9]   | R/W | 1'h0 | R/B order switch for RGB data                                       |
|                |       |     |      | 0- DONOT switch;                                                    |
|                |       |     |      | 1- exchange R and B.                                                |
|                |       |     |      | Active for RGB888/666/565/555 data.                                 |
| OSDx_SWITCH    | [8:7] | R/W | 2'h0 | OSD layer data byte order in a 32bits                               |
|                |       |     |      | word, the source is $B_0B_1B_2B_3$ , the                            |
|                |       |     |      | destination is:                                                     |
|                |       |     |      | $0-B_0B_1B_2B_3$ ;                                                  |
|                |       |     |      | $1-B_3B_2B_1B_0;$                                                   |
|                |       |     |      | $2-B_2B_3B_0B_1$ ;                                                  |
|                |       |     |      | 3-reserved.                                                         |
| OSDx_FORMAT    | [6:3] | R/W | 4'h0 | OSD layer data format, it supports                                  |
|                |       |     |      | following ones:                                                     |
|                |       |     |      | 0011-RGB888;                                                        |
|                |       |     |      | 0100-RGB666;                                                        |
|                |       |     |      | 0101-RGB565;                                                        |
|                |       |     |      | 0110-RGB555;                                                        |
|                |       |     |      | 0111-GREY;                                                          |
|                |       |     |      | Others are invalid.                                                 |
| OSDx_ALPHA_SEL | [2]   | R/W | 1'h0 | OSD layer alpha selection,                                          |
| V)             |       |     |      | 0-pixel alpha;                                                      |
|                |       |     |      | 1-block alpha.                                                      |
|                |       |     |      | When RGB565 format, only OSD1                                       |
|                |       |     |      | support pixel alpha, others OSD layers                              |
|                |       |     |      | will ignore this setting, and use its layer                         |
|                |       |     |      | alpha.                                                              |
|                |       |     |      |                                                                     |



|         |     |     |      | 0-disable;        |
|---------|-----|-----|------|-------------------|
|         |     |     |      | 1-enable.         |
| OSDx_EN | [0] | R/W | 1'h0 | OSD layer enable, |
|         |     |     |      | 0-disable;        |
|         |     |     |      | 1-enable.         |

#### 7.3.5.2.14 OSDx\_BASE\_ADDR

Description: OSD layer base address, x=1~5.

| 0x0054 |    |                | OSD.                          | 1 layer | base | addres | ss (res | et 0x0 | )      |      |          |   | 05 | D1_B  | ASE_A | ADDR |
|--------|----|----------------|-------------------------------|---------|------|--------|---------|--------|--------|------|----------|---|----|-------|-------|------|
| 0x0084 |    |                | OSD                           | 2 layer | base | addres | ss (res | et 0x0 | )      |      | <b>*</b> |   | 05 | D2_B  | ASE_A | ADDR |
| 0x00b4 |    |                | OSD                           | 3 layer | base | addres | ss (res | et 0x0 | )      |      | X        |   | OS | SD3_B | ASE_A | ADDR |
| 0x00e4 |    |                | OSD                           | 4 layer | base | addres | ss (res | et 0x0 | )      |      |          |   | 05 | SD4_B | ASE_A | ADDR |
| 0x0114 |    |                | OSD                           | 5 layer | base |        | 05      | SD5_B  | ASE_A  | ADDR |          |   |    |       |       |      |
| Bit    | 31 | 30             | 29 28 27 26 25 24 23 22 21 20 |         |      |        |         |        |        |      |          |   |    | 18    | 17    | 16   |
| Name   |    |                |                               |         |      |        | 0       | SDx_BA | SE_ADD | )R   |          |   |    |       |       |      |
| Туре   |    |                |                               |         |      |        |         | R      | W      |      |          |   |    |       |       |      |
| 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   |    | OSDx_BASE_ADDR |                               |         |      |        |         |        |        |      |          |   |    |       |       |      |
| Туре   |    | R/W            |                               |         |      |        |         |        |        |      |          |   |    |       |       |      |
| Reset  | 0  | 0              | 0                             | 0       | 0    | 0      | 0       | 0      | 0      | 0    | 0        | 0 | 0  | 0     | 0     | 0    |

| Field Name     | Bit    | Туре | Reset<br>Value | Description                     |
|----------------|--------|------|----------------|---------------------------------|
| OSDx_BASE_ADDR | [31:0] | R/W  | 32'h0          | Base address of OSD layer data. |

## 7.3.5.2.15 OSD1\_ALPHA\_BASE\_ADDR

Description: OSD1 layer alpha data base address.



| 0x0058 |    |    | OSD | 1 layer                   | · alpha | base | addres | ss (res | et 0x0 | )    |    |    | osi | D1_AL |    | BASE |  |
|--------|----|----|-----|---------------------------|---------|------|--------|---------|--------|------|----|----|-----|-------|----|------|--|
| Bit    | 31 | 30 | 29  | 28                        | 27      | 26   | 25     | 24      | 23     | 22   | 21 | 20 | 19  | 18    | 17 | 16   |  |
| Name   |    |    |     | OSD1_ALPHA_BASE_ADDR      |         |      |        |         |        |      |    |    |     |       |    |      |  |
| Туре   |    |    |     | 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   |    |    |     |                           |         |      | OSD1   | _ALPHA  | _BASE_ | ADDR |    |    |     |       |    |      |  |
| Туре   |    |    |     | R/W                       |         |      |        |         |        |      |    |    |     |       |    |      |  |
| Reset  | 0  | 0  | 0   | 0 0 0 0 0 0 0 0 0 0 0 0 0 |         |      |        |         |        |      |    |    |     |       |    |      |  |

| Field Name           | Bit    | Туре | Reset<br>Value | Description                      |
|----------------------|--------|------|----------------|----------------------------------|
| OSD1_ALPHA_BASE_ADDR | [31:0] | R/W  | 32'h0          | When OSD1 data is RGB565 format, |
|                      |        |      |                | it is base address of OSD1 alpha |
|                      |        | \    |                | data, else it is not used.       |

## 7.3.5.2.16 OSDx\_SIZE\_XY

Description: OSD layer size, x=1~5.



| 0x005c |    |      | OSD   | 1 layer | size (                  | reset ( | )x0) |   |   |       |        |   |    | OSD | 1_SIZ | E_XY |
|--------|----|------|-------|---------|-------------------------|---------|------|---|---|-------|--------|---|----|-----|-------|------|
| 0x008c |    |      | OSD   | 2 layer | size (                  | reset ( | )x0) |   |   |       |        |   |    | OSD | 2_SIZ | E_XY |
| 0x00bc |    |      | OSD   | 3 layer | size (                  | reset ( | )x0) |   |   |       |        |   |    | OSD | 3_SIZ | E_XY |
| 0x00ec |    |      | OSD   | 4 layer | size (                  | reset ( | )x0) |   |   |       |        |   |    | OSD | 4_SIZ | E_XY |
| 0x011c |    |      | OSD   | 5 layer | r size (reset 0x0)      |         |      |   |   |       |        |   |    | OSD | 5_SIZ | E_XY |
| Bit    | 31 | 30   | 29    | 28      | 27 26 25 24 23 22 21 20 |         |      |   |   |       |        |   | 19 | 18  | 17    | 16   |
| Name   |    | Rese | erved |         |                         |         |      |   |   | OSDx_ | SIZE_Y |   |    |     | abla  |      |
| Туре   |    | R    | 10    |         |                         |         |      |   |   | R/    | W      |   |    |     |       |      |
| 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   |    | Rese | erved |         | OSDx_SIZE_X             |         |      |   |   |       |        |   |    |     |       |      |
| Туре   |    | R    | 10    |         |                         |         |      |   |   | R/    | w      |   |    |     |       |      |
| Reset  | 0  | 0    | 0     | 0       | 0                       | 0       | 0    | 0 | 0 | 0     | 0      | 0 | 0  | 0   | 0     | 0    |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                                                                                                                  |
|-------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
|             | [31:28] | RO   | 4'h0           | Reserved                                                                                                                                     |
| OSDx_SIZE_Y | [27:16] | R/W  | 12'h0          | OSD layer vertical size, it is based on the top left point of work plane. Please ensure it is in work plane.                                 |
| . 3         | [15:12] | RO   | 4'h0           | Reserved                                                                                                                                     |
| OSDx_SIZE_X | [11:0]  | R/W  | 12'h0          | OSD layer horizontal size, it is based on the top left point of work plane. Please ensure it is in work plane, and OSD data is word aligned. |

# 7.3.5.2.17 OSDx\_PITCH

Description: OSD layer pitch, x=1~5.



| 0x0060 |    |      | OSD.  | 1 layer | pitch      | (reset | 0x0) |      |       |    |   |   |   | 0 | SD1_P | птсн |
|--------|----|------|-------|---------|------------|--------|------|------|-------|----|---|---|---|---|-------|------|
| 0x0090 |    |      | OSD   | 2 layer | pitch      | (reset | 0x0) |      |       |    |   |   |   | 0 | SD2_P | ІТСН |
| 0x00c0 |    |      | OSD   | 3 layer | pitch      | (reset | 0x0) |      |       |    |   |   |   | 0 | SD3_P | ІТСН |
| 0x00f0 |    |      | OSD   | 4 layer | pitch      | (reset | 0x0) |      |       |    |   |   |   | 0 | SD4_P | тсн  |
| 0x0120 |    |      | OSD   | 5 layer | pitch      | (reset | 0x0) |      |       |    |   |   |   | 0 | SD5_P | тсн  |
| Bit    | 31 | 30   | 29    | 28      | 27         | 25     | 19   | 18   | 17    | 16 |   |   |   |   |       |      |
| Name   |    |      |       |         |            |        |      | Rese | erved |    |   |   |   |   |       |      |
| Туре   |    |      |       |         |            |        |      | R    | .0    |    |   |   |   |   |       |      |
| 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   |    | Rese | erved |         | OSDx_PITCH |        |      |      |       |    |   |   |   |   |       |      |
| Туре   |    | R    | .0    |         |            |        |      |      |       | R/ | w |   |   |   |       |      |
| Reset  | 0  | 0    | 0     | 0       | 0          | 0      | 0    | 0    | 0     | 0  | 0 | 0 | 0 | 0 | 0     | 0    |

| Field Name | Bit     | Туре | Reset<br>Value | Description      |
|------------|---------|------|----------------|------------------|
|            | [31:12] | RO   | 20'h0          | Reserved         |
| OSDx_PITCH | [11:0]  | R/W  | 12'h0          | OSD layer pitch. |

# 7.3.5.2.18 OSDx\_DISP\_XY

Description: OSD layer start position, x=1~5.



| 0x0064 |    |      | OSD.  | 1 layer | start                      | positio | n (res | et 0x0) | ) |        |        |   |    | OSD | 1_DIS | P_XY |
|--------|----|------|-------|---------|----------------------------|---------|--------|---------|---|--------|--------|---|----|-----|-------|------|
| 0x0094 |    |      | OSD   | 2 layer | start                      | positio | n (res | et 0x0) | ) |        |        |   |    | OSD | 2_DIS | P_XY |
| 0x00c4 |    |      | OSD   | 3 layer | start                      | positio | n (res | et 0x0) | ) |        |        |   |    | OSD | 3_DIS | P_XY |
| 0x00f4 |    |      | OSD   | 4 layer | start                      | positio | n (res | et 0x0) | ) |        |        |   |    | OSD | 4_DIS | P_XY |
| 0x0124 |    |      | OSD   | 5 layer | start position (reset 0x0) |         |        |         |   |        |        |   |    | OSD | 5_DIS | P_XY |
| Bit    | 31 | 30   | 29    | 28      | 27 26 25 24 23 22 21 20    |         |        |         |   |        |        |   | 19 | 18  | 17    | 16   |
| Name   |    | Rese | erved |         |                            |         |        |         |   | OSDx_I | DISP_Y |   |    |     | abla  |      |
| Туре   |    | R    | .0    |         |                            |         |        |         |   | R/     | W      |   |    |     |       |      |
| 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   |    | Rese | erved |         | OSDx_DISP_X                |         |        |         |   |        |        |   |    |     |       |      |
| Туре   |    | R    | 0     |         |                            |         |        |         |   | R/     | w      |   |    |     |       |      |
| Reset  | 0  | 0    | 0     | 0       | 0                          | 0       | 0      | 0       | 0 | 0      | 0      | 0 | 0  | 0   | 0     | 0    |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                                                                                    |
|-------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------|
|             | [31:28] | RO   | 4'h0           | Reserved                                                                                                       |
| OSDx_DISP_Y | [27:16] | R/W  | 12'h0          | OSD layer vertical size, it is based on the top left point of work plane. Please ensure it is in work plane.   |
|             | [15:12] | RO   | 4'h0           | Reserved                                                                                                       |
| OSDx_DISP_X | [11:0]  | R/W  | 12'h0          | OSD layer horizontal size, it is based on the top left point of work plane. Please ensure it is in work plane. |

## 7.3.5.2.19 OSDx\_ALPHA

Description: OSD layer alpha, x=1~5.



| 0x0068 |    |          | OSD.                   | 1 alpha | a (rese | t 0x0) |    |      |               |    |    |       |       | os | D1_AI | _PHA |
|--------|----|----------|------------------------|---------|---------|--------|----|------|---------------|----|----|-------|-------|----|-------|------|
| 0x0098 |    |          | OSD                    | 2 alpha | a (rese | t 0x0) |    |      |               |    |    |       |       | os | D2_AI | _PHA |
| 0x00c8 |    |          | OSD                    | 3 alpha | a (rese | t 0x0) |    |      |               |    |    |       |       | os | D3_AI | _PHA |
| 0x00f8 |    |          | OSD                    | 4 alpha | a (rese | t 0x0) |    |      |               |    |    |       |       | os | D4_A  | РНА  |
| 0x0128 |    |          | OSD5 alpha (reset 0x0) |         |         |        |    |      |               |    |    |       |       | os | D5_A  | _PHA |
| Bit    | 31 | 30       | 29                     | 28      | 27      | 26     | 25 | 24   | 22            | 21 | 20 | 19    | 18    | 17 | 16    |      |
| Name   |    |          |                        |         |         |        |    | Rese | erved         |    |    |       |       |    |       |      |
| Туре   |    |          |                        |         |         |        |    | R    | 0             |    |    |       |       |    |       |      |
| 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   |    | Reserved |                        |         |         |        |    |      |               |    |    | OSDx_ | ALPHA |    |       |      |
| Туре   |    |          |                        | R       | 0       |        |    |      | i             |    |    |       | RW    |    |       |      |
| Reset  | 0  | 0        | 0                      | 0       | 0       | 0      | 0  | 0    | 0 0 0 0 0 0   |    |    |       | 0     |    |       |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description      |
|------------|--------|------|----------------|------------------|
|            | [31:8] | RO   | 24'h0          | Reserved         |
| OSDx_ALPHA | [7:0]  | R/W  | 8'h0           | OSD layer alpha. |

## 7.3.5.2.20 OSDx\_GREY\_RGB

Description: OSD layer RGB constant of GREY format, x=1~5.



| 0x006c |    |                       | OSD                                                | 1 layer | RGB    | consta | int of ( | GREY 1 | ormat       | (reset | 0x0) |        | C             | SD1_   | GREY_ | RBG |  |  |
|--------|----|-----------------------|----------------------------------------------------|---------|--------|--------|----------|--------|-------------|--------|------|--------|---------------|--------|-------|-----|--|--|
| 0x009c |    |                       | OSD2 layer RGB constant of GREY format (reset 0x0) |         |        |        |          |        |             |        |      |        | OSD2_GREY_RBG |        |       |     |  |  |
| 0х00сс |    |                       | OSD                                                | 3 layer | RGB    | consta | int of ( | SREY   | ormat       | (reset | 0x0) |        | С             | SD3_   | GREY_ | RBG |  |  |
| 0x00fc |    |                       | OSD                                                | 4 layer | RGB    | consta | int of ( | SREY   | ormat       | (reset | 0x0) |        | С             | SD4_   | GREY_ | RBG |  |  |
| 0x012c |    |                       | OSD                                                | 5 layer | RGB    | consta | int of ( | GREY 1 | ormat       | (reset | 0x0) |        | С             | SD5_0  | GREY_ | RBG |  |  |
| Bit    | 31 | 30                    | 29                                                 | 28      | 27     | 26     | 25       | 24     | 23          | 22     | 21   | 20     | 19            | 18     | 17    | 16  |  |  |
| Name   |    |                       |                                                    | Rese    | erved  |        |          |        |             |        |      | OSDx_0 | GREY_R        | GREY_R |       |     |  |  |
| Туре   |    |                       |                                                    | R       | 0      |        |          |        |             |        |      | R      | w             |        |       |     |  |  |
| Reset  | 0  | 0                     | 0                                                  | 0       | 0      | 0      | 0        | 0      | 0           | 0      | 0    | 0      | 0             | 0      | 0     | 0   |  |  |
| Bit    | 15 | 15 14 13 12 11 10 9 8 |                                                    |         |        |        |          |        | 7           | 6      | 5    | 4      | 3             | 2      | 1     | 0   |  |  |
| Name   |    |                       |                                                    | OSDx_G  | SREY_G |        |          |        | OSDx_GREY_B |        |      |        |               |        |       |     |  |  |
| Туре   |    | R/W                   |                                                    |         |        |        |          |        | R/W         |        |      |        |               |        |       |     |  |  |
| Reset  | 0  | 0                     | 0                                                  | 0       | 0      | 0      | 0        | 0      | 0 0 0 0 0 0 |        |      |        | 0             |        |       |     |  |  |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                   |
|-------------|---------|------|----------------|-----------------------------------------------|
|             | [31:24] | RO   | 8'h0           | Reserved                                      |
| OSDx_GREY_R | [23:16] | R/W  | 8'h0           | Constant R for GREY data format in OSD layer. |
| OSDx_GREY_G | [15:8]  | R/W  | 8'h0           | Constant G for GREY data format in OSD layer. |
| OSDx_GREY_B | [7:0]   | R/W  | 8'h0           | Constant B for GREY data format in OSD layer. |

## 7.3.5.2.21 OSDx\_CK

Description: OSD layer color-key, x=1~5.



| 0x0070 |                       |     | OSD                              | 1 layer | color- | -key (r | eset 0 | x0) |               |        |    |      |         |    | OSD  | 1_CK |
|--------|-----------------------|-----|----------------------------------|---------|--------|---------|--------|-----|---------------|--------|----|------|---------|----|------|------|
| 0x00a0 |                       |     | OSD2 layer color-key (reset 0x0) |         |        |         |        |     |               |        |    |      | OSD2_CK |    |      |      |
| 0x00d0 |                       |     | OSD                              | 3 layer | color- | -key (r | eset 0 | x0) |               |        |    |      |         |    | OSD  | 3_CK |
| 0x0100 |                       |     | OSD                              | 4 layer | color- | -key (r | eset 0 | x0) |               |        |    |      |         |    | OSD  | 4_CK |
| 0x0130 |                       |     | OSD                              | 5 layer | color- | -key (r | eset 0 | x0) |               |        |    |      |         |    | OSD  | 5_CK |
| Bit    | 31                    | 30  | 29                               | 28      | 27     | 26      | 25     | 24  | 23            | 22     | 21 | 20   | 19      | 18 | 17   | 16   |
| Name   |                       |     |                                  | Rese    | erved  |         |        |     |               |        |    | OSDx | _CK_R   |    | abla |      |
| Туре   |                       |     |                                  | R       | 0      |         |        |     | R/W           |        |    |      |         |    |      |      |
| 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 |     |                                  |         |        |         |        | 8   | 7 6 5 4 3 2 1 |        |    |      |         |    | 0    |      |
| Name   | OSDx_CK_G OSD         |     |                                  |         |        |         |        |     | OSDx.         | x_CK_B |    |      |         |    |      |      |
| Туре   |                       | R/W |                                  |         |        |         |        |     | RW            |        |    |      |         |    |      |      |
| Reset  | 0                     | 0   | 0                                | 0       | 0      | 0       | 0      | 0   | 0             | 0      | 0  | 0    | 0       | 0  | 0    | 0    |

| Field Name | Bit     | Туре | Reset<br>Value | Description                      |
|------------|---------|------|----------------|----------------------------------|
|            | [31:24] | RO   | 8'h0           | Reserved                         |
| OSDx_CK_R  | [23:16] | R/W  | 8'h0           | Color-key R value for OSD layer. |
| OSDx_CK_G  | [15:8]  | R/W  | 8'h0           | Color-key G value for OSD layer. |
| OSDx_CK_B  | [7:0]   | R/W  | 8'h0           | Color-key B value for OSD layer. |

## 7.3.5.2.22 CAP\_CTRL

Description: Capture configuration.



| 0x0140 |    |                                    | Capt                | ure co                           | nfigura | ation ( | reset ( | )x0) |  |  |            |      |       |       | CAP_ | CTRL |
|--------|----|------------------------------------|---------------------|----------------------------------|---------|---------|---------|------|--|--|------------|------|-------|-------|------|------|
| Bit    | 31 | 30                                 | 29                  | 29 28 27 26 25 24 23 22 21 20 19 |         |         |         |      |  |  |            |      |       |       | 17   | 16   |
| Name   |    | Reserved                           |                     |                                  |         |         |         |      |  |  |            |      |       |       |      |      |
| Туре   |    | RO                                 |                     |                                  |         |         |         |      |  |  |            |      |       |       |      |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0          |                     |                                  |         |         |         |      |  |  |            |      |       |       |      |      |
| Bit    | 15 | 5 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |                     |                                  |         |         |         |      |  |  |            | 1    | 0     |       |      |      |
|        |    |                                    |                     |                                  |         |         |         |      |  |  | CAP        |      |       |       |      |      |
| l      |    |                                    |                     |                                  |         |         |         |      |  |  | _RB        | CAP_ | SWITC | CAP_I | FORM | CAP  |
| Name   |    |                                    |                     |                                  | Rese    | erved   |         |      |  |  | _SW<br>ITC | 1    | H     | A     | т    | _EN  |
|        |    |                                    |                     |                                  |         |         |         |      |  |  | н          |      |       |       |      |      |
| Туре   |    | RO RW                              |                     |                                  |         |         |         |      |  |  | R          | W    | R/    | W     | R/W  |      |
| Reset  | 0  | 0                                  | 0 0 0 0 0 0 0 0 0 0 |                                  |         |         |         |      |  |  | 0          | 0    | 0     | 0     | 0    |      |

| Field Name    | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                   |
|---------------|--------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [31:6] | RO   | 26'h0          | Reserved                                                                                                                                                                                      |
| CAP_RB_SWITCH | [5]    | R/W  | 1'h0           | R/B order switch for RGB data  0- DONOT switch;  1- exchange R and B.                                                                                                                         |
| CAP_SWITCH    | [4:3]  | R/W  | 2'h0           | Captured data byte order in a 32bits word, the source is $B_0B_1B_2B_3$ , the destination is: $0\text{-}B_0B_1B_2B_3;$ $1\text{-}B_3B_2B_1B_0;$ $2\text{-}B_2B_3B_0B_1;$ $3\text{-}reserved.$ |
| CAP_FORMAT    | [2:1]  | R/W  | 2'h0           | Data storage format, 00-RGB888; 01-RGB666; 10-RGB565; 11-reserved.                                                                                                                            |
| CAP_EN        | [0]    | R/W  | 1'h0           | Capture enable,<br>0-disable;                                                                                                                                                                 |



| 1-enable |  |
|----------|--|
|----------|--|

#### 7.3.5.2.23 CAP\_BASE\_ADDR

Description: Capture base address.

| 0x0144 |    |    | Capt          | ure ba                                   | se add | lress ( | reset ( | )x0) |   |   |   |   | C | AP_B | ASE_A | DDR |
|--------|----|----|---------------|------------------------------------------|--------|---------|---------|------|---|---|---|---|---|------|-------|-----|
| Bit    | 31 | 30 | 29            | 9 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |         |         |      |   |   |   |   |   |      |       |     |
| Name   |    |    | CAP_BASE_ADDR |                                          |        |         |         |      |   |   |   |   |   |      |       |     |
| Туре   |    |    |               | R/W                                      |        |         |         |      |   |   |   |   |   |      |       |     |
| 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   |    |    |               | CAP_BASE_ADDR                            |        |         |         |      |   |   |   |   |   |      |       |     |
| Туре   |    |    | R/W           |                                          |        |         |         |      |   |   |   |   |   |      |       |     |
| Reset  | 0  | 0  | 0             |                                          |        |         |         |      |   |   |   |   |   |      |       |     |

| Field Name    | Bit    | Туре | Reset<br>Value | Description           |
|---------------|--------|------|----------------|-----------------------|
| CAP_BASE_ADDR | [31:0] | R/W  | 32'h0          | Capture base address. |

# 7.3.5.2.24 CAP\_START\_XY

Description: Capture start position in work plane.

| 0x0148 |    |      | Capt  | ure sta | rt pos                | ition ir | n work | plane | (reset | 0x0)  |        |    | CAP_START_XY |    |    |    |  |  |  |
|--------|----|------|-------|---------|-----------------------|----------|--------|-------|--------|-------|--------|----|--------------|----|----|----|--|--|--|
| Bit    | 31 | 30   | 29    | 28      | 27                    | 26       | 25     | 24    | 23     | 22    | 21     | 20 | 19           | 18 | 17 | 16 |  |  |  |
| Name   |    | Rese | erved |         | CAP_START_Y           |          |        |       |        |       |        |    |              |    |    |    |  |  |  |
| Туре   |    | R    | 0     |         | R/W                   |          |        |       |        |       |        |    |              |    |    |    |  |  |  |
| 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   |    | Rese | erved |         |                       |          |        |       |        | CAP_S | ΓART_X |    |              |    |    |    |  |  |  |
| Туре   |    | R    | 0     |         | R/W                   |          |        |       |        |       |        |    |              |    |    |    |  |  |  |
| Reset  | 0  | 0    | 0     | 0       | 0 0 0 0 0 0 0 0 0 0 0 |          |        |       |        |       |        | 0  |              |    |    |    |  |  |  |



| Field Name  | Bit     | Туре | Reset<br>Value | Description                                                                                                          |
|-------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------|
|             | [31:28] | RO   | 4'h0           | Reserved                                                                                                             |
| CAP_START_Y | [27:16] | R/W  | 12'h0          | Capture window start Y position, it is based on the top left point of work plane. Please ensure it is in work plane. |
|             | [15:12] | RO   | 4'h0           | Reserved                                                                                                             |
| CAP_START_X | [11:0]  | R/W  | 12'h0          | Capture window start X position, it is based on the top left point of work plane. Please ensure it is in work plane. |

#### 7.3.5.2.25 CAP\_SIZE\_XY

Description: Capture size.

| 0x014c |    |      | Capt  | ure siz | e (res | et 0x0)             | )  |    |    |       |        |    |    | CAP_SIZE_XY |    |    |  |
|--------|----|------|-------|---------|--------|---------------------|----|----|----|-------|--------|----|----|-------------|----|----|--|
| Bit    | 31 | 30   | 29    | 28      | 27     | 26                  | 25 | 24 | 23 | 22    | 21     | 20 | 19 | 18          | 17 | 16 |  |
| Name   |    | Rese | erved |         |        | CAP_SIZE_Y          |    |    |    |       |        |    |    |             |    |    |  |
| Туре   |    | R    | .0    |         |        | R/W                 |    |    |    |       |        |    |    |             |    |    |  |
| 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   |    | Rese | erved |         |        |                     |    |    |    | CAP_S | SIZE_X |    |    |             |    |    |  |
| Туре   |    | R    | .0    |         |        | R/W                 |    |    |    |       |        |    |    |             |    |    |  |
| Reset  | 0  | 0    | 0     | 0       | 0      | 0 0 0 0 0 0 0 0 0 0 |    |    |    |       |        |    | 0  |             |    |    |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                         |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------|
|            | [31:28] | RO   | 4'h0           | Reserved                                                                                                            |
| CAP_SIZE_Y | [27:16] | R/W  | 12'h0          | Capture window size in Y, it is based on<br>the top left point of work plane. Please<br>ensure it is in work plane. |
|            | [15:12] | RO   | 4'h0           | Reserved                                                                                                            |
| CAP_SIZE_X | [11:0]  | R/W  | 12'h0          | Capture window size in X, it is based on the top left point of work plane. Please                                   |



|  |  | ensure it is in work plane, and image |
|--|--|---------------------------------------|
|  |  | data is word aligned.                 |

#### 7.3.5.2.26 CAP\_PITCH

Description: Capture pitch.

| 0x0150 |    |      | Capt  | ure pit               | ch (res             | set 0x0 | )) |      |       |       |       |    |    | (  | CAP_P | тсн |
|--------|----|------|-------|-----------------------|---------------------|---------|----|------|-------|-------|-------|----|----|----|-------|-----|
| Bit    | 31 | 30   | 29    | 28                    | 27                  | 26      | 25 | 24   | 23    | 22    | 21    | 20 | 19 | 18 | 17    | 16  |
| Name   |    |      |       |                       |                     |         |    | Rese | erved |       |       |    |    |    |       |     |
| Туре   |    |      |       | RO                    |                     |         |    |      |       |       |       |    |    |    |       |     |
| 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   |    | Rese | erved |                       |                     |         |    |      |       | CAP_I | PITCH |    |    |    |       |     |
| Туре   |    | R    | 0     | R/W                   |                     |         |    |      |       |       |       |    |    |    |       |     |
| Reset  | 0  | 0    | 0     | 0                     | 0 0 0 0 0 0 0 0 0 0 |         |    |      |       |       |       |    |    |    |       |     |

| Field Name | Bit Typ |     | Reset<br>Value | Description    |
|------------|---------|-----|----------------|----------------|
|            | [31:12] | RO  | 20'h0          | Reserved       |
| CAP_PITCH  | [11:0]  | R/W | 12'h0          | Capture pitch. |

## 7.3.5.2.27 Y2R\_CTRL

Description: YUV to RGB configuration.



| 0x0160 |    |       | YUV                           | to RGI | B conf | igurati | on (re | set 0x(  | D)    |    |    |    |    |     | Y2R_( | CTRL |
|--------|----|-------|-------------------------------|--------|--------|---------|--------|----------|-------|----|----|----|----|-----|-------|------|
| Bit    | 31 | 30    | 29                            | 28     | 27     | 26      | 25     | 24       | 23    | 22 | 21 | 20 | 19 | 18  | 17    | 16   |
| Name   |    |       |                               |        |        |         |        | Rese     | erved |    |    |    |    |     |       |      |
| Туре   |    |       |                               |        |        |         |        | R        | 0     |    |    |    |    |     |       |      |
| Reset  | 0  | 0     |                               |        |        |         |        |          |       |    |    |    |    |     |       |      |
| Bit    | 15 | 14    | 13 12 11 10 9 8 7 6 5 4 3 2 1 |        |        |         |        |          |       |    |    |    |    |     |       | 0    |
|        |    |       |                               |        |        |         |        |          |       |    |    |    |    |     |       | Y2R  |
| Name   |    |       |                               |        |        |         | I      | Reserved | i     |    |    |    |    |     |       | _CT  |
|        |    |       |                               |        |        |         |        |          |       |    |    |    |    |     |       | RL   |
| Туре   |    | RO R. |                               |        |        |         |        |          |       |    |    |    |    | R/W |       |      |
| Reset  | 0  |       |                               |        |        |         |        |          |       |    |    |    |    |     | 0     |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                     |
|------------|--------|------|----------------|---------------------------------|
|            | [31:1] | RO   | 31'h0          | Reserved                        |
| Y2R_CTRL   | [0]    | R/W  | 1'h0           | UV horizontal up-sampling mode, |
|            |        |      |                | 0-duplicated;                   |
|            |        |      |                | 1-average.                      |

## 7.3.5.2.28 Y2R\_CONTRAST

Description: Adjustment value of contrast.

| 0x0164 |                             |                             | Adju | stmen | t value | of co | ntrast | (reset | 0x0) |    |    |        |        | Y2R_ | CONTI | RAST |
|--------|-----------------------------|-----------------------------|------|-------|---------|-------|--------|--------|------|----|----|--------|--------|------|-------|------|
| Bit    | 31                          | 30                          | 29   | 28    | 27      | 26    | 25     | 24     | 23   | 22 | 21 | 20     | 19     | 18   | 17    | 16   |
| Name   |                             | Reserved                    |      |       |         |       |        |        |      |    |    |        |        |      |       |      |
| Туре   |                             | RO                          |      |       |         |       |        |        |      |    |    |        |        |      |       |      |
| 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   |                             |                             |      | Rese  | erved   |       |        |        |      |    | ,  | Y2R_CO | NTRAST | Г    |       |      |
| Туре   |                             | RO R/W                      |      |       |         |       |        |        |      |    |    |        |        |      |       |      |
| Reset  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                             |      |       |         |       |        |        |      |    |    |        |        |      |       |      |



| Field Name   | Bit    | Туре | Reset<br>Value | Description                    |
|--------------|--------|------|----------------|--------------------------------|
|              | [31:8] | RO   | 24'h0          | Reserved                       |
| Y2R_CONTRAST | [7:0]  | R/W  | 8'h0           | Contrast configuration, 0~255. |

#### 7.3.5.2.29 Y2R\_SATURATION

Description: Adjustment value of saturation.

| 0x0168 |    |                           | Adju | stmen | t value | of sat | uratio | n (rese | et 0x0) |    |    |        | Y      | 2R_SA | TURA | TION |
|--------|----|---------------------------|------|-------|---------|--------|--------|---------|---------|----|----|--------|--------|-------|------|------|
| Bit    | 31 | 30                        | 29   | 28    | 27      | 26     | 25     | 24      | 23      | 22 | 21 | 20     | 19     | 18    | 17   | 16   |
| Name   |    | Reserved                  |      |       |         |        |        |         |         |    |    |        |        |       |      |      |
| Туре   |    | RO                        |      |       |         |        |        |         |         |    |    |        |        |       |      |      |
| 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   |    |                           |      | Rese  | erved   |        |        |         |         |    | Υ  | 2R_SAT | URATIO | N     |      |      |
| Туре   |    | RO RW                     |      |       |         |        |        |         |         |    |    |        |        |       |      |      |
| Reset  | 0  |                           |      |       |         |        |        |         |         |    |    |        |        |       |      |      |

| Field Name     | Bit    | Туре | Reset<br>Value | Description                      |
|----------------|--------|------|----------------|----------------------------------|
|                | [31:8] | RO   | 24'h0          | Reserved                         |
| Y2R_SATURATION | [7:0]  | R/W  | 8'h0           | Saturation configuration, 0~255. |

## 7.3.5.2.30 Y2R BRIGHTNESS

Description: Adjustment value of brightness.



| 0x016c |    |    | Adju                      | stmen    | t value | of bri | ghtnes | ss (res | et 0x0 | )  |      |        | Y2R_BRIGHTNESS |    |    |    |
|--------|----|----|---------------------------|----------|---------|--------|--------|---------|--------|----|------|--------|----------------|----|----|----|
| Bit    | 31 | 30 | 29                        | 28       | 27      | 26     | 25     | 24      | 23     | 22 | 21   | 20     | 19             | 18 | 17 | 16 |
| Name   |    |    |                           |          |         |        |        | Rese    | erved  |    |      |        |                |    |    |    |
| Туре   |    | 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   |    |    | ı                         | Reserved | d       |        |        |         |        |    | Y2R_ | BRIGHT | NESS           |    |    |    |
| Туре   | RO |    |                           |          |         |        |        |         |        |    |      |        |                |    |    |    |
| Reset  | 0  | 0  | 0                         | 0        | 0       | 0      | 0      | 0       | 0      | 0  | 0    | 0      | 0              | 0  | 0  | 0  |

| Field Name     | Bit    | Туре | Reset<br>Value | Description                              |
|----------------|--------|------|----------------|------------------------------------------|
|                | [31:9] | RO   | 23'h0          | Reserved                                 |
| Y2R_BRIGHTNESS | [8:0]  | R/W  | 9'h0           | Brightness configuration (S9), -256~255. |

#### 7.3.5.2.31 LCDC\_IRQ\_EN

Description: LCDC interrupt enable.



| 0x0170 |          |    | LCD | C inter | rupt ei | nable ( | reset ( | 0x0)  |    |    |    |     |     | LCI | DC_IR | Q_EN |
|--------|----------|----|-----|---------|---------|---------|---------|-------|----|----|----|-----|-----|-----|-------|------|
| Bit    | 31       | 30 | 29  | 28      | 27      | 26      | 25      | 24    | 23 | 22 | 21 | 20  | 19  | 18  | 17    | 16   |
| Name   | Reserved |    |     |         |         |         |         |       |    |    |    |     |     |     |       |      |
| Туре   | 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    |
|        |          |    |     |         |         |         |         |       |    |    |    |     |     |     |       | IRQ  |
|        |          |    |     |         |         |         |         |       |    |    |    |     |     |     | IRQ   | _LC  |
| Name   |          |    |     |         |         |         | Rese    | erved |    |    |    |     |     |     | _FM   | DC_  |
|        |          |    |     |         |         |         |         |       |    |    |    |     |     |     | ARK   | DON  |
|        |          |    |     |         |         |         |         |       |    |    |    |     |     |     | _EN   | E_E  |
|        |          |    |     |         |         |         |         |       |    |    |    |     | N   |     |       |      |
| Туре   |          | RO |     |         |         |         |         |       |    |    |    | R/W | R/W |     |       |      |
| Reset  | 0        | 0  | 0   | 0       | 0       | 0       | 0       | 0     | 0  | 0  | 0  | 0   | 0   | 0   | 0     | 0    |

| Field Name        | Bit    | Туре | Reset<br>Value | Description                                                                          |
|-------------------|--------|------|----------------|--------------------------------------------------------------------------------------|
|                   | [31:2] | RO   | 30'h0          | Reserved                                                                             |
| IRQ_FMARK_EN      | [1]    | R/W  | 1'h0           | Enable FMARK interrupt, the interrupt is for LCDC detect a FMARK input.              |
| IRQ_LCDC _DONE_EN | [0]    | R/W  | 1'h0           | Enable LCDC_DONE interrupt, the interrupt is for LCDC completing display or capture. |

## 7.3.5.2.32 LCDC\_IRQ\_CLR

Description: LCDC interrupt clear.



| 0x0174 |          |    | LCDC interrupt clear (reset 0x0) LCDC |    |    |    |    |    |    |                               |                                          |    |    | C_IRQ | _CLR |    |
|--------|----------|----|---------------------------------------|----|----|----|----|----|----|-------------------------------|------------------------------------------|----|----|-------|------|----|
| Bit    | 31       | 30 | 29                                    | 28 | 27 | 26 | 25 | 24 | 23 | 22                            | 21                                       | 20 | 19 | 18    | 17   | 16 |
| Name   | Reserved |    |                                       |    |    |    |    |    |    |                               |                                          |    |    |       |      |    |
| Туре   |          | 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   | Reserved |    |                                       |    |    |    |    |    |    | IRQ<br>_FM<br>ARK<br>_CL<br>R | IRQ<br>_LC<br>_DC<br>_DO<br>_NE_<br>_CLR |    |    |       |      |    |
| Туре   |          |    |                                       |    |    |    | R  | 0  |    |                               |                                          |    |    |       | wo   | wo |
| Reset  | 0        | 0  | 0                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0                             | 0                                        | 0  | 0  | 0     | 0    | 0  |

| Field Name        | Bit    | Туре | Reset<br>Value | Description                             |
|-------------------|--------|------|----------------|-----------------------------------------|
|                   | [31:2] | RO   | 30'h0          | Reserved                                |
| IRQ_FMARK_CLR     | [1]    | wo   | 1'h0           | Write '1' to clear FMARK interrupt.     |
| IRQ_LCDC_DONE_CLR | [0]    | wo   | 1'h0           | Write '1' to clear LCDC_DONE interrupt. |

# 7.3.5.2.33 LCDC\_IRQ\_STATUS

Description: LCDC masked interrupt status.



| 0x0178 |          |                                   | LCD | C masl                              | ked int | errupt | status | s (rese | t 0x0) |   |                               |                                       | LC | DC_IR | Q_ST/ | ATUS |
|--------|----------|-----------------------------------|-----|-------------------------------------|---------|--------|--------|---------|--------|---|-------------------------------|---------------------------------------|----|-------|-------|------|
| Bit    | 31       | 30                                | 29  | 29 28 27 26 25 24 23 22 21 20 19 18 |         |        |        |         |        |   |                               |                                       |    | 17    | 16    |      |
| Name   | Reserved |                                   |     |                                     |         |        |        |         |        |   |                               |                                       |    |       |       |      |
| Туре   |          | RO                                |     |                                     |         |        |        |         |        |   |                               |                                       |    |       |       |      |
| Reset  | 0        | 0                                 | 0   | 0                                   | 0       | 0      | 0      | 0       | 0      | 0 | 0                             | 0                                     | 0  | 0     | 0     | 0    |
| Bit    | 15       | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 |     |                                     |         |        |        |         |        |   | 1                             | 0                                     |    |       |       |      |
| Name   | Reserved |                                   |     |                                     |         |        |        |         |        |   | IRQ<br>_FM<br>ARK<br>_ST<br>S | IRQ<br>_LC<br>DC_<br>DON<br>E_S<br>TS |    |       |       |      |
| Туре   |          |                                   |     |                                     |         |        | R      | 0       |        |   |                               |                                       |    |       | RO    | RO   |
| Reset  | 0        | 0                                 | 0   | 0                                   | 0       | 0      | 0      | 0       | 0      | 0 | 0                             | 0                                     | 0  | 0     | 0     | 0    |

| Field Name        | Bit    | Туре | Reset<br>Value | Description                 |
|-------------------|--------|------|----------------|-----------------------------|
|                   | [31:2] | RO   | 30'h0          | Reserved                    |
| IRQ_FMARK_STS     | [1]    | RO   | 1'h0           | Masked FMARK interrupt.     |
| IRQ_LCDC_DONE_STS | [0]    | RO   | 1'h0           | Masked LCDC_DONE interrupt. |

# 7.3.5.2.34 LCDC\_IRQ\_RAW

Description: LCDC raw interrupt status.



| 0x017c |    |          | LCD                                 | C raw i                     | interru | pt stat | us (re | set 0x( | 0) |   |   |   |    | LCDC | _IRQ_                         | RAW                                   |
|--------|----|----------|-------------------------------------|-----------------------------|---------|---------|--------|---------|----|---|---|---|----|------|-------------------------------|---------------------------------------|
| Bit    | 31 | 30       | 29 28 27 26 25 24 23 22 21 20 19 18 |                             |         |         |        |         |    |   |   |   |    |      | 17                            | 16                                    |
| Name   |    | Reserved |                                     |                             |         |         |        |         |    |   |   |   |    |      |                               |                                       |
| Туре   |    | RO       |                                     |                             |         |         |        |         |    |   |   |   |    |      |                               |                                       |
| Reset  | 0  | 0        | 0 0 0 0 0 0 0 0 0 0 0               |                             |         |         |        |         |    |   |   |   | 0  | 0    | 0                             |                                       |
| Bit    | 15 | 14       | 13                                  | 13 12 11 10 9 8 7 6 5 4 3 2 |         |         |        |         |    |   |   |   |    | 1    | 0                             |                                       |
| Name   |    |          |                                     |                             |         |         | Rese   | erved   |    |   |   |   |    |      | IRQ<br>_FM<br>ARK<br>_RA<br>W | IRQ<br>_LC<br>DC_<br>DON<br>E_R<br>AW |
| Туре   |    |          | RO                                  |                             |         |         |        |         |    |   |   |   | RO | RO   |                               |                                       |
| Reset  | 0  | 0        | 0                                   | 0                           | 0       | 0       | 0      | 0       | 0  | 0 | 0 | 0 | 0  | 0    | 0                             | 0                                     |

| Field Name        | Bit    | Туре | Reset<br>Value | Description              |
|-------------------|--------|------|----------------|--------------------------|
|                   | [31:2] | RO   | 30'h0          | Reserved                 |
| IRQ_FMARK_RAW     | [1]    | RO   | 1'h0           | Raw FMARK interrupt.     |
| IRQ_LCDC_DONE_RAW | [0]    | RO   | 1'h0           | Raw LCDC_DONE interrupt. |

# 7.3.5.2.35 LCM\_CTRL

Description: LCM control.



| 0x0180 |      |       | LCM     | contro | ol (rese    | et 0x0) |    |                  |      |       |       |                 |    |          | LCM_ | CTRL             |
|--------|------|-------|---------|--------|-------------|---------|----|------------------|------|-------|-------|-----------------|----|----------|------|------------------|
| Bit    | 31   | 30    | 29      | 28     | 27          | 26      | 25 | 24               | 23   | 22    | 21    | 20              | 19 | 18       | 17   | 16               |
| Name   |      |       |         |        | Reserved    | d       |    |                  |      | LCM.  | _STS  | AHB<br>_AC<br>T | ı  | Reserve  | d    | LCM<br>_CS       |
| Туре   |      |       | RO      |        |             |         |    |                  |      |       | RO RO |                 | RO |          |      | R/W              |
| 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   | Rese | erved | PIXEL   |        | TS IF_BITS1 |         |    | IF_T<br>YPE<br>1 | Rese | erved | PIXEL | _BITS           |    | IF_BITS0 | 0    | IF_T<br>YPE<br>0 |
| Туре   | R    | 0     | R/W R/W |        |             |         |    | R/W              | R    | O R/W |       | R/W             |    | R/W      |      |                  |
| Reset  | 0    | 0     | 0       | 0      | 0           | 0       | 0  | 0                | 0    | 0     | 0     | 0               | 0  | 0        | 0    | 0                |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                         |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:23] | RO   | 9'h0           | Reserved                                                                                                                                                                                                            |
| LCM_STS    | [22:21] | RO   | 2'h0           | LCM work status, only for debug purpose.  0- LCM state is in idle;  1- LCM state is in setup;  2- LCM state is in low;  3- LCM state is in high.                                                                    |
| AHB_ACT    | [20]    | RO   | 1'h0           | AHB channel status in current LCM 0- Idle; 1- Active, some AHB channel CMD/DATA is sending. It is ready to send next CMD/DATA when it is idle, it must inquire this status bit before every AHB channel read/write. |
|            | [19:17] | RO   | 3'h0           | Reserved                                                                                                                                                                                                            |
| LCM_CS     | [16]    | R/W  | 1'h0           | LCM selection 0- use LCM0 device;                                                                                                                                                                                   |



|             |         |     |      | 3000 to Design Specia                      |
|-------------|---------|-----|------|--------------------------------------------|
|             |         |     |      | 1- use LCM1 device.                        |
|             | [15:14] | RO  | 2'h0 | Reserved                                   |
| PIXEL_BITS1 | [13:12] | R/W | 2'h0 | Panel pixel data bit width for LCM1 device |
|             |         |     |      | 0- 16bits;                                 |
|             |         |     |      | 1- 18bits;                                 |
|             |         |     |      | 2- 24bits;                                 |
|             |         |     |      | Others are reserved.                       |
| IF_BITS1    | [11:9]  | R/W | 3'h0 | LCM interface bus width for LCM1 device    |
|             |         |     |      | 0- 8bits;                                  |
|             |         |     |      | 1- 9bits;                                  |
|             |         |     |      | 2- 16bits;                                 |
|             |         |     |      | 3- 18bits;                                 |
|             |         |     |      | 4- 24bits;                                 |
|             |         |     |      | Others are reserved.                       |
| IF_TYPE1    | [8]     | R/W | 1'h0 | LCM interface type for LCM1 device         |
|             |         |     |      | 0- 8080;                                   |
|             |         |     |      | 1- 6800.                                   |
|             | [7:6]   | RO  | 2'h0 | Reserved                                   |
| PIXEL_BITS0 | [5:4]   | R/W | 2'h0 | Panel pixel data bit width for LCM0 device |
|             |         |     |      | 0- 16bits;                                 |
|             |         |     |      | 1- 18bits;                                 |
|             |         |     |      | 2- 24bits;                                 |
|             |         |     |      | Others are reserved.                       |
| IF_BIT\$0   | [3:1]   | R/W | 3'h0 | LCM interface bus width for LCM0 device    |
|             |         |     |      | 0- 8bits;                                  |
|             |         |     |      | 1- 9bits;                                  |
|             |         |     |      | 2- 16bits;                                 |
|             |         |     |      | 3- 18bits;                                 |
|             |         |     |      | 4- 24bits;                                 |
|             |         |     |      | Others are reserved.                       |
| IF_TYPE0    | [0]     | R/W | 1'h0 | LCM interface type for LCM0 device         |



|  |  | 0- 8080; |
|--|--|----------|
|  |  | 1- 6800. |

### 7.3.5.2.36 LCM\_TIMING

Description: LCM read/write timing setting.

| 0x0184 |    |      | LCM   | timing                                        | for ac | tive L  | CM0 d | evice ( | reset ( | 0x0) |    |    | LCM_TIMING0 |             |    |    |  |  |  |
|--------|----|------|-------|-----------------------------------------------|--------|---------|-------|---------|---------|------|----|----|-------------|-------------|----|----|--|--|--|
| 0x0188 |    |      | LCM   | .CM timing for active LCM1 device (reset 0x0) |        |         |       |         |         |      |    |    |             | LCM_TIMING1 |    |    |  |  |  |
| Bit    | 31 | 30   | 29    | 28                                            | 27     | 26      | 25    | 24      | 23      | 22   | 21 | 20 | 19          | 18          | 17 | 16 |  |  |  |
| Name   |    | Rese | erved |                                               |        | RC      | SS    |         |         | RL   | PW |    |             | RH          | PW |    |  |  |  |
| Туре   |    | R    | 0     |                                               |        | R/      | W     |         | R/W     |      |    |    | R/W         |             |    |    |  |  |  |
| 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   |    | Rese | erved |                                               |        | wcss    |       |         |         | WL   | PW |    | WHPW        |             |    |    |  |  |  |
| Туре   |    | R    | .0    |                                               |        | R/W     |       |         |         | R/W  |    |    |             | R/W         |    |    |  |  |  |
| Reset  | 0  | 0    | 0     | 0                                             | 0      | 0 0 0 0 |       |         |         | 0    | 0  | 0  | 0           | 0           | 0  | 0  |  |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                         |
|------------|---------|------|----------------|-------------------------------------|
|            | [31:28] | RO   | 4'h0           | Reserved                            |
| RCSS       | [27:24] | R/W  | 4'h0           | Read to CS setup time, it is 0~3.   |
| RLPW       | [23:20] | R/W  | 4'h0           | Read low pulse width, it is 0~15.   |
| RHPW       | [19:16] | R/W  | 4'h0           | Read high pulse width, it is 0~15.  |
|            | [15:12] | RO   | 4'h0           | Reserved                            |
| wcss       | [11:8]  | R/W  | 4'h0           | Write to CS setup time, it is 0~15. |
| WLPW       | [7:4]   | R/W  | 4'h0           | Write low pulse Width, it is 0~15.  |
| WHPW       | [3:0]   | R/W  | 4'h0           | Write high pulse width, it is 0~15. |

NOTE: Above settings all are HCLK unit.

## 7.3.5.2.37 LCM\_RDATA

Description: LCM read back data.



| 0x018c |    |    | LCM       | read b    | ack da | ata (re | set 0x( | 0) |    |    |    |    |    | L  | CM_RE | DATA |
|--------|----|----|-----------|-----------|--------|---------|---------|----|----|----|----|----|----|----|-------|------|
| Bit    | 31 | 30 | 29        | 28        | 27     | 26      | 25      | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
| Name   |    |    | LCM_RDATA |           |        |         |         |    |    |    |    |    |    |    |       |      |
| Туре   |    |    |           | 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   |    |    |           | LCM_RDATA |        |         |         |    |    |    |    |    |    |    |       |      |
| Туре   |    |    |           | RO        |        |         |         |    |    |    |    |    |    |    |       |      |
| Reset  | 0  | 0  | 0         | 0         | 0      | 0       | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                 |
|------------|--------|------|----------------|-----------------------------|
| LCM_RDATA  | [31:0] | RO   | 32'h0          | Read back data from device. |

# 7.3.5.2.38 LCM\_RSTN

Description: External panel reset control.

| 0x0190 |    |       | Exte | rnal pa | nel re | set co | ntrol (r | eset 0   | x0)   |    |     |     |    |    | LCM_F | RSTN |
|--------|----|-------|------|---------|--------|--------|----------|----------|-------|----|-----|-----|----|----|-------|------|
| Bit    | 31 | 30    | 29   | 28      | 27     | 26     | 25       | 24       | 23    | 22 | 21  | 20  | 19 | 18 | 17    | 16   |
| Name   |    |       |      |         |        |        |          | Rese     | erved |    |     |     |    |    |       |      |
| Туре   |    | 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    |
|        |    |       |      |         |        |        |          |          |       |    |     |     |    |    |       | LCM  |
| Name   |    |       |      |         |        |        | 1        | Reserved | ı     |    |     |     |    |    |       | _RS  |
|        |    | T_N   |      |         |        |        |          |          |       |    |     | T_N |    |    |       |      |
| Туре   |    | RO RA |      |         |        |        |          |          |       |    | R/W |     |    |    |       |      |
| Reset  | 0  | 0     | 0    | 0       | 0      | 0      | 0        | 0        | 0     | 0  | 0   | 0   | 0  | 0  | 0     | 0    |

| Field Name | Bit | Туре | Reset | Description |
|------------|-----|------|-------|-------------|
|            |     |      | Value |             |



|           | [31:1] | RO  | 31'h0 | Reserved                               |
|-----------|--------|-----|-------|----------------------------------------|
| LCM_RST_N | [0]    | R/W | 1'h0  | Panel reset control, '0'- reset panel. |
|           |        |     |       | The watch-dog reset doesn't affect it. |

# 7.3.5.2.39 LCM\_CMD

Description: LCM AHB channel command output.

| 0x01a0 |          | LCM0 AHB channel command (reset 0x0)  LCM_CMD |    |    |         |    |    | CMD0 |    |    |    |    |    |    |    |    |
|--------|----------|-----------------------------------------------|----|----|---------|----|----|------|----|----|----|----|----|----|----|----|
| Bit    | 31       | 30                                            | 29 | 28 | 27      | 26 | 25 | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | Reserved |                                               |    |    | LCM_CMD |    |    |      |    |    |    |    |    |    |    |    |
| Туре   |          |                                               |    | R  | 0       |    |    |      |    |    | C  | W  | 0  |    |    |    |
| 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   |          | LCM_CMD                                       |    |    |         |    |    |      |    |    |    |    |    |    |    |    |
| Туре   | wo       |                                               |    |    |         |    |    |      |    |    |    |    |    |    |    |    |
| Reset  | 0        | 0                                             | 0  | 0  | 0       | 0  | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                     |
|------------|---------|------|----------------|---------------------------------|
|            | [31:24] | RO   | 8'h0           | Reserved                        |
| LCM_CMD    | [23:0]  | WO   | 24'h0          | Write data to device with CD=0. |

# 7.3.5.2.40 LCM\_DATA

Description: LCM AHB channel data output.



| 0x01a4 |          |          | LCM0 AHB channel data (reset 0x0)  LCM_DATA0 |    |    |            |          |    |    | ATA0 |    |    |    |    |    |    |
|--------|----------|----------|----------------------------------------------|----|----|------------|----------|----|----|------|----|----|----|----|----|----|
| Bit    | 31       | 30       | 29                                           | 28 | 27 | 26         | 25       | 24 | 23 | 22   | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | Reserved |          |                                              |    |    | LCM<br>_RW | LCM_DATA |    |    |      |    |    |    |    |    |    |
| Туре   |          |          |                                              | RO |    |            |          | 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   |          | LCM_DATA |                                              |    |    |            |          |    |    |      |    |    |    |    |    |    |
| Туре   |          |          | wo                                           |    |    |            |          |    |    |      |    |    |    |    |    |    |
| Reset  | 0        | 0        | 0                                            | 0  | 0  | 0          | 0        | 0  | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                     |
|------------|---------|------|----------------|---------------------------------|
|            | [31:25] | RO   | 7'h0           | Reserved                        |
| LCM_RW     | [24]    | WO   | 1'h0           | Read/write flag,                |
|            |         |      |                | 0- write;                       |
|            |         |      |                | 1- read.                        |
| LCM_DATA   | [23:0]  | WO   | 24'h0          | Write data to device with CD=1. |

# 7.3.6 Application Notes

#### 7.3.6.1 Program Flow

Before configure module, set some global parameters,

Set bit[7:6] of 0x8b00\_0070 to select LCD clock source;

Set bit[2:0] of 0x8b00\_0060 to control the divider value of LCD clock;

Set bit[3] of 0x2090\_0200 to enable LCD clock;

Set or reset bit[3] of 0x2090\_0210 to reset LCDC module;

Set bit[29] of 0x8000\_3008 to enable LCDC global interrupt.

## Display mode

- Clear ARM interrupt and LCDC module interrupt, and enable them;
- Enable LCDC, set the bit 0 of LCDC\_CTRL to '1';
- Configure layer information, includes format, size, position, address, etc;

V.0.1



- Configure LCM parameters;
- Start LCDC, write '1' to bit[3] of LCDC\_CTRL;
- Wait LCDC\_DONE interrupt for completing a frame;
- Re-configure parameters, and start a new frame;

#### Capture mode

- Clear ARM interrupt and LCDC module interrupt, and enable them;
- Enable LCDC, set the bit 0 of LCDC\_CTRL to '1';
- Configure layer information, includes format, size, position, address, etc;
- Enable capture, set the bit[0] of CAP\_CTRL to '1';
- Start LCDC, write '1' to bit[3] of LCDC\_CTRL;
- Wait LCDC\_DONE interrupt for completing a frame;
- Re-configure parameters, and start a new frame;

#### 7.3.6.2 Program Notes

- All address configure all are 8bits byte unit;
- All size or position configure all are pixel unit;
- Image and OSD source data must be with word-aligned pitch;
- When fetched image is YUV data, the position and size of image layer must be even;

#### Normal IF\_BITS and PIX\_BITS list







# 7.4 Graphics

#### 7.4.1 Overview

The Mali-300 GPU is a hardware accelerator for 2D and 3D graphics systems.

The GPU consists of:

- a Pixel Processor (PP)
- a Geometry Processor (GP)
- a Level 2 Cache Controller (L2)
- a Memory Management Unit (MMU) for each GP and PP included in the GPU
- a Power Management Unit (PMU).

### 7.4.2 Pixel processor features

The pixel processor features are:

- · programmable fragment shader
- · alpha blending
- complete non-power-of-2 texture support
- · cube mapping
- fast dynamic branching
- fast trigonometric functions, including arctangent



- full floating-point arithmetic
- · framebuffer blend with destination Alpha
- indexable texture samplers
- line, quad, triangle and point sprites
- no limit on program length
- · perspective correct texturing
- · point sampling, bilinear, and trilinear filtering
- programmable mipmap level-of-detail biasing and replacement
- stencil buffering, 8-bit
- two-sided stencil
- · unlimited dependent texture reads
- 4-level hierarchical Z and stencil operations
- Up to 512 times *Full Scene Anti-Aliasing* (FSAA). 4x multisampling times 128x supersampling
- 4-bit per texel compressed texture format.

### 7.4.3 Geometry processor features

The geometry processor features are:

- programmable vertex shader
- · flexible input and output formats
- autonomous operation tile list generation
- indexed and non-indexed geometry input
- primitive constructions with points, lines, triangles and quads.

#### 7.4.4 Level 2 cache controller features

The L2 cache controller features are:

- size is 8KB
- · 4-way set-associative
- supports up to 32 outstanding AXI transactions
- implements a standard pseudo-LRU algorithm
- cache line and line fill burst size is 64 bytes
- supports eight to 64bytes uncached read bursts and write bursts
- 64-bit or 128-bit interface to memory sub-system
- support for hit-under-miss and miss-under-miss with the only limitation of AXI ordering rules.

#### 7.4.5 MMU

The MMU features are:



- accesses control registers through the bus infrastructure to configure the memory system.
- each processor has its own MMU to control and translate memory accesses that the GPU initiates.

### 7.4.6 PMU

The PMU features are:

- programmable power management
- powers up and down the GP, PP and Level 2 cache controller separately
- controls the clock, isolation and power of each device
- provides an interrupt when all requested devices are powered up.



# 8 Audio Subsystem

### 8.1 Overview

The audio subsystem is shown in Figure 8-1. It is a mixed mode system that includes both digital and analog components, and can facilitate audio or voice functions. Essentially, the system consists of one uplink Analog to Digital Converter (ADC) channel, two downlink Digital to Analog Converter (DAC) channels, and some additional function circuitry. Both ARM and DSP can control the audio subsystem separately.



Figure 8-1 Audio subsystem architecture



The mono ADC channel receives signal from an external microphone, converts the analog signal into digital data, and transfers the data to buffers in voice band control (VBC) interface, and finally the data in the buffers will be fetched by software.

The stereo DAC data path is just the opposite of the ADC channel. Software loads voice or audio data into buffers in voice band control interface, and then the data will be converted to analog signals by DAC. Through a mixer that also achieves a low pass filter function, three outputs are supplied: a headphone output for each DAC channel, a differential line output for combined signal of left and right channels, and a BTL output also for combined signal of left and right channels.

An analog line input path (analog bypass path marked in Figure 8-1) is provided. The line-in signals from AIL1 and AIR1 also input to the mixers. The mixers allow signal from either DAC or line-in passing through. Signals output from the mixers goes to three paths, which has been described above.

The line-in recording function is also supported. The line-out signals from PAD AUXSPP/AUXSPN pass through a PGA, a MUX circuit and then into the PAD AUXMICP/AUXMICN, as the input of the ADC channel.

The voice band control (VBC) interface communicates with software or DMA, and this block contains ping-pong buffers for each channel, control registers for the entire audio subsystem, APB bus for ARM, Z bus for DSP, interrupt control, DAI test interface and DMA interface control logic.

Except the VBC interface, all the other parts of the system together constitute the audio codec. Main clock (MCLK) and global reset of audio codec are generated from top-level clock and reset management logic.

Two groups of I2S serial interface connect ADC/DAC of the audio codec with the VBC interface, one is for ADC channel, and the other is for DAC channel. The VBC interface is always the slave, and the audio codec part is the master.



### 8.2 Features

The audio sub-system provides the following features.

- Mono ADC channel and stereo DAC channels
- Programmable sampling frequency (Fs): 8, 9.6, 11.025, 12, 16, 22.05, 24, 32, 44.1, 48, or 96 kHz
- Two differential microphone input with a 0 or 20 dB boost gain stage
- Stereo programmable gain amplifier for headphone output
- Differential line output
- Differential BTL output
- Stereo analog line input
- Stereo analog mixer with programmable gains to select signals coming from the DAC and the analog line-in input
- Support line-in recording
- Internal voltage reference (resistive potential divider) to generate all required internal voltages
- Both ARM and DSP can control the audio subsystem independently, and they are able to access the same control registers
- DMA hard channel provided in ARM control mode
- Audio codec main clock frequency is 12 MHz
- Audio codec and VBC interface can be separately soft reset
- Independent interrupt for ADC and DAC channels
- External I2S interface is provided and can be connected with the audio codec

### 8.3 Audio Codec Path Details

#### 8.3.1 ADC Path

Two pairs of differential microphone input pads are provided: MICP/MICN, AUXMICP/AUXMICN, and it is configurable which pair is enabled. The differential analog signals are applied through capacitors that remove DC voltage, which allows a more flexible usage by removing the constraint of a specific input common mode voltage.



The ADC path in the audio codec includes:

- A switchable microphone amplifier
- A programmable (4bits) gain amplifier (PGATM)
- A delta-sigma modulator
- A set of digital decimating filters
- An optional high pass filter

The microphone amplifier is switchable with a 0 or 20 dB gain, and the PGATM provides a gain ranges from 0 dB to 22.5 dB with 1.5 dB steps that allows covering a wide range of input levels.

The delta-sigma modulator and the decimating filters belong to the ADC function block. Figure 8-2 shows the ADC block diagram. The  $\Delta$ - $\Sigma$  modulator is the analog part, while the decimating filter and the high pass filter form the digital part.



Figure 8-2 ADC function block diagram

The  $\Delta$ - $\Sigma$  modulator converts the input amplified analog signal into a succession of 0/1 bit stream. This bit stream is sent to the decimating filters that transform it into a 16 bit signal at the selected Fs frequency. Finally, an optional high pass filter removes the DC component. By IIS serial interface, the output data is sent to the ping-pong buffers in VBC digital interface. Once receiving the ADC interrupt that indicates one buffer is full, ARM or DSP or DMA will read the data out.

Tables 8-1 and 8-2 give the decimating filter and high pass filter characteristics.



#### Table 8-1 The decimating filter characteristics

#### For Fs ≤ 48 kHz

| Filter characteristics | Min.    | Tvp. | Max.     | Unit     |
|------------------------|---------|------|----------|----------|
| Stop band              | 0.545Fs |      |          | Hz       |
|                        | (TRC)   |      |          | <b>*</b> |
| Stop band attenuation  | -80     |      |          | dB       |
|                        | (TRC)   |      |          |          |
| Pass band              |         |      | 0.455Fs  | Hz       |
|                        |         |      | (TRC)    |          |
| Pass band ripple       |         |      | +/- 0.05 | dB       |
|                        |         |      | (TRC)    |          |

#### For Fs = 96 kHz

| Filter characteristics | Min.    | Typ. | Max.     | Unit |
|------------------------|---------|------|----------|------|
| Stop band              | 0.545Fs |      |          | Hz   |
|                        | (TBC)   |      |          |      |
| Stop band attenuation  | -80     |      |          | dB   |
|                        | (TRC)   |      |          |      |
| Pass band              |         |      | 0.288Fs  | Hz   |
|                        |         |      | (TRC)    |      |
| Pass band ripple       |         |      | +/- 0.05 | dB   |
|                        |         |      | (TBC)    |      |

Table 8-2 The high pass filter characteristics (for Fs = 44.1 kHz)

|                                   | -0.1dB | 24Hz   |
|-----------------------------------|--------|--------|
| High Pass Filter corner frequency | -0.5dB | 10.5Hz |
|                                   | -3dB   | 3.8Hz  |

### 8.3.2 DAC Path

The stereo DAC path contains two parallel channels. For each channel, data path function blocks include:

- Optional de-emphasis filter
- Cascaded interpolating filters
- The noise shaper
- The switched capacitor low pass filter (reconstruction filter)
- The output path (headphone output amplifier, line out amplifier, or BTL amplifier)

For the downlink channels, software first loads data into buffers in VBC at the beginning or after receiving interrupt that indicates the data in the ping-pong buffer has been moved out to DAC of



audio codec. The 16-bit data are applied to the input of interpolating filters, followed by a noise shaper to be transformed into a bit stream.

The audio codec DAC function block diagram is shown in Figure 8-3. The digital part includes the optional de-emphasis filter, the cascaded interpolation filters, and the noise shaper. The other part is analog blocks.

A de-emphasis filter is implemented in the input of the DAC path. This enables compatibility with old audio CD records. Due to this, the filter coefficients are fitted to work when Fs = 44.1 kHz. This filter is activated when DEEMPH (ARM 0x8200\_3108 or DSP 0xBA42 bit [7]) is set to '1'.



Figure 8-3 DAC function block diagram

The analog part is a switched capacitor low pass filter (reconstruction filter), followed by a continuous time low pass filter which is achieved by the mixer. In addition, before the mixer a PGA is available, this provides programmable attenuation range from 0 dB to -22.5 dB with 1.5 dB steps through a 4-bit word. They allow filtering the out-of-band quantization noise introduced by the digital noise shaper.

Table 8-3 shows the interpolation filter characteristics

Table 8-3 The interpolation filter characteristics

For Fs ≤ 48 kHz

| Filter characteristics | Min.    | Tvp. | Max. | Unit |
|------------------------|---------|------|------|------|
| Stop band              | 0.545Fs |      |      | Hz   |
|                        | (TBC)   |      |      |      |



| Stop band attenuation | -90<br>(TBC) |          | dB |
|-----------------------|--------------|----------|----|
| Pass band             | 7181         | 0.455Fs  | Hz |
| Pass band ripple      |              | +/- 0.05 | dB |

#### For Fs = 96 kHz

| Filter characteristics | Min.    | Tvp.         | Max.     | Unit |
|------------------------|---------|--------------|----------|------|
| Stop band              | 0.545Fs |              |          | Hz   |
|                        | (TRC)   | <u> </u>     |          |      |
| Stop band attenuation  | -90     |              |          | dB   |
|                        | (TRC)   |              |          |      |
| Pass band              |         | <b>*</b> . ( | 0.288Fs  | Hz   |
|                        |         |              | (TRC)    |      |
| Pass band ripple       |         |              | +/- 0.05 | dB   |
|                        |         |              | (TRC)    |      |

The output signal from the mixer goes to three ends: headphone output through pads HEAD\_P\_L and HEAD\_P\_R, differential line output through pads AUXSPP and AUXSPN, and BTL output through pads EARP and EARN. The following section "Output Branch Description" gives a detailed explanation.

### 8.3.3 Analog Line-in Path

The analog line-in path, or analog bypass path, is provided for additional applications (for example, FM radio), and includes the Line input buffer, the Mixer, and the output path (headphone output amplifier, line out amplifier, or BTL amplifier).

Analog signal from pads AIL1 (left channel) and AIR1 (right channel) directly input to the two mixers through line input buffers, and the output signal from the mixers pass through three branch and also arrive to three ends.

#### 8.3.4 Mixer Path

Besides allowing a single path (either the DAC output signal or the analog line-in signal) passing through, the Mixers also allow select the signals from the two inputs.

Before inputting to the Mixer, a PGA is used for both paths. For the line-in path, the programmable gain/attenuation range varies from +6 dB to -22.5 dB with 1.5 dB steps through a 5-bit word. For the DAC path, the programmable attenuation range varies from 0 dB to -22.5 dB with 1.5 dB steps through a 4-bit word.



# 8.3.5 Output Branch Description

The signal output from the Mixer is applied to:

- A headphone output amplifier (PGAT) to drive a low impedance load (down to 16 Ohm) through an external bypass capacitor. This stage allows a programmable gain/attenuation range from +4.5 dB to -33.5 dB with a variable step through a 5-bit word
- A differential line output amplifier to drive a minimum of 10 kOhm load
- A BTL (Bridge Tied Load) driver through the line output amplifier in order to provide 240 mW on an 8 Ohm load

Two mute signals allow suppressing the output signal while the DAC and LPF are still working on mixer and BTL stages.

Note: The headphone output stage is configurable, 3-wire capacitor-less headphone output or 2-wire with bypass capacitors output can be selected by user.



### 8.4 I2S Serial Interface

#### 8.4.1 General Features

There are two groups of I2S interface signals between the audio codec and the VBC block, one group is for the mono ADC channel, and the other is for the stereo DAC channels. I2S serial communication is performed via three one-bit signals: a clock signal, a data signal and a synchronization signal.

The two groups of I2S serial interface signals are defined as in Table 8-4.

| Interface Name | Descriptions               |
|----------------|----------------------------|
| ADC_BCLK       | ADC bit clock signal       |
| ADC_LRO        | ADC synchronization signal |
| ADC_SDATA      | ADC data signal            |
| DAC_BCLK       | DAC bit clock signal       |
| DAC_LRO        | DAC synchronization signal |
| DAC_SDATA      | DAC data signal            |

Table 8-4 I2S interface list

- a) Master and Slave Audio Codec is the master of the serial interface, meaning that the audio codec initiates data transmission. For the ADC channel, the three signals ADC\_BCLK, ADC\_LRO, ADC\_SDATA are all output from audio codec to VBC interface. For the DAC channel, DAC\_BCLK and DAC\_LRO are output from audio codec to VBC interface, and DAC\_SDATA, which is generated on DAC\_BCLK and DAC\_LRO by VBC interface, is output from VBC interface to audio codec.
- b) **Synchronization** For the ADC channel, ADC\_LRO and ADC\_SDATA are generated on ADC\_BCLK falling edge by the audio codec, and to ensure a data transmission robust to setup/hold requirements, VBC interface samples ADC\_SDATA on the rising edge of ADC\_BCLK. On the other hand, for the DAC channels, DAC\_LRO is generated on DAC\_BCLK falling edge by the audio codec, so VBC interface also generates DAC\_SDATA on DAC\_BCLK falling edge, and the audio codec samples DAC\_SDATA on DAC\_BCLK rising edge.



c) Frequency Relationship The audio codec MCLK (Main Clock) frequency is equal to 12 MHz, and for different audio sampling frequency, Fs, the frequency of BCLK is different. The mean frequency of LRO is equal to Fs, but the delay between two LRO may vary (one BCLK cycle difference max) when Ts (= 1/Fs) is not an integer multiple of MCLK period. For instance, if Fs = 44.1 kHz and BCLK frequency is equal to 3 MHz, the mean LRO period is equal to 68.02721... BCLK periods, and so the number of BCLK cycles between two LRO high-levels varies between 68 and 69. Table 7-5 describes the relation between MCLK, Fs and BCLK frequency.

MCLK (MHz) Fs (kHz) MCLK/BCLK BCLK/Fs **BCLK** frequency (kHz) frequency ratio frequency ratio 12 62.5 24 500 12 9.6 20 62.5 600 750 12 11.025 16 68.0272109 12 12 62.5 750 16 12 16 12 62.5 1000 12 22.05 8 68.0272109 1500 24 8 62.5 1500 12 32 6 62.5 12 2000 12 44.1 4 68.0272109 3000 12 48 4 62.5 3000

Table 8-5 The relation between MCLK, Fs and BCLK frequency

The serial interfaces can work in two modes: DSP mode or I2S mode. The mode is selected through the VB\_AICR register described in Section 8.6. The following two sections describe the two serial interface modes in detail.

2

62.5

#### 8.4.2 DSP Mode Timing

12

96

In DSP mode, DAC\_LRO or ADC\_LRO signal is a one DAC\_BCLK or ADC\_BCLK cycle high-level pulse. DAC\_SDATA or ADC SDATA transmission has to start one BCLK cycle after LRO rising edge, left channel first, from MSB to LSB, then right channel, from MSB to LSB. There is no delay between left and right channel transmission, so word length (16 bits data width) must be taken into account when transmitting or receiving data. The ADC is mono channel, the same data are sent twice in each cycle. The following two figures show the timing of the DSP interface modes.

6000





Figure 8-4 ADC serial interface timing in DSP mode



Figure 8-5 DAC serial interface timing in DSP mode

### 8.4.3 I2S Mode Timing

In I2S mode, DAC\_LRO or ADC\_LRO signal high-level duration is 32 BCLK cycles, and low-level duration is the remaining BCLK cycles, that is, LRO period in BCLK of the current LRO cycle minus 32. Therefore, duty cycle of LRO is different from 50%. DAC or ADC SDATA transmission has to start one BCLK cycle after LRO edge.

For DAC channels, right channel data are sent after the LRO rising edge, MSB first. Left channel data are sent after the LRO falling edge, MSB first. The ADC is mono channel, and the same data are sent twice in each cycle. Depending on data word length (16 bits supported only), SDATA is filled with '0' until next channel transmission. The following two figures show the timing of the I2S interface modes.





Figure 8-6 ADC serial interface timing in I2S mode



Figure 8-7 DAC serial interface timing in I2S mode

# 8.5 VBC Interface

### 8.5.1 Overview

The VBC module is designed as a digital interface, for software control and data handling with Audio Codec. Digital high-pass IIR filters, digital gain, side tone module and loop path are also implemented in VBC for special applications.



#### 8.5.2 Features

- Both ARM and DSP can control Voice Band independently, so both APB bus and DSP Z bus are included in VBC module. They are able to access the same VB control registers
- I Support two ADC channels: ADC0 and ADC1(one is reserved)
- Support two DAC channels: DAC0 and DAC1
- I Two slave IIS/PCM serial interface for ADC/DAC data
- 2 320x16 SRAM are used as ADC ping-pong buffer, in which address 0~159 is for ADC0, and address 160~319 is for ADC1
- 2 320x16 SRAM are used as DAC0, DAC1 ping-pong buffer, in which address 0~159 is for DAC0, and address 160~319 is for DAC1
- I Max buffer size of 4 channels supported is 160
- Support DMA access in ARM control mode
- I DAC serial 6th-order IIR filter sections are designed for application such as high-pass filter and EQ
- I DAC auto-level control(ALC) is supported
- I DAC digital gain is supported
- I DAC output limit is supported
- I DAC output can be selected as 16 bits or 24 bits
- I ADC digital gain is supported
- I Side tone is supported
- ADC input signal can be sent to DAC through side tone
- I DAC output signal can be loop to ADC
- External IIS serial data can be selected as ADC input
- I ADC interrupt to software if one ADC buffer is full
- I DAC interrupt to software if one DAC buffer is empty

### 8.5.3 Signal Description

#### 8.5.4 Function Description





Figure 8-8 Voice Band Digital Interface

In the figure, the red parts belong to VBC module, and the blue part, which converts APB bus to uC bus.

Audio Codec digital interface includes clocks, serial audio interface and control interface. MCLK are generated from clock managing block in the top level of the chip. IIS/PCM serial interface transfer audio data between Codec and 160-word data ping-pong buffer. APB-MC interface converter, together with the ADI interface, work as a data bridge between APB/Z-bus and 8-bit uC interface.

Both ARM and DSP can control Voice Band independently. They are able to access the same VB control register, and control the data interrupt frequency. Through ARM and DSP register, four Voice paths ADC0,ADC1, DAC0, DAC1 can be shut down at different time, VB register access clock can also be shut down. Interrupt will be sent to ARM/DSP after the data in the ping-pong buffer is full for ADC channel, or empty for DAC channel.



In ARM global register 0x8B00\_0044, a 1-bit control register "arm\_vb\_acc" is used to select ARM or DSP control voice band. Default value is 0, allowing DSP controlling.

If ARM controlling is selected, a DMA hardware channel is provided for ADC and DAC respectively. Instead of interrupt, DMA request will be sent to DMA after the data in the ping-pong buffer is full for ADC channel, or empty for DAC channel.

#### 8.5.4.1 Path Control and Function Module



Figure 8-9 VBC Path Control



The above figure describes all VBC data flow paths. Except the direct DAC and ADC paths, several loop paths are added for different application.

- I ADC loop to DAC
  - Side tone module is implemented between ADC and DAC path, and through the side tone module, ADC data can loop to DAC, either to the input of DAC HPF, or output of DAC channel, added or subtracted by the DAC data.
- I DAC loop to ADC

The output of DAC can also loop to ADC path, after right shifting 8 bits and into the ADC digital gain module

The input data of each ADC channel can be selected between the two input channel, and also an external-chip input is also designed, which is useful when external audio signal is needed to be processed.

A digital gain is implemented for each DAC and ADC channel, and the gain coefficient DG[6:0] is parsed as follows..

Figure 8-10 VBC Digital Gain



The 6th-order IIR high-pass filter is showed in the following figure. The filter is grouped into 3 parts. Each part is a 2<sup>nd</sup>-order IIR, and implemented in one module, named vbhp\_s01.v, vbhp\_s23.v and vbhp\_45.v. In each 2<sup>nd</sup>-order IIR, DAC0 and DAC1 share the hardware, so after a valid-in signal, the DAC0 data are processed first, and then the DAC1 data are processed. After DAC1 data processing finishes, the valid-out signal is generated.

All the data during IIR processing are 34bits. The input 16bits data are left shifted 16bits and extended 2 bits to be 34bits, and the output data are 28bits for ALC module processing.

As for the ALC module, please refer to the document "SC6820 VBC\_ALC Design Specification".

The 8bits hp\_limit control register is for the output limit logic. The output signal also can be limited to an expected value, and the value is hp\_limit[7:0]<<16+16'hFFFF.

**Note 1:** The input 16bit data of the 6-band IIR are left shifted 16bits and then extended to be 34bits, but the output 34bits data from the 6-band IIR are first right shifted 6 bits to be 28bits, pass through ALC, clipped to 24bits, and then right shifted 8 bits after the limiter to be 16bits.

**Note2:** Since the input data is 16bits left shifted, and the output data are 6+8=14bit right shifted, if the digital gain and the 6-band IIR are both configured to be bypass-state, the output of DAC is 4-times amplified.

**Note3:** If the 6-band IIR is enabled, the following configuration of the 43 HPCOEF registers is corresponding to the bypass-state of the 6-band IIR

HPCOEF0: 'h1000 HPCOEF1: 'h4000 HPCOEF2: 'h4000

HPCOEF3: 'h0000 HPCOEF4: 'h0000 HPCOEF5: 'h0000 HPCOEF6: 'h0000

HPCOEF7: 'h1000 HPCOEF8: 'h4000 HPCOEF9: 'h4000

HPCOEF10: 'h0000 HPCOEF11: 'h0000 HPCOEF12: 'h0000 HPCOEF13: 'h0000

HPCOEF14: 'h1000 HPCOEF15: 'h4000 HPCOEF16: 'h4000

HPCOEF17: 'h0000 HPCOEF18: 'h0000 HPCOEF19: 'h0000 HPCOEF20: 'h0000



HPCOEF21: 'h1000 HPCOEF22: 'h4000 HPCOEF23: 'h4000

HPCOEF24: 'h0000 HPCOEF25: 'h0000 HPCOEF26: 'h0000 HPCOEF27: 'h0000

HPCOEF28: 'h1000 HPCOEF29: 'h4000 HPCOEF30: 'h4000

HPCOEF31: 'h0000 HPCOEF32: 'h0000 HPCOEF33: 'h0000 HPCOEF34: 'h0000

HPCOEF35: 'h1000 HPCOEF36: 'h4000 HPCOEF37: 'h4000

HPCOEF38: 'h0000 HPCOEF39: 'h0000 HPCOEF40: 'h0000 HPCOEF41: 'h0000

HPCOEF42: 'h1000





Figure 8-11 VBC 6-order DAC IIR filter

The side tone module includes a high-pass filter and a digital gain. The coefficient N[3:0] of the high-pass filter should be configured by software. The digital gain of side tone is the same with the DAC and ADC channel digital gain.



$$h(z) = (1 - 1) \times (N + 1)$$

$$1 - Z^{-1}$$

$$1 - (1 - 1) \times N) Z^{-1}$$

$$Gi = DG[2:0] = 0,1,2,3,4,5,6,7$$

$$G0.75[Gi] = \begin{bmatrix} 128 & 117 & 108 & 99 & 90 & 83 & 76 & 70 \end{bmatrix}$$

$$M = DG[6:3] = 0,1,2,3,4,...15$$

N = HPF[3:0] = 0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15



Figure 8-12 VBC Side Tone

### 8.5.4.2 Clock Domain

Clock for ADC/DAC I2S slave interface and data buffer can be shut down independently. Totally four clocks input to voice band interface:

- ADC\_BCLK for ADC I2S Slave block, ADC digital gain and ADC data buffer. Control signal: vb\_ad0on and vb\_ad1on. If ARM controlling voice band, the two control bits are located in global control register 0x8B00\_0044 bit[5:4]. If DSP controlling voice band, the two control bits are located in STC(system timing and controls) control register 0x0064\_0294 bit[6:5].
- DAC\_BCLK for DAC I2S Slave block, DAC digital gain, DAC high pass filter and DAC data buffer. Control signal: vb\_da0on and vb\_da1on. If ARM controlling voice band, the two control bits are located in global control register 0x8B00\_044 bit[4:3]. If DSP controlling voice band, the two control bits are located in STC(system timing and controls) control register FORCE\_PD bit[8:7].
- APB clock or Z bus clock for ADC, DAC data buffer, selected by arm\_vb\_acc, global control register 0x8B00\_0044 bit[7].
- .CLK\_12M for Audio Codec main clock.



#### 8.5.4.3 I2S Slave Interface

The I2S slave interface receives serial ADC data under the control of ADC\_BCLK and ADC\_LRO, which are generated by audio codec I2S master interface, and sends serial DAC data under the control of DAC\_BCLK and DAC\_LRO, which are also generated by audio codec I2S master interface.

#### 8.5.4.4 Audio Codec control Interface

For the control registers located in audio codec, ARM or DSP access them through an 8-bit parallel  $\mu$ C interface. The 8-bit parallel  $\mu$ C interfaces are synchronized to MC\_CLK. The other control signals, MC\_ADDR, MC\_LOAD and MC\_DIN, are supposed to be generated on MC\_CLK rising edge.

To read registers in the audio codec, ARM/DSP sends a read operation through the ADI interface, and the APB-MC bridge generates MC\_ADDR, to the Audio Codec, then the Audio Codec outputs MC\_DOUT data after a Tread delay. MC\_DOUT can be sampled by the APB-MC bridge just after the Tread delay time (sure on the next rising edge of MC\_CLK). MC\_DOUT will be sent to ARM/DSP through the ADI interface after word length expanded to 16 bits.

To write registers in the audio codec, ARM/DSP sends a write operation through the ADI interface, and the APB-MC bridge generates MC\_ADDR, MC\_LOAD and the input data MC\_DIN on the MC\_CLK rising edge. MC\_DIN is sampled by the Codec on the next MC\_CLK rising edge.

The following two figures show the read and write timing of the 8-bit parallel µC interfaces.





Figure 8-13 Parallel µC Interface Register Read Timing



Figure 8-14 Parallel µC Interface Register Write Timing

# 8.5.4.5 Digital Audio Data Buffer

Two 160x16 bit SRAM work as ping-pong buffers for each channel. The 4 160x16 SRAM for DAC0 and DAC1 ping-pong buffers are combined to 2 320 x 16 SRAM. The address 0 ~ 159 in each SRAM is DAC0 ping-pong buffer, and the address 160~319 in each SRAM is DAC1 ping-pong buffer. It's the same for ADC0 and ADC1 ping-pong buffer.

Received voice data are read out from ADC0 and ADC1 data buffer by software, and data for transmit are sent to DAC0, DAC1 data buffer also by software. Buffer size is programmable from 1 to 160 words. ADC interrupt(shared by ADC0 and ADC1) will be generated when ADC data buffer is full (written by hardware), and DAC interrupt (shared by DAC0 and DAC1) will be generated when DAC data buffer is empty (read by hardware). Voice interrupt frequency can be calculated from the buffer size. For example: when playing voice at 8 kHz sampling rate, buffer size is 160 words, the interval between two interrupt is: 125 us x 160 = 20 ms.



If DAC and ADC buffer sizes are the same, after voice band is enabled, the buffer size is not changed, two interrupts should be synchronized (within one voice sample duration), either one can be used as buffer full/empty interrupt.

Address counter for each path will be reset to zero after interrupt is generated or at VBENABLE register (0xBB06 bit 15) changing from low to high.

## 8.5.5 Control Registers

### 8.5.5.1 Memory map

DSP side base address: 0x0063\_0000

DSP controls the Voice Band Controller (VBC) by default.

ARM side base address: 0x8200\_3000/0x1063\_0000

From the ARM side, please set 0x8B00\_0044 bit[7] = 1'b1, to enable ARM access to VB

#### Note:

- ARM can access Voice Band Codec module either through APB space, at base address 32'h8200\_3000 or through AHB space (from ARM matrix to DSP matrix), at base address 32'h1063\_0000.
- For all Voice Band Codec registers through AHB space, please use half-word access; byte, word, or double-word accessing is forbidden. If access through APB space, only word access is permitted.

#### Table 7-6 Voice Band control registers

| Offset Address | Name  | Description                 |
|----------------|-------|-----------------------------|
| 0x0000(0x0000) | VBDA0 | Voice band DAC0 data buffer |
| 0x0004(0x0002) | VBDA1 | Voice band DAC1 data buffer |
| 0x0008(0x0004) | VBAD0 | Voice band ADC0 data buffer |
| 0x000C(0x0006) | VBAD1 | Voice band ADC1 data buffer |



| Offset Address                    | Name        | Description                             |
|-----------------------------------|-------------|-----------------------------------------|
| 0x0010(0x0008)                    | VBBUFFSIZE  | Voice band buffer size                  |
| 0x0014(0x000A)                    | VBADBUFFDTA | Voice band AD buffer control            |
| 0x0018(0x000C)                    | VBDABUFFDTA | Voice band DA buffer control            |
| 0x001C(0x000E)                    | VBADCNT     | Voice band AD buffer counter            |
| 0x0020(0x0010)                    | VBDACNT     | Voice band DA buffer counter            |
| 0x0024 ~0x0030                    |             | Reserved                                |
| (0x0012~0x0018)                   |             | Reserved                                |
| 0x0034 (0x001A)                   | VBINTTYPE   | Voice band interrupt type               |
| 0x0038 ~0x003C<br>(0x001C~0x001E) |             | Reserved                                |
| 0x0040(0x0020)                    | DAPATHCTL   | DAC path control                        |
| 0x0044(0x0022)                    | DADGCTL     | DAC digital gain control                |
| 0x0048(0x0024)                    | DAHPCTL     | DAC 6-band IIR high-pass filter control |
| 0x004C(0x0026)                    | DAALCCTL0   | DAC ALC coefficient: hold               |
| 0x0050(0x0028)                    | DAALCCTL1   | DAC ALC coefficient: rise               |
| 0x0054(0x002A)                    | DAALCCTL2   | DAC ALC coefficient: fall               |
| 0x0058(0x002C)                    | DAALCCTL3   | DAC ALC coefficient: limit              |
| 0x005C(0x002E)                    | DAALCCTL4   | DAC ALC coefficient: threshold          |
| 0x0060(0x0030)                    | DAALCCTL5   | DAC ALC coefficient: ratio              |
| 0x0064(0x0032)                    | DAALCCTL6   | DAC ALC coefficient: cg_var             |
| 0x0068(0x0034)                    | DAALCCTL7   | DAC ALC coefficient: release_rate       |
| 0x006C(0x0036)                    | DAALCCTL8   | DAC ALC coefficient: attack_rate        |
| 0x0070(0x0038)                    | DAALCCTL9   | DAC ALC coefficient: release_rate_ex    |
| 0x0074(0x003A)                    | DAALCCTL10  | DAC ALC coefficient: attack_rate_ex     |
| 0x0078(0x003C)                    | STCTL0      | Side tone control of channel 0          |
| 0x007C(0x003E)                    | STCTL1      | Side tone control of channel 1          |
| 0x0080(0x0040)                    | ADPATHCTL   | ADC path control                        |



| ſ | Offset Address                          | Name     | Description                                       |
|---|-----------------------------------------|----------|---------------------------------------------------|
| ŀ | 0x0084(0x0042)                          | ADDGCTL  | ADC digital gain control                          |
|   | 0x0088 ~ 0x00FC<br>(0x0044 ~<br>0x007E) | Reserved |                                                   |
|   | 0x0100 (0x0080)                         | HPCOEF0  | DAC 6 band IIR High-pass filter coefficients s0   |
|   | 0x0104 (0x0082)                         | HPCOEF1  | DAC 6 band IIR High-pass filter coefficients b0_0 |
|   | 0x0108 (0x0084)                         | HPCOEF2  | DAC 6 band IIR High-pass filter coefficients a0_0 |
| • | 0x010C (0x0086)                         | HPCOEF3  | DAC 6 band IIR High-pass filter coefficients b1_0 |
|   | 0x0110 (0x0088)                         | HPCOEF4  | DAC 6 band IIR High-pass filter coefficients a1_0 |
|   | 0x0114 (0x008A)                         | HPCOEF5  | DAC 6 band IIR High-pass filter coefficients b2_0 |
|   | 0x0118 (0x008C)                         | HPCOEF6  | DAC 6 band IIR High-pass filter coefficients a2_0 |
|   | 0x011C (0x008E)                         | HPCOEF7  | DAC 6 band IIR High-pass filter coefficients s1   |
|   | 0x0120 (0x0090)                         | HPCOEF8  | DAC 6 band IIR High-pass filter coefficients b0_1 |
|   | 0x0124 (0x0092)                         | HPCOEF9  | DAC 6 band IIR High-pass filter coefficients a0_1 |
|   | 0x0128 (0x0094)                         | HPCOEF10 | DAC 6 band IIR High-pass filter coefficients b1_1 |
|   | 0x012C (0x0096)                         | HPCOEF11 | DAC 6 band IIR High-pass filter coefficients a1_1 |
|   | 0x0130 (0x0098)                         | HPCOEF12 | DAC 6 band IIR High-pass filter coefficients b2_1 |
|   | 0x0134 (0x009A)                         | HPCOEF13 | DAC 6 band IIR High-pass filter coefficients a2_1 |
|   | 0x0138 (0x009C)                         | HPCOEF14 | DAC 6 band IIR High-pass filter coefficients s2   |



| Offset Address  | Name                                                                                                                                                                                                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x013C (0x009E) | HPCOEF15                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients b0_2                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0140 (0x00A0) | HPCOEF16                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients a0_2                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0144 (0x00A2) | HPCOEF17                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients b1_2                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0148 (0x00A4) | HPCOEF18                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients a1_2                                                                                                                                                                                                                                                                                                                                                                              |
| 0x014C (0x00A6) | HPCOEF19                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients b2_2                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0150 (0x00A8) | HPCOEF20                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients a2_2                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0154 (0x00AA) | HPCOEF21                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients s3                                                                                                                                                                                                                                                                                                                                                                                |
| 0x0158 (0x00AC) | HPCOEF22                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients b0_3                                                                                                                                                                                                                                                                                                                                                                              |
| 0x015C (0x00AE) | HPCOEF23                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients a0_3                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0160 (0x00B0) | HPCOEF24                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients b1_3                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0164 (0x00B2) | HPCOEF25                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients a1_3                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0168 (0x00B4) | HPCOEF26                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients b2_3                                                                                                                                                                                                                                                                                                                                                                              |
| 0x016C (0x00B6) | HPCOEF27                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients a2_3                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0170 (0x00B8) | HPCOEF28                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients s4                                                                                                                                                                                                                                                                                                                                                                                |
| 0x0174 (0x00BA) | HPCOEF29                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients b0_4                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0178 (0x00BC) | HPCOEF30                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients a0_4                                                                                                                                                                                                                                                                                                                                                                              |
| 0x017C (0x00BE) | HPCOEF31                                                                                                                                                                                                        | DAC 6 band IIR High-pass filter coefficients b1_4                                                                                                                                                                                                                                                                                                                                                                              |
|                 | 0x013C (0x009E) 0x014O (0x00A0) 0x014A (0x00A2) 0x014A (0x00A4) 0x014C (0x00A6) 0x015O (0x00A8) 0x015A (0x00AA) 0x015C (0x00AE) 0x016O (0x00B0) 0x016A (0x00B2) 0x016C (0x00B6) 0x017O (0x00B8) 0x017A (0x00BA) | 0x013C (0x009E) HPCOEF15  0x0140 (0x00A0) HPCOEF16  0x0144 (0x00A2) HPCOEF17  0x0148 (0x00A4) HPCOEF18  0x014C (0x00A6) HPCOEF19  0x0150 (0x00A8) HPCOEF20  0x0154 (0x00AA) HPCOEF21  0x0158 (0x00AC) HPCOEF22  0x015C (0x00AE) HPCOEF23  0x0160 (0x00B0) HPCOEF24  0x0164 (0x00B2) HPCOEF25  0x0168 (0x00B4) HPCOEF26  0x016C (0x00B6) HPCOEF27  0x0170 (0x00B8) HPCOEF28  0x0174 (0x00BA) HPCOEF29  0x0178 (0x00BC) HPCOEF30 |



| Offset Address  | Name     | Description                                       |
|-----------------|----------|---------------------------------------------------|
| 0x0180 (0x00C0) | HPCOEF32 | DAC 6 band IIR High-pass filter coefficients a1_4 |
| 0x0184 (0x00C2) | HPCOEF33 | DAC 6 band IIR High-pass filter coefficients b2_4 |
| 0x0188 (0x00C4) | HPCOEF34 | DAC 6 band IIR High-pass filter coefficients a2_4 |
| 0x018C (0x00C6) | HPCOEF35 | DAC 6 band IIR High-pass filter coefficients s5   |
| 0x0190 (0x00C8) | HPCOEF36 | DAC 6 band IIR High-pass filter coefficients b0_5 |
| 0x0194 (0x00CA) | HPCOEF37 | DAC 6 band IIR High-pass filter coefficients a0_5 |
| 0x0198 (0x00CC) | HPCOEF38 | DAC 6 band IIR High-pass filter coefficients b1_5 |
| 0x019C(0x00CE)  | HPCOEF39 | DAC 6 band IIR High-pass filter coefficients a1_5 |
| 0x01A0 (0x00D0) | HPCOEF40 | DAC 6 band IIR High-pass filter coefficients b2_5 |
| 0x01A4 (0x00D2) | HPCOEF41 | DAC 6 band IIR High-pass filter coefficients a2_5 |
| 0x01A8 (0x00D4) | HPCOEF42 | DAC 6 band IIR High-pass filter coefficients s6   |

## 8.5.5.2 Register Descriptions

8.5.5.2.1 VBDA0



| 0x0000 | (0x000 | 00)                                             | Voice | Voice band DAC0 data (reset 0x0000_0000) VBD |    |    |   |     |     |   |   |   |   |   |   | BDA0 |
|--------|--------|-------------------------------------------------|-------|----------------------------------------------|----|----|---|-----|-----|---|---|---|---|---|---|------|
| Bit    | 31     | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |       |                                              |    |    |   |     |     |   |   |   |   |   |   |      |
| Name   |        | Reserved                                        |       |                                              |    |    |   |     |     |   |   |   |   |   |   |      |
| Туре   |        |                                                 | RO    |                                              |    |    |   |     |     |   |   |   |   |   |   |      |
| 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   |        |                                                 |       |                                              |    |    |   | VBI | DA0 |   |   |   |   |   |   |      |
| Туре   |        | R/W                                             |       |                                              |    |    |   |     |     |   |   |   |   |   |   |      |
| Reset  | 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                   |       |                                              |    |    |   |     |     |   |   |   |   |   |   |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                  |
|------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VBDA0      | [15:0] | R/W  | 16'h0          | Voice band DAC0 channel data from ARM/DSP. ARM/DSP writes every word of DAC0 data to this control register, and VBC moves the 16bits data to corresponding address of DAC0 buffer one by one |

8.5.5.2.2 VBDA1



| 0x0004 | (0x000 | )2)                                                                                                                                                                     | Voice band DAC1 data (reset 0x0000_0000) VBDA1 |       |    |    |   |   |   |   |   |   |   |   | 3DA1 |   |
|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------|----|----|---|---|---|---|---|---|---|---|------|---|
| Bit    | 31     | 31         30         29         28         27         26         25         24         23         22         21         20         19         18         17         16 |                                                |       |    |    |   |   |   |   |   |   |   |   |      |   |
| Name   |        | Reserved                                                                                                                                                                |                                                |       |    |    |   |   |   |   |   |   |   |   |      |   |
| Туре   |        | RO                                                                                                                                                                      |                                                |       |    |    |   |   |   |   |   |   |   |   |      |   |
| 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   |        |                                                                                                                                                                         |                                                | VBDA1 |    |    |   |   |   |   |   |   |   |   |      |   |
| Туре   |        | R/W                                                                                                                                                                     |                                                |       |    |    |   |   |   |   |   |   |   |   |      |   |
| Reset  | 0      | 0                                                                                                                                                                       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0                    |       |    |    |   |   |   |   |   |   |   |   |      |   |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                  |
|------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VBDA1      | [15:0] | R/W  | 16'h0          | Voice band DAC1 channel data from ARM/DSP. ARM/DSP writes every word of DAC1 data to this control register, and VBC moves the 16bits data to corresponding address of DAC1 buffer one by one |

8.5.5.2.3 VBAD0



| 0x0008 | (0x000 | )4)                                             | Voice | Voice band ADC0 data (reset 0x0000_0000) VBAD0 |    |    |   |    |     |   |   |   |   |   |   | BAD0 |
|--------|--------|-------------------------------------------------|-------|------------------------------------------------|----|----|---|----|-----|---|---|---|---|---|---|------|
| Bit    | 31     | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |       |                                                |    |    |   |    |     |   |   |   |   |   |   |      |
| Name   |        | Reserved                                        |       |                                                |    |    |   |    |     |   |   |   |   |   |   |      |
| Туре   |        |                                                 | RO    |                                                |    |    |   |    |     |   |   |   |   |   |   |      |
| 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   |        |                                                 |       |                                                |    |    |   | VB | AD0 |   |   |   |   |   |   |      |
| Туре   |        | RO                                              |       |                                                |    |    |   |    |     |   |   |   |   |   |   |      |
| Reset  | 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0                       |       |                                                |    |    |   |    |     |   |   |   |   |   |   |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                  |
|------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VBAD0      | [15:0] | RO   | 16'h0          | ADC0 channel data from Audio CODEC to<br>ARM/DSP. VBC moves every word from ADC0<br>buffer one by one to this register, and ARM/DSP<br>read the ADC0 data from this register |

8.5.5.2.4 VBAD1



| 0x000C | (0x00 | 06)                                             | VBAD1 Voice band ADC1 data (reset 0x0000_0000) |    |    |    |   |     |     |   |   |   |   |    | VI | BAD1 |
|--------|-------|-------------------------------------------------|------------------------------------------------|----|----|----|---|-----|-----|---|---|---|---|----|----|------|
| Bit    | 31    | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                                                |    |    |    |   |     |     |   |   |   |   | 16 |    |      |
| Name   |       | Reserved                                        |                                                |    |    |    |   |     |     |   |   |   |   |    |    |      |
| Туре   |       | 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   |       |                                                 |                                                |    |    |    |   | VBA | AD1 |   |   |   |   |    |    |      |
| Туре   |       | RO                                              |                                                |    |    |    |   |     |     |   |   |   |   |    |    |      |
| Reset  | 0     | 0                                               | 0 0 0 0 0 0 0 0 0 0 0 0                        |    |    |    |   |     |     |   | 0 |   |   |    |    |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                           |
|------------|--------|------|----------------|-----------------------------------------------------------------------------------------------------------------------|
| VBAD1      | [15:0] | RO   | 16'h0          | Reserved for voice band another ADC channel input data. 0x0000 will be output if software reads this control register |

8.5.5.2.5 VBBUFFSIZE



| 0x0010 | (0x000 | 0x0008) Voice band buffer size(reset 0x0000_0000) VB |    |        |         |    |   |        |              |   |   |   |   | BBUFF | SIZE |   |
|--------|--------|------------------------------------------------------|----|--------|---------|----|---|--------|--------------|---|---|---|---|-------|------|---|
| Bit    | 31     | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 10      |    |        |         |    |   |        |              |   |   |   |   | 16    |      |   |
| Name   |        |                                                      |    |        |         |    |   | served |              |   |   |   |   |       |      |   |
| Туре   |        |                                                      |    |        |         |    |   | R      | 0            |   |   |   |   |       |      |   |
| 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   |        |                                                      |    | VBDABU | JFFSIZE |    |   |        | VBADBUFFSIZE |   |   |   |   |       |      |   |
| Туре   |        |                                                      |    | R      | W       |    |   |        | RW           |   |   |   |   |       |      |   |
| Reset  | 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0                            |    |        |         |    |   |        |              |   |   | 0 |   |       |      |   |

| Field Name   | Bit    | Туре | Reset<br>Value | Description                                                                                                                          |
|--------------|--------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------|
| VBDABUFFSIZE | [15:8] | R/W  | 8'h0           | Voice band DAC0 and DAC1 channel data buffer size, equals to real buffer size minus 1. max 159. 0~159 maps to real buffer size 1~160 |
| VBADBUFFSIZE | [7:0]  | R/W  | 8'h0           | Voice band ADC channel data buffer size, equals to real buffer size minus 1. max 159. 0~159 maps to real buffer size 1~160           |

8.5.5.2.6 VBADBUFFDTA



| 0x0014 | (0x00(             | )A)                    | Voic                    | e band                  | buffe            | r and I                  | 2S cor                   | ntrol(re | set 0x | 0000_ | 1000) |      |    | VBA | DBUFI | FDTA |
|--------|--------------------|------------------------|-------------------------|-------------------------|------------------|--------------------------|--------------------------|----------|--------|-------|-------|------|----|-----|-------|------|
| Bit    | 31                 | 30                     | 29                      | 28                      | 27               | 26                       | 25                       | 24       | 23     | 22    | 21    | 20   | 19 | 18  | 17    | 16   |
| Name   |                    |                        |                         |                         |                  |                          |                          | Rese     | erved  |       |       |      |    |     |       |      |
| Туре   |                    |                        |                         |                         |                  |                          |                          | R        | 0      |       |       |      |    |     |       |      |
| 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   | VBII<br>S_L<br>RCK | VBP<br>CM_<br>MO<br>DE | VBII<br>S_D<br>LOO<br>P | VBI<br>SAD<br>_DS<br>EL | VBL<br>SB_<br>EB | VBI<br>SDA<br>CK_I<br>NV | VBI<br>SAD<br>CK_I<br>NV |          |        |       | ΑC    | BUFF | Δ  | 2   |       |      |
| Туре   | R/W                | R/W                    | R/W                     | R/W                     | R/W              | R/W                      | R/W                      |          |        |       | (     | R/W  |    |     |       |      |
| Reset  | 0                  | 0                      | 0                       | 1                       | 0                | 0                        | 0                        | 0        | 0      | 0     | 0     | 0    | 0  | 0   | 0     | 0    |

| Field Name  | Bit  | Туре | Reset<br>Value | Description                                                                                                                                                                    |
|-------------|------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VBIIS_LRCK  | [15] | R/W  | 1'h0           | Active level of 0/1 channel for both ADC and DAC channel "0": High for channel 0, low for channel 1 "1": Low for channel 0, high for channel 1                                 |
| VBPCM_MODE  | [14] | R/W  | 1'h0           | I2S interface format for both ADC and DAC channel 0: I2S compatible format 1: PCM compatible format Note: I2S mode is recommended to be compatible with audio CODEC I2S master |
| VBIIS_DLOOP | [13] | R/W  | 1'h0           | Loop IIS three Tx signals(DA) to IIS 3 Rx signals(AD).  0: normal mode  1: loop mode                                                                                           |
| VBISAD_DSEL | [12] | R/W  | 1'h1           | Reserved, No use                                                                                                                                                               |
| VBLSB_EB    | [11] | R/W  | 1'h0           | I2S serial data transfer order for both ADC and DAC channel 0: MSB first                                                                                                       |



|              |       |     |      | 1: LSB first  Note: must always be programmed to '0'                                                                                       |
|--------------|-------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------|
| VBISDACK_INV | [10]  | R/W | 1'h0 | VBC interface reverses DAC I2S BCLK from audio CODEC as its I2S BCLK to send serial data  0: normal mode  1: inverse mode                  |
| VBISADCK_INV | [9]   | R/W | 1'h0 | VBC interface reverses ADC I2S BCLK from audio CODEC as its I2S BCLK to receive serial data  0: normal mode  1: inverse mode               |
| ADBUFF_Δ     | [8:0] | R/W | 9'h0 | Voice band ADC channel data buffer size change, 2's compliment number added to VBADBUFFSIZE, control AD data buffer change for next block. |

## 8.5.5.2.7 VBDABUFFDTA

| 0x0018 | (0x00            | OC)                     | Voice                   | e band                  | buff                    | er and           | mode                   | contr | ol(rese | et 0x00 | 00_00 | 00)   |    | VBDABUFFDTA |    |    |  |
|--------|------------------|-------------------------|-------------------------|-------------------------|-------------------------|------------------|------------------------|-------|---------|---------|-------|-------|----|-------------|----|----|--|
| Bit    | 31               | 30                      | 29                      | 28                      | 27                      | 26               | 25                     | 24    | 23      | 22      | 21    | 20    | 19 | 18          | 17 | 16 |  |
| Name   |                  |                         |                         |                         |                         |                  |                        | Rese  | erved   |         |       |       |    |             |    |    |  |
| Туре   |                  |                         |                         |                         |                         |                  |                        | R     | 0       |         |       |       |    |             |    |    |  |
| 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   | VBE<br>NAB<br>LE | VBD<br>A1D<br>MA_<br>EN | VBD<br>A0D<br>MA_<br>EN | VBA<br>D1D<br>MA_<br>EN | VBA<br>D0D<br>MA_<br>EN | RAM<br>SW_<br>EN | RAM<br>SW_<br>NU<br>MB |       |         |         | D/    | ∖BUFF |    |             |    |    |  |
| Туре   | 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     | 0     | 0  | 0           | 0  | 0  |  |



| Field Name  | Bit  | Туре | Reset<br>Value | Description                                                                                                                                                                                                      |
|-------------|------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VBENABLE    | [15] | R/W  | 1'h0           | Enable this bit then VBC interface starts working and software can receive voice band interrupt.  Better set this bit after all other register bits are programmed.  0: disable  1: enable                       |
| VBDA1DMA_EN | [14] | R/W  | 1'h0           | DMA write DAC1 data buffer enable, set this bit to enable DAC1 DMA mode 0: disable 1: enable                                                                                                                     |
| VBDA0DMA_EN | [13] | R/W  | 1'h0           | DMA write DAC0 data buffer enable, set this bit to enable DAC0 DMA mode  0: disable  1: enable                                                                                                                   |
| VBAD1DMA_EN | [12] | R/W  | 1'h0           | Reserved for DMA reading ADC1 data buffer enable  0: disable  1: enable  Note: No use since there is only one ADC channel                                                                                        |
| VBAD0DMA_EN | [11] | R/W  | 1'h0           | DMA read ADC0 data buffer enable, set this bit to enable ADC0 DMA mode  0: disable  1: enable                                                                                                                    |
| RAMSW_EN    | [10] | R/W  | 1'h0           | Software access ping-pong buffer enable when VBENABE bit low(before VBC interface start working), for both ADC and DAC channel(reading ADC data buffer and writing DAC0, DAC1 data buffer)  0: disable 1: enable |
| RAMSW_NUMB  | [9]  | R/W  | 1'h0           | Software accessing ping-pong buffer indication, for both ADC and DAC channel(reading ADC data buffer and writing DAC0, DAC1 data                                                                                 |



|          |       |     |      | buffer) 0: software access data buffer 0 1: software access data buffer 1                                                                  |
|----------|-------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------|
| DABUFF_Δ | [8:0] | R/W | 9'h0 | Voice band DAC channel data buffer size change, 2's compliment number added to VBDABUFFSIZE, control DA data buffer change for next block. |

## 8.5.5.2.8 VBADCNT

Description:

0x001C (0x000E) Voice band ADC buffer counter(reset 0x0000\_0000)

**VBADCNT** 

| Bit   | 31 | 30 | 29 | 28   | 27   | 26 | 25 | 24   | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |
|-------|----|----|----|------|------|----|----|------|----------|----|----|----|----|----|----|----|--|
| Name  |    |    |    |      |      |    |    | Rese | served   |    |    |    |    |    |    |    |  |
| Туре  |    |    |    |      |      |    |    | R    | 0        |    |    |    |    |    |    |    |  |
| 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  |    |    |    | VBAD | 1CNT |    |    |      | VBADOCNT |    |    |    |    |    |    |    |  |
| Туре  |    | RO |    |      |      |    |    |      |          | RO |    |    |    |    |    |    |  |
| Reset | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0    | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                              |
|------------|--------|------|----------------|--------------------------------------------------------------------------------------------------------------------------|
| VBAD1CNT   | [15:8] | RO   | 8'h0           | Reserved for ADC1 data buffer address counter.                                                                           |
| VBADOCNT   | [7:0]  | RO   | 8'h0           | ADC0 data buffer address counter (address of VBC interface writing input data from audio CODEC to ADC0 ping-pong buffer) |



## 8.5.5.2.9

## **VBDACNT**

Description:

| 0x0020 | (0x00° | 10)                         | Voice                                     | e band | DAC  | buffer | counte | er(rese | t 0x00 | 00_00 | 00) |      |      |   | VBDA | CNT |
|--------|--------|-----------------------------|-------------------------------------------|--------|------|--------|--------|---------|--------|-------|-----|------|------|---|------|-----|
| Bit    | 31     | 30                          | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |      |        |        |         |        |       |     |      |      |   |      |     |
| Name   |        | Reserved                    |                                           |        |      |        |        |         |        |       |     |      |      |   |      |     |
| Туре   |        |                             |                                           |        |      |        |        | R       | 0      |       |     |      |      |   |      |     |
| 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   |        |                             |                                           | VBDA   | 1CNT |        |        |         |        |       |     | VBDA | OCNT |   |      |     |
| Туре   |        | RO RO                       |                                           |        |      |        |        |         |        |       |     |      |      |   |      |     |
| Reset  | 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                           |        |      |        |        |         |        |       |     |      |      |   |      |     |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                               |
|------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------|
| VBDA1CNT   | [15:8] | RO   | 8'h0           | DAC1 data buffer address counter (address of VBC interface reading output data from DAC1 ping-pong buffer to audio CODEC) |
| VBDA0CNT   | [7:0]  | RO   | 8'h0           | DAC0 data buffer address counter (address of VBC interface reading output data from DAC0 ping-pong buffer to audio CODEC) |

8.5.5.2.10

**VBINTTYPE** 



| 0x0034 | (0x001 | 1A)      | Voice | e Band | linter | rupt ty | pe(res | et 0x0 | 000_00 | 000) |    |     |     | ,  | VBINT               | ГҮРЕ                |
|--------|--------|----------|-------|--------|--------|---------|--------|--------|--------|------|----|-----|-----|----|---------------------|---------------------|
| Bit    | 31     | 30       | 29    | 28     | 27     | 26      | 25     | 24     | 23     | 22   | 21 | 20  | 19  | 18 | 17                  | 16                  |
| Name   |        | Reserved |       |        |        |         |        |        |        |      |    |     |     |    |                     |                     |
| Туре   |        |          | 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   |        |          |       |        |        |         | Rese   | erved  |        |      |    |     |     |    | Da_i<br>nt_t<br>ype | Ad_i<br>nt_t<br>ype |
| Туре   |        |          | RO    |        |        |         |        |        |        |      |    | R/W | R/W |    |                     |                     |
| Reset  | 0      | 0        | 0     | 0      | 0      | 0       | 0      | 0      | 0      | 0    | 0  | 0   | 0   | 0  | 0                   | 0                   |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                                                                                                                |
|-------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------|
|             | [15:2] | RO   | 14'h0          | Reserved                                                                                                                   |
| Da_int_type | [1]    | R/W  | 1'h0           | DAC interrupt type,  1'b0: wide pulse, and the width is 12 DAC IIS bit clock cycles  1'b1: one apb/z-bus clock cycle pulse |
| Ad_int_type | [0]    | R/W  | 1'h0           | ADC interrupt type,  1'b0: wide pulse, and the width is 12 ADC IIS bit clock cycles  1'b1: one apb/z-bus clock cycle pulse |

8.5.5.2.11 DAPATHCTL



Reset

| 0x0040 | (0x002 | 20)      | Voice | e band | DAC   | path c | ontrol | (reset | 0x000 | 0_0000        |       | DAPATHCTL |       |    |       |    |
|--------|--------|----------|-------|--------|-------|--------|--------|--------|-------|---------------|-------|-----------|-------|----|-------|----|
| Bit    | 31     | 30       | 29    | 28     | 27    | 26     | 25     | 24     | 23    | 22            | 21    | 20        | 19    | 18 | 17    | 16 |
| Name   |        | Reserved |       |        |       |        |        |        |       |               |       |           |       |    |       |    |
| Туре   |        | RO       |       |        |       |        |        |        |       |               |       |           |       |    |       |    |
| Reset  | 0      |          |       |        |       |        |        |        |       |               |       |           |       |    |       |    |
| Bit    | 15     | 14       | 13    | 12     | 11    | 10     | 9      | 8      | 7     | 6             | 5     | 4         | 3     | 2  | 1     | 0  |
| Name   |        |          |       | Rese   | erved |        |        |        | Da1_a | iddst_s<br>el | Da0_a |           | Da1_a |    | Da0_a |    |
| Туре   |        |          |       | R      | 0     |        |        |        | R     | W             | R     | w         | R/    | W  | R     | W  |
|        |        |          |       |        |       |        |        |        | 1     | 1             |       |           |       |    |       |    |

| Field Name    | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                             |
|---------------|--------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [15:8] | RO   | 8'h0           | Reserved                                                                                                                                                                                                                                |
| Da1_addst_sel | [7:6]  | R/W  | 2'h0           | 2'b00: DAC1 data from ALC directly sent to DAC I2S 2'b01: DAC1 data from ALC added with side tone data, then sent to DAC I2S 2'b10: DAC1 data from ALC subtracted from side tone output data, then sent to DAC I2S 60.96cmb11: Reserved |
| Da0_addst_sel | [5:4]  | R/W  | 2'h0           | 2'b00: DAC0 data from ALC directly sent to DAC I2S 2'b01: DAC0 data from ALC added with side tone data, then sent to DAC I2S 2'b10: DAC0 data from ALC subtracted from side tone output data, then sent to DAC I2S 2'b11: Reserved      |
| Da1_addfm_sel | [3:2]  | R/W  | 2'h0           | 2'b00: DAC1 buffer data directly sent to DAC HPF 2'b01: DAC1 buffer data added with side tone data, then sent to DAC HPF 2'b10: DAC1 buffer data subtracted from side tone output data, then sent to DAC HPF 2'b11: Reserved            |
| Da0_addfm_sel | [1:0]  | R/W  | 2'h0           | 2'b00: DAC0 buffer data directly sent to DAC HPF 2'b01: DAC0 buffer data added with side tone output data, then sent to DAC HPF 2'b10: DAC0 buffer data subtracted from side                                                            |



|  | tone output data, then sent to DAC HPF |
|--|----------------------------------------|
|  | 2'b11: Reserved                        |

#### 8.5.5.2.12 DADGCTL

| 0x0044 | (0x002 | 22) | Voic | e band | DAC     | digital | gain c | ontrol | ol (reset 0x0000_1818) |    |    |    |         |    | DADGCTL |    |  |  |
|--------|--------|-----|------|--------|---------|---------|--------|--------|------------------------|----|----|----|---------|----|---------|----|--|--|
| Bit    | 31     | 30  | 29   | 28     | 27      | 26      | 25     | 24     | 23                     | 22 | 21 | 20 | 19      | 18 | 17      | 16 |  |  |
| Name   |        |     |      |        |         |         |        | Res    | erved                  |    |    |    |         |    |         |    |  |  |
| Туре   |        |     | RO   |        |         |         |        |        |                        |    |    |    |         |    |         |    |  |  |
| 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  |  |  |
|        | Dad    |     |      |        |         |         |        |        | Dad                    |    |    |    |         |    |         |    |  |  |
| Name   | g_en   |     |      | D      | adg_dg_ | _1      |        |        | g_en                   |    |    | D  | adg_dg_ | _0 |         |    |  |  |
|        | _1     |     |      |        |         |         |        |        | _0                     |    |    |    |         |    |         |    |  |  |
| Туре   | 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  |  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                      |
|------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Dadg_en_1  | [15]   | R/W  | 1'h0           | DAC1 digital gain enable                                                                                                                                                         |
| Dadg_dg_1  | [14:8] | R/W  | 7'h00          | DAC1 digital gain coefficient 7'h18: 0db larger than 7'h18: amplify the input signal, and the step is 0.75db smaller than 7'h18: reduce the input signal, and the step is 0.75db |
| Dadg_en_0  | [7]    | R/W  | 1'h0           | DAC0 digital gain enable                                                                                                                                                         |
| Dadg_dg_0  | [6:0]  | R/W  | 7'h00          | DAC0 digital gain coefficient 7'h18: 0db larger than 7'h18: amplify the input signal, and the step is 0.75db smaller than 7'h18: reduce the input signal, and the step is 0.75db |



#### 8.5.5.2.13 DAHPCTL

Description:

0x0048 (0x0024) Voice band DAC High pass filter control (reset  $0x0000\_007F$ )

DAHPCTI

| Bit   | 31 | 30   | 29    | 28 | 27                 | 26          | 25                 | 24          | 23    | 22 | 21 | 20  | 19   | 18 | 17 | 16 |
|-------|----|------|-------|----|--------------------|-------------|--------------------|-------------|-------|----|----|-----|------|----|----|----|
| Name  |    |      |       |    |                    |             |                    | Rese        | erved |    |    |     |      |    |    |    |
| Туре  |    |      |       |    |                    |             |                    | R           | 0     |    |    |     |      |    |    |    |
| 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  |    | Rese | erved |    | Dac<br>_alc<br>_en | Vbh<br>p_en | Hp_r<br>eg_c<br>Ir | Wid<br>_sel |       | 5  |    | R_I | imit |    |    |    |
| Туре  |    | R    | 0     |    | R/W                | R/W         | R/W                | R/W         |       |    |    | R/  | W    |    |    |    |
| Reset | 0  | 0    | 0     | 0  | 0                  | 0           | 0                  | 0           | 0     | 1  | 1  | 1   | 1    | 1  | 1  | 1  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                    |
|------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------|
|            | [15:12] | RO   | 4'h0           | Reserved                                                                                                       |
| Dac_alc_en | [11]    | R/W  | 1'h0           | 1'b0: ALC bypass<br>1'b1: ALC enable(if vbhp_en=1)                                                             |
| Vbhp_en    | [10]    | R/W  | 1'h0           | 1'b0: 6-band IIR and ALC bypass<br>1'b1: 6-band IIR and ALC enable                                             |
| Hp_reg_clr | [9]     | R/W  | 1'h0           | Clear all HPF IIR registers,<br>Please write 1'b1 and later write 1'b0 to finish<br>the register clear process |
| Wid_sel    | [8]     | R/W  | 1'h0           | 1'b0: 16bits output<br>1'b1: 24bits output                                                                     |
| R_limit    | [7:0]   | R/W  | 8'h7F          | DAC output signal limit, the actual limit value on the 24bits output signal is: r_limit[7:0]<<16+16'hFFFF      |



#### 8.5.5.2.14 DAALCCTL0

Description:

| 0x004C | (0x00 | 26)      | Voice                     | Voice band DAC ALC coefficient : hold (reset 0x0000_0000) DAALCCTL0 |    |    |    |       |         |    |    |    |    |    |    |    |
|--------|-------|----------|---------------------------|---------------------------------------------------------------------|----|----|----|-------|---------|----|----|----|----|----|----|----|
| Bit    | 31    | 30       | 29                        | 28                                                                  | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |       | Reserved |                           |                                                                     |    |    |    |       |         |    |    |    |    |    |    |    |
| Туре   | RO    |          |                           |                                                                     |    |    |    |       |         |    |    |    |    |    |    |    |
| 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   |       |          |                           |                                                                     |    |    |    | Dac_a | alc_hld |    |    |    |    |    |    |    |
| Туре   |       | R/W      |                           |                                                                     |    |    |    |       |         |    |    |    |    |    |    |    |
| Reset  | 0     | 0        | 0                         | 0                                                                   | 0  | 0  | 0  | 0     | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name  | Bit    | Туре | Reset<br>Value | Description               |
|-------------|--------|------|----------------|---------------------------|
| Dac_alc_hld | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: hold |

8.5.5.2.15 DAALCCTL1



| 0x0050 | (0x002                        | 28) Voice band DAC ALC coefficient : rise (reset 0x0000_0000) DAALCCTL1 |    |    |    |    |    |       |          |    |    |    |    |    | CTL1 |    |
|--------|-------------------------------|-------------------------------------------------------------------------|----|----|----|----|----|-------|----------|----|----|----|----|----|------|----|
| Bit    | 31                            | 30                                                                      | 29 | 28 | 27 | 26 | 25 | 24    | 23       | 22 | 21 | 20 | 19 | 18 | 17   | 16 |
| Name   |                               | Reserved                                                                |    |    |    |    |    |       |          |    |    |    |    |    |      |    |
| Туре   |                               | 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   |                               |                                                                         |    |    |    |    |    | Dac_a | ılc_rise |    |    |    |    |    |      |    |
| Туре   |                               |                                                                         |    |    |    |    |    | R     | /W       |    |    |    |    |    |      |    |
| Reset  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                                         |    |    |    |    |    |       |          |    |    |    |    |    |      |    |

| Field Name   | Bit    | Туре | Reset<br>Value | Description               |
|--------------|--------|------|----------------|---------------------------|
| Dac_alc_rise | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: rise |

## 8.5.5.2.16 DAALCCTL2

| 0x0054 | (0x00 | 0x002A) Voice band DAC ALC coefficient : fall (reset 0x0000_0000) DAALCCTL2 |    |    |    |    |   |       |          |   |   |   |   |   | CTL2 |    |
|--------|-------|-----------------------------------------------------------------------------|----|----|----|----|---|-------|----------|---|---|---|---|---|------|----|
| Bit    | 31    | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16                             |    |    |    |    |   |       |          |   |   |   |   |   |      | 16 |
| Name   |       | Reserved                                                                    |    |    |    |    |   |       |          |   |   |   |   |   |      |    |
| Туре   |       | 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   |       |                                                                             |    |    |    |    |   | Dac_a | alc_fall |   |   |   |   |   |      |    |
| Туре   |       |                                                                             |    |    |    |    |   | R     | /W       |   |   |   |   |   |      |    |
| Reset  | 0     | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                               |    |    |    |    |   |       |          |   |   |   |   |   |      |    |



| Field Name   | Bit    | Туре | Reset<br>Value | Description               |
|--------------|--------|------|----------------|---------------------------|
| Dac_alc_fall | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: fall |

## 8.5.5.2.17 DAALCCTL3

Description:

0x0058 (0x002C) Voice band DAC ALC coefficient : limit (reset 0x0000\_0000) DAALCCTL3

|       | (  | - /                         |     |    |    |    |    |       |         |    |    |    |    |    |    |    |
|-------|----|-----------------------------|-----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
| Bit   | 31 | 30                          | 29  | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |                             |     |    |    |    |    | Rese  | erved   |    |    |    |    |    |    |    |
| Туре  |    |                             |     |    |    |    |    | R     | 0       |    |    |    |    |    |    |    |
| 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  |    |                             |     |    |    |    |    | Dac_a | alc_lmt |    |    |    |    |    |    |    |
| Туре  |    |                             | R/W |    |    |    |    |       |         |    |    |    |    |    |    |    |
| Reset | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |     |    |    |    |    |       |         |    |    |    |    |    |    |    |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                |
|-------------|--------|------|----------------|----------------------------|
| Dac_alc_Imt | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: limit |

8.5.5.2.18 DAALCCTL4



0x005C (0x002E)

# Voice band DAC ALC coefficient : threshold (reset 0x0000\_0000)

DAALCCTL4

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    |    | Rese  | erved   |    |    |    |    |    |    |    |
| Туре  |    |     |    |    |    |    |    | R     | 0       |    |    |    |    |    |    |    |
| 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  |    |     |    |    |    |    |    | Dac_a | alc_thd |    |    |    |    |    |    |    |
| Туре  |    | R/W |    |    |    |    |    |       |         |    |    |    |    |    |    |    |
| Reset | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0     | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                    |
|-------------|--------|------|----------------|--------------------------------|
| Dac_alc_thd | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: threshold |

## 8.5.5.2.19 DAALCCTL5

| 0x0060 | (0x00 | 30) | VOIC | e band | DAC | ALC C | petticie | ent : ra | itio (re | set uxi | 0000_0 | 1000) |    | ט  | AALC | CILS |
|--------|-------|-----|------|--------|-----|-------|----------|----------|----------|---------|--------|-------|----|----|------|------|
| Bit    | 31    | 30  | 29   | 28     | 27  | 26    | 25       | 24       | 23       | 22      | 21     | 20    | 19 | 18 | 17   | 16   |

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    |    | Rese  | erved   |    |    |    |    |    |    |    |
| Туре  |    |     |    |    |    |    |    | R     | 0       |    |    |    |    |    |    |    |
| 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  |    |     |    |    |    |    |    | Dac_a | c_ratio |    |    |    |    |    |    |    |
| Туре  |    | R/W |    |    |    |    |    |       |         |    |    |    |    |    |    |    |
| Reset | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0     | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  |



| Field Name    | Bit    | Туре | Reset<br>Value | Description                |
|---------------|--------|------|----------------|----------------------------|
| Dac_alc_ratio | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: ratio |

8.5.5.2.20 DAALCCTL6

Description:

Voice band DAC ALC coefficient : cg\_var (reset

0x0000\_0000)

DAALCCTL6

|       |    |                             |    |    |    |    |    |         |          |    |    |    | _  |    |    |    |
|-------|----|-----------------------------|----|----|----|----|----|---------|----------|----|----|----|----|----|----|----|
| Bit   | 31 | 30                          | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |                             |    |    |    |    |    | Rese    | erved    |    |    |    |    |    |    |    |
| Туре  |    | 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  |    |                             |    |    |    |    |    | Dac_alc | c_cg_var |    |    |    |    |    |    |    |
| Туре  |    | R/W                         |    |    |    |    |    |         |          |    |    |    |    |    |    |    |
| Reset | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |         |          |    |    |    |    |    |    |    |

| Field Name     | Bit    | Туре | Reset<br>Value | Description                 |
|----------------|--------|------|----------------|-----------------------------|
| Dac_alc_cg_var | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: cg_var |

8.5.5.2.21 DAALCCTL7



0x0068 (0x0034)

Voice band DAC ALC coefficient : release rate(reset 0x0000\_0000)

DAALCCTL7

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23        | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|---------|-----------|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | Res     | erved     |    |    |    |    |    |    |    |
| Туре  |    |    |    |    |    |    |    | R       | 0         |    |    |    |    |    |    |    |
| 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  |    |    |    |    |    |    |    | Dac_alc | _rls_rate | 1  |    |    |    | 7  |    |    |
| Туре  |    |    |    |    |    |    |    | R       | /W        |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name       | Bit    | Туре | Reset<br>Value | Description                       |
|------------------|--------|------|----------------|-----------------------------------|
| Dac_alc_rls_rate | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: release rate |

#### 8.5.5.2.22 DAALCCTL8

Description:

0x006C (0x0036)

Voice band DAC ALC coefficient : attack rate(reset 0x0000\_0000)

**DAALCCTL8** 

| Bit   | 31 | 30                              | 29 | 28 | 27 | 26 | 25 | 24       | 23        | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|---------------------------------|----|----|----|----|----|----------|-----------|----|----|----|----|----|----|----|
| Name  |    |                                 |    |    |    |    |    | Rese     | erved     |    |    |    |    |    |    |    |
| Туре  |    | RO                              |    |    |    |    |    |          |           |    |    |    |    |    |    |    |
| Reset | 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  |    |                                 |    |    |    |    |    | Dac_alc_ | _atk_rate | )  |    |    |    |    |    |    |
| Туре  |    | R/W                             |    |    |    |    |    |          |           |    |    |    |    |    |    |    |
| Reset | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |          |           |    |    |    |    |    |    |    |



| Field Name       | Bit    | Туре | Reset<br>Value | Description                      |
|------------------|--------|------|----------------|----------------------------------|
| Dac_alc_atk_rate | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: attack rate |

8.5.5.2.23 DAALCCTL9

Description:

0x0070 (0x0038) Voice band DAC ALC coefficient : release\_rate\_ex(reset 0x0000\_0000)

DAALCCTL9

| Bit   | 31 | 30                        | 29 | 28 | 27 | 26 | 25 | 24       | 23        | <b>2</b> 2 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|---------------------------|----|----|----|----|----|----------|-----------|------------|----|----|----|----|----|----|
| Name  |    |                           |    |    |    |    |    | Rese     | erved     |            |    |    |    |    |    |    |
| Туре  |    | RO                        |    |    |    |    |    |          |           |            |    |    |    |    |    |    |
| 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  |    |                           |    |    |    | -  | D  | ac_alc_r | ls_rate_e | эх         |    |    |    |    |    |    |
| Туре  |    | R/W                       |    |    |    |    |    |          |           |            |    |    |    |    |    |    |
| Reset | 0  |                           |    |    |    |    |    |          |           |            |    |    |    |    |    |    |

| Field Name          | Bit    | Туре | Reset<br>Value | Description                          |
|---------------------|--------|------|----------------|--------------------------------------|
| Dac_alc_rls_rate_ex | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: release_rate_ex |

8.5.5.2.24 DAALCCTL10



0x0074 (0x003A)

# Voice band DAC ALC coefficient : attack\_rate\_ex(reset 0x0000\_0000)

DAALCCTL10

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24       | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----|----------|----------|----|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    |    | Res      | erved    |    |    |    |    |    |    |    |
| Туре  |    |     |    |    |    |    |    | R        | 0        |    |    |    |    |    |    |    |
| 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  |    |     |    |    |    |    | D  | ac_alc_a | tk_rate_ | ex |    |    |    |    |    |    |
| Туре  |    | R/W |    |    |    |    |    |          |          |    |    |    |    |    |    |    |
| Reset | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0        | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name          | Bit    | Туре | Reset<br>Value | Description                         |
|---------------------|--------|------|----------------|-------------------------------------|
| Dac_alc_atk_rate_ex | [15:0] | R/W  | 16'h0          | DAC ALC coefficient: attack_rate_ex |

8.5.5.2.25 STCTLO



0x0078 (0x003C)

# Voice band Side Tone control of channel0(reset 0x0000\_0183)

STCTL0

| Bit   | 31 | 30      | 29 | 28                | 27                        | 26        | 25 | 24  | 23       | 22  | 21 | 20 | 19 | 18     | 17     | 16 |
|-------|----|---------|----|-------------------|---------------------------|-----------|----|-----|----------|-----|----|----|----|--------|--------|----|
| Name  |    |         |    |                   |                           |           |    | Res | erved    |     |    |    |    |        |        |    |
| Туре  |    |         |    |                   | 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  |    | Reserve | d  | Vbst<br>_en_<br>0 | Vbst<br>_hpf<br>_en_<br>0 |           |    | Vb  | st_hpf_d | g_0 | *  |    |    | Vbst_h | pf_n_0 |    |
| Туре  |    | RO      |    | R/W               | R/W                       | W R/W R/W |    |     |          |     |    |    |    |        |        |    |
| Reset | 0  | 0       | 0  | 0                 | 0                         | 0         | 0  | 0   | 0        | 0   | 0  | 0  | 0  | 0      | 0      | 0  |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                |
|---------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [15:13] | RO   | 3'h0           | Reserved                                                                                                                                                                                   |
| Vbst_en_0     | [12]    | R/W  | 1'h0           | Side tone of channel 0 disable     Side tone of channel 0 enable                                                                                                                           |
| Vbst_hpf_en_0 | [11]    | R/W  | 1'h0           | Side tone HPF of channel 0 disable     Side tone HPF of channel 0 enable                                                                                                                   |
| Vbst_hpf_dg_0 | [10:4]  | R/W  | 7'h0           | Side tone gain coefficient of channel 0 7'h18: 0db larger than 7'h18: amplify the input signal, and the step is 0.75db smaller than 7'h18: reduce the input signal, and the step is 0.75db |
| Vbst_hpf_n_0  | [3:0]   | R/W  | 4'h0           | Side tone high-pass filter coefficient of channel0. If the high-pass filter is enabled, 4'h3 is the typical configuration, and 4'h0 is reserved.                                           |

8.5.5.2.26 STCTL1



0x007C (0x003E)

# Voice band Side Tone control of channel1(reset 0x0000\_0183)

STCTL1

| Bit   | 31 | 30      | 29 | 28                | 27                        | 26        | 25 | 24  | 23       | 22  | 21 | 20 | 19 | 18     | 17     | 16 |
|-------|----|---------|----|-------------------|---------------------------|-----------|----|-----|----------|-----|----|----|----|--------|--------|----|
| Name  |    |         |    |                   |                           |           |    | Res | erved    |     |    |    |    |        |        |    |
| Туре  |    |         |    |                   | 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  |    | Reserve | d  | Vbst<br>_en_<br>1 | Vbst<br>_hpf<br>_en_<br>1 |           |    | Vb  | st_hpf_d | g_1 |    |    |    | Vbst_h | pf_n_1 |    |
| Туре  |    | RO      |    | R/W               | R/W                       | W R/W R/W |    |     |          |     |    |    |    |        |        |    |
| Reset | 0  | 0       | 0  | 0                 | 0                         | 0         | 0  | 0   | 0        | 0   | 0  | 0  | 0  | 0      | 0      | 0  |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                |
|---------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [15:13] | RO   | 3'h0           | Reserved                                                                                                                                                                                   |
| Vbst_en_1     | [12]    | R/W  | 1'h0           | Side tone of channel 1 disable     Side tone of channel 1 enable                                                                                                                           |
| Vbst_hpf_en_1 | [11]    | R/W  | 1'h0           | <ul><li>0: Side tone HPF of channel 1 disable</li><li>1: Side tone HPF of channel 1 enable</li></ul>                                                                                       |
| Vbst_hpf_dg_1 | [10:4]  | R/W  | 7'h0           | Side tone gain coefficient of channel 1 7'h18: 0db larger than 7'h18: amplify the input signal, and the step is 0.75db smaller than 7'h18: reduce the input signal, and the step is 0.75db |
| Vbst_hpf_n_1  | [3:0]   | R/W  | 4'h0           | Side tone high-pass filter coefficient of channel 1. If the high-pass filter is enabled, 4'h3 is the typical configuration, and 4'h0 is reserved.                                          |

8.5.5.2.27 ADPATHCTL



| 0x0080 | (0x00 | 40) | Voice          | e band                     | ADC  | path c | ontrol | reset ( | 0x0000 | _0000 | )    |      |        | Α     | DPATI  | HCTL  |
|--------|-------|-----|----------------|----------------------------|------|--------|--------|---------|--------|-------|------|------|--------|-------|--------|-------|
| Bit    | 31    | 30  | 29             | 28                         | 27   | 26     | 25     | 24      | 23     | 22    | 21   | 20   | 19     | 18    | 17     | 16    |
| Name   |       |     |                |                            |      |        |        | Res     | erved  |       |      |      |        |       |        |       |
| Туре   |       |     |                |                            |      |        |        | F       | RO     |       |      |      |        |       |        |       |
| 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     |
|        |       |     |                |                            |      |        |        |         |        |       | Ad1  | Ad0  |        |       |        |       |
| Name   |       |     |                |                            | Dan  | erved  |        |         |        |       | _dg  | _dg  | Ad1_ir | mux_s | Ad0_in | mux_s |
| Name   |       |     |                |                            | Kesi | erveu  |        |         |        |       | mux  | mux  |        | el    | e      | el    |
|        |       |     |                |                            |      |        |        |         |        |       | _sel | _sel |        |       |        |       |
| Туре   |       |     | RO R/W R/W R/W |                            |      |        |        |         |        |       |      |      |        |       |        |       |
| Reset  | 0     | 0   | 0              | 0                          | 0    | 0      | 0      | 0       | 0      | 0     | 0    | 0    | 0      | 0     | 0      | 0     |

| Field Name    | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                   |
|---------------|--------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | [15:6] | RO   | 3'h0           | Reserved                                                                                                                                                                                      |
| Ad1_dgmux_sel | [5]    | R/W  | 1'h0           | 1'b0: ADC data as input of ADC1 DG 1'b1: DAC ALC output data as input of ADC1 DG                                                                                                              |
| Ad0_dgmux_sel | [4]    | R/W  | 1'h0           | 1'b0: ADC data as input of ADC0 DG 1'b1: DAC ALC output data as input of ADC0 DG                                                                                                              |
| Ad1_inmux_sel | [3:2]  | R/W  | 2'h0           | 2'b00: I2S ADC1 data as input of ADC1 path<br>2'b01: I2S ADC0 data as input of ADC1 path<br>2'b10: Digital TV I2S ADC1 data as input of<br>ADC1 path<br>2'b11: All zero as input of ADC1 path |
| Ad0_inmux_sel | [1:0]  | R/W  | 2'h0           | 2'b00: I2S ADC0 data as input of ADC0 path<br>2'b01: I2S ADC1 data as input of ADC1 path<br>2'b10: Digital TV I2S ADC0 data as input of<br>ADC0 path<br>2'b11: All zero as input of ADC0 path |



## 8.5.5.2.28

## **ADDGCTL**

Description:

Reset

| 0x0084 | (0x004 | 42) | Voice | e band         | ADC | digital | gain c | ontrol | (reset | 0x000 | 0_181 | 8) |     |    | ADDO | 3CTL |
|--------|--------|-----|-------|----------------|-----|---------|--------|--------|--------|-------|-------|----|-----|----|------|------|
| Bit    | 31     | 30  | 29    | 28             | 27  | 26      | 25     | 24     | 23     | 22    | 21    | 20 | 19  | 18 | 17   | 16   |
| Name   |        |     |       |                |     |         |        | Res    | erved  |       |       |    |     |    |      |      |
| Туре   |        |     |       |                |     |         |        | R      | 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    |
|        | Add    |     |       |                |     |         |        |        | Add    |       |       |    |     |    |      |      |
| Name   | g_en   |     |       | Addg_dg_1 g_en |     |         |        |        |        |       |       |    |     | .0 |      |      |
|        | _1     |     | _0    |                |     |         |        |        |        |       |       |    |     |    |      |      |
| Туре   | R/W    |     | •     |                | R/W | •       | •      |        | R/W    |       |       |    | R/W | •  |      |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                      |
|------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Addg_en_1  | [15]   | R/W  | 1'h0           | ADC1 digital gain enable                                                                                                                                                         |
| Addg_dg_1  | [14:8] | R/W  | <b>7</b> 'h00  | ADC1 digital gain coefficient 7'h18: 0db larger than 7'h18: amplify the input signal, and the step is 0.75db smaller than 7'h18: reduce the input signal, and the step is 0.75db |
| Addg_en_0  | [7]    | R/W  | 1'h0           | ADC0 digital gain enable                                                                                                                                                         |
| Addg_dg_0  | [6:0]  | R/W  | 7'h00          | ADC0 digital gain coefficient 7'h18: 0db larger than 7'h18: amplify the input signal, and the step is 0.75db smaller than 7'h18: reduce the input signal, and the step is 0.75db |

8.5.5.2.29 HPCOEF0



| 0x0010 | 0x00 | 080) | DAC                       | DAC 6 band IIR HPF coefficient s0(reset 0x0000_0000) HPCOEF |    |    |   |      |       |   |   |   |   |   |   |   |
|--------|------|------|---------------------------|-------------------------------------------------------------|----|----|---|------|-------|---|---|---|---|---|---|---|
| Bit    | 31   | 30   | 29                        | 9 28 27 26 25 24 23 22 21 20 19 18 17 16                    |    |    |   |      |       |   |   |   |   |   |   |   |
| Name   |      |      |                           |                                                             |    |    |   | Rese | erved |   |   |   |   |   |   |   |
| Туре   |      |      |                           |                                                             |    |    |   | R    | .0    |   |   |   |   |   |   |   |
| 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   |      |      |                           |                                                             |    |    |   | Нрс  | oef0  |   |   |   |   |   |   |   |
| Туре   |      |      |                           | R/W                                                         |    |    |   |      |       |   |   |   |   |   |   |   |
| Reset  | 0    | 0    | 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                             |    |    |   |      |       |   |   |   |   |   |   |   |

| Field Name | Bit    | Туре | Reset<br>Value | Description                       |
|------------|--------|------|----------------|-----------------------------------|
| Hpcoef0    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient s0 |

## 8.5.5.2.30 HPCOEF1

| 0x00104 | 4 (0x00 | )82) | DAC                     | 6 ban | d IIR H | PF co | efficie | nt b0_( | O(reset | 0x000 | 00_000 | 0) |    |    | HPC | OEF1 |
|---------|---------|------|-------------------------|-------|---------|-------|---------|---------|---------|-------|--------|----|----|----|-----|------|
| Bit     | 31      | 30   | 29                      | 28    | 27      | 26    | 25      | 24      | 23      | 22    | 21     | 20 | 19 | 18 | 17  | 16   |
| Name    |         |      |                         |       |         |       |         | Rese    | erved   |       |        |    |    |    |     |      |
| Туре    |         |      |                         |       |         |       |         | R       | 0       |       |        |    |    |    |     |      |
| 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    |         |      |                         |       |         |       |         | Нрс     | oef1    |       |        |    |    |    |     |      |
| Туре    |         |      | R/W                     |       |         |       |         |         |         |       |        |    |    |    |     |      |
| Reset   | 0       | 0    | 0 0 0 0 0 0 0 0 0 0 0 0 |       |         |       |         |         |         |       |        |    |    |    |     |      |



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef1    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b0_0 |

8.5.5.2.31 HPCOEF2

Description:

0x00108 (0x0084) DAC 6 band IIR HPF coefficient a0\_0(reset 0x0000\_0000)

**HPCOEF2** 

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25       | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----------|------|-------|----|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    |          | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    |     |    |    |    |    |          | R    | .0    |    |    |    |    |    |    |    |
| 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  |    |     |    |    | 1  |    | <b>\</b> | Нрс  | oef2  |    |    |    |    |    |    |    |
| Туре  |    | R/W |    |    |    |    |          |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0   | 0  | 0  | 0  | 0  | 0        | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef2    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a0_0 |

8.5.5.2.32 HPCOEF3



| 0x00100 | C (0x0 | 086) | DAC | 6 ban                 | d IIR H | PF co | efficie | nt b1_( | O(reset | 0x000 | 00_000 | 0) |    |    | HPC | OEF3 |
|---------|--------|------|-----|-----------------------|---------|-------|---------|---------|---------|-------|--------|----|----|----|-----|------|
| Bit     | 31     | 30   | 29  | 28                    | 27      | 26    | 25      | 24      | 23      | 22    | 21     | 20 | 19 | 18 | 17  | 16   |
| Name    |        |      |     |                       |         |       |         | Rese    | erved   |       |        |    |    |    |     |      |
| Туре    |        |      |     |                       |         |       |         | R       | .0      |       |        |    |    |    |     |      |
| 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    |        |      |     |                       |         |       |         | Нрс     | oef3    |       |        |    |    |    |     |      |
| Туре    |        |      |     | R/W                   |         |       |         |         |         |       |        |    |    |    |     |      |
| Reset   | 0      | 0    |     |                       |         |       |         |         |         |       |        |    |    |    |     |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef3    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b1_0 |

#### 8.5.5.2.33 HPCOEF4

| 0x00110 | 0x0) | 088) | DAC                     | DAC 6 band IIR HPF coefficient a1_0(reset 0x0000_0000) HPCOE |    |    |   |      |       |   |   |   |   |   |   |   |
|---------|------|------|-------------------------|--------------------------------------------------------------|----|----|---|------|-------|---|---|---|---|---|---|---|
| Bit     | 31   | 30   | 29                      | 29 28 27 26 25 24 23 22 21 20 19 18 17 16                    |    |    |   |      |       |   |   |   |   |   |   |   |
| Name    |      |      |                         |                                                              |    |    |   | Rese | erved |   |   |   |   |   |   |   |
| Туре    |      |      |                         |                                                              |    |    |   | R    | 0     |   |   |   |   |   |   |   |
| 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    |      |      |                         |                                                              |    |    |   | Нрс  | oef4  |   |   |   |   |   |   |   |
| Туре    |      |      | R/W                     |                                                              |    |    |   |      |       |   |   |   |   |   |   |   |
| Reset   | 0    | 0    | 0 0 0 0 0 0 0 0 0 0 0 0 |                                                              |    |    |   |      |       |   |   |   |   |   |   |   |



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef4    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a1_0 |

## 8.5.5.2.34 HPCOEF5

Description:

0x00114 (0x008A) DAC 6 band IIR HPF coefficient b2\_0(reset 0x0000\_0000)

HPCOEF5

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    |     |    |    |    |    |    | R    | 0     |    |    |    |    |    |    |    |
| 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  |    |     |    |    |    |    |    | Нрс  | oef5  |    |    |    |    |    |    |    |
| Туре  |    | R/W |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef5    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b2_0 |

8.5.5.2.35 HPCOEF6



| 0x0011 | 8 (0x00 | )8C)                      | DAC | DAC 6 band IIR HPF coefficient a2_0(reset 0x0000_0000) HPCC |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|---------|---------------------------|-----|-------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit    | 31      | 30                        | 29  | 28                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |         |                           |     | Reserved                                                    |    |    |    |    |    |    |    |    |    |    |    |    |
| Туре   |         |                           |     | RO                                                          |    |    |    |    |    |    |    |    |    |    |    |    |
| 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   |         |                           |     | Hpcoef6                                                     |    |    |    |    |    |    |    |    |    |    |    |    |
| Туре   |         |                           | R/W |                                                             |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset  | 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 |     |                                                             |    |    |    |    |    |    |    |    |    |    |    |    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef6    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a2_0 |

8.5.5.2.36 **HPCOEF7** 

Description:

DAC 6 band IIR HPF coefficient s1(reset 0x0000\_0000) **HPCOEF7** 

| Bit   | 31 | 30                          | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----------------------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |                             |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    | RO                          |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 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  |    |                             |    |    |    |    |    | Нрс  | oef7  |    |    |    |    |    |    |    |
| Туре  |    | R/W                         |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |      |       |    |    |    |    |    |    |    |



| Field Name | Bit    | Туре | Reset<br>Value | Description                       |
|------------|--------|------|----------------|-----------------------------------|
| Hpcoef7    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient s1 |

8.5.5.2.37 HPCOEF8

Description:

| 0x0012 | 0x0) | 090)    | DAC                             | 6 ban                                     | d IIR H | PF co | efficier | nt b0_' | 1(reset | 0x000 | 000_000 | 0) |  |   | HPC | OEF8 |
|--------|------|---------|---------------------------------|-------------------------------------------|---------|-------|----------|---------|---------|-------|---------|----|--|---|-----|------|
| Bit    | 31   | 30      | 29                              | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |       |          |         |         |       |         |    |  |   |     | 16   |
| Name   |      |         |                                 |                                           |         |       |          | Rese    | erved   |       |         |    |  |   |     |      |
| Туре   |      | RO      |                                 |                                           |         |       |          |         |         |       |         |    |  |   |     |      |
| 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 |                                           |         |       |          |         |         |       |         |    |  | 0 |     |      |
| Name   |      | Hpcoef8 |                                 |                                           |         |       |          |         |         |       |         |    |  |   |     |      |
| Туре   |      | R/W     |                                 |                                           |         |       |          |         |         |       |         |    |  |   |     |      |

0

0

0

0

0

0

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef8    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b0_1 |

8.5.5.2.38 HPCOEF9

Description:

Reset



| 0x0012 | 4 (0x00 | )92)                      | DAC | 6 band                                    | d IIR H | PF co | efficier | nt a0_1 | l(reset | 0x000 | 0_000 | 0) |   |   | HPC | DEF9 |
|--------|---------|---------------------------|-----|-------------------------------------------|---------|-------|----------|---------|---------|-------|-------|----|---|---|-----|------|
| Bit    | 31      | 30                        | 29  | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |       |          |         |         |       |       |    |   |   |     |      |
| Name   |         |                           |     | Reserved                                  |         |       |          |         |         |       |       |    |   |   |     |      |
| Туре   |         |                           |     | RO                                        |         |       |          |         |         |       |       |    |   |   |     |      |
| 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   |         |                           |     | Hpcoef9                                   |         |       |          |         |         |       |       |    |   |   |     |      |
| Туре   |         |                           | R/W |                                           |         |       |          |         |         |       |       |    |   |   |     |      |
| Reset  | 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 |     |                                           |         |       |          |         |         |       |       |    |   |   |     |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef9    | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a0_1 |

#### 8.5.5.2.39 HPCOEF10

| 0x0012 | 8 (0x00 | )94)                      | DAC 6 band IIR HPF coefficient b1_1(reset 0x0000_0000) HPCOEF |                                           |    |    |   |   |   |   |   |   |   |   |   | EF10 |
|--------|---------|---------------------------|---------------------------------------------------------------|-------------------------------------------|----|----|---|---|---|---|---|---|---|---|---|------|
| Bit    | 31      | 30                        | 29                                                            | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |    |   |   |   |   |   |   |   |   |   |      |
| Name   |         |                           | Reserved                                                      |                                           |    |    |   |   |   |   |   |   |   |   |   |      |
| Туре   |         |                           | 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   |         |                           | Hpcoef10                                                      |                                           |    |    |   |   |   |   |   |   |   |   |   |      |
| Туре   |         | R/W                       |                                                               |                                           |    |    |   |   |   |   |   |   |   |   |   |      |
| Reset  | 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                               |                                           |    |    |   |   |   |   |   |   |   |   |   |      |



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef10   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b1_1 |

## 8.5.5.2.40 HPCOEF11

Description:

0x0012C (0x0096) DAC 6 band IIR HPF coefficient a1\_1(reset 0x0000\_0000)

HPCOEF11

| Bit   | 31       | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | Reserved |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Туре  | 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  |          | Hpcoef11 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Туре  | R/W      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0        | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef11   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a1_1 |

8.5.5.2.41 HPCOEF12



| 0x0013 | 0 (0x0) | 098) | DAC | DAC 6 band IIR HPF coefficient b2_1(reset 0x0000_0000) HPCOEF12 |    |    |    |      |       |    |    |    |    |    |    |    |
|--------|---------|------|-----|-----------------------------------------------------------------|----|----|----|------|-------|----|----|----|----|----|----|----|
| Bit    | 31      | 30   | 29  | 28                                                              | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |         |      |     |                                                                 |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре   |         |      |     | RO                                                              |    |    |    |      |       |    |    |    |    |    |    |    |
| 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   |         |      |     | Hpcoef12                                                        |    |    |    |      |       |    |    |    |    |    |    |    |
| Туре   |         |      | R/W |                                                                 |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset  | 0       |      |     |                                                                 |    |    |    |      |       |    |    |    |    |    |    |    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef12   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b2_1 |

#### 8.5.5.2.42 HPCOEF13

Description:

| 0x00134 | 4 (0x00 | 09A)                               | DAC                       | 6 ban | d IIR H | PF co | efficie | nt a2_1 | 1(reset | 0x000 | 0_00 | 0) |    |    | НРСО | EF13 |
|---------|---------|------------------------------------|---------------------------|-------|---------|-------|---------|---------|---------|-------|------|----|----|----|------|------|
| Bit     | 31      | 30                                 | 29                        | 28    | 27      | 26    | 25      | 24      | 23      | 22    | 21   | 20 | 19 | 18 | 17   | 16   |
| Name    |         |                                    |                           |       |         |       |         | Rese    | erved   |       |      |    |    |    |      |      |
| Туре    |         |                                    |                           |       |         |       |         | R       | .0      |       |      |    |    |    |      |      |
| 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    |         | Hpcoef13                           |                           |       |         |       |         |         |         |       |      |    |    |    |      |      |
| Туре    |         |                                    |                           |       |         |       |         | R       | /W      |       |      |    |    |    |      |      |
|         |         | ·                                  |                           |       | ·       | 1     |         | ·       | 1       |       | ·    |    |    | ·  |      | 1    |

Reset



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef13   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a2_1 |

### 8.5.5.2.43 HPCOEF14

Description:

0x00138 (0x009C) DAC 6 band IIR HPF coefficient s2(reset 0x0000\_0000)

HPCOEF14

| Bit   | 31 | 30                      | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-------------------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |                         |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    | RO                      |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 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  |    |                         |    |    |    |    |    | Нрсс | pef14 |    |    |    |    |    |    |    |
| Туре  |    | R/W                     |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0                       | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                       |
|------------|--------|------|----------------|-----------------------------------|
| Hpcoef14   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient s2 |

8.5.5.2.44 HPCOEF15



| 0x0013 | C (0x0 | 09E) | DAC | 6 band                         | d IIR H | PF co | efficie | nt b0_2 | 2(reset | 0x000 | 000_000 | 0) |    |    | HPCO | EF15 |
|--------|--------|------|-----|--------------------------------|---------|-------|---------|---------|---------|-------|---------|----|----|----|------|------|
| Bit    | 31     | 30   | 29  | 28                             | 27      | 26    | 25      | 24      | 23      | 22    | 21      | 20 | 19 | 18 | 17   | 16   |
| Name   |        |      |     |                                |         |       |         | Rese    | erved   |       |         |    |    |    |      |      |
| Туре   |        |      |     | RO                             |         |       |         |         |         |       |         |    |    |    |      |      |
| Reset  | 0      | 0    | 0   | 0 0 0 0 0 0 0 0 0 0 0          |         |       |         |         |         |       |         |    |    |    |      |      |
| Bit    | 15     | 14   | 13  | 3 12 11 10 9 8 7 6 5 4 3 2 1 0 |         |       |         |         |         |       |         |    |    |    |      |      |
| Name   |        |      |     | Hpcoef15                       |         |       |         |         |         |       |         |    |    |    |      |      |
| Туре   |        |      |     | R/W                            |         |       |         |         |         |       |         |    |    |    |      |      |
| Reset  | 0      |      |     |                                |         |       |         |         |         |       |         |    |    |    |      |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef15   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b0_2 |

### 8.5.5.2.45 HPCOEF16

Description:

| 0x00140 | 0x0) | )A0) | DAC | 6 ban                          | d IIR H | PF co | efficie | nt a0_2 | 2(reset | 0x000 | 0_000 | 0) |    |    | НРСО | EF16 |
|---------|------|------|-----|--------------------------------|---------|-------|---------|---------|---------|-------|-------|----|----|----|------|------|
| Bit     | 31   | 30   | 29  | 28                             | 27      | 26    | 25      | 24      | 23      | 22    | 21    | 20 | 19 | 18 | 17   | 16   |
| Name    |      |      |     |                                |         |       |         | Rese    | erved   |       |       |    |    |    |      |      |
| Туре    |      |      |     |                                |         |       |         | R       | .0      |       |       |    |    |    |      |      |
| Reset   | 0    | 0    | 0   | 0 0 0 0 0 0 0 0 0 0 0 0        |         |       |         |         |         |       |       |    |    |    |      |      |
| Bit     | 15   | 14   | 13  | 3 12 11 10 9 8 7 6 5 4 3 2 1 0 |         |       |         |         |         |       |       |    |    |    |      |      |
| Name    |      |      |     |                                |         |       |         | Нрсс    | pef16   |       |       |    |    |    |      |      |
| Туре    |      |      | R/W |                                |         |       |         |         |         |       |       |    |    |    |      |      |
|         |      |      |     |                                |         |       |         |         |         |       |       |    |    |    |      |      |

Reset



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef16   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a0_2 |

8.5.5.2.46 HPCOEF17

Description:

0x00144 (0x00A2) DAC 6 band IIR HPF coefficient b1\_2(reset 0x0000\_0000)

HPCOEF17

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    |    |    |    |    |    |    | R    | 0     |    |    |    |    |    |    |    |
| 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  |    |    |    |    |    |    |    | Нрсс | pef17 |    |    |    |    |    |    |    |
| Туре  |    |    |    |    |    |    |    | R/   | w     |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef17   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b1_2 |

8.5.5.2.47 HPCOEF18



| 0x0014 | 8 (0x00 | )A4) | DAC                         | DAC 6 band IIR HPF coefficient a1_2(reset 0x0000_0000) HPCOEF18 |    |    |   |      |       |   |   |   |   |   |   |    |
|--------|---------|------|-----------------------------|-----------------------------------------------------------------|----|----|---|------|-------|---|---|---|---|---|---|----|
| Bit    | 31      | 30   | 29                          | 29 28 27 26 25 24 23 22 21 20 19 18 17 16                       |    |    |   |      |       |   |   |   |   |   |   | 16 |
| Name   |         |      |                             |                                                                 |    |    |   | Rese | erved |   |   |   |   |   |   |    |
| Туре   |         |      |                             | RO                                                              |    |    |   |      |       |   |   |   |   |   |   |    |
| 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   |         |      |                             | Hpcoef18                                                        |    |    |   |      |       |   |   |   |   |   |   |    |
| Туре   |         |      |                             | R/W                                                             |    |    |   |      |       |   |   |   |   |   |   |    |
| Reset  | 0       | 0    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                                 |    |    |   |      |       |   |   |   |   |   |   |    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef18   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a1_2 |

### 8.5.5.2.48 HPCOEF19

| 0x00140 | C (0x0 | 0A6) | DAC | 6 ban | d IIR H | PF co | efficie | nt b2_2 | 2(reset | 0x000 | 000_000 | 0) |    |    | нрсо | EF19 |
|---------|--------|------|-----|-------|---------|-------|---------|---------|---------|-------|---------|----|----|----|------|------|
| Bit     | 31     | 30   | 29  | 28    | 27      | 26    | 25      | 24      | 23      | 22    | 21      | 20 | 19 | 18 | 17   | 16   |
| Name    |        |      |     |       |         |       |         | Rese    | erved   |       |         |    |    |    |      |      |
| Туре    |        |      |     |       |         |       |         | R       | 0       |       |         |    |    |    |      |      |
| 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    |        |      |     |       |         |       |         | Нрсс    | pef19   |       |         |    |    |    |      |      |
| Туре    |        | R/W  |     |       |         |       |         |         |         |       |         |    |    |    |      |      |
| Reset   | 0      | 0    | 0   | 0     | 0       | 0     | 0       | 0       | 0       | 0     | 0       | 0  | 0  | 0  | 0    | 0    |



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef19   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b2_2 |

### 8.5.5.2.49 HPCOEF20

Description:

0x00150 (0x00A8) DAC 6 band IIR HPF coefficient a2\_2(reset 0x0000\_0000)

HPCOEF20

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    |     |    |    |    |    |    | R    | 0     |    |    |    |    |    |    |    |
| 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  |    |     |    |    |    |    |    | Нрсс | pef20 |    |    |    |    |    |    |    |
| Туре  |    | R/W |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef20   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a2_2 |

8.5.5.2.50 HPCOEF21



| 0x00154 | 4 (0x00 | DAA) | DAC | 6 ban | d IIR H | PF co | efficier | nt s3(re | eset 0x | <b>(</b> 0000_ | 0000) |    |    |    | НРСО | EF21 |
|---------|---------|------|-----|-------|---------|-------|----------|----------|---------|----------------|-------|----|----|----|------|------|
| Bit     | 31      | 30   | 29  | 28    | 27      | 26    | 25       | 24       | 23      | 22             | 21    | 20 | 19 | 18 | 17   | 16   |
| Name    |         |      |     |       |         |       |          | Rese     | erved   |                |       |    |    |    |      |      |
| Туре    |         |      |     |       |         |       |          | R        | 0       |                |       |    |    |    |      |      |
| 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    |

Hpcoef21

R/W

0

| Field Name | Bit    | Туре | Reset<br>Value | Description                       |
|------------|--------|------|----------------|-----------------------------------|
| Hpcoef21   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient s3 |

0

0

#### 8.5.5.2.51 HPCOEF22

Description:

Name

Type

Reset

0x00158 (0x00AC) DAC 6 band IIR HPF coefficient b0\_3(reset 0x0000\_0000)

HPCOEF22

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    |     |    |    |    |    |    | R    | 0     |    |    |    |    |    |    |    |
| 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  |    |     |    |    |    |    |    | Нрсс | ef22  |    |    |    |    |    |    |    |
| Туре  |    | R/W |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef22   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b0_3 |

### 8.5.5.2.52 HPCOEF23

Description:

0x0015C (0x00AE) DAC 6 band IIR HPF coefficient a0\_3(reset 0x0000\_0000)

HPCOEF23

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    |     |    |    |    |    |    | R    | 0     |    |    |    |    |    |    |    |
| 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  |    |     |    |    |    |    |    | Нрсс | pef23 |    |    |    |    |    |    |    |
| Туре  |    | R/W |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef23   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a0_3 |

8.5.5.2.53 HPCOEF24



| 0x0016 | 0x00 | )B0) | DAC | DAC 6 band IIR HPF coefficient b1_3(reset 0x0000_0000) HPCOEF24 |    |    |    |      |       |    |    |    |    |    |    |    |
|--------|------|------|-----|-----------------------------------------------------------------|----|----|----|------|-------|----|----|----|----|----|----|----|
| Bit    | 31   | 30   | 29  | 28                                                              | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |      |      |     |                                                                 |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре   |      |      |     | RO                                                              |    |    |    |      |       |    |    |    |    |    |    |    |
| 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   |      |      |     | Hpcoef24                                                        |    |    |    |      |       |    |    |    |    |    |    |    |
| Туре   |      |      |     | R/W                                                             |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset  | 0    |      |     |                                                                 |    |    |    |      |       |    |    |    |    |    |    |    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef24   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b1_3 |

### 8.5.5.2.54 HPCOEF25

| 0x0016 | 4 (0x00 | )B2)                               | DAC | 6 ban | d IIR H | PF co | efficie | nt a1_3 | (reset | 0x000 | 0_00 | 0) |    |    | HPCO | EF25 |
|--------|---------|------------------------------------|-----|-------|---------|-------|---------|---------|--------|-------|------|----|----|----|------|------|
| Bit    | 31      | 30                                 | 29  | 28    | 27      | 26    | 25      | 24      | 23     | 22    | 21   | 20 | 19 | 18 | 17   | 16   |
| Name   |         |                                    |     |       |         |       |         | Rese    | erved  |       |      |    |    |    |      |      |
| Туре   |         | RO                                 |     |       |         |       |         |         |        |       |      |    |    |    |      |      |
| 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   |         | Hpcoef25                           |     |       |         |       |         |         |        |       |      |    |    |    |      |      |
| Туре   |         | R/W                                |     |       |         |       |         |         |        |       |      |    |    |    |      |      |
| Reset  | 0       |                                    |     |       |         |       |         |         |        |       |      |    |    |    |      |      |



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef25   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a1_3 |

8.5.5.2.55 HPCOEF26

Description:

0x00168 (0x00B4) DAC 6 band IIR HPF coefficient b2\_3(reset 0x0000\_0000)

HPCOEF26

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    |    |    |    |    |    |    | R    | 0     |    |    |    |    |    |    |    |
| 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  |    |    |    |    |    |    |    | Нрсс | pef26 |    |    |    |    |    |    |    |
| Туре  |    |    |    |    |    |    |    | R/   | w     |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef26   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b2_3 |

8.5.5.2.56 HPCOEF27



| 0x0016 | C (0x0 | 0B6) | DAC | DAC 6 band IIR HPF coefficient a2_3(reset 0x0000_0000) HPCOEF27 |    |    |    |      |       |    |    |    |    |    |    |    |
|--------|--------|------|-----|-----------------------------------------------------------------|----|----|----|------|-------|----|----|----|----|----|----|----|
| Bit    | 31     | 30   | 29  | 28                                                              | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |        |      |     |                                                                 |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре   |        |      |     | RO                                                              |    |    |    |      |       |    |    |    |    |    |    |    |
| 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   |        |      |     | Hpcoef27                                                        |    |    |    |      |       |    |    |    |    |    |    |    |
| Туре   |        |      | R/W |                                                                 |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset  | 0      |      |     |                                                                 |    |    |    |      |       |    |    |    |    |    |    |    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef27   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a2_3 |

### 8.5.5.2.57 HPCOEF28

| 0x0017 | 0x0) | )B8)                               | DAC | 6 ban | d IIR H | PF co | efficie | nt s4(re | eset 0 | k0000_ | _0000) |    |    |    | HPCO | EF28 |
|--------|------|------------------------------------|-----|-------|---------|-------|---------|----------|--------|--------|--------|----|----|----|------|------|
| Bit    | 31   | 30                                 | 29  | 28    | 27      | 26    | 25      | 24       | 23     | 22     | 21     | 20 | 19 | 18 | 17   | 16   |
| Name   |      |                                    |     |       |         |       |         | Rese     | erved  |        |        |    |    |    |      |      |
| Туре   |      | RO                                 |     |       |         |       |         |          |        |        |        |    |    |    |      |      |
| 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   |      | Hpcoef28                           |     |       |         |       |         |          |        |        |        |    |    |    |      |      |
| Type   |      | R/W                                |     |       |         |       |         |          |        |        |        |    |    |    |      |      |
| Reset  | 0    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0        |     |       |         |       |         |          |        |        |        |    |    |    |      |      |



| Field Name | Bit    | Туре | Reset<br>Value | Description                       |
|------------|--------|------|----------------|-----------------------------------|
| Hpcoef28   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient s4 |

8.5.5.2.58 HPCOEF29

Description:

0x00174 (0x00BA) DAC 6 band IIR HPF coefficient b0\_4(reset 0x0000\_0000)

HPCOEF29

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    |     |    |    |    |    |    | R    | 0     |    |    |    |    |    |    |    |
| 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  |    |     |    |    |    |    |    | Нрсс | pef29 |    |    |    |    |    |    |    |
| Туре  |    | R/W |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef29   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b0_4 |

8.5.5.2.59 HPCOEF30



| 0x0017 | 8 (0x00 | BC)                       | DAC 6 band IIR HPF coefficient a0_4(reset 0x0000_0000) HPCOEF30 |    |    |    |    |      |       |    |    |    |    |    |    |    |
|--------|---------|---------------------------|-----------------------------------------------------------------|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Bit    | 31      | 30                        | 29                                                              | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |         |                           |                                                                 |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре   |         | RO                        |                                                                 |    |    |    |    |      |       |    |    |    |    |    |    |    |
| 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   |         |                           |                                                                 |    |    |    |    | Нрсс | oef30 |    |    |    |    |    |    |    |
| Туре   |         | R/W                       |                                                                 |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset  | 0       | 0                         | 0 0 0 0 0 0 0 0 0 0 0 0 0                                       |    |    |    |    |      |       |    |    |    |    |    |    |    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef30   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a0_4 |

8.5.5.2.60 HPCOEF31

Description:

 0x0017C (0x00BE)
 DAC 6 band IIR HPF coefficient b1\_4(reset 0x0000\_0000)
 HPCOEF31

 Bit
 31
 30
 29
 28
 27
 26
 25
 24
 23
 22
 21
 20
 19
 18
 17
 16

| Bit   | 31                          | 30                                    | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----------------------------|---------------------------------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |                             |                                       |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |                             |                                       |    |    |    |    |    | R    | 0     |    |    |    |    |    |    |    |
| Reset | 0                           | 0 0 0 0 0 0 0 0 0 0 0 0 0             |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Bit   | 15                          | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Name  |                             |                                       |    |    |    |    |    | Нрсс | oef31 |    |    |    |    |    |    |    |
| Туре  | R/W                         |                                       |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                       |    |    |    |    |    |      |       |    |    |    |    |    |    |    |



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef31   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b1_4 |

8.5.5.2.61 HPCOEF32

Description:

0x00180 (0x00C0) DAC 6 band IIR HPF coefficient a1\_4(reset 0x0000\_0000)

HPCOEF32

| Bit   | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |     |    |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |     | 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  |     |    |    |    |    |    |    | Нрсс | pef32 |    |    |    |    |    |    |    |
| Туре  | R/W |    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef32   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a1_4 |

8.5.5.2.62 HPCOEF33



| 0x00184 | 4 (0x00 | )C2)                      | DAC | 6 band | d IIR H | PF co | efficie | nt b2_4 | 4(reset | 0x000 | 000_000 | 0) |    |    | HPCO | EF33 |
|---------|---------|---------------------------|-----|--------|---------|-------|---------|---------|---------|-------|---------|----|----|----|------|------|
| Bit     | 31      | 30                        | 29  | 28     | 27      | 26    | 25      | 24      | 23      | 22    | 21      | 20 | 19 | 18 | 17   | 16   |
| Name    |         |                           |     |        |         |       |         | Rese    | erved   |       |         |    |    |    |      |      |
| Туре    |         | RO                        |     |        |         |       |         |         |         |       |         |    |    |    |      |      |
| 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    |         |                           |     |        |         |       |         | Нрсс    | oef33   |       |         |    |    |    |      |      |
| Туре    |         | R/W                       |     |        |         |       |         |         |         |       |         |    |    |    |      |      |
| Reset   | 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 |     |        |         |       |         |         |         |       |         |    |    |    |      |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef33   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b2_4 |

8.5.5.2.63 HPCOEF34

Description:

0x00188 (0x00C4) DAC 6 band IIR HPF coefficient a2\_4(reset 0x0000\_0000) HPCOEF34 Bit Name Reserved RO Type Reset Bit Name Hpcoef34 Type R/W Reset 



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef34   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a2_4 |

#### 8.5.5.2.64 HPCOEF35

Description:

0x0018C (0x00C6) DAC 6 band IIR HPF coefficient s5(reset 0x0000\_0000)

HPCOEF35

|       |    |                             |    |    |    |    |    |      |       |    |    |    | _  | _  |    |    |
|-------|----|-----------------------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Bit   | 31 | 30                          | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |                             |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    | 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  |    |                             |    |    |    |    |    | Нрсс | pef35 |    |    |    |    |    |    |    |
| Туре  | RW |                             |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                       |
|------------|--------|------|----------------|-----------------------------------|
| Hpcoef35   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient s5 |

8.5.5.2.65 HPCOEF36



| 0x0019 | 0x00 | )C8)                      | DAC | 6 band | d IIR H | PF co | efficie | nt b0_ | 5(reset | 0x000 | 000_000 | 0) |    |    | HPCO | EF36 |
|--------|------|---------------------------|-----|--------|---------|-------|---------|--------|---------|-------|---------|----|----|----|------|------|
| Bit    | 31   | 30                        | 29  | 28     | 27      | 26    | 25      | 24     | 23      | 22    | 21      | 20 | 19 | 18 | 17   | 16   |
| Name   |      |                           |     |        |         |       |         | Rese   | erved   |       |         |    |    |    |      |      |
| Туре   |      | RO                        |     |        |         |       |         |        |         |       |         |    |    |    |      |      |
| 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   |      |                           |     |        |         |       |         | Нрсс   | oef36   |       |         |    |    |    |      |      |
| Туре   |      | R/W                       |     |        |         |       |         |        |         |       |         |    |    |    |      |      |
| Reset  | 0    | 0 0 0 0 0 0 0 0 0 0 0 0 0 |     |        |         |       |         |        |         |       |         |    |    |    |      |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef36   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b0_5 |

8.5.5.2.66 HPCOEF37

Description:

0x00194 (0x00CA) DAC 6 band IIR HPF coefficient a0\_5(reset 0x0000\_0000) HPCOEF37 Bit Name Reserved RO Type Reset Bit Name Hpcoef37 Type R/W Reset 



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef37   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a0_5 |

8.5.5.2.67 HPCOEF38

Description:

0x00198 (0x00CC) DAC 6 band IIR HPF coefficient b1\_5(reset 0x0000\_0000)

HPCOEF38

|       |    |                                       |    |    |    |    |    |      |       |    |    |    | _  | _  |    |    |
|-------|----|---------------------------------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Bit   | 31 | 30                                    | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |                                       |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    | RO                                    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0             |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Bit   | 15 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |    |      |       |    | 0  |    |    |    |    |    |
| Name  |    |                                       |    |    |    |    |    | Нрсс | pef38 |    |    |    |    |    |    |    |
| Туре  |    | R/W                                   |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0                                     | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef38   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b1_5 |

8.5.5.2.68 HPCOEF39



| 0x0019 | C (0x0 | OCE)                        | DAC                       | 6 band | d IIR H | PF co | efficier | nt a1_ | (reset | 0x000 | 0_000 | 0) |    |    | HPCO | EF39 |
|--------|--------|-----------------------------|---------------------------|--------|---------|-------|----------|--------|--------|-------|-------|----|----|----|------|------|
| Bit    | 31     | 30                          | 29                        | 28     | 27      | 26    | 25       | 24     | 23     | 22    | 21    | 20 | 19 | 18 | 17   | 16   |
| Name   |        | Reserved                    |                           |        |         |       |          |        |        |       |       |    |    |    |      |      |
| Туре   |        |                             | RO                        |        |         |       |          |        |        |       |       |    |    |    |      |      |
| 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   |        |                             |                           |        |         |       |          | Нрсс   | oef39  |       |       |    |    |    |      |      |
| Туре   |        |                             | R/W                       |        |         |       |          |        |        |       |       |    |    |    |      |      |
| Reset  | 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                           |        |         |       |          |        |        |       |       |    |    |    |      |      |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef39   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a1_5 |

8.5.5.2.69 HPCOEF40

| 0x001A | 0x0) 0 | 0D0)                                            | DAC | 6 ban | d IIR H | PF co | efficier | nt b2_ | (reset | 0x000 | 000_000 | 0) |   |   | HPCO | EF40 |
|--------|--------|-------------------------------------------------|-----|-------|---------|-------|----------|--------|--------|-------|---------|----|---|---|------|------|
| Bit    | 31     | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |     |       |         |       |          |        |        |       |         |    |   |   |      |      |
| Name   |        | Reserved                                        |     |       |         |       |          |        |        |       |         |    |   |   |      |      |
| Туре   |        | RO                                              |     |       |         |       |          |        |        |       |         |    |   |   |      |      |
| 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   |        |                                                 |     |       |         |       |          | Нрсс   | ef40   |       |         |    |   |   |      |      |
| Туре   |        | R/W                                             |     |       |         |       |          |        |        |       |         |    |   |   |      |      |
| Reset  | 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                   |     |       |         |       |          |        |        |       |         |    |   |   |      |      |



| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef40   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient b2_5 |

8.5.5.2.70 HPCOEF41

Description:

0x001A4 (0x00D2) DAC 6 band IIR HPF coefficient a2\_5(reset 0x0000\_0000)

HPCOEF41

| Bit   | 31 | 30                      | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-------------------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    |                         |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| Туре  |    | RO                      |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 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  |    |                         |    |    |    |    |    | Нрсс | pef41 |    |    |    |    |    |    |    |
| Туре  |    | R/W                     |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset | 0  | 0                       | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                         |
|------------|--------|------|----------------|-------------------------------------|
| Hpcoef41   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient a2_5 |

8.5.5.2.71 HPCOEF42



| 0x001A | 8 (0x0 | 0D4) | DAC | 6 ban                   | d IIR H | PF co | efficie | nt s6(r | eset 0 | x0000_ | 0000) |    |    |    | HPCO | EF42 |
|--------|--------|------|-----|-------------------------|---------|-------|---------|---------|--------|--------|-------|----|----|----|------|------|
| Bit    | 31     | 30   | 29  | 28                      | 27      | 26    | 25      | 24      | 23     | 22     | 21    | 20 | 19 | 18 | 17   | 16   |
| Name   |        |      |     | Reserved                |         |       |         |         |        |        |       |    |    |    |      |      |
| Туре   |        |      |     | RO                      |         |       |         |         |        |        |       |    |    |    |      |      |
| 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   |        |      |     | Hpcoef42                |         |       |         |         |        |        |       |    |    |    |      |      |
| Туре   |        |      |     | R/W                     |         |       |         |         |        |        |       |    |    |    |      |      |
| Dooot  | 0      | _    |     | 0                       | 0       | 0     | 0       | 0       |        | 0      | _     | 0  |    |    |      | 0    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                       |
|------------|--------|------|----------------|-----------------------------------|
| Hpcoef42   | [15:0] | R/W  | 16'h0          | DAC 6 band IIR HPF coefficient s6 |

# 8.6 Audio Codec Control Registers

The Audio Coedc control registers base address is 0x8200\_0100(ARM) or 0x007F\_0100(DSP). The following table lists these control registers.

| Offset Address | Name    | Description           |
|----------------|---------|-----------------------|
| 0x0100         | VB_AICR | Voice band Codec AICR |
| 0x0104         | VB_CR1  | Voice band Codec CR1  |
| 0x0108         | VB_CR2  | Voice band Codec CR2  |
| 0x010C         | VB_CCR1 | Voice band Codec CCR1 |



| Offset Address | Name     | Description            |
|----------------|----------|------------------------|
| 0x0110         | VB_CCR2  | Voice band Codec CCR2  |
| 0x0114         | VB_PMR1  | Voice band Codec PMR1  |
| 0x0118         | VB_PMR2  | Voice band Codec PMR2  |
| 0x011C         | VB_CRR   | Voice band Codec CRR   |
| 0x0120         | VB_ICR   | Voice band Codec ICR   |
| 0x0124         | VB_IFR   | Voice band Codec IFR   |
| 0x0128         | VB_CGR1  | Voice band Codec CGR1  |
| 0x012C         | VB_CGR2  | Voice band Codec CGR2  |
| 0x0130         | VB_CGR3  | Voice band Codec CGR3  |
| 0x0134~0x0140  | Reserved |                        |
| 0x0144         | VB_CGR8  | Voice band Codec CGR8  |
| 0x0148         | VB_CGR9  | Voice band Codec CGR9  |
| 0x014C         | VB_CGR10 | Voice band Codec CGR10 |
| 0x0150         | VB_TR1   | Voice band Codec TR1   |
| 0x0154         | VB_TR2   | Voice band Codec TR2   |
|                |          |                        |

8.6.1 VB\_AICR



| 0x0100 |                               |          | Audi | o Cod | ec inte | rface | mode ( | contro | I        |         |    |    |     |     | VB_ | AICR |
|--------|-------------------------------|----------|------|-------|---------|-------|--------|--------|----------|---------|----|----|-----|-----|-----|------|
| Bit    | 31                            | 30       | 29   | 28    | 27      | 26    | 25     | 24     | 23       | 22      | 21 | 20 | 19  | 18  | 17  | 16   |
| Name   |                               | Reserved |      |       |         |       |        |        |          |         |    |    |     |     |     |      |
| Туре   |                               | 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  |     |     |     |      |
|        |                               |          |      |       |         |       |        |        |          |         | С  |    |     |     |     | AD   |
|        |                               |          |      |       |         |       |        |        | Reserved |         |    |    | C_  | C_  | C_I | C_I  |
| Name   |                               |          |      | Rese  | erved   |       |        |        |          |         |    |    | SE  | SE  | 2S  | 2S   |
|        |                               |          |      |       |         |       |        |        |          |         |    |    | RIA | RIA |     |      |
|        |                               |          |      |       |         |       |        |        |          |         |    |    | L   | L   |     |      |
| Туре   | RO                            |          |      |       |         |       |        |        |          | R/W R/V |    |    |     | R/W | R/W | R/W  |
| Reset  | 0                             | 0        | 0    | 0     | 0       | 0     | 0      | 0      | 0        | 0       | 0  | 0  | 1   | 1   | 0   | 0    |

| Field Name | Bit    | Туре | Reset | Description                                                                                                                                                                                               |
|------------|--------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |        | 71   | Value |                                                                                                                                                                                                           |
|            | [15:8] | RO   | 8'h0  | Reserved                                                                                                                                                                                                  |
|            | [7:4]  | R/W  | 4'h0  | Reserved                                                                                                                                                                                                  |
| DAC_SERIAL | [3]    | R/W  | 1'h1  | Selection of the DAC digital serial audio interface  0= Parallel interface  1= Serial interface  Note: Parallel interface is not supported, this control bit should not be changed from the default value |
| ADC_SERIAL | [2]    | R/W  | 1'h1  | Selection of the ADC digital serial audio interface  0= Parallel interface  1= Serial interface  Note: Parallel interface is not supported, this control bit should not be changed from the default value |
| DAC_I2S    | [1]    | R/W  | 1'h0  | Working mode of the DAC digital serial audio                                                                                                                                                              |



|         |     |     |      | interface                                                                   |
|---------|-----|-----|------|-----------------------------------------------------------------------------|
|         |     |     |      | 0= DSP mode                                                                 |
|         |     |     |      | 1= I2S mode                                                                 |
|         |     |     |      | Note: I2S mode is recommended to be compatible with VBC interface I2S slave |
| ADC_I2S | [0] | R/W | 1'h0 | Working mode of the ADC digital serial audio interface  0= DSP mode         |
|         |     |     |      | 1= I2S mode                                                                 |
|         |     |     |      | Note: I2S mode is recommended to be                                         |
|         |     |     |      | compatible with VBC interface I2S slave                                     |

## 8.6.2 VB\_CR1

| 0x0104             | Audio Codec mode control   | VB              | CR1   |
|--------------------|----------------------------|-----------------|-------|
| 0X010 <del>4</del> | Addio Codec Illode Collino | AP <sup>-</sup> | OIX I |

| Bit   | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23     | 22       | 21               | 20         | 19         | 18         | 17               | 16               |
|-------|----------|----|----|----|----|----|----|-----|--------|----------|------------------|------------|------------|------------|------------------|------------------|
| Name  |          |    |    |    |    |    |    | Res | served |          |                  |            |            |            |                  |                  |
| Туре  |          | 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  | Reserved |    |    |    |    |    |    |     |        | MON<br>O | DAC<br>_MU<br>TE | HP_<br>DIS | DAC<br>SEL | BYP<br>ASS | BTL<br>_MU<br>TE | Res<br>erve<br>d |
| Type  | RO       |    |    |    |    |    |    |     |        | R/W      | R/W              | R/W        | R/W        | R/W        | R/W              | R/W              |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 1      | 0        | 1                | 0          | 1          | 0          | 1                | 0                |

| Field Name | Bit    | Туре | Reset<br>Value | Description |
|------------|--------|------|----------------|-------------|
|            | [15:8] | RO   | 8'h0           | Reserved    |



| [7] | R/W             | 1'h1                                    | Microphone biasing buffer power-down                                               |
|-----|-----------------|-----------------------------------------|------------------------------------------------------------------------------------|
|     |                 |                                         | 0= active                                                                          |
|     |                 |                                         | 1= power-down                                                                      |
| [6] | R/W             | 1'h0                                    | Stereo-to-mono conversion for DAC path                                             |
|     |                 |                                         | 0= stereo                                                                          |
|     |                 |                                         | 1= mono                                                                            |
| [5] | R/W             | 1'h1                                    | DAC soft mute mode                                                                 |
|     |                 |                                         | 0= mute inactive, digital input signal transmitted                                 |
|     |                 |                                         | to the DAC                                                                         |
|     |                 |                                         | 1= puts the DAC in soft mute mode                                                  |
| [4] | R/W             | 1'h0                                    | Headphone output signal disabled:                                                  |
|     |                 |                                         | 0= Signal applied to headphone outputs                                             |
|     |                 |                                         | 1= no signal on headphone outputs, acts as a                                       |
|     |                 |                                         | mute signal                                                                        |
| [3] | R/W             | 1'h1                                    | Mixer input selection                                                              |
|     |                 |                                         | 0= DAC output ignored in input of the mixer                                        |
|     |                 |                                         | 1= DAC output selected as an input of the                                          |
|     |                 |                                         | mixer                                                                              |
| [2] | R/W             | 1'h0                                    | Mixer input selection (line)                                                       |
|     |                 |                                         | 0= Bypass path ignored in input of the mixer                                       |
|     |                 |                                         | 1= Bypass path selected as an input of the                                         |
|     |                 |                                         | mixer                                                                              |
| [1] | R/W             | 1'h1                                    | BTL mute mode                                                                      |
|     |                 |                                         | 0= active                                                                          |
|     |                 |                                         | 1= puts the BTL stage in mute mode                                                 |
| [0] | R/W             | 1'h0                                    | Reserved                                                                           |
|     | [6] [5] [4] [2] | [6] R/W [5] R/W [4] R/W [2] R/W [1] R/W | [6] R/W 1'h0  [7] R/W 1'h1  [8] R/W 1'h1  [9] R/W 1'h1  [1] R/W 1'h1  [1] R/W 1'h1 |

8.6.3 VB\_CR2



| 0x0108 |                             |          | Audi | o Cod | ec mo | de con | trol |    |                   |                   |    |    |      |                 | VB         | _CR2             |
|--------|-----------------------------|----------|------|-------|-------|--------|------|----|-------------------|-------------------|----|----|------|-----------------|------------|------------------|
| Bit    | 31                          | 30       | 29   | 28    | 27    | 26     | 25   | 24 | 23                | 22                | 21 | 20 | 19   | 18              | 17         | 16               |
| Name   |                             | Reserved |      |       |       |        |      |    |                   |                   |    |    |      |                 |            |                  |
| Туре   |                             | RO       |      |       |       |        |      |    |                   |                   |    |    |      |                 |            |                  |
| 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   |                             |          |      | Rese  | erved |        |      |    | DAC<br>_DE<br>EMP | DAC_ADWL ADC_ADWL |    |    | ADWL | ADC<br>_HP<br>F | MIC<br>SEL | Res<br>erve<br>d |
| Туре   | RO                          |          |      |       |       |        |      |    |                   | R                 | w  | R  | W    | R/W             | R/W        | R/W              |
| Reset  | 0                           | 0        | 0    | 0     | 0     | 0      | 0    | 0  | 0                 | 1                 | 1  | 1  | 1    | 0               | 0          | 0                |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                |
|------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [15:8] | RO   | 8'h0           | Reserved                                                                                                                                                                                                                                                   |
| DAC_DEEMP  | [7]    | R/W  | 1'h0           | DAC De-emphasize filter enable 0= inactive 1= enables the de-emphasis filter                                                                                                                                                                               |
| DAC_ADWL   | [6:5]  | R/W  | 2'h3           | Audio Data Word Length: for DAC paths  00 = 16-bit word length data  01 = 18-bit word length data  10 = 20-bit word length data  11 = 24-bit word length data  Note: Only 16-bit word length audio data is supported, so it must be programmed to be 2'b00 |
| ADC_ADWL   | [4:3]  | R/W  | 2'h3           | Audio Data Word Length: for ADC paths  00 = 16-bit word length data  01 = 18-bit word length data  10 = 20-bit word length data  11 = 24-bit word length data  Note: Only 16-bit word length audio data is supported, so it must be programmed to be       |



|         |     |     |      | 2'b00                                        |
|---------|-----|-----|------|----------------------------------------------|
| ADC_HPF | [2] | R/W | 1'h0 | ADC High Pass Filter enable                  |
|         |     |     |      | 0= inactive                                  |
|         |     |     |      | 1= enables the ADC High Pass Filter          |
| MICSEL  | [1] | R/W | 1'h0 | selection of the signal converted by the ADC |
|         |     |     |      | 0 = Microphone input 1 (MICP, MICN)          |
|         |     |     |      | 1 = Microphone input 2 (AUXMICP, AUXMICN)    |
|         | [0] | R/W | 1'h0 | Reserved                                     |

### 8.6.4 VB\_CCR1

| 0x010C |    |                                              | Audi | o Code | ec mod | de con | trol |   |   |   |     |   | VB_CCR1 |   |   |   |
|--------|----|----------------------------------------------|------|--------|--------|--------|------|---|---|---|-----|---|---------|---|---|---|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 |      |        |        |        |      |   |   |   |     |   | 16      |   |   |   |
| Name   |    | Reserved                                     |      |        |        |        |      |   |   |   |     |   |         |   |   |   |
| Туре   |    | RO                                           |      |        |        |        |      |   |   |   |     |   |         |   |   |   |
| 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   |    | Reserved CRYSTA                              |      |        |        |        |      |   |   |   | STA |   |         |   |   |   |
| Туре   |    | RO R/W                                       |      |        |        |        |      |   |   |   |     |   |         |   |   |   |
| Reset  | 0  | 0                                            | 0    | 0      | 0      | 0      | 0    | 0 | 0 | 0 | 0   | 0 | 0       | 0 | 0 | 0 |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                   |
|------------|--------|------|----------------|-----------------------------------------------|
|            | [15:4] | RO   | 12'h0          | Reserved                                      |
| CRYSTAL    | [3:0]  | R/W  | 4'h0           | Selection of the MCLK frequency               |
|            |        |      |                | The sampling frequency value is as following: |
|            |        |      |                | 0000: 12 MHz                                  |
|            |        |      |                | 0001:16.9344 MHz (for further use)            |
|            |        |      |                | 0010: 16.9344 MHz (for further use)           |



| 0011: 16.9344 MHz (for further use)         |
|---------------------------------------------|
| 0100 :16.9344 MHz (for further use)         |
| 0101 :16.9344 MHz (for further use)         |
| 0110 :16.9344 MHz (for further use)         |
| 0111 :16.9344 MHz (for further use)         |
| 1000 :16.9344 MHz (for further use)         |
| 1001 :16.9344 MHz (for further use)         |
| 1010 :16.9344 MHz (for further use)         |
| 1011 :16.9344 MHz (for further use)         |
| 1100 :16.9344 MHz (for further use)         |
| 1101 :16.9344 MHz (for further use)         |
| 1110 :16.9344 MHz (for further use)         |
| 1111 :16.9344 MHz (for further use)         |
|                                             |
| Note: Only 12MHz MCLK is supported, so it   |
| should be always 4'b0000, please remain the |
| default value unchanged                     |

# 8.6.5 VB\_CCR2

| 0x0110 |    |                                           | Audi | o Code | ec mo | de con | trol |   |           |   |   |   |     |    | VB_0 | CCR2 |
|--------|----|-------------------------------------------|------|--------|-------|--------|------|---|-----------|---|---|---|-----|----|------|------|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 |      |        |       |        |      |   |           |   |   |   |     | 17 | 16   |      |
| Name   |    | Reserved                                  |      |        |       |        |      |   |           |   |   |   |     |    |      |      |
| Туре   |    | 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   |    |                                           |      | Rese   | rved  |        |      |   | DREEQ ARE |   |   |   |     |    | ≣Q   |      |
| Туре   |    |                                           |      | R      | 0     |        |      |   | R/W       |   |   |   | R/W |    |      |      |
| Reset  | 0  | 0                                         | 0    | 0      | 0     | 0      | 0    | 0 | 0         | 0 | 0 | 0 | 0   | 0  | 0    | 0    |



| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                             |
|------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [15:8] | RO   | 8'h0           | Reserved                                                                                                                                                                                                |
| DFREQ      | [7:4]  | R/W  | 4'h0           | Selection of the DAC sampling rate (Fs) The sampling frequency value is given in the following: 0000: 96kHz 0001: 48kHz 0010: 44.1kHz 0011: 32kHz                                                       |
|            |        |      |                | 0111: 32kHz 0100: 24kHz 0101: 22.05kHz 0110: 16kHz 0111: 12kHz 1000: 11.025kH 1001: 9.6kHz 1010: 8kHz 1010: 8kHz 1110: 8kHz 1110: 8kHz 1111: 8kHz                                                       |
| AFREQ      | [3:0]  | R/W  | 4'h0           | Selection of the ADC sampling rate (Fs) The sampling frequency value is given in the following: 0000: 96kHz 0001: 48kHz 0010: 44.1kHz 0011: 32kHz 0100: 24kHz 0101: 22.05kHz 0111: 12kHz 1000: 11.025kH |



|  | 1001: 9.6kHz |
|--|--------------|
|  | 1010: 8kHz   |
|  | 1011: 8kHz   |
|  | 1100: 8kHz   |
|  | 1101: 8kHz   |
|  | 1110: 8kHz   |
|  | 1111: 8kHz   |

### 8.6.6 VB\_PMR1

| 0x0114 | Audio Codec mode control |  |  |  | VB_F | PMR1 |
|--------|--------------------------|--|--|--|------|------|
|        |                          |  |  |  |      |      |

|       |    |               |    |    |    |    | _  |    | _  |            |            |            |            |            |                 |                  |
|-------|----|---------------|----|----|----|----|----|----|----|------------|------------|------------|------------|------------|-----------------|------------------|
| Bit   | 31 | 30            | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22         | 21         | 20         | 19         | 18         | 17              | 16               |
| Name  |    | Reserved      |    |    |    |    |    |    |    |            |            |            |            |            |                 |                  |
| Туре  |    | 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  |    | Reserved      |    |    |    |    |    |    |    | SB_<br>OUT | SB_<br>MIX | SB_<br>ADC | SB_<br>LIN | SB_<br>BTL | SB_<br>LOU<br>T | Res<br>erve<br>d |
| Туре  |    | RO            |    |    |    |    |    |    |    | R/W        | R/W        | R/W        | R/W        | R/W        | R/W             | R/W              |
| Reset | 0  | 0 0 0 0 0 0 0 |    |    |    |    |    |    | 1  | 1          | 1          | 1          | 1          | 1          | 1               | 1                |

| Field Name | Bit    | Туре | Reset<br>Value | Description         |
|------------|--------|------|----------------|---------------------|
|            | [15:8] | RO   | 8'h0           | Reserved            |
| SB_DAC     | [7]    | R/W  | 1'h1           | DAC power-down mode |
|            |        |      |                | 0= active           |
|            |        |      |                | 1= power-down       |



| SB_OUT  | [6] | R/W | 1'h1 | Output stage power-down mode                      |
|---------|-----|-----|------|---------------------------------------------------|
|         |     |     |      | 0= active                                         |
|         |     |     |      | 1= power-down                                     |
| SB_MIX  | [5] | R/W | 1'h1 | Mixer and line output stage power-down            |
|         |     |     |      | 0= active                                         |
|         |     |     |      | 1= power-down                                     |
| SB_ADC  | [4] | R/W | 1'h1 | ADC power-down mode                               |
|         |     |     |      | 0= active                                         |
|         |     |     |      | 1= power-down                                     |
| SB_LIN  | [3] | R/W | 1'h1 | Analog line Input (Bypass) conditioning circuitry |
|         |     |     |      | power-down mode                                   |
|         |     |     |      | 0= active                                         |
|         |     |     |      | 1= power-down                                     |
| SB_BTL  | [2] | R/W | 1'h1 | BTL output conditioning circuitry power-down      |
|         |     |     |      | mode                                              |
|         |     |     |      | 0= active                                         |
|         |     |     |      | 1= power-down                                     |
| SB_LOUT | [1] | R/W | 1'h1 | Line out + BTL conditioning circuitry             |
|         |     |     |      | power-down mode                                   |
|         |     |     |      | 0= active                                         |
|         |     |     |      | 1= power-down                                     |
|         | [0] | R/W | 1'h1 | Reserved                                          |

8.6.7 VB\_PMR2



| 0x0118 |                                                                                                                                                   |          | Audi | o Cod | ec mo | de con | trol |   |   |   |           |           |     |           | VB_F | PMR2             |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------|------|-------|-------|--------|------|---|---|---|-----------|-----------|-----|-----------|------|------------------|
| Bit    | 31         30         29         28         27         26         25         24         23         22         21         20         19         18 |          |      |       |       |        |      |   |   |   |           |           | 17  | 16        |      |                  |
| Name   |                                                                                                                                                   | Reserved |      |       |       |        |      |   |   |   |           |           |     |           |      |                  |
| Туре   |                                                                                                                                                   | RO       |      |       |       |        |      |   |   |   |           |           |     |           |      |                  |
| Reset  | 0                                                                                                                                                 |          |      |       |       |        |      |   |   |   |           |           | 0   |           |      |                  |
| Bit    | 15                                                                                                                                                | 14       | 13   | 12    | 11    | 10     | 9    | 8 | 7 | 6 | 5         | 4         | 3   | 2         | 1    | 0                |
| Name   |                                                                                                                                                   | Reserved |      |       |       |        |      |   |   |   | LRG<br>OD | RLG<br>OD | GIM | SB_<br>MC | SB   | SB_<br>SLE<br>EP |
| Туре   |                                                                                                                                                   | RO       |      |       |       |        |      |   |   |   |           | R/W       | R/W | R/W       | R/W  | R/W              |
| Reset  | 0                                                                                                                                                 | 0        | 0    | 0     | 0     | 0      | 0    | 0 | 0 | 0 | 0         | 0         | 0   | 0         | 1    | 1                |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                               |
|------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | [15:6] | RO   | 10'h0          | Reserved                                                                                                                                                                                                                                                                  |
| LRGOD      | [5]    | R/W  | 1'h0           | DAC mixing gain coupling  00: Left and right channels gains are independent, respectively given by GODL and GODR  10: Left and right channels gain is given by GODL  01: Left and right channels gain is given by GODR  11: Left and right channels gain is given by GODL |



|          |     | _   | 1    |                                                                                        |
|----------|-----|-----|------|----------------------------------------------------------------------------------------|
|          | [4] | R/W | 1'h0 | DAC mixing gain coupling                                                               |
|          |     |     |      | 00: Left and right channels gains are independent, respectively given by GODL and GODR |
| RLGOD    |     |     |      | 10: Left and right channels gain is given by GODL                                      |
|          |     |     |      | 01: Left and right channels gain is given by GODR                                      |
|          |     |     |      | 11: Left and right channels gain is given by GODL                                      |
|          | [3] | R/W | 1'h0 | Microphone amplifier gain control                                                      |
| GIM      |     |     |      | 0= 0 dB gain                                                                           |
|          |     |     |      | 1= 20 dB gain                                                                          |
|          | [2] | R/W | 1'h0 | Output Stage common mode buffer                                                        |
|          |     |     |      | power-down                                                                             |
| SB_MC    |     |     |      | 0= active (capacitor less headphone output configuration)                              |
|          |     |     |      | 1= power-down (line output configuration)                                              |
|          | [1] | R/W | 1'h1 | complete power-down mode                                                               |
| SB       |     |     |      | 0= normal mode (active)                                                                |
|          |     |     |      | 1= complete power-down                                                                 |
| SB_SLEEP | [0] | R/W | 1'h1 | sleep mode                                                                             |
|          |     |     |      | 0= normal mode (active)                                                                |
|          |     |     |      | 1= sleep mode                                                                          |
|          |     |     |      |                                                                                        |

8.6.8 VB\_CRR



| 0x011C |    | Audio Codec mode control VB_CRR                                                                                                                              |    |    |    |    |   |   |   |     |   |     |       | CRR |   |   |
|--------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|---|-----|---|-----|-------|-----|---|---|
| Bit    | 31 | 31         30         29         28         27         26         25         24         23         22         21         20         19         18         17 |    |    |    |    |   |   |   |     |   |     |       | 16  |   |   |
| Name   |    | Reserved                                                                                                                                                     |    |    |    |    |   |   |   |     |   |     |       |     |   |   |
| Туре   |    | RO                                                                                                                                                           |    |    |    |    |   |   |   |     |   |     |       |     |   |   |
| 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   |    | Reserved RATIO KFAST                                                                                                                                         |    |    |    |    |   |   |   |     |   |     | TRESH |     |   |   |
| Туре   | RO |                                                                                                                                                              |    |    |    |    |   |   |   | R/W |   | R/W |       | R/W |   |   |
| Reset  | 0  | 0                                                                                                                                                            | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 1   | 0 | 1   | 0     | 0   | 0 | 1 |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                                               |
|------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------|
|            | [15:7] | RO   | 9'h0           | Reserved                                                                                                                  |
| RATIO      | [6:5]  | R/W  | 2'h2           | ratio between fast and slow steps  00: Ratio =1  01: Ratio = 2  10: Ratio = 4  (default, remain unchanged)  11: Ratio = 8 |



|        | [4:2] | R/W | 3'h4                        | factor for step time in fast slope part     |
|--------|-------|-----|-----------------------------|---------------------------------------------|
|        |       |     |                             | 000: KFast =1                               |
|        |       |     |                             | 001: KFast = 2                              |
| KFAST  |       |     |                             | 010: KFast = 4                              |
| NI AST |       |     |                             | 011: KFast = 8                              |
|        |       |     |                             | 100: KFast =16                              |
|        |       |     | (default, remain unchanged) |                                             |
|        |       |     |                             | 101: KFast = 32                             |
|        | [1:0] | R/W | 2'h1                        | threshold between fast and slow slope parts |
|        |       |     |                             | 00: Threshold = 0                           |
| TRESH  |       |     |                             | 01: Threshold = 32                          |
|        |       |     |                             | (default, remain unchanged)                 |
|        |       |     |                             | 10: Threshold = 64                          |
|        |       |     |                             | 11: Threshold = 128                         |

# 8.6.9 VB\_ICR

| 0x0120 |          | Audio Codec mode control VB_ICF |    |    |    |    |    |    |       |      |                   |                       |                  |                  | _ICR             |                  |
|--------|----------|---------------------------------|----|----|----|----|----|----|-------|------|-------------------|-----------------------|------------------|------------------|------------------|------------------|
| Bit    | 31       | 30                              | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22   | 21                | 20                    | 19               | 18               | 17               | 16               |
| Name   |          | Reserved                        |    |    |    |    |    |    |       |      |                   |                       |                  |                  |                  |                  |
| Туре   |          | 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   | Reserved |                                 |    |    |    |    |    |    | INT_F | FORM | JAC<br>K_M<br>ASK | CC<br>MC_<br>MAS<br>K | RUD<br>_MA<br>SK | RDD<br>_MA<br>SK | GUD<br>_MA<br>SK | GDD<br>_MA<br>SK |
| Туре   | RO       |                                 |    |    |    |    |    |    | 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    | 1                 | 1                     | 1                | 1                | 1                | 1                |



| Field Name | Bit    | Туре | Reset | Description                                                                                                                                                                         |
|------------|--------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |        |      | Value |                                                                                                                                                                                     |
|            | [15:8] | RO   | 8'h0  | Reserved                                                                                                                                                                            |
| INT_FORM   | [7:6]  | R/W  | 2'h0  | Waveform and polarity of the IRQ signal                                                                                                                                             |
|            |        |      |       | 00: The generated IRQ is a high level                                                                                                                                               |
|            |        |      |       | 01: The generated IRQ is a low level                                                                                                                                                |
|            |        |      |       | 10: The generated IRQ is a high level pulse with an 8 MC_CLK cycles duration when using 8-bit parallel control interface or 8 MCLK cycles duration when using I2C control interface |
|            |        |      |       | 11: The generated IRQ is a low level pulse with an 8 MC_CLK cycles duration when using 8-bit parallel control interface or 8 MCLK cycles duration when using I2C control interface  |
| JACK_MASK  | [5]    | R/W  | 1'h1  | Mask for the JACK_EVENT flag                                                                                                                                                        |
|            |        |      |       | 0: interrupt enabled                                                                                                                                                                |
|            |        |      |       | 1: interrupt masked (no IRQ generation)                                                                                                                                             |



|               | [4] | R/W | 1'h1 | Mask for the CCMC flag                  |
|---------------|-----|-----|------|-----------------------------------------|
| CCMC MASK     |     |     |      | Read/Write                              |
| CCIVIC_IVIASK |     |     |      | 0: interrupt enabled                    |
|               |     |     |      | 1: interrupt masked (no IRQ generation) |
|               | [3] | R/W | 1'h1 | Mask for the RAMP_UP_DONE flag          |
| RUD_MASK      |     |     |      | 0: interrupt enabled                    |
|               |     |     |      | 1: interrupt masked (no IRQ generation) |
|               | [2] | R/W | 1'h1 | Mask for the RAMP_DOWN_DONE flag        |
| RDD_MASK      |     |     |      | 0: interrupt enabled                    |
|               |     |     |      | 1: interrupt masked (no IRQ generation) |
|               | [1] | R/W | 1'h1 | Mask for the GAIN_UP_DONE flag          |
| GUD_MASK      |     |     |      | 0: interrupt enabled                    |
|               |     |     |      | 1: interrupt masked (no IRQ generation) |
|               | [0] | R/W | 1'h1 | Mask for the GAIN_DOWN_DONE flag        |
| GDD_MASK      |     |     |      | 0: interrupt enabled                    |
|               |     |     |      | 1: interrupt masked (no IRQ generation) |

8.6.10 VB\_IFR



| 0x0124 |    |    | Audi | o Cod | ec mo   | de con | trol |     | VB_IFR |          |                   |          |                 |                    |                          |                    |
|--------|----|----|------|-------|---------|--------|------|-----|--------|----------|-------------------|----------|-----------------|--------------------|--------------------------|--------------------|
| Bit    | 31 | 30 | 29   | 28    | 27      | 26     | 25   | 24  | 23     | 22       | 21                | 20       | 19              | 18                 | 17                       | 16                 |
| Name   |    |    |      |       |         |        |      | Res | erved  |          |                   |          |                 |                    |                          |                    |
| Туре   |    |    |      |       |         |        |      |     |        |          |                   |          |                 |                    |                          |                    |
| 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   |    |    |      |       | Reserve | d      |      |     |        | JAC<br>K | JAC<br>K_E<br>VEN | CC<br>MC | RAM P_U P_D ONE | RAM P_D OW N_D ONE | GAI<br>N_U<br>P_D<br>ONE | GAI N_D OW N_D ONE |
| Туре   |    | RO |      |       |         |        |      |     |        |          | R/W               | R/W      | 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                  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                |
|------------|--------|------|----------------|--------------------------------------------|
|            | [15:7] | RO   | 9'h0           | Reserved                                   |
| JACK       | [6]    | RO   | 1'h0           | Output Jack plug detection status          |
|            |        |      |                | Read                                       |
|            |        |      |                | 0 = no jack                                |
|            |        |      |                | 1 = output jack present                    |
| JACK_EVENT | [5]    | R/W  | 1'h0           | Event on output Jack plug detection status |
|            |        |      |                | Read                                       |
|            |        |      |                | 0 = no event                               |
|            |        |      |                | 1 = event detected                         |
| 0.4        |        |      |                | Write                                      |
|            |        |      |                | 1 = Reset of the flag                      |



| ССМС           | [4] | R/W | 1'h0 | Output short circuit detection status - Reserved for future use Read 0 = inactive 1 = indicates that a short circuit has been detected by the output stage. Write 1 = Update of the flag                                                   |
|----------------|-----|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RAMP_UP_DONE   | [3] | R/W | 1'h0 | End of output stage ramp up flag Read  1 = the ramp-up sequence is completed (output stage is active).  Write  1 = Reset of the flag                                                                                                       |
| RAMP_DOWN_DONE | [2] | R/W | 1'h0 | End of output stage ramp down flag Read  1 = the ramp-down sequence is completed (output stage in stand-by mode).  Write  1 = Reset of the flag                                                                                            |
| GAIN_UP_DONE   | [1] | R/W | 1'h0 | End of mute gain up sequence flag Read  1 = the mute sequence is completed, the DAC input signal is transmitted to the DAC path.  Write  1 = Reset of the flag                                                                             |
| GAIN_DOWN_DONE | [0] | R/W | 1'h0 | End of mute gain down sequence flag Bit Read  1 = the mute sequence is completed, a 0 DC signal is transmitted to the DAC path. Interpretation of any unspecified point is absolutely up to the designer of this Virtual Component.  Write |



|  | 1 = | Reset of the flag |
|--|-----|-------------------|

# 8.6.11 VB\_CGR1

| 0x0128 |    |                             | Audi | o Code | ec mo | de con | trol |    |           |    |    | VB_CGR1 |    |    |     |    |  |  |
|--------|----|-----------------------------|------|--------|-------|--------|------|----|-----------|----|----|---------|----|----|-----|----|--|--|
| Bit    | 31 | 30                          | 29   | 28     | 27    | 26     | 25   | 24 | 23        | 22 | 21 | 20      | 19 | 18 | 17  | 16 |  |  |
| Name   |    | Reserved                    |      |        |       |        |      |    |           |    |    |         |    |    |     |    |  |  |
| Туре   |    | 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   |    |                             |      | Rese   | erved |        |      |    | GODR GODL |    |    |         |    |    |     |    |  |  |
| Туре   | RO |                             |      |        |       |        |      |    |           | R/ | W  |         |    | R  | R/W |    |  |  |
| Reset  | 0  | 0                           | 0    | 0      | 0     | 0      | 0    | 0  | 0         | 0  | 0  | 0       | 0  | 0  | 0   | 0  |  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                     |
|------------|--------|------|----------------|-------------------------------------------------|
|            | [15:8] | RO   | 8'h0           | Reserved                                        |
| GODR       | [7:4]  | R/W  | 4'h0           | DAC mixing right channel gain programming value |
| GODL       | [3:0]  | R/W  | 4'h0           | DAC mixing left channel gain programming value  |

8.6.12 VB\_CGR2



| 0x012C |             |    | Audi | o Cod | ec mo | de con | trol |     |                         |    |     |    |    |     |    |    |  |  |
|--------|-------------|----|------|-------|-------|--------|------|-----|-------------------------|----|-----|----|----|-----|----|----|--|--|
| Bit    | 31          | 30 | 29   | 28    | 27    | 26     | 25   | 24  | 23                      | 22 | 21  | 20 | 19 | 18  | 17 | 16 |  |  |
| Name   |             |    |      |       |       |        |      | Res | erved                   |    |     |    |    |     |    |    |  |  |
| Туре   |             |    |      |       |       |        |      | F   | 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   |             |    |      | Rese  | erved |        |      |     | LRGOB/RLG Res erve GOBL |    |     |    |    |     |    |    |  |  |
| Туре   |             |    |      | R     | 0     |        |      |     | R/                      | W  | R/W |    |    | R/W |    |    |  |  |
| Reset  | 0 0 0 0 0 0 |    |      |       |       |        |      |     | 0                       | 0  | 0   | 0  | 0  | 1   | 0  | 0  |  |  |

| Field Name  | Bit    | Туре | Reset<br>Value | Description                                                                                                                                                          |
|-------------|--------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | [15:8] | RO   | 8'h0           | Reserved                                                                                                                                                             |
| LRGOB/RLGOB | [7:6]  | R/W  | 2'h0           | Line mixing gain coupling  00: Left and right channels gains are independent, respectively given by GOBL and GOBR  10: Left and right channels gain is given by GOBL |
|             |        |      |                | 01: Left and right channels gain is given by GOBR  11: Left and right channels gain is given by GOBL                                                                 |
| 60          | [5]    | R/W  | 1'h0           | Reserved                                                                                                                                                             |
| GOBL        | [4:0]  | R/W  | 5'h4           | Line mixing left channel gain programming value                                                                                                                      |

# 8.6.13 VB\_CGR3



| 0x0130 |                       | Audio Codec mode control    |    |    |    |         |    |    |    |    |    |      |     | VB_CGR3 |    |    |  |  |
|--------|-----------------------|-----------------------------|----|----|----|---------|----|----|----|----|----|------|-----|---------|----|----|--|--|
| Bit    | 31                    | 30                          | 29 | 28 | 27 | 26      | 25 | 24 | 23 | 22 | 21 | 20   | 19  | 18      | 17 | 16 |  |  |
| Name   |                       | Reserved                    |    |    |    |         |    |    |    |    |    |      |     |         |    |    |  |  |
| Туре   |                       | 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   |                       |                             |    |    |    | Reserve | d  |    |    |    |    | GOBR |     |         |    |    |  |  |
| Туре   | RO                    |                             |    |    |    |         |    |    |    |    |    |      | R/W |         |    |    |  |  |
| Reset  | 0 0 0 0 0 0 0 0 0 0 0 |                             |    |    |    |         |    |    |    |    | 0  | 0    | 0   | 1       | 0  | 0  |  |  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                      |
|------------|--------|------|----------------|--------------------------------------------------|
|            | [15:5] | RO   | 11'h0          | Reserved                                         |
| GOBR       | [4:0]  | R/W  | 5'h4           | Line mixing right channel gain programming value |

8.6.14 VB\_CGR8



| 0x0144 |               |    | Audi | o Cod | ec mo | de con | trol |     |                    |    |     |    |     |    | VB_0 | CGR8 |
|--------|---------------|----|------|-------|-------|--------|------|-----|--------------------|----|-----|----|-----|----|------|------|
| Bit    | 31            | 30 | 29   | 28    | 27    | 26     | 25   | 24  | 23                 | 22 | 21  | 20 | 19  | 18 | 17   | 16   |
| Name   |               |    |      |       |       |        |      | Res | erved              |    |     |    |     |    |      |      |
| Туре   |               | 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    |
|        |               |    |      |       |       |        |      |     |                    |    | Res |    |     |    |      |      |
| Name   |               |    |      | Rese  | erved |        |      |     | LRGO/RLGO erve GOL |    |     |    |     |    |      |      |
| Туре   |               |    |      | R     | .0    |        |      |     | R/W R/W R/W        |    |     |    | R/W |    |      |      |
| Reset  | 0 0 0 0 0 0 0 |    |      |       |       |        |      |     | 0                  | 0  | 0   | 0  | 1   | 0  | 1    | 0    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                          |
|------------|--------|------|----------------|--------------------------------------------------------------------------------------|
|            | [15:8] | RO   | 8'h0           | Reserved                                                                             |
| LRGO/RLGO  | [7:6]  | R/W  | 2'h0           | Output stages gain coupling                                                          |
|            |        |      |                | 00: Left and right channels gains are independent, respectively given by GOL and GOR |
|            |        |      |                | 10: Left and right channels gain is given by GOL                                     |
|            |        |      |                | 01: Left and right channels gain is given by GOR                                     |
|            |        |      |                | 11: Left and right channels gain is given by GOL                                     |
| 6          | [5]    | R/W  | 1'h0           | Reserved                                                                             |
| GOL        | [4:0]  | R/W  | 5'hA           | Output stage left channel gain programming value                                     |

# 8.6.15 VB\_CGR9



| 0x0148 |    |          | Audi | o Cod | ec mo | de con  | trol |    |    |    |    |    |    |     | VB_C | CGR9 |
|--------|----|----------|------|-------|-------|---------|------|----|----|----|----|----|----|-----|------|------|
| Bit    | 31 | 30       | 29   | 28    | 27    | 26      | 25   | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17   | 16   |
| Name   |    | Reserved |      |       |       |         |      |    |    |    |    |    |    |     |      |      |
| Туре   |    |          |      |       |       |         |      | F  | 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   |    |          |      |       | ı     | Reserve | d    |    |    |    |    |    |    | GOR |      |      |
| Туре   |    | RO R/W   |      |       |       |         |      |    |    |    |    |    |    |     |      |      |
| Reset  | 0  | 0        | 0    | 0     | 0     | 0       | 0    | 0  | 0  | 0  | 0  | 0  | 1  | 0   | 1    | 0    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                       |
|------------|--------|------|----------------|---------------------------------------------------|
|            | [15:5] | RO   | 11'h0          | Reserved                                          |
| GOR        | [4:0]  | R/W  | 5'hA           | Output stage right channel gain programming value |

8.6.16 VB CGR10



| 0x014C |    |                                              | Audi | o Cod | ec mo | de con | trol |   | VB_CGR10    |    |   |   |    |   |   |   |
|--------|----|----------------------------------------------|------|-------|-------|--------|------|---|-------------|----|---|---|----|---|---|---|
| Bit    | 31 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 |      |       |       |        |      |   |             |    |   |   | 16 |   |   |   |
| Name   |    | Reserved                                     |      |       |       |        |      |   |             |    |   |   |    |   |   |   |
| Туре   |    |                                              |      |       |       |        |      | F | 10          |    |   |   |    |   |   |   |
| 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   |    |                                              |      | Rese  | erved |        |      |   | GI Reserved |    |   |   |    |   |   |   |
| Туре   | RO |                                              |      |       |       |        |      |   |             | R/ | W |   |    | R | W |   |
| Reset  | 0  | 0                                            | 0    | 0     | 0     | 0      | 0    | 0 | 0           | 0  | 0 | 0 | 0  | 0 | 0 | 0 |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                    |
|------------|--------|------|----------------|------------------------------------------------|
|            | [15:8] | RO   | 8'h0           | Reserved                                       |
| GI         | [7:4]  | R/W  | 4'h0           | ADC channel PGATM input gain programming value |
|            | [3:0]  | R/W  | 4'h0           | Reserved                                       |

8.6.17 VB\_TR1



| 0x0150 |    |          | Audi | o Cod | ec mo | de con | trol |     |       |           |            |            |          |                 | VB       | _TR1            |
|--------|----|----------|------|-------|-------|--------|------|-----|-------|-----------|------------|------------|----------|-----------------|----------|-----------------|
| Bit    | 31 | 30       | 29   | 28    | 27    | 26     | 25   | 24  | 23    | 22        | 21         | 20         | 19       | 18              | 17       | 16              |
| Name   |    |          |      |       |       |        |      | Res | erved |           |            |            |          |                 |          |                 |
| Туре   |    |          |      |       |       |        |      | F   | 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   |    | Reserved |      |       |       |        |      |     |       | STB<br>YI | TST<br>DAC | TST<br>ADC | TES<br>T | STO<br>PUL<br>L | NOS<br>C | FAS<br>T_O<br>N |
| Туре   |    |          |      | R     | .0    |        |      |     | 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          | 0          | 0        | 0               | 0        | 0               |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                     |
|------------|--------|------|----------------|-----------------------------------------------------------------|
|            | [15:8] | RO   | 8'h0           | Reserved                                                        |
| STBYO      | [7]    | R/W  | 1'h0           | analog output stage power down mode 0: in normal mode           |
| STBYI      | [6]    | R/W  | 1'h0           | analog input stage power down mode  0: in normal mode           |
| TSTDAC     | [5]    | R/W  | 1'h0           | DAC analog test mode 0: in normal mode                          |
| TSTADC     | [4]    | R/W  | 1'h0           | ADC analog test mode 0: in normal mode                          |
| TEST       | [3]    | R/W  | 1'h0           | Test mode 0: in normal mode                                     |
| STOPULL    | [2]    | R/W  | 1'h0           | disables the input circuitry starting system  0: in normal mode |
| NOSC       | [1]    | R/W  | 1'h0           | Disable the output short circuit protection 0: in normal mode   |
| FAST_ON    | [0]    | R/W  | 1'h0           | Disables the pop reduction internal mechanisms                  |



|  |  | 0: in normal mode |
|--|--|-------------------|

## 8.6.18 VB\_TR2

### VB\_TR2 0x0154 **Audio Codec mode control** Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 Name Reserved RO Type 0 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 FAE FAE NEN UNS Rese NOD HIP NO\_ Name Reserved NDA NAD CO ΕM AS RST TBL rved C C MP R/W Type RO R/W R/W R/W R/W R/W R/W

0

0

0

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                                        |
|------------|--------|------|----------------|----------------------------------------------------------------------------------------------------|
|            | [15:8] | RO   | 8'h0           | Reserved                                                                                           |
| FAENDAC    | [7]    | R/W  | 1'h0           | Flow adapter command control bit (DAC path)  0: inactive  1: enables the flow adapter working mode |
| FAENDAC    | [6]    | R/W  | 1'h0           | Flow adapter command control bit (ADC path) 0: inactive 1: enables the flow adapter working mode   |
| NENCOMP    | [5]    | R/W  | 1'h0           | Biasing bit control 0: in normal mode                                                              |

Reset

0



|        | [4] | R/W | 1'h0 | Reserved                                       |
|--------|-----|-----|------|------------------------------------------------|
| NODEM  | [3] | R/W | 1'h0 | DAC DEM control                                |
|        |     |     |      | 0: in normal mode                              |
| HIPAS  | [2] | R/W | 1'h0 | ADC NTF test control                           |
|        |     |     |      | 0: in normal mode                              |
| NO_RST | [1] | R/W | 1'h0 | ADC auto reset control                         |
|        |     |     |      | 0: in normal mode                              |
| UNSTBL | [0] | R/W | 1'h0 | disables the pop reduction internal mechanisms |
|        |     |     |      | 0: in normal mode                              |

# 8.7 Application Note

### 8.7.1 ARM Control Mode

If the audio system is controlled by ARM, the following programming flow is recommended:

- Enable VBC and ADI module by setting global register GEN0(0x8B00\_0008) bit [23] and bit [6]. Enable and select ADI clock by configuring global register CLK\_DLY\_CTRL(0x8B00\_005C) bit [29:28].
- Turn on LDO\_VB by setting ARM side global control register LDO\_PD\_CTL (0x8200\_0490) bit [14] through ADI.
- Enable ARM access Audio Codec and MCLK of Audio Codec by setting ARM side global control register CLK\_CTL(0x8200\_0488) bit [2:1] through ADI.
- Enable ARM access VBC and necessary audio channels (ADC/DAC0/DAC1) by programming global register BUSCLK (0x8B00\_0044) bit [7:1]
- Program buffer size of AD and DA in register VBBUFFSIZE (0x8200\_3010). If needed, program all necessary modes in register VBADBUFFDTA (0x8200\_3014).



- 6. Set bit [10] of register VBDABUFFDTA (0x8200\_3018) to enable software initialization of both of the DAC0 and DAC1 ping-pong buffers. Set bit [9] to write buffer 1 and reset bit [9] to write buffer 0.
- 7. Program necessary VBC path control and HPF control registers.
- 8. Program necessary control registers of the audio codec.
- Reset bit [10] and bit [9] of register VBDABUFFDTA to finish the software initialization, and then set bit [15] to enable the voice band process.
- 10. Wait for interrupt. The interrupt status can be read from global control register INT\_CTRL (0x8B00\_0010) bits [6:5]. If AD interrupt got, clear it by writing global control register ICLR (0x8B00\_0014) bit [5] and read AD data from VBC interface control register VBAD0 (0x8200\_3008), and the totally data number is buffer size programmed at step 2. Then wait for the next AD interrupt. If DA interrupt got, clear it by writing global control register INT\_CLR (0x8B00\_0014) bit [6] and write another block of data, the number of which is also the buffer size, to VBC interface control register VBDA0 (0x8200\_3000) and VBDA1 (0x8200\_3004). Then wait for the next DA interrupt.

### 8.7.2 DSP Control Mode

If the audio system is controlled by DSP, the following programming flow is recommended:

- Enable STC, VBC and ADI module by setting PMU register PLL\_CFG0 (0x0013\_0000) bit [26], bit [22] and bit [7]. Enable ADI HCLK by resetting PMU register XHPMOD(0x0013\_0018) bit [9].
- 2. Turn on LDO\_VB by setting ARM side global control register LDO\_PD\_CTL (0x8200\_0490) bit [14] through ADI.
- 3. Enable MCLK of Audio Codec by setting DSP side global control register DSP\_CTL(0x007F\_0528) bit [0] through ADI.
- Enable necessary audio channels (ADC/DAC0/DAC1) by programming STC control register FORCE\_PD (0x0064\_0294) bits [8:4].
- Program buffer size of AD and DA in register VBBUFFSIZE (0x0063\_0008). If needed, program all necessary modes in register VBADBUFFDTA (0x0063\_000A).
- 6. Set bit [10] of register VBDABUFFDTA (0x0063\_000C) to enable software initialization of both of the DAC0 and DAC1 ping-pong buffers. Set bit [9] to write buffer 1 and reset bit [9] to write buffer 0.
- 7. Program necessary VBC path control and HPF control registers



- 8. Program necessary control registers of the audio codec.
- Enable DAC interrupt by setting STC control register CLK\_AGC\_LDO (0x0064\_02BE) bit [5].
- Reset bit [10] and bit [9]of register VBDABUFFDTA to finish the software initialization, and then set bit [15] to enable the voice band process.
- 11. Wait for interrupt. The interrupt status can be read from ICU control register ISR\_1 (0x0013\_0404) bit [4] and bit [5]. If AD interrupt comes, clear it by writing ICU control register ICR\_1 (0x0013\_040C) bit [4] and read AD data from VBC interface control register VBAD0 (0x0063\_0004), and the total data number is the buffer size programmed at step 2. Then wait for the next AD interrupt. If DA interrupt comes, clear it by writing ICU control register ICR\_1 (0x0013\_040C) bit [5] and write another block of data, the number of which is also the buffer size, to VBC interface control register VBDA0 (0x0063\_0000) and VBDA1 (0x0063\_0002). Then wait for the next DA interrupt.

### 8.7.3 DMA Controlling Mode

If the audio system is controlled by ARM DMA, the following programming flow is recommended:

- Enable VBC and ADI module by setting global register GEN0(0x8B00\_0008) bit [23] and bit [6]. Enable and select ADI clock by configuring global register CLK\_DLY\_CTRL(0x8B00\_005C) bit [29:28].
- 2. Turn on LDO\_VB by setting ARM side global control register LDO PD CTL (0x8200 0490) bit [14] through ADI.
- Enable MCLK of Audio Codec by setting DSP side global control register DSP\_CTL(0x007F\_0528) bit [0] through ADI.
- 4. Enable necessary audio channels (ADC/DAC0/DAC1) by programming STC control register FORCE\_PD (0x0064\_0294) bits [8:4].
- Program buffer size of AD and DA in register VBBUFFSIZE (0x8200\_3010). If needed, program all necessary modes in register VBADBUFFDTA (0x8200\_3014).
- 6. Set bit [10] of register VBDABUFFDTA (0x8200\_3018) to enable software initialization (clearing zero is recommended) of both DAC0 and DAC1 ping-pong buffers. Set bit [9] to write buffer 1 and reset bit [9] to write buffer 0.



- Enable DMA by setting AHB general control register AHB\_CTL0
   (0x2090\_0200) bit [6], and then enable the three DMA channels
   respectively for VBC ADC, DAC0 and DAC1, by setting DMA control
   register DMA\_Chn\_En bits [12:10].
- 8. Program necessary control registers of the audio codec.
- Enable DMA All\_int by setting DMA control register
   TRANS\_DONE\_EN(0x2010\_0048) bits [12:10] for the three channels,
   and enable DMA interrupt in Interrupt control register INTCV\_INT\_EN
   (0x8000\_3008) bit [21]. Disable VBC interrupt by setting Interrupt
   control register INTCV\_INT\_EN\_CLR(0x8000\_300C) bit [22].
- Write first block of DAC data (the number of which is integral times of buffer size) into DMA DAC0 and DAC1 source memory.
- Program DMA VBC DAC0 channel control registers 0x2010\_0540 ~ 0x2010\_055C, DAC1 channel control registers 0x2010\_0560 ~ 0x2010\_057C, and ADC0 channel control registers 0x2010\_0580 ~ 0x2010\_059C.
- 12. Enable DMA access to VBC ping-pong buffers of three channels by setting VBC control register VBDABUFFDTA (0x8200\_3018) bits [14], [13] and [11], Reset bit [10] and bit [9] of register VBDABUFFDTA and set bit [15] to enable the voice band process.
- 13. Wait for DMA all transfer finish interrupt. ADC0, DAC0 and DAC1 channel interrupt status can be checked by reading DMA control register TRANS\_DONE\_RAW(0x2010\_0068) bits [12:10]. Clear interrupt of the DMA three channels by setting DMA control register TRANS\_DONE\_CLR (0x2010\_0078) bits [12:10].
- 14. For ADC channel, ARM reads ADC data (the number of which is integral times of buffer size) from DMA ADC0 destination memory, and then program DMA ADC0 channel control registers for the next block. For DAC channels, ARM write next block of DAC data (integral times of buffer size) into DMA DAC0 and DAC1 source memory, and then program DMA DAC0 and DAC1 channel control registers for the next block.
- 15. Repeat steps 10 and 11 until all ADC data are received by ARM, and all DAC data are sent by ARM. Especially for DAC, ARM should wait for the last two interrupts of VBC. After clearing the last DMA DAC0 and DAC1 interrupts, first clear previous VBC interrupt, and then enable VBC interrupt in Interrupt controller by setting Interrupt control register 0x8000\_300C bit [22]. Wait for VBC interrupt, and check if the two DAC channels both finished by reading global register INT\_CTRL (0x8B00\_0010) bit [6]. Clear the VBC DAC interrupt by setting global



control register INT\_CLR ( 0x8B00\_0014) bit [6]. Repeat once more for the last VBC DAC interrupt.



# 9 Power Management

### 9.1 Overview

SC6820 integrated power management unit supports direct connection to battery, which means all supply voltages are generated on-chip with integrated linear voltage regulators and DC-DC. The input of these linear voltage regulators is from the battery.

PMU contains the following blocks:

- I 25 LDOs.
- I 2 DCDC, which supply the digital power
- I Battery charger, which can be used with lithium ion batteries.
- I Three current sinks for keypad LED, white LED and vibrator control.
- I Under/UP Voltage Lock-out Protection
- I Over Temperature Protection
- I Band-gap
- I Power-on reset generator

The integrated power management also provides sophisticated controls for system startup, including start-up with discharged batteries, trickle charging and system reset control. The flexible clock switching options allow minimizing the power consumption during the operation phases. Current consumption in the deep sleep mode is minimized by reducing the clock frequency to 32 kHz and switching most LDOs off for maximum battery life.







### Figure 9-1 SC6820 PMU Architecture

Note1: When VBATLOW signal is high, chip is powered off.

# 9.2 LDO and DC-DC

SC6820 integrated low-voltage and low quiescent current low dropout regulators (LDO) for power supply and power management purposes. Some extra LDO regulators are designed for external use. All LDOs have their own bypass (power-down) control signals. External tantalum or MLCC ceramic capacitors are recommended to use with the LDOs. SC6820 also intergrated DC-DC as digital power supply. The brief specifications are listed below.

Table 9-1 Performance of the integrated LDO regulators

| Parameter                  | Comments                                 | Min | Typical | Max | Unit |
|----------------------------|------------------------------------------|-----|---------|-----|------|
| External Memory Vol        | tage(VDDMEM)                             |     |         |     |      |
| Status after reset         | on                                       |     |         |     |      |
| Application                | SDRAM                                    |     |         |     |      |
| Output Voltage             | 0(default)                               | 1.7 | 1.8     | 1.9 | V    |
| Output Current             |                                          |     |         | 300 | mA   |
| Line regulation            | Vi=3.6V-4.2V;Io=100mA;                   | 5   | 10      | 20  | mV   |
| Line Transient<br>Response | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 25  | 50      | 75  | mV   |
| Load regulation            | Vi=3.8V; Io=0-200mA;                     | 25  | 50      | 75  | mV   |
| Load Transient<br>Response | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 30  | 60      | 90  | mV   |
| PSRR                       | F=217Hz,lo=100mA,                        | 36  | 40      | 50  | dB   |
| Три                        | Supply ramp from 0 to 3.6v in 10μs       | 50  | 85      | 120 | us   |
| Tpd                        | Vo=0.1V (lout=lmax/2)                    | 50  | 80      | 120 | us   |
| Isleep                     | Io=0mA                                   | 8   | 10      | 20  | uA   |



| Parameter                    | Comments                                 | Min  | Typical | Max  | Unit |
|------------------------------|------------------------------------------|------|---------|------|------|
| Cext                         | External cap                             | 2.2  | 2.2     | 4.7  | uF   |
| Digital 2.8V IO Volta        | age(VDD28)                               | •    | •       |      | 1    |
| Status after reset           | on                                       |      |         |      |      |
| Application                  | IO/ NAND Flash/LCM                       |      |         |      |      |
| Output Voltage               | 00(default)                              | 2.7  | 2.8     | 2.9  | V    |
|                              | 01                                       | 2.9  | 3.0     | 3.1  | V    |
|                              | 10                                       | 2.55 | 2.65    | 2.75 | V    |
|                              | 11                                       | 1.75 | 1.8     | 1.85 | V    |
| Output Current               |                                          |      | CA      | 200  | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=100mA;                   | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 15   | 25      | 50   | mV   |
| Load Regulation              | Vi=3.8V; Io=0-200mA;                     | 30   | 50      | 75   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 30   | 50      | 75   | mV   |
| Short current limit          |                                          | 75   | 90      | 120  | mA   |
| Current limit                | Vi=3.8V                                  | 410  | 480     | 640  | mA   |
| PSRR                         | F=217Hz,lo=100mA,                        | 36   | 40      | 50   | dB   |
| Три                          | Supply ramp from 0 to 3.6v in 10μs       | 80   | 100     | 120  | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                    | 200  | 300     | 400  | us   |
| Isleep                       | lo=0mA                                   | 12   | 15      | 25   | uA   |
| Cext                         | External cap                             | 2.2  | 2.2     | 4.7  | uF   |
| Digital 1.8V IO Volta        | age(VDD18)                               |      |         |      |      |
| Status after reset           | on                                       |      |         |      |      |
| Application                  | IO/ NAND Flash/LCM                       |      |         |      |      |
| Output Voltage               | 00(default)                              | 1.75 | 1.8     | 1.85 | V    |
|                              | 01                                       | 2.7  | 2.8     | 2.9  | V    |
|                              | 10                                       | 1.45 | 1.5     | 1.55 | V    |



| Parameter                    | Comments                                 | Min  | Typical | Max  | Unit |
|------------------------------|------------------------------------------|------|---------|------|------|
|                              | 11                                       | 1.15 | 1.2     | 1.25 | ٧    |
| Output Current               |                                          |      |         | 200  | mA   |
| Line Regulation              | Vi=3.6V-4.2V;Io=100mA;                   | 6    | 12      | 24   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 10   | 20      | 30   | mV   |
| Load regulation              | Vi=3.8V; Io=0-200mA;                     | 30   | 60      | 90   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 30   | 60      | 90   | mV   |
| Short current limit          |                                          | 75   | 90      | 120  | mA   |
| Current limit                | Vi=3.8V                                  | 410  | 480     | 640  | mA   |
| PSRR                         | F=217Hz,lo=100mA,                        | 36   | 40      | 50   | dB   |
| Три                          | Supply ramp from 0 to 3.6v in 10µs       | 90   | 150     | 225  | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                    | 90   | 150     | 225  | us   |
| Isleep                       | Io=0mA                                   | 10   | 15      | 25   | uA   |
| Cext                         |                                          | 2.2  | 2.2     | 4.7  | uF   |
| LDO for RF0(VDDRF            | 0)                                       |      |         |      |      |
| Status after reset           | on                                       |      |         |      |      |
| Application                  | RF/TCXO                                  |      |         |      |      |
| Output Voltage               | 00(default)                              | 2.75 | 2.85    | 2.95 | V    |
|                              | 01                                       | 2.85 | 2.95    | 3.05 | V    |
|                              | 10                                       | 2.65 | 2.75    | 2.85 | V    |
|                              | 11                                       | 1.75 | 1.8     | 1.85 | V    |
| Output Current               |                                          |      |         | 200  | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=100mA;                   | 3    | 5       | 10   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 5    | 10      | 20   | mV   |
| Load regulation              | Vi=3.8V; Io=0-200mA;                     | 25   | 50      | 75   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 25   | 50      | 75   | mV   |



| Parameter                 | Comments                                 | Min  | Typical | Max  | Unit |
|---------------------------|------------------------------------------|------|---------|------|------|
| PSRR                      | F=217Hz,lo=100mA,                        | 48   | 60      | 72   | dB   |
| Tpu                       | Supply ramp from 0 to 3.6v in 10μs       | 30   | 50      | 75   | us   |
| Tpd                       | Vo=0.1V (lout=lmax/2)                    | 110  | 160     | 240  | us   |
| Isleep                    | Io=0mA                                   | 30   | 40      | 55   | uA   |
| Cext                      |                                          | 2.2  | 2.2     | 4.7  | uF   |
| LDO for RF1 (VDDR         | F1)                                      |      |         |      |      |
| Status after reset        | off                                      |      |         | A    |      |
| Application               | Supply for external terminal             |      |         |      |      |
| Output Voltage            | 00(default)                              | 2.75 | 2.85    | 2.95 | V    |
|                           | 01                                       | 2.85 | 2.95    | 3.05 | V    |
|                           | 10                                       | 2.4  | 2.5     | 2.6  | V    |
|                           | 11                                       | 1.75 | 1.8     | 1.85 | V    |
| Output Current            |                                          |      |         | 200  | mA   |
| Line regulation           | Vi=3.6V-4.2V;lo=100mA;                   | 3    | 5       | 10   | mV   |
| Line Transient Regulation | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 5    | 10      | 20   | mV   |
| Load regulation           | Vi=3.8V; Io=0-100mA;                     | 25   | 50      | 75   | mV   |
| Load Transient Regulation | Vi=3.8V; Io=0-100mA;Co=2.2uF;<br>Tr=10us | 25   | 50      | 75   | mV   |
| PSRR                      | F=217Hz,lo=100mA,                        | 48   | 60      | 72   | dB   |
| Три                       | Supply ramp from 0 to 3.6v in 10µs       | 30   | 50      | 75   | us   |
| Tpd                       | Vo=0.1V (lout=lmax/2)                    | 96   | 160     | 240  | us   |
| Isleep                    | Io=0mA                                   | 32   | 40      | 55   | uA   |
| Cext                      |                                          | 2.2  | 2.2     | 4.7  | uF   |
| Digital SDIO0 Voltag      | ge (VDDSD0)                              | •    |         |      |      |
| Status after reset        | off                                      |      |         |      |      |
| Application               | SD Card                                  |      |         |      |      |
| Output Voltage            | 00(default)                              | 2.7  | 2.8     | 2.9  | V    |



| _                            |                                       |     |         |     |      |
|------------------------------|---------------------------------------|-----|---------|-----|------|
| Parameter                    | Comments                              | Min | Typical | Max | Unit |
|                              | 01                                    | 2.9 | 3.0     | 3.1 | V    |
|                              | 10                                    | 2.4 | 2.5     | 2.6 | V    |
|                              | 11                                    | 1.7 | 1.8     | 1.9 | V    |
| Output Current               |                                       |     |         | 150 | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                 | 5   | 10      | 20  | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us          | 15  | 30      | 45  | mV   |
| Load regulation              | Vi=3.8V; Io=0-50mA;                   | 15  | 30      | 45  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-50mA;Co=1uF;<br>Tr=10us | 25  | 50      | 75  | mV   |
| Short current limit          |                                       | 75  | 90      | 120 | mA   |
| Current limit                | Vi=3.8V                               | 410 | 480     | 640 | mA   |
| PSRR                         | F=217Hz,lo=50mA,                      | 36  | 40      | 50  | dB   |
| Три                          | Supply ramp from 0 to 3.6v in 10µs    | 20  | 35      | 50  | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                 | 110 | 180     | 270 | us   |
| Isleep                       | Io=0mA                                | 16  | 20      | 30  | uA   |
| Cext                         |                                       | 1   | 2.2     | 4.7 | uF   |
| Digital SDIO1 Voltag         | e (VDDSD1)                            | ı   |         |     |      |
| Status after reset           | off                                   |     |         |     |      |
| Application                  | SD Card                               |     |         |     |      |
| Output Voltage               | 00(default)                           | 2.7 | 2.8     | 2.9 | V    |
|                              | 01                                    | 2.9 | 3.0     | 3.1 | ٧    |
| 0.9                          | 10                                    | 2.4 | 2.5     | 2.6 | ٧    |
|                              | 11                                    | 1.7 | 1.8     | 1.9 | ٧    |
| Output Current               |                                       |     |         | 150 | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                 | 5   | 10      | 20  | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us          | 15  | 30      | 45  | mV   |
| Load regulation              | Vi=3.8V; Io=0-50mA;                   | 15  | 30      | 45  | mV   |



| Parameter                    | Comments                              | Min  | Typical | Max  | Unit |  |  |  |
|------------------------------|---------------------------------------|------|---------|------|------|--|--|--|
| Load Transient<br>Regulation | Vi=3.8V; Io=0-50mA;Co=1uF;<br>Tr=10us | 25   | 50      | 75   | mV   |  |  |  |
| Short current limit          |                                       | 75   | 90      | 120  | mA   |  |  |  |
| Current limit                | Vi=3.8V                               | 410  | 480     | 640  | mA   |  |  |  |
| PSRR                         | F=217Hz,lo=50mA,                      | 36   | 40      | 50   | dB   |  |  |  |
| Tpu                          | Supply ramp from 0 to 3.6v in 10μs    | 20   | 35      | 50   | us   |  |  |  |
| Tpd                          | Vo=0.1V (lout=lmax/2)                 | 110  | 180     | 270  | us   |  |  |  |
| Isleep                       | Io=0mA                                | 16   | 20      | 30   | uA   |  |  |  |
| Cext                         |                                       | 1    | 2.2     | 4.7  | uF   |  |  |  |
| General LDO(VDDC             | General LDO(VDDCAMD0)                 |      |         |      |      |  |  |  |
| Status after reset           | off                                   |      |         |      |      |  |  |  |
| Application                  | Supply for external sensor            |      |         |      |      |  |  |  |
| Output Voltage               | 00(default)                           | 1.75 | 1.8     | 1.85 | V    |  |  |  |
|                              | 01                                    | 2.7  | 2.8     | 2.9  | V    |  |  |  |
|                              | 10                                    | 1.45 | 1.5     | 1.55 | ٧    |  |  |  |
|                              | 11                                    | 1.25 | 1.3     | 1.35 | ٧    |  |  |  |
| Output Current               |                                       |      |         | 100  | mA   |  |  |  |
| Line regulation              | Vi=3.6V-4.2V;lo=50mA;                 | 5    | 10      | 20   | mV   |  |  |  |
| Line Transient Regulation    | Vi=3.6V-4.2V;Io=50mA;Tr=10us          | 10   | 20      | 30   | mV   |  |  |  |
| Load regulation              | Vi=3.8V; Io=0-50mA;                   | 15   | 30      | 45   | mV   |  |  |  |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-50mA;Co=1uF;<br>Tr=10us | 15   | 30      | 45   | mV   |  |  |  |
| PSRR                         | F=217Hz,lo=50mA,                      | 36   | 40      | 50   | dB   |  |  |  |
| Tpu                          | Supply ramp from 0 to 3.6v in 10μs    | 12   | 20      | 30   | us   |  |  |  |
| Tpd                          | Vo=0.1V (lout=lmax/2)                 | 110  | 180     | 270  | us   |  |  |  |
| Isleep                       | Io=0mA                                | 16   | 20      | 30   | uA   |  |  |  |
| Cext                         |                                       | 1    | 1       | 2.2  | uF   |  |  |  |



| Parameter                    | Comments                              | Min  | Typical | Max  | Unit |
|------------------------------|---------------------------------------|------|---------|------|------|
| General LDO (VDDC            | AMDA)                                 |      |         |      |      |
| Status after reset           | off                                   |      |         |      |      |
| Application                  | Supply for external sensor            |      |         |      |      |
| Output Voltage               | 00(default)                           | 2.7  | 2.8     | 2.9  | ٧    |
|                              | 01                                    | 2.9  | 3.0     | 3.1  | ٧    |
|                              | 10                                    | 2.4  | 2.5     | 2.6  | V    |
|                              | 11                                    | 1.7  | 1.8     | 1.9  | V    |
| Output Current               |                                       |      |         | 150  | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=80mA;                 | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=80mA;Tr=10us          | 10   | 20      | 30   | mV   |
| Load regulation              | Vi=3.8V; Io=0-80mA;                   | 15   | 30      | 45   | mV   |
| Load Transient               | Vi=3.8V; Io=0-80mA;Co=1uF;            | 15   | 30      | 45   | mV   |
| Regulation                   | Tr=10us                               |      |         |      |      |
| PSRR                         | F=217Hz,lo=50mA,                      | 36   | 40      | 50   | dB   |
| Cext                         |                                       | 1    | 1       | 2.2  | uF   |
| General LDO (VDDC            | AMD1)                                 |      |         |      |      |
| Status after reset           | off                                   |      |         |      |      |
| Application                  | Supply for external sensor            | •    | _       |      |      |
| Output Voltage               | 00(default)                           | 2.7  | 2.8     | 2.9  | V    |
|                              | 01                                    | 3.2  | 3.3     | 3.4  | V    |
|                              | 10                                    | 1.75 | 1.8     | 1.85 | V    |
|                              | 11                                    | 1.15 | 1.2     | 1.25 | V    |
| Output Current               |                                       |      |         | 100  | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                 | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us          | 10   | 20      | 30   | mV   |
| Load regulation              | Vi=3.8V; Io=0-50mA;                   | 15   | 30      | 45   | mV   |
| Load Transient Regulation    | Vi=3.8V; Io=0-50mA;Co=1uF;<br>Tr=10us | 15   | 30      | 45   | mV   |



| a gor nerto mom          |                                    |        |         |      | <u> </u> |
|--------------------------|------------------------------------|--------|---------|------|----------|
| Parameter                | Comments                           | Min    | Typical | Max  | Unit     |
| PSRR                     | F=217Hz,lo=50mA,                   | 36     | 40      | 50   | dB       |
| Три                      | Supply ramp from 0 to 3.6v in 10μs | 12     | 20      | 30   | us       |
| Tpd                      | Vo=0.1V (lout=lmax/2)              | 110    | 180     | 270  | us       |
| Isleep                   | Io=0mA                             | 16     | 20      | 30   | uA       |
| Cext                     |                                    | 1      | 1       | 2.2  | uF       |
| Small battery and Re     | eal time clock LDO (VDDBK and V    | DDRTC) |         |      |          |
| Status after reset       | On                                 |        |         | X    |          |
| Application              | Supply for small battery and RTC   |        |         |      |          |
| VBATBK Output<br>Voltage | 00                                 | 2.45   | 2.6     | 2.75 | V        |
|                          | 01 (default)                       | 2.65   | 2.8     | 2.95 | V        |
|                          | 10                                 | 2.85   | 3.0     | 3.15 | V        |
|                          | 11                                 | 3.05   | 3.2     | 3.35 | V        |
| VBATBK output resistor   | 00 (default)                       | 160    | 200     | 240  | Ω        |
|                          | 01                                 | 400    | 500     | 600  | Ω        |
|                          | 10                                 | 1200   | 1500    | 1800 | Ω        |
|                          | 11                                 | 1600   | 2000    | 2400 | Ω        |
| VDDRTC Output<br>Voltage | 00(default)                        | 1.75   | 1.8     | 1.85 | V        |
|                          | 01                                 | 1.65   | 1.7     | 1.75 | V        |
|                          | 10                                 | 1.55   | 1.6     | 1.65 | V        |
| ~0                       | 11                                 | 1.45   | 1.5     | 1.55 | V        |
| Output Current           |                                    |        |         | 1    | mA       |
| Line regulation          | Vi=3.6V-4.2V;Io=0.2mA;             | 8      | 15      | 30   | mV       |
| Load regulation          | Vi=3.8V; Io=0-0.2mA                | 5      | 10      | 20   | mV       |
| Три                      | Supply ramp from 0 to 3.6v in 10μs | 50     | 80      | 120  | us       |
| Isleep                   | Vbat                               | 15     | 18      | 24   | uA       |



| Parameter                    | Comments                              | Min  | Typical | Max   | Unit |  |  |  |
|------------------------------|---------------------------------------|------|---------|-------|------|--|--|--|
|                              | Vbuk                                  | 10   | 11.5    | 17    | uA   |  |  |  |
| Cext                         |                                       | 0.01 | 0.01    | 0.047 | uF   |  |  |  |
| SIMO LDO (VSIM0)             |                                       |      |         |       |      |  |  |  |
| Status after reset           | On                                    |      |         |       |      |  |  |  |
| Application                  | Supply for SIM Card                   |      |         |       |      |  |  |  |
| Output Voltage               | 00(default)                           | 1.7  | 1.8     | 1.9   | V    |  |  |  |
|                              | 01                                    | 2.8  | 2.9     | 3.0   | V    |  |  |  |
|                              | 10                                    | 2.9  | 3.0     | 3.1   | V    |  |  |  |
|                              | 11                                    | 3.0  | 3.1     | 3.2   | ٧    |  |  |  |
| Output Current               |                                       |      |         | 60    | mA   |  |  |  |
| Line regulation              | Vi=3.6V-4.2V;Io=30mA;                 | 5    | 10      | 20    | mV   |  |  |  |
| Line Transient Regulation    | Vi=3.6V-4.2V;Io=30mA;Tr=10us          | 10   | 20      | 30    | mV   |  |  |  |
| Load regulation              | Vi=3.8V; Io=0-30mA;                   | 15   | 30      | 45    | mV   |  |  |  |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=1uF;<br>Tr=10us | 15   | 30      | 45    | mV   |  |  |  |
| Short current limit          |                                       | 25   | 30      | 45    | mA   |  |  |  |
| Current limit                | Vi=3.8V                               | 120  | 150     | 225   | mA   |  |  |  |
| PSRR                         | F=217Hz,lo=30mA,                      | 36   | 40      | 50    | dB   |  |  |  |
| Три                          | Supply ramp from 0 to 3.6v in 10µs    | 60   | 100     | 150   | us   |  |  |  |
| Tpd                          | Vo=0.1V (lout=lmax/2)                 | 150  | 250     | 375   | us   |  |  |  |
| Isleep                       | Io=0mA                                | 12   | 15      | 23    | uA   |  |  |  |
| Cext                         |                                       | 1    | 1       | 2.2   | uF   |  |  |  |
| SIM1 LDO (VSIM1)             |                                       | •    | •       |       | •    |  |  |  |
| Status after reset           | Off                                   |      |         |       |      |  |  |  |
| Application                  | Supply for SIM Card                   |      |         |       |      |  |  |  |
| Output Voltage               | 00(default)                           | 1.7  | 1.8     | 1.9   | V    |  |  |  |
|                              | 01                                    | 2.8  | 2.9     | 3.0   | V    |  |  |  |
|                              | 10                                    | 2.9  | 3.0     | 3.1   | V    |  |  |  |



| Parameter                    | Comments                                | Min     | Typical | Max | Unit |
|------------------------------|-----------------------------------------|---------|---------|-----|------|
|                              | 11                                      | 3.0     | 3.1     | 3.2 | V    |
| Output Current               |                                         |         |         | 60  | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=30mA;                   | 5       | 10      | 20  | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=30mA;Tr=10us            | 10      | 20      | 30  | mV   |
| Load regulation              | Vi=3.8V; Io=0-30mA;                     | 15      | 30      | 45  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=1uF;<br>Tr=10us   | 15      | 30      | 45  | mV   |
| Short current limit          |                                         | 25      | 30      | 45  | mA   |
| Current limit                | Vi=3.8V                                 | 120     | 150     | 225 | mA   |
| PSRR                         | F=217Hz,lo=30mA,                        | 36      | 40      | 50  | dB   |
| Три                          | Supply ramp from 0 to 3.6v in 10μs      | 60      | 100     | 150 | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                   | 150     | 250     | 375 | us   |
| Isleep                       | Io=0mA                                  | 12      | 15      | 23  | uA   |
| Cext                         |                                         | 1       | 1       | 2.2 | uF   |
| Analog BB Voltage(A          | AVDDBB)                                 |         |         |     |      |
| Status after reset           | On                                      |         |         |     |      |
| Application                  | Supply for BB circuit, for example      | ADC/DAC | C//APC  |     |      |
| Output Voltage               | 00(default)                             | 2.9     | 3.0     | 3.1 | V    |
|                              | 01                                      | 3.0     | 3.1     | 3.2 | V    |
|                              | 10                                      | 2.8     | 2.9     | 3.0 | V    |
|                              | 11                                      | 2.7     | 2.8     | 2.9 | V    |
| Output Current               |                                         |         |         | 60  | mA   |
| Line regulation              | Vi=3.6V-4.2;Io=50mA;                    | 3       | 5       | 10  | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2;Io=50mA;Tr=10us             | 5       | 10      | 20  | mV   |
| Load regulation              | Vi=3.8V; Io=0-100mA;                    | 15      | 30      | 60  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-50mA;Co=2.2uF;<br>Tr=10us | 25      | 50      | 100 | mV   |



| SC8810 Design S           |                                        |     |         |     |      |  |
|---------------------------|----------------------------------------|-----|---------|-----|------|--|
| Parameter                 | Comments                               | Min | Typical | Max | Unit |  |
| PSRR                      | F=217Hz,lo=50mA,                       | 48  | 60      | 72  | dB   |  |
| Tpu                       | Supply ramp from 0 to 3.6v in 10μs     | 36  | 60      | 90  | us   |  |
| Tpd                       | Vo=0.1V (lout=Imax/2)                  | 90  | 150     | 225 | us   |  |
| Isleep                    | Io=0mA                                 | 32  | 40      | 60  | uA   |  |
| Cext                      |                                        | 2.2 | 2.2     | 4.7 | uF   |  |
| Analog VB Voltage(        | (AVDDVB)                               |     |         | _ ( |      |  |
| Status after reset        | Off                                    |     |         | A   |      |  |
| Application               | VB analog/VB output                    |     |         |     |      |  |
| Output Voltage            | 00(default)                            | 3.2 | 3.3     | 3.4 | V    |  |
|                           | 01                                     | 3.3 | 3.4     | 3.5 | V    |  |
|                           | 10                                     | 3.1 | 3.2     | 3.3 | ٧    |  |
|                           | 11                                     | 2.8 | 2.9     | 3.0 | ٧    |  |
| Output Current            |                                        |     |         | 100 | mA   |  |
| Line regulation           | Vi=3.6V-4.2V;Io=50mA;                  | 3   | 5       | 10  | mV   |  |
| Line Transient Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us           | 5   | 10      | 20  | mV   |  |
| Load regulation           | Vi=3.8V; Io=0-100mA;                   | 8   | 15      | 30  | mV   |  |
| Load Transient Regulation | Vi=3.8V; Io=0-50mA;Co=4.7F;<br>Tr=10us | 25  | 50      | 75  | mV   |  |
| PSRR                      | F=217Hz,lo=50mA,                       | 48  | 60      | 72  | dB   |  |
| Три                       | Supply ramp from 0 to 3.6v in 10μs     | 30  | 50      | 75  | us   |  |
| Tpd                       | Vo=0.1V (lout=lmax/2)                  | 210 | 350     | 500 | us   |  |
| Isleep                    | Io=0mA                                 | 32  | 40      | 60  | uA   |  |
| Cext                      |                                        | 2.2 | 2.2     | 4.7 | uF   |  |
| USB High Voltage(\        | /DDUSBH)                               |     |         |     |      |  |
| Status after reset        | Off                                    |     |         |     |      |  |
| Application               | USB IP                                 |     |         |     |      |  |
| Output Voltage            | 00 (default)                           | 3.2 | 3.3     | 3.4 | V    |  |
|                           | •                                      | -   |         |     |      |  |



| Parameter                    | Comments                                | Min  | Typical | Max  | Unit |
|------------------------------|-----------------------------------------|------|---------|------|------|
|                              | 01                                      | 3.3  | 3.4     | 3.5  | ٧    |
|                              | 10                                      | 3.1  | 3.2     | 3.3  | V    |
|                              | 11                                      | 3.0  | 3.1     | 3.2  | V    |
| Output Current               |                                         |      |         | 60   | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                   | 5    | 10      | 20   | mV   |
| Line Transient Regulation    | Vi=3.6V-4.2V;Io=50mA;Tr=10us            | 10   | 20      | 40   | mV   |
| Load regulation              | Vi=3.8V; Io=0-30mA;                     | 15   | 30      | 60   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=2.2uF;<br>Tr=10us | 15   | 30      | 60   | mV   |
| PSRR                         | F=217Hz,lo=50mA,                        | 36   | 40      | 50   | dB   |
| Три                          | Supply ramp from 0 to 3.6v in 10µs      | 9    | 15      | 23   | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                   | 240  | 400     | 600  | us   |
| Isleep                       | Io=0mA                                  | 12   | 15      | 23   | uA   |
| Cex                          |                                         | 1    | 1       | 2.2  | uF   |
| VDD25(VDD25)                 |                                         |      |         |      |      |
| Status after reset           | On                                      |      |         |      |      |
| Application                  | PLL and EFUSE                           |      |         |      |      |
| Output Voltage               | 00 (default)                            | 2.4  | 2.5     | 2.6  | V    |
|                              | 01                                      | 2.65 | 2.75    | 2.85 | V    |
|                              | 10                                      | 2.9  | 3.0     | 3.1  | V    |
|                              | 11                                      | 2.8  | 2.9     | 3.0  | V    |
| Output Current               |                                         |      |         | 60   | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                   | 5    | 10      | 20   | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us            | 10   | 20      | 40   | mV   |
| Load regulation              | Vi=3.8V; Io=0-30mA;                     | 20   | 40      | 80   | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=2.2uF;<br>Tr=10us | 20   | 40      | 80   | mV   |



| SC8810 Design                |                                         |      |         |      | ·9·· • • |
|------------------------------|-----------------------------------------|------|---------|------|----------|
| Parameter                    | Comments                                | Min  | Typical | Max  | Unit     |
| Tpu                          | Supply ramp from 0 to 3.6v in 10μs      | 60   | 100     | 200  | us       |
| PSRR                         | F=217Hz,lo=30mA,                        | 48   | 60      | 72   | dB       |
| Cex                          |                                         | 2.2  | 2.2     | 4.7  | uF       |
| DVDD18(VDD_A)                |                                         |      |         |      |          |
| Status after reset           | On                                      |      |         |      |          |
| Application                  | Analog 1.8V power                       |      |         |      | 7        |
| Output Voltage               |                                         | 1.7  | 1.8     | 1.9  | ٧        |
| Output Current               |                                         |      |         | 80   | mA       |
| Line regulation              | Vi=3.6V-4.2V;Io=50mA;                   | 5    | 10      | 20   | mV       |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=50mA;Tr=10us            | 10   | 20      | 40   | mV       |
| Load regulation              | Vi=3.8V; Io=0-30mA;                     | 20   | 40      | 80   | mV       |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=2.2uF;<br>Tr=10us | 20   | 40      | 80   | mV       |
| PSRR                         | F=217Hz,lo=50mA,                        | 36   | 40      | 50   | dB       |
| Cex                          |                                         | 1    | 1       | 2.2  | uF       |
| WIF0 LDO Voltage (           | VDDWIF0)                                |      |         |      | •        |
| Status after reset           | Off                                     |      |         |      |          |
| Application                  | Supply for external Wif terminal        |      |         |      |          |
| Output Voltage               | 00                                      | 2.7  | 2.8     | 2.9  | V        |
|                              | 01(default)                             | 3.15 | 3.3     | 3.45 | V        |
|                              | 10                                      | 1.7  | 1.8     | 1.9  | ٧        |
|                              | 11                                      | 1.1  | 1.2     | 1.3  | V        |
| Output Current               |                                         |      |         | 200  | mA       |
| Line regulation              | Vi=3.6V-4.2V;Io=100mA;                  | 5    | 10      | 20   | mV       |
| Line Transient Regulation    | Vi=3.6V-4.2V;Io=100mA;Tr=10us           | 12   | 25      | 50   | mV       |
| Load Regulation              | Vi=3.8V; Io=0-200mA;                    | 25   | 50      | 100  | mV       |
| Load Transient               | Vi=3.8V; Io=0-200mA;Co=2.2uF;           | 25   | 50      | 100  | mV       |



| Parameter                    | Comments                                 | Min  | Typical | Max  | Unit |
|------------------------------|------------------------------------------|------|---------|------|------|
| Regulation                   | Tr=10us                                  |      |         |      |      |
| Short current limit          |                                          | 75   | 90      | 120  | mA   |
| Current limit                | Vi=3.8V                                  | 410  | 480     | 640  | mA   |
| PSRR                         | F=217Hz,lo=100mA,                        | 36   | 40      | 50   | dB   |
| Три                          | Supply ramp from 0 to 3.6v in 10μs       | 60   | 100     | 150  | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                    | 180  | 300     | 450  | us   |
| Isleep                       | Io=0mA                                   | 12   | 15      | 23   | uA   |
| Cext                         | External cap                             | 2.2  | 2.2     | 4.7  | uF   |
| WIF1 LDO Voltage             | (VDDWIF1)                                |      | X       |      |      |
| Status after reset           | Off                                      |      |         | -    |      |
| Application                  | Supply for external Wif terminal         |      |         |      |      |
| Output Voltage               | 00                                       | 2.7  | 2.8     | 2.9  | V    |
|                              | 01(default)                              | 3.15 | 3.3     | 3.45 | V    |
|                              | 10                                       | 1.7  | 1.8     | 1.9  | ٧    |
|                              | 11                                       | 1.1  | 1.2     | 1.3  | V    |
| Output Current               |                                          |      |         | 200  | mA   |
| Line regulation              | Vi=3.6V-4.2V;lo=100mA;                   | 5    | 10      | 20   | mV   |
| Line Transient Regulation    | Vi=3.6V-4.2V;Io=100mA;Tr=10us            | 12   | 25      | 50   | mV   |
| Load Regulation              | Vi=3.8V; Io=0-200mA;                     | 25   | 50      | 100  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-200mA;Co=2.2uF;<br>Tr=10us | 25   | 50      | 100  | mV   |
| Short current limit          |                                          | 75   | 90      | 120  | mA   |
| Current limit                | Vi=3.8V                                  | 410  | 480     | 640  | mA   |
| PSRR                         | F=217Hz,lo=100mA,                        | 36   | 40      | 50   | dB   |
| Три                          | Supply ramp from 0 to 3.6v in 10μs       | 60   | 100     | 150  | us   |
| Tpd                          | Vo=0.1V<br>(lout=lmax/2)                 | 180  | 300     | 450  | us   |



| Parameter                    | Comments                              | Min | Typical | Max | Unit |  |  |  |
|------------------------------|---------------------------------------|-----|---------|-----|------|--|--|--|
| Isleep                       | Io=0mA                                | 12  | 15      | 23  | uA   |  |  |  |
| Cext                         | External cap                          | 2.2 | 2.2     | 4.7 | uF   |  |  |  |
| SIM2 LDO (VSIM2)             | SIM2 LDO (VSIM2)                      |     |         |     |      |  |  |  |
| Status after reset           | Off                                   |     |         |     |      |  |  |  |
| Application                  | Supply for SIM Card or CMMB RF        |     |         |     |      |  |  |  |
| Output Voltage               | 00                                    | 2.7 | 2.8     | 2.9 | V    |  |  |  |
|                              | 01                                    | 2.9 | 3       | 3.1 | V    |  |  |  |
|                              | 10(default)                           | 1.7 | 1.8     | 1.9 | V    |  |  |  |
|                              | 11                                    | 1.3 | 1.2     | 1.1 | V    |  |  |  |
| Output Current               |                                       |     |         | 200 | mA   |  |  |  |
| Line regulation              | Vi=3.6V-4.2V;Io=30mA;                 | 5   | 10      | 20  | mV   |  |  |  |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=30mA;Tr=10us          | 10  | 20      | 40  | mV   |  |  |  |
| Load regulation              | Vi=3.8V; Io=0-30mA;                   | 15  | 30      | 60  | mV   |  |  |  |
| Load Transient Regulation    | Vi=3.8V; Io=0-30mA;Co=1uF;<br>Tr=10us | 15  | 30      | 60  | mV   |  |  |  |
| Short current limit          |                                       | 130 | 150     | 200 | mA   |  |  |  |
| Current limit                | Vi=3.8V                               | 410 | 480     | 640 | mA   |  |  |  |
| PSRR                         | F=217Hz,Io=30mA,                      | 48  | 60      | 72  | dB   |  |  |  |
| Три                          | Supply ramp from 0 to 3.63v in 10μs   | 72  | 120     | 180 | us   |  |  |  |
| Tpd                          | Vo=0.1V (lout=Imax/2)                 | 150 | 250     | 333 | us   |  |  |  |
| Isleep                       | Io=0mA                                | 12  | 15      | 23  | uA   |  |  |  |
| Cext                         |                                       | 2.2 | 2.2     | 4.7 | uF   |  |  |  |
| SIM3 LDO (VSIM3)             |                                       |     |         |     |      |  |  |  |
| Status after reset           | Off                                   |     |         |     |      |  |  |  |
| Application                  | Supply for SIM Card or CMMB RF        |     |         |     |      |  |  |  |
| Output Voltage               | 00                                    | 2.7 | 2.8     | 2.9 | V    |  |  |  |
|                              | 01                                    | 2.9 | 3       | 3.1 | V    |  |  |  |



| Parameter                    | Comments                              | Min | Typical | Max | Unit |
|------------------------------|---------------------------------------|-----|---------|-----|------|
|                              | 10(default)                           | 1.7 | 1.8     | 1.9 | ٧    |
|                              | 11                                    | 1.3 | 1.2     | 1.1 | V    |
| Output Current               |                                       |     |         | 200 | mA   |
| Line regulation              | Vi=3.6V-4.2V;Io=30mA;                 | 5   | 10      | 20  | mV   |
| Line Transient<br>Regulation | Vi=3.6V-4.2V;Io=30mA;Tr=10us          | 10  | 20      | 40  | mV   |
| Load regulation              | Vi=3.8V; Io=0-30mA;                   | 15  | 30      | 60  | mV   |
| Load Transient<br>Regulation | Vi=3.8V; Io=0-30mA;Co=1uF;<br>Tr=10us | 15  | 30      | 60  | mV   |
| Short current limit          |                                       | 130 | 150     | 200 | mA   |
| Current limit                | Vi=3.8V                               | 410 | 480     | 640 | mA   |
| PSRR                         | F=217Hz,lo=30mA,                      | 48  | 60      | 72  | dB   |
| Три                          | Supply ramp from 0 to 3.6v in 10µs    | 72  | 120     | 180 | us   |
| Tpd                          | Vo=0.1V (lout=lmax/2)                 | 150 | 250     | 333 | us   |
| Isleep                       | Io=0mA                                | 12  | 15      | 23  | uA   |
| Cext                         |                                       | 2.2 | 2.2     | 4.7 | uF   |
| LDO_PA                       |                                       |     |         |     |      |
| Status after reset           | off                                   |     |         |     |      |
| Application                  | Audio PA                              |     |         |     |      |
| Output voltage               | 000                                   | 2.7 | 2.9     | 3.1 | V    |
|                              | 001                                   | 2.8 | 3.0     | 3.2 | V    |
|                              | 010                                   | 2.9 | 3.1     | 3.3 | V    |
|                              | 011                                   | 3.0 | 3.2     | 3.4 | V    |
|                              | 100(default)                          | 3.1 | 3.3     | 3.5 | V    |
|                              | 101                                   | 3.2 | 3.4     | 3.6 | V    |
|                              | 110                                   | 3.3 | 3.5     | 3.6 | V    |
|                              | 111                                   | 3.4 | 3.6     | -   | V    |
| Output current               |                                       |     |         | 400 | mA   |



| Parameter                 | Comments                                     | Min | Typical | Max | Unit |
|---------------------------|----------------------------------------------|-----|---------|-----|------|
| Line regulation           | Vsupply=3.6->4.2V, Iout=200mA                | 5   | 10      | 20  | mV   |
| Line transient regulation | Vsupply=3.6->4.2V, Iout=200mA,<br>Trise=10us | 10  | 20      | 40  | mV   |
| Load regulation           | Vsupply=3.8V, lout=0->400mA                  | 40  | 80      | 160 | mV   |
| Load transient regulation | Vsupply=3.8V, lout=0->400mA,<br>Trise=10us   | 50  | 100     | 200 | mV   |
| PSRR                      | Freq=217Hz, lout=400mA                       | 36  | 40      | 50  | dB   |
| Time to power up          | Vsupply=0->3.8V, Trise=10us                  | 60  | 100     | 150 | us   |
| Time to power down        | Vout=0.1V, Iout=400mA                        | 180 | 300     | 450 | us   |
| Isleep                    | lout=0mA                                     | 12  | 15      | 23  | uA   |
| Output capacitor          | Required for stability and ripple rejection  | 4.7 | 4.7     | 10  | μF   |

Table 9-2 Performance of DC-DC circuit

| Parameter          | Comments/Conditions           | Min  | Typical | Max  | Unit |  |  |
|--------------------|-------------------------------|------|---------|------|------|--|--|
| DCDC for ARM       |                               |      |         |      |      |  |  |
| Status after reset | on                            |      |         |      |      |  |  |
| Application        | Digital core power            |      |         |      |      |  |  |
|                    | 000                           | 0.55 | 0.65    | 0.75 | V    |  |  |
| Output voltage     | 001                           | 0.6  | 0.7     | 0.8  | V    |  |  |
|                    | 010                           | 0.7  | 0.8     | 0.9  | V    |  |  |
|                    | 011                           | 0.8  | 0.9     | 1    | V    |  |  |
|                    | 100                           | 0.9  | 1.0     | 1.1  | V    |  |  |
|                    | 101                           | 1    | 1.1     | 1.2  | V    |  |  |
|                    | 110(default)                  | 1.1  | 1.2     | 1.3  | V    |  |  |
|                    | 111                           | 1.2  | 1.3     | 1.4  | V    |  |  |
| Trim voltage       | Trim votage step (32 step)    | 2    | 3       | 4    | mv   |  |  |
| Output current     |                               |      |         | 500  | mA   |  |  |
| Line regulation    | Vsupply=3.6->4.2V, lout=200mA | 5    | 10      | 20   | mV   |  |  |



| Scotto Design Specif      |                                              |      |         |      |      |  |
|---------------------------|----------------------------------------------|------|---------|------|------|--|
| Parameter                 | Comments/Conditions                          | Min  | Typical | Max  | Unit |  |
| Line transient regulation | Vsupply=3.6->4.2V, Iout=200mA,<br>Trise=10us | 15   | 30      | 60   | mV   |  |
| Load regulation           | Vsupply=3.8V, lout=0->400mA                  | 40   | 80      | 160  | mV   |  |
| Load transient regulation | Vsupply=3.8V, lout=0->400mA,<br>Trise=10us   | 50   | 100     | 200  | mV   |  |
| Time to power up          | Vsupply=0->4.3V, Trise=10us                  | 60   | 100     | 150  | us   |  |
| Switching frequency       |                                              | 1    | 1.5     | 2.25 | MHz  |  |
| Isleep                    | lout=0mA                                     | 72   | 90      | 100  | uA   |  |
| Effiency                  | 100mA loading                                | 80   | 85      | 90   | %    |  |
| Parameter                 | Comments/Conditions                          | Min  | Typical | Мах  | Unit |  |
| DCDC for other Core       |                                              |      |         |      |      |  |
| Status after reset        | on                                           |      |         |      |      |  |
| Application               | Digital core power                           |      |         |      |      |  |
|                           | 000                                          | 0.55 | 0.65    | 0.75 | ٧    |  |
|                           | 001                                          | 0.6  | 0.7     | 0.8  | V    |  |
|                           | 010                                          | 0.7  | 0.8     | 0.9  | ٧    |  |
|                           | 011                                          | 0.8  | 0.9     | 1    | V    |  |
| Output voltage            | 100                                          | 0.9  | 1.0     | 1.1  | V    |  |
|                           | 101(default)                                 | 1    | 1.1     | 1.2  | V    |  |
| <b>.</b> X                | 110                                          | 1.1  | 1.2     | 1.3  | V    |  |
|                           | 111                                          | 1.2  | 1.3     | 1.4  | V    |  |
| Trim voltage              | Trim votage step (32 step)                   | 2    | 3       | 4    | mv   |  |
| Output current            |                                              |      |         | 500  | mA   |  |
| Line regulation           | Vsupply=3.6->4.2V, lout=200mA                | 5    | 10      | 20   | mV   |  |
| Line transient regulation | Vsupply=3.6->4.2V, Iout=200mA,<br>Trise=10us | 15   | 30      | 60   | mV   |  |
| Load regulation           | Vsupply=3.8V, lout=0->400mA                  | 40   | 80      | 160  | mV   |  |
| Load transient regulation | Vsupply=3.8V, lout=0->400mA,<br>Trise=10us   | 50   | 100     | 200  | mV   |  |
| Time to power up          | Vsupply=0->4.3V, Trise=10us                  | 60   | 100     | 150  | us   |  |
|                           | •                                            | _    |         |      |      |  |



| Parameter           | Comments/Conditions | Min | Typical | Max  | Unit |
|---------------------|---------------------|-----|---------|------|------|
| Switching frequency |                     | 1   | 1.5     | 2.25 | MHz  |
| Isleep              | lout=0mA            | 72  | 90      | 100  | uA   |
| Effiency            | 100mA loading       | 80  | 85      | 90   | %    |

Note1: IO voltage can be switched between 1.8V and 2.8V supplied by VDD18 and VDD28.

Note2. There are two structures for these intergrated LDOs.

Note3. The PSRR listed means the worst value for all loading statuses and cover all frequency range.



Figure 9-2 DCDC Application diagram





Figure 9-3 DCDC efficiency vs loading

## 9.3 Charger

SC6820 provides an integrated Li-ion battery charger control module. With an external PMOS transistor and a current sensing resistor, SC6820 can control the charging of Li-ion battery. SC6820 also supports charging from USB port. SC6820 can monitor both charging current and battery voltage with the auxiliary ADC.





Figure 9-4 Charger application diagram

# 9.3.1 Charging Process

A charge cycle begins when the voltage at VCHG pin rises above 4.5 V.

If the VBAT is less than 1.1 V, the charger enters activate charge mode. In this mode, charger supplies approximately 5 mA charge current to activate the battery.

If VBAT is more than 1.1 V but less than 2.7 V, the charger enters small current charge mode. In this mode, charger supplies approximately 50 mA charge current to bring the battery voltage up to a safe level for full current charging.

When VBAT voltage rises above 2.7 V, the charger enters full current charge mode. The charger uses a constant-current algorithm in both small current and full charge modes.

When VBAT approaches the final float voltage (4.2 V), the charger enters constant-voltage mode, and the charging current begins to decrease. As the charging current drops to 1/10 of the programmed value, the charge cycle ends.



### 9.3.2 Programming Charge Current

The charge current is programmed using an internal resistor from the PROG pin to ground. Rint =  $3 \text{ k}\Omega$ . If PROG is 1.2 V, the charge current Ichg =  $1.2 \times 1000 / 3 \text{k} = 400 \text{ mA}$ .

## 9.3.3 Charge Standby

When the charge current falls to 1/10 of the programmed current, or when the PROG pin voltage falls bellow 120 mV, the charger goes into standby mode. In standby mode, the charger ceases to provide charge current to the battery.

#### 9.3.4 Recharge Control

If the charger power supply is connected, software can control for recharge after the initial charge is finished. The charger control circuit sends out a signal STANDBY, when the initial charge is done. The charger control circuit accepts a control signal, RECHG, with an initial value of 0. Software can generate an active-high pulse at RECHG when the following conditions are met.

- CHGON = 1, indicating the charger power supply is connected and its voltage is > 4.5 V.
- STANDBY = 1, indicating the initial charge is done.
- VBAT is less than some predetermined value for recharge.

#### 9.3.5 Software Over Current Protection

In charge cycle, if the charge current is above 1.3 times the programmed current, the charger ceases to provide charge current to the battery and enters standby mode.

# 9.4 LCD Backlight LED Driver

The LCD Backlight module provides four matched current sources, sinks up to 24.75 mA of load current to accommodate each of the four White LEDs. The module uses current mirror to construct LCD backlight driver. The reference current source ISET is set with an external resistor R. Each of the matched current regulators has a 100:1 current ratio between the VLEDx outputs (one channel) and the ISET currents. It requires no charge pump. Brightness can be controlled by software. The module is in shut down mode when the whiled pd is active.





Figure 9-5 LCD backlight LED driver application

Note1: D1 in the diagram must be connected to a LED when in use, otherwise the LED driver current control bits will not be effective.

Table 9-3 Peformance of LCD backlight LED driver

| Parameter          | Conditions/Comments          | Min | Typical | Max | Unit |  |  |  |  |  |  |
|--------------------|------------------------------|-----|---------|-----|------|--|--|--|--|--|--|
| Status after reset | off                          |     |         |     |      |  |  |  |  |  |  |
|                    | 00000(min current) (default) |     | 1.5     |     |      |  |  |  |  |  |  |
|                    | 00001                        |     | 2.25    |     |      |  |  |  |  |  |  |
|                    | 00010                        |     | 3.0     |     |      |  |  |  |  |  |  |
|                    | 00011                        |     | 3.75    |     |      |  |  |  |  |  |  |
|                    | 00100                        |     | 4.5     |     |      |  |  |  |  |  |  |
|                    | 00101                        |     | 5.25    |     |      |  |  |  |  |  |  |
| Output average     | 00110                        |     | 6.0     |     |      |  |  |  |  |  |  |
| Output current     | 00111                        |     | 6.75    |     |      |  |  |  |  |  |  |
|                    | 01000                        |     | 7.5     |     |      |  |  |  |  |  |  |
|                    | 01001                        |     | 8.25    |     | 1    |  |  |  |  |  |  |
|                    | 01010                        |     | 9       |     | 1    |  |  |  |  |  |  |
|                    | 01011                        |     | 9.75    |     |      |  |  |  |  |  |  |
|                    | 01100                        |     | 10.5    |     |      |  |  |  |  |  |  |
|                    | 01101                        |     | 11.25   |     |      |  |  |  |  |  |  |



|                | 01110              | 12.0  |   |    |
|----------------|--------------------|-------|---|----|
|                | 01111              | 12.75 |   |    |
|                | 10000              | 13.5  |   |    |
|                | 10001              | 14.25 |   |    |
|                | 10010              | 15.0  |   |    |
|                | 10011              | 15.75 |   |    |
|                | 10100              | 16.5  |   |    |
|                | 10101              | 17.25 |   |    |
|                | 10110              | 18.0  | 1 |    |
|                | 10111              | 18.75 |   |    |
| Output current | 11000              | 19.5  |   | mA |
|                | 11001              | 20.25 |   |    |
|                | 11010              | 21.0  |   |    |
|                | 11011              | 21.75 |   |    |
|                | 11100              | 22.5  |   |    |
|                | 11101              | 23.25 |   |    |
|                | 11110              | 24.0  |   |    |
|                | 11111(max current) | 24.75 |   |    |

# 9.5 Keypad Backlight LED Driver

The keypad backlight driver is constructed with current mirror.





Figure 9-6 Keypad backlight LED driver application

Table 9-4 Performance of Keypad backlight LED driver

| Parameter          | Conditions/Comments        | Typical | Max | Unit |    |
|--------------------|----------------------------|---------|-----|------|----|
| Status after reset | off                        |         |     |      |    |
|                    | 000(min current) (default) |         | 5   |      |    |
|                    | 001                        |         | 10  |      |    |
|                    | 010                        |         | 15  |      |    |
| Output ourrant     | 011                        |         | 20  |      | ^  |
| Output current     | 100                        |         | 25  |      | mA |
|                    | 101                        |         | 30  |      |    |
|                    | 110                        |         | 35  |      |    |
|                    | 111                        |         | 40  |      |    |

# 9.6 Vibrator Driver

The vibrator driver is constructed with current mirror.





Figure 9-7 Vibrator driver application

Table 9-5 Performance of Vibrator driver

| Parameter          | Conditions/Comments | Conditions/Comments Min |     |  |      |  |  |  |
|--------------------|---------------------|-------------------------|-----|--|------|--|--|--|
| Status after reset | off                 |                         |     |  |      |  |  |  |
|                    | 0000 (default)      |                         | 20  |  |      |  |  |  |
|                    | 0001                |                         | 30  |  |      |  |  |  |
|                    | 0010                |                         | 40  |  |      |  |  |  |
|                    | 0011                |                         | 50  |  | ]    |  |  |  |
|                    | 0100                |                         | 60  |  | - mA |  |  |  |
|                    | 0101                |                         | 70  |  |      |  |  |  |
|                    | 0110                |                         | 80  |  |      |  |  |  |
| Output oursel      | 0111                |                         | 90  |  |      |  |  |  |
| Output current     | 1000                |                         | 100 |  |      |  |  |  |
|                    | 1001                |                         | 110 |  |      |  |  |  |
|                    | 1010                |                         | 120 |  |      |  |  |  |
|                    | 1011                |                         | 130 |  |      |  |  |  |
|                    | 1100                |                         | 140 |  | - mA |  |  |  |
|                    | 1101                |                         | 150 |  |      |  |  |  |
|                    | 1110                |                         | 160 |  |      |  |  |  |
|                    | 1111                |                         | 170 |  |      |  |  |  |
|                    |                     |                         |     |  |      |  |  |  |



## **9.7 UVLO**

The UVLO (Under Voltage Lockout) function prevents startup when initial voltage of the main battery is below the 3.1 V threshold. The UVLO circuit is used to provide more stable operation. After turning on power, the UVLO function keeps the internal circuit in the standby state until 128ms after the main battery's voltage reaches the UVLO voltage, there is 3.1V, so as to reduce supply current, avoid mis-operation and prohibit PMU to work when supply is surging. If the main battery's voltage is below 2.7V or above 5.2V for longer than 2ms, the UVLO circuit will give a signal to the internal circuit that the main battery is low/high power, which need to be powered down.

A UVLO filter is designed to remove the glitch under 2ms, and 128ms recovery time is added. Once chip enters UVLO state, it draws very low quiescent current, typically < 50 uA.

The de-glitch function of UVLO can be described as figure 16-8:





#### Figure 9-8 UVLO function

#### 9.8 OTP

The OTP (Over Temperature Protection) function in SC6820 will disable all the LDOs except the LDO\_RTC if the die temperature exceeds 150 °C. Once the over temperature condition is resolved, a new power on sequence is required to enable the LDOs. And the OTP has 35 °C sluggish.

The OTP function is disabled by default and can be enabled by software.



Figure 9-9 OTP operation condition

## 9.9 Band-Gap

The band gap block provides the first level reference for all LDO's except LDO RTC. When system is reset, it will be on.

Note:

- 1) When Band-gap is powered off, all LDOs except LDO\_RTC will be disabled.
- 2) When BG is power off, OTP should Power off too. However, when BG is power on, OTP can be either power on or power off.

#### 9.10 Power Control

## 9.10.1 Power on Procedure

SC6820 can be powered on in four ways, by connecting the battery, by pressing the power button, by inserting the battery charger or by alarm interrupt.



#### 9.10.1.1 Power on by Connecting the Battery

The battery is the master power supply to the entire system. When the battery is connected, the 3.6 V battery voltage should be supplied to the AVDD36 pin.

As the AVDD36 supply voltage goes from 0 to 3.6 V, a power-on-reset (POR) is generated and this POR resets all the control registers, including the one that controls the internal 1.8 V LDO. As soon as the 1.8 V LDO control register is reset, the 1.8 V LDO start to function, providing the 1.8 V power supply to the core. At the end of the POR, basic blocks start to function and the system is considered powered on.

#### 9.10.1.2 Power on by the Power Button

When the system is powered off with the battery still connected, pressing the power button can power on the system. When the power button is pressed, a reset signal is generated and all the control registers get reset, including the one that controls the internal 1.8 V LDO. As soon as the 1.8 V LDO control register is reset, the 1.8 V LDO start to function, providing the 1.8 V power supply to the core. In addition, an interrupt is sent to the MCU. The MCU should check the interrupt source and branch accordingly.

#### 9.10.1.3 Power on by the Charger

When the system is powered off with the battery still connected, inserting the battery charger can also power on the system. When the charger is inserted, a power-on-reset is also triggered, and the system starts with its normal power on procedure. After powered on, the MCU should detect the source of the reset trigger and act accordingly.

#### 9.10.1.4 Power on by Alarm

When the system is powered off with the battery still connected, alarm interrupt from RTC domain can also power on the system. When the alarm interrupt is generated, a power-on-reset is also triggered, and the system starts with its normal power on procedure. After being powered on, the MCU should detect the source of the reset trigger and act accordingly.





#### Figure 9-10 Power on reset

Note1: PBINT, ALMINT, CHGINT symbolize power button interrupt, charger interrupt and charger interrupt separately. CORE\_PD is high when the chip is power off. EXTRSTN is the signal from ball B3 and POR\_N is internal signal to power up the chip.



#### 9.10.2 Power on Sequence

#### Normal power up



Other LDOS (L)

## Power up with backup battery



### Power up without backup battery



V.0.1



#### Figure 9-11 Power on sequence

Note: (H) symbolize high voltage, (L) symbolize low voltage

## 9.10.3 Reset sequence



Figure 9-12 Rest sequence

Note1: (H) symbolize high voltage

Note2: Sequence after POR\_N, please refer to figure16-10



# 9.10.4 Clock stable sequence



Figure 9-13 Clock stable sequence



# **10 Analog Control Registers**

# 10.1 Global Register

#### 10.1.1 ARM Side

ARM Base Address: 0x8200\_0600

Table 1-1 Analog ARM Global Register

| Offset<br>Address | Name          | Description                |
|-------------------|---------------|----------------------------|
| 0x00              | APB_CLK_EN    | APB slave clock enable     |
| 0x04              | APB_ARM_RST   | APB slave ARM soft reset   |
| 0x08              | LDO_PD_SET    | LDO power down set         |
| 0x0C              | LDO_PD_RST    | LDO power down reset       |
| 0x10              | LDO_PD_CTRL0  | LDO power down control0    |
| 0x14              | LDO_PD_CTRL1  | LDO power down control1    |
| 0x18              | LDO_VCTRL0    | LDO voltage control0       |
| 0x1C              | LDO_VCTRL1    | LDO voltage control1       |
| 0x20              | LDO_VCTRL2    | LDO voltage control2       |
| 0x24              | LDO_VCTRL3    | LDO voltage control3       |
| 0x28              | LDO_VCTRL4    | LDO voltage control4       |
| 0x2C              | LDO_SLP_CTRL0 | LDO sleep control0         |
| 0x30              | LDO_SLP_CTRL1 | LDO sleep control1         |
| 0x34              | LDO_SLP_CTRL2 | LDO sleep control2         |
| 0x38              | DCDC_CTRL     | DCDC control               |
| 0x3C              | DCDC_CTRL_DS  | DCDC control in deep sleep |
| 0x40              | DCDC_CTRL_CAL | DCDC calibration control   |
| 0x44              | DCDCARM_CTRL  | DCDCARM control            |



| Offset<br>Address | Name             | Description                                            |
|-------------------|------------------|--------------------------------------------------------|
| 0x48              | DCDCARM_CTRL_CAL | DCDCARM calibration control                            |
| 0x4C              | PLL_CTRL         | APLL control                                           |
| 0x50              | APLLMN           | APLL MN control                                        |
| 0x54              | APLLWAIT         | APLL WAIT control                                      |
| 0x58              | RTC_CTRL         | RTC OSC/VBAT control                                   |
| 0x5C              | TRF_CTRL         | Transfer 26M buffer control                            |
| 0x60              | CHGR_CTRL0       | Charger control0                                       |
| 0x64              | CHGR_CTRL1       | Charger control1                                       |
| 0x68              | LED_CTRL         | LED control                                            |
| 0x6C              | VIBRATOR_CTRL0   | Vibrator control0                                      |
| 0x70              | VIBRATOR_CTRL1   | Vibrator control1                                      |
| 0x74              | AUDIO_CTRL       | Audio general control                                  |
| 0x78              | AUDIO_PA_CTRL0   | Audio PA control0                                      |
| 0x7C              | AUDIO_PA_CTRL1   | Audio PA control1                                      |
| 0x80              | ANA_MIXED_CTRL   | Analog circuit miscellaneous(OTP, BT,26MBUF) control   |
| 0x84              | ANA_STATUS       | Analog circuit (Bonding option,<br>Charger, PA) status |
| 0x88              | RST_STATUS       | Reset status                                           |
| 0x8C              | MCU_WR_PROT      | MCU write protection                                   |
| 0x90              | VIBR_WR_PROT     | VIBR register write protection                         |
| 0x94              | INT_GPI_DEBUG    | Analog interrupt and GPI debug                         |
| 0x98              | HWRST_RTC        | RTC test register                                      |
| 0x9C              | IF_SPR_CTRL      | IF_SPR pin control                                     |
| 0xF8              | CHIP_ID_LOW      | 8810 CHIP ID low 16 bits                               |
| 0xFC              | CHIP_ID_HIGH     | 8810 CHIP ID high 16 bits                              |

### 10.1.1.1 APB\_CLK\_EN

Description: APB slave related clock enable



| 0x0000 |                        |                          | АРВ                           | APB slave related clock enable (reset 0x0000_0181) |                    |                        |                        |                         |                   |                 |            |            |            | APB_CLK_EN     |            |                         |  |
|--------|------------------------|--------------------------|-------------------------------|----------------------------------------------------|--------------------|------------------------|------------------------|-------------------------|-------------------|-----------------|------------|------------|------------|----------------|------------|-------------------------|--|
| Bit    | 31                     | 30                       | 29                            | 28                                                 | 27                 | 26                     | 25                     | 24                      | 23                | 22              | 21         | 20         | 19         | 18             | 17         | 16                      |  |
| Name   |                        | Reserved                 |                               |                                                    |                    |                        |                        |                         |                   |                 |            |            |            |                |            |                         |  |
| Туре   |                        | 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   | CHG<br>RW<br>DG_<br>EB | CLK<br>_AU<br>XAD<br>_EN | CLK<br>_AU<br>XAD<br>C_E<br>N | RTC<br>_TP<br>C_E<br>B                             | RTC<br>_EIC<br>_EB | RTC<br>_WD<br>G_E<br>B | RTC<br>_RT<br>C_E<br>B | RTC<br>_AR<br>CH_<br>EB | PIN<br>REG<br>_EB | GPI<br>O_E<br>B | ADC<br>_EB | TPC<br>_EB | EIC_<br>EB | WD<br>G_E<br>B | RTC<br>_EB | APB<br>_AR<br>CH_<br>EB |  |
| Туре   | R/W                    | R/W                      | R/W                           | R/W                                                | R/W                | 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                      | 1                       | 1                 | 0               | 0          | 0          | 0          | 0              | 0          | 1                       |  |

| Field Name    | Bit     | Туре | Reset | Description                                                                 |
|---------------|---------|------|-------|-----------------------------------------------------------------------------|
|               |         |      | Value |                                                                             |
|               | [31:16] | RO   | 16'h0 | Reserved                                                                    |
| CHGRWDG_EB    | [15]    | R/W  | 1'h0  | CHGRWDG APB clock enable                                                    |
| CLK_AUXAD_EN  | [14]    | R/W  | 1'h0  | Set this bit will enable AUXAD converter clock generation                   |
| CLK_AUXADC_EN | [13]    | R/W  | 1'h0  | AUXAD controller 6.5M work clock enable                                     |
| RTC_TPC_EB    | [12]    | R/W  | 1'h0  | TPC controller RTC clock enable  0: The RTC clock of TPC controller will be |
|               |         |      |       | off                                                                         |
|               |         |      |       | 1: Enable RTC clock of TPC controller                                       |
| RTC_EIC_EB    | [11]    | R/W  | 1'h0  | EIC RTC clock enable                                                        |
|               |         |      |       | 0: The RTC clock of EIC will be off                                         |
|               |         |      |       | 1: Enable RTC clock of EIC                                                  |
| RTC_WDG_EB    | [10]    | R/W  | 1'h0  | Watch dog RTC clock enable                                                  |
|               |         |      |       | 0: The RTC clock of watch dog will be off                                   |
|               |         |      |       | 1: Enable RTC clock of watch dog                                            |
| RTC_RTC_EB    | [9]     | R/W  | 1'h0  | RTC controller RTC clock enable                                             |
|               |         |      |       | 0: The RTC clock of RTC controller will be                                  |



|             |     |     |      | off                                                        |
|-------------|-----|-----|------|------------------------------------------------------------|
|             |     |     |      | 1: Enable RTC clock of RTC controller                      |
| RTC_ARCH_EB | [8] | R/W | 1'h1 | APB system RTC clock enable                                |
|             |     |     |      | 0: disable clock_rtc_arch                                  |
|             |     |     |      | 1: enable clock_rtc_arch                                   |
| PINREG_EB   | [7] | R/W | 1'h1 | Pin register APB clock enable                              |
| GPIO_EB     | [6] | R/W | 1'h0 | GPIO APB clock enable                                      |
| ADC_EB      | [5] | R/W | 1'h0 | AUXAD controller APB clock enable                          |
| TPC_EB      | [4] | R/W | 1'h0 | Touch panel controller APB clock enable                    |
| EIC_EB      | [3] | R/W | 1'h0 | EIC APB clock enable                                       |
| WDG_EB      | [2] | R/W | 1'h0 | Watch dog APB clock enable                                 |
| RTC_EB      | [1] | R/W | 1'h0 | RTC controller APB clock enable                            |
| APB_ARCH_EB | [0] | R/W | 1'h1 | APB system clock enable to enable clock                    |
|             |     |     |      | for global register, interrupt controller, reset generator |
|             |     |     |      | Note: This bit could only be modified when                 |
|             |     |     |      | MCU_WR_PROT register is released                           |

### 10.1.1.2 APB\_ARM\_RST

Description: APB slave ARM soft reset



| 0x0004 |    |          | APB slave arm soft reset (reset 0x0000_0000) |    |    |    |    |    |                   |                          |                          |                          | APB_ARM_RST             |                                      |                               |                          |
|--------|----|----------|----------------------------------------------|----|----|----|----|----|-------------------|--------------------------|--------------------------|--------------------------|-------------------------|--------------------------------------|-------------------------------|--------------------------|
| Bit    | 31 | 30       | 29                                           | 28 | 27 | 26 | 25 | 24 | 23                | 22                       | 21                       | 20                       | 19                      | 18                                   | 17                            | 16                       |
| Name   |    | Reserved |                                              |    |    |    |    |    |                   |                          |                          |                          |                         |                                      |                               |                          |
| Туре   |    | 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   |    | Reserved |                                              |    |    |    |    |    | GPI O_S OFT _RS T | EIC_<br>SOF<br>T_R<br>ST | TPC<br>_SO<br>FT_<br>RST | ADC<br>_SO<br>FT_<br>RST | WD<br>G_S<br>OFT<br>_RS | CHG<br>RW<br>DG_<br>SOF<br>T_R<br>ST | VBM<br>C_S<br>OFT<br>_RS<br>T | RTC<br>_SO<br>FT_<br>RST |
| Туре   |    | RO       |                                              |    |    |    |    |    | 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                        | 0                        | 0                       | 0                                    | 0                             | 0                        |

| Field Name       | Bit    | Туре | Reset<br>Value | Description                  |
|------------------|--------|------|----------------|------------------------------|
|                  | [31:8] | RO   | 24'h0          | Reserved                     |
| GPIO_SOFT_RST    | [7]    | R/W  | 1'b0           | APB slave GPIO soft reset    |
| EIC_SOFT_RST     | [6]    | R/W  | 1'b0           | APB slave EIC soft reset     |
| TPC_SOFT_RST     | [5]    | R/W  | 1'b0           | APB slave TPC soft reset     |
| ADC_SOFT_RST     | [4]    | R/W  | 1'b0           | APB slave ADC soft reset     |
| WDG_SOFT_RST     | [3]    | R/W  | 1'b0           | APB slave WDG soft reset     |
| CHGRWDG_SOFT_RST | [2]    | R/W  | 1'b0           | APB slave CHGRWDG soft reset |
| VBMC_SOFT_RST    | [1]    | R/W  | 1'b0           | APB slave VBMC soft reset    |
| RTC_SOFT_RST     | [0]    | R/W  | 1'b0           | APB slave RTC soft reset     |

10.1.1.3 LDO\_PD\_SET

Description: LDO power down set



| 0x0008 |    |    | LDO  | power | down | set (r | eset 0x                | (0000_                  | 0000)                   |                         |                          |                   |                   | LD                    | LDO_PD_SET      |          |  |
|--------|----|----|------|-------|------|--------|------------------------|-------------------------|-------------------------|-------------------------|--------------------------|-------------------|-------------------|-----------------------|-----------------|----------|--|
| Bit    | 31 | 30 | 29   | 28    | 27   | 26     | 25                     | 24                      | 23                      | 22                      | 21                       | 20                | 19                | 18                    | 17              | 16       |  |
| Name   |    |    |      |       |      |        |                        | Rese                    | erved                   |                         |                          |                   |                   |                       |                 |          |  |
| Туре   |    |    |      |       |      |        |                        | R                       | 0                       |                         |                          |                   |                   |                       |                 |          |  |
| 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   |    |    | Rese | erved |      |        | DCD<br>CAR<br>M_P<br>D | LDO<br>_BP<br>VDD<br>25 | LDO<br>_BP<br>VDD<br>18 | LDO<br>_BP<br>VDD<br>28 | LDO<br>_BP<br>AVD<br>DBB | LDO<br>_BP<br>RF1 | LDO<br>_BP<br>RF0 | LDO<br>_BP<br>ME<br>M | DCD<br>C_P<br>D | PDB<br>G |  |
| Туре   |    |    | R    | 0     |      |        | 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                        | 0                 | 0                 | 0                     | 0               | 0        |  |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                         |
|--------------|---------|------|----------------|---------------------------------------------------------------------|
|              | [31:10] | RO   | 22'h0          | Reserved                                                            |
| DCDCARM_PD   | [9]     | R/W  | 1'h0           | DCDCARM power down                                                  |
| LDO_BPVDD25  | [8]     | R/W  | 1'h0           | LDO_VDD25_PD. When set, LDO_VDD25 will power down (LDO bypassed).   |
| LDO_BPVDD18  | [7]     | R/W  | 1'h0           | LDO_VDD18_PD. When set, LDO_VDD18 will power down (LDO bypassed).   |
| LDO_BPVDD28  | [6]     | R/W  | 1'h0           | LDO_VDD28_PD. When set, LDO_VDD28 will power down (LDO bypassed).   |
| LDO_BPAVDDBB | [5]     | R/W  | 1'h0           | LDO_AVDDBB_PD. When set, LDO_AVDDBB will power down (LDO bypassed). |
| LDO_BPRF1    | [4]     | R/W  | 1'h0           | LDO_RF1_PD. When set, LDO_RF1 will power down (LDO bypassed).       |
| LDO_BPRF0    | [3]     | R/W  | 1'h0           | LDO_RF0_PD. When set, LDO_RF0 will power down (LDO bypassed).       |
| LDO_BPMEM    | [2]     | R/W  | 1'h0           | LDO_MEM power down                                                  |



| DCDC_PD | [1] | R/W | 1'h0 | DCDC/LDO_DVDD18 power down |
|---------|-----|-----|------|----------------------------|
| PDBG    | [0] | R/W | 1'h0 | Band-Gap power down        |

### 10.1.1.4 LDO\_PD\_RST

Description: LDO power down reset

| 0x000C |                                     |    | LDO  | power | down | reset | (reset                         | 0x000               | 0_000                           | 0)                  |                       |                   |                    | LD                | O_PD                    | RST              |
|--------|-------------------------------------|----|------|-------|------|-------|--------------------------------|---------------------|---------------------------------|---------------------|-----------------------|-------------------|--------------------|-------------------|-------------------------|------------------|
| Bit    | 31 30 29 28 27 26 25 24 23 22 21 20 |    |      |       |      |       |                                |                     |                                 | 20                  | 19                    | 18                | 17                 | 16                |                         |                  |
| Name   |                                     |    |      |       |      |       |                                | Rese                | erved                           |                     |                       |                   |                    |                   |                         |                  |
| Туре   |                                     |    |      |       |      |       |                                | R                   | 0                               |                     |                       |                   |                    |                   |                         |                  |
| 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   |                                     |    | Rese |       |      |       | DCD<br>CAR<br>M_P<br>D_R<br>ST | LDO _BP VDD 25_ RST | LDO<br>_BP<br>VDD<br>18_<br>RST | LDO _BP VDD 28_ RST | LDO _BP AVD DBB _RS T | LDO _BP RF1 _RS T | LDO _BP RF0 _RS _T | LDO _BP ME M_R ST | DCD<br>C_P<br>D_R<br>ST | PDB<br>G_R<br>ST |
| Reset  | 0                                   | 0  | 0    | 0     | 0    | 0     | 0                              | 0                   | 0                               | 0                   | 0                     | 0                 | 0                  | 0                 | 0                       | 0                |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                                          |
|-----------------|---------|------|----------------|------------------------------------------------------------------------------------------------------|
|                 | [31:10] | RO   | 22'h0          | Reserved                                                                                             |
| DCDCARM_PD_RST  | [9]     | R/W  | 1'h0           | When set, DCDCARM power on, This bit has higher priority than DCDCARM_ PD.                           |
| LDO_BPVDD25_RST | [8]     | R/W  | 1'h0           | When set, LDO_VDD25 will power on (LDO bypass reset). This bit has higher priority than LDO_BPVDD25. |
| LDO_BPVDD18_RST | [7]     | R/W  | 1'h0           | When set, LDO_VDD18 will power on (LDO bypass reset). This bit has higher priority than LDO_BPVDD18. |
| LDO_BPVDD28_RST | [6]     | R/W  | 1'h0           | When set, LDO_VDD28 will power on (LDO bypass reset). This bit has higher priority than LDO_BPVDD28. |



| LDO_BPAVDDBB_RST | [5] | R/W | 1'h0 | When set, LDO_AVDDBB will power on (LDO bypass reset). This bit has higher priority than LDO_BPAVDDBB. |
|------------------|-----|-----|------|--------------------------------------------------------------------------------------------------------|
| LDO_BPRF1_RST    | [4] | R/W | 1'h0 | When set, LDO_RF1 will power on (LDO bypass reset). This bit has higher priority than LDO_BPRF1.       |
| LDO_BPRF0_RST    | [3] | R/W | 1'h0 | When set, LDO_RF0 will power on (LDO bypass reset). This bit has higher priority than LDO_BPRF0.       |
| LDO_BPMEM_RST    | [2] | R/W | 1'h0 | When set, LDO_MEM power on, This bit has higher priority than LDOBPMEM.                                |
| DCDC_PD_RST      | [1] | R/W | 1'h0 | When set, DCDC/LDO_DVDD18 power on, This bit has higher priority than DCDC_ PD.                        |
| PDBG_RST         | [0] | R/W | 1'h0 | When set, Band-Gap power on                                                                            |

#### 10.1.1.5 LDO\_PD\_CTRL0

Description: LDO power down control0

| 0x0010        |                                     |                  | LDO                            | power                  | down                | contr                   | ol0(res             | et 0x0                  | 000_0                          | 000)                   |                                |                        |                     | LDO_                    | PD_C                           | TRL0                   |
|---------------|-------------------------------------|------------------|--------------------------------|------------------------|---------------------|-------------------------|---------------------|-------------------------|--------------------------------|------------------------|--------------------------------|------------------------|---------------------|-------------------------|--------------------------------|------------------------|
| Bit           | 31 30 29 28 27 26 25 24 23 22 21 20 |                  |                                |                        |                     |                         |                     |                         |                                |                        | 20                             | 19                     | 18                  | 17                      | 16                             |                        |
| Name          |                                     |                  |                                |                        |                     |                         |                     | Rese                    | erved                          |                        |                                |                        |                     |                         |                                |                        |
| Туре          |                                     |                  |                                |                        |                     |                         |                     | R                       | 0                              |                        |                                |                        |                     |                         |                                |                        |
| 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          | LDO<br>_BP<br>VB_<br>RST            | LDO<br>_BP<br>VB | LDO<br>_BP<br>CAM<br>A_R<br>ST | LDO<br>_BP<br>CAM<br>A | LDO _BP CAM D1_ RST | LDO<br>_BP<br>CAM<br>D1 | LDO _BP CAM DO_ RST | LDO<br>_BP<br>CAM<br>D0 | LDO<br>_BP<br>SIM<br>1_R<br>ST | LDO<br>_BP<br>SIM<br>1 | LDO<br>_BP<br>SIM<br>0_R<br>ST | LDO<br>_BP<br>SIM<br>0 | LDO _BP SDI OO_ RST | LDO<br>_BP<br>SDI<br>O0 | LDO<br>_BP<br>USB<br>H_R<br>ST | LDO<br>_BP<br>USB<br>H |
| Type<br>Reset | R/W<br>0                            | R/W<br>0         | R/W<br>0                       | R/W<br>0               | R/W<br>0            | R/W<br>0                | R/W<br>0            | R/W<br>0                | R/W<br>0                       | R/W<br>0               | R/W<br>0                       | R/W<br>0               | R/W<br>0            | R/W<br>0                | R/W<br>0                       | R/W<br>0               |

| Field Name | Bit | Туре | Reset | Description |
|------------|-----|------|-------|-------------|
|            |     |      | Value |             |



|                 | [31:16] | RO  | 16'h0 | Reserved                                                                                             |
|-----------------|---------|-----|-------|------------------------------------------------------------------------------------------------------|
| LDO_BPVB_RST    | [15]    | R/W | 1'h0  | When set, LDO_VB will power on (LDO bypass reset). This bit has higher priority than LDO_BPVB.       |
| LDO_BPVB        | [14]    | R/W | 1'h0  | LDO_VB_PD. When set, LDO_VB will power down (LDO bypassed).                                          |
| LDO_BPCAMA_RST  | [13]    | R/W | 1'h0  | When set, LDO_CAMA will power on (LDO bypass reset). This bit has higher priority than LDO_BPCAMA.   |
| LDO_BPCAMA      | [12]    | R/W | 1'h0  | LDO_CAMA_PD. When set, LDO_CAMA will power down (LDO bypassed).                                      |
| LDO_BPCAMD1_RST | [11]    | R/W | 1'h0  | When set, LDO_CAMD1 will power on (LDO bypass reset). This bit has higher priority than LDO_BPCAMD1. |
| LDO_BPCAMD1     | [10]    | R/W | 1'h0  | LDO_CAMD1_PD. When set, LDO_CAMD1 will power down (LDO bypassed).                                    |
| LDO_BPCAMD0_RST | [9]     | R/W | 1'h0  | When set, LDO_CAMD0 will power on (LDO bypass reset). This bit has higher priority than LDO_BPCAMD0. |
| LDO_BPCAMD0     | [8]     | R/W | 1'h0  | LDO_CAMD0_PD. When set, LDO_CAMD0 will power down (LDO bypassed).                                    |
| LDO_BPSIM1_RST  | [7]     | R/W | 1'h0  | When set, LDO_SIM1 will power on (LDO bypass reset). This bit has higher priority than LDO_BPSIM1.   |
| LDO_BPSIM1      | [6]     | R/W | 1'h0  | LDO_SIM1_PD. When set, LDO_SIM1 will power down (LDO bypassed).                                      |
| LDO_BPSIM0_RST  | [5]     | R/W | 1'h0  | When set, LDO_SIM0 will power on (LDO bypass reset). This bit has higher priority than LDO_BPSIM0.   |
| LDO_BPSIM0      | [4]     | R/W | 1'h0  | LDO_SIM0_PD. When set, LDO_SIM0 will power down (LDO bypassed).                                      |
| LDO_BPSDIO0_RST | [3]     | R/W | 1'h0  | When set, LDO_SDIO0 will power on (LDO bypass reset). This bit has higher priority than LDO_BPSDIO0. |



| LDO_BPSDIO0    | [2] | R/W | 1'h0 | LDO_SDIO0_PD. When set, LDO_SDIO0 will power down (LDO bypassed).                                  |
|----------------|-----|-----|------|----------------------------------------------------------------------------------------------------|
| LDO_BPUSBH_RST | [1] | R/W | 1'h0 | When set, LDO_USBH will power on (LDO bypass reset). This bit has higher priority than LDO_BPUSBH. |
| LDO_BPUSBH     | [0] | R/W | 1'h0 | LDO_USBH_PD. When set, LDO_USBH will power down (LDO bypassed).                                    |

### 10.1.1.6 LDO\_PD\_CTRL1

Description: LDO power down control1

| 0x0014 |          |                                     | LDO | power | down | contr | ol1(res                        | set 0x0                | 000_0              | 000)                   | •                              |                        |                    | LDO                    | PD_C                | TRL1                    |
|--------|----------|-------------------------------------|-----|-------|------|-------|--------------------------------|------------------------|--------------------|------------------------|--------------------------------|------------------------|--------------------|------------------------|---------------------|-------------------------|
| Bit    | 31       | 31 30 29 28 27 26 25 24 23 22 21 20 |     |       |      |       |                                |                        |                    |                        | 20                             | 19                     | 18                 | 17                     | 16                  |                         |
| Name   |          | Reserved                            |     |       |      |       |                                |                        |                    |                        |                                |                        |                    |                        |                     |                         |
| Туре   |          |                                     |     |       |      |       |                                | R                      | 0                  |                        |                                |                        |                    |                        |                     |                         |
| 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   | Reserved |                                     |     |       |      |       | LDO<br>_BP<br>SIM<br>3_R<br>ST | LDO<br>_BP<br>SIM<br>3 | LDO _BP SIM 2_R ST | LDO<br>_BP<br>SIM<br>2 | LDO<br>_BP<br>WIF<br>1_R<br>ST | LDO<br>_BP<br>WIF<br>1 | LDO _BP WIF 0_R ST | LDO<br>_BP<br>WIF<br>0 | LDO _BP SDI O1_ RST | LDO<br>_BP<br>SDI<br>O1 |
| Туре   |          |                                     | R   | 0     |      |       | 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                              | 0                      | 0                  | 0                      | 0                   | 0                       |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                                        |
|----------------|---------|------|----------------|----------------------------------------------------------------------------------------------------|
| ~ 0            | [31:10] | RO   | 22'h0          | Reserved                                                                                           |
| LDO_BPSIM3_RST | [9]     | R/W  | 1'h0           | When set, LDO_SIM3 will power on (LDO bypass reset). This bit has higher priority than LDO_BPSIM3. |
| LDO_BPSIM3     | [8]     | R/W  | 1'h0           | LDO_SIM3_PD. When set, LDO_SIM3 will power down (LDO bypassed).                                    |
| LDO_BPSIM2_RST | [7]     | R/W  | 1'h0           | When set, LDO_SIM2 will power on (LDO bypass reset). This bit has higher                           |



|                 |     |     |      | priority than LDO_BPSIM2.                                                                            |
|-----------------|-----|-----|------|------------------------------------------------------------------------------------------------------|
| LDO_BPSIM2      | [6] | R/W | 1'h0 | LDO_SIM2_PD. When set, LDO_SIM2 will power down (LDO bypassed).                                      |
| LDO_BPWIF1_RST  | [5] | R/W | 1'h0 | When set, LDO_WIF1 will power on (LDO bypass reset). This bit has higher priority than LDO_BPWIF1.   |
| LDO_BPWIF1      | [4] | R/W | 1'h0 | LDO_WIF1_PD. When set, LDO_WIF1 will power down (LDO bypassed).                                      |
| LDO_BPWIF0_RST  | [3] | R/W | 1'h0 | When set, LDO_WIF0 will power on (LDO bypass reset). This bit has higher priority than LDO_BPWIF0.   |
| LDO_BPWIF0      | [2] | R/W | 1'h0 | LDO_WIF0_PD. When set, LDO_WIF0 will power down (LDO bypassed).                                      |
| LDO_BPSDIO1_RST | [1] | R/W | 1'h0 | When set, LDO_SDIO1 will power on (LDO bypass reset). This bit has higher priority than LDO_BPSDIO2. |
| LDO_BPSDIO1     | [0] | R/W | 1'h0 | LDO_SDIO1_PD. When set, LDO_SDIO1 will power down (LDO bypassed).                                    |

### 10.1.1.7 LDO\_VCTRL0

| 0x0018 |    |        | LDO      | voltag                        | e cont                    | rol0 (r | eset 0 | x0000_ | _0000) |   |   |    | LDO_VCTRL0   |    |    |   |  |
|--------|----|--------|----------|-------------------------------|---------------------------|---------|--------|--------|--------|---|---|----|--------------|----|----|---|--|
| Bit    | 31 | 30     | 29       | 29 28 27 26 25 24 23 22 21 20 |                           |         |        |        |        |   |   | 19 | 18           | 17 | 16 |   |  |
| Name   |    |        | Reserved |                               |                           |         |        |        |        |   |   |    |              |    |    |   |  |
| Туре   |    |        |          | 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   | LC | O_AVDI | DBB_VC   | TL                            | LDO_RF1_VCTL LDO_RF0_VCTL |         |        |        |        |   |   |    | LDO_RTC_VCTL |    |    |   |  |
| Туре   |    | 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 |  |

| Field Name | Bit | Туре | Reset | Description |
|------------|-----|------|-------|-------------|
|            |     |      | Value |             |



|                 |         |     |       | SCOOTO Design Specia                                           |
|-----------------|---------|-----|-------|----------------------------------------------------------------|
|                 | [31:16] | RO  | 16'h0 | Reserved                                                       |
| LDO_AVDDBB_VCTL | [15:12] | R/W | 4'h0  | LDO_AVDDBB voltage control                                     |
|                 |         |     |       | [15]: ldo_avddbb_b1_rst, set this bit will clear ldo_avddbb_b1 |
|                 |         |     |       | [14]: ldo_avddbb_b1                                            |
|                 |         |     |       | [13]: ldo_avddbb_b0_rst, set this bit will clear ldo_avddbb_b0 |
|                 |         |     |       | [12]: ldo_avddbb_b0                                            |
|                 |         |     |       | b1b0: 00-3.0V 01-3.1V 10-2.9V<br>11-2.8V                       |
| LDO_RF1_VCTL    | [11:8]  | R/W | 4'h0  | LDO_RF1 voltage control                                        |
|                 |         |     |       | [11]: ldo_rf1_b1_rst, set this bit will clear<br>ldo_rf1_b1    |
|                 |         |     |       | [10]: ldo_rf1_b1                                               |
|                 |         |     |       | [9]: Ido_rf1_b0_rst, set this bit will clear                   |
|                 |         |     |       | ldo_rf1_b0                                                     |
|                 |         |     |       | [8]: Ido_rf1_b0                                                |
|                 |         |     |       | b1b0: 00-2.85V 01-2.95V 10-2.5V                                |
|                 |         |     |       | 11-1.8V                                                        |
| LDO_RF0_VCTL    | [7:4]   | R/W | 4'h0  | LDO_RF0 voltage control                                        |
|                 |         |     |       | [7]: Ido_rf0_b1_rst, set this bit will clear<br>Ido_rf0_b1     |
|                 |         |     |       | [6]: ldo_rf0_b1                                                |
|                 |         |     |       | [5]: ldo_rf0_b0_rst, set this bit will clear ldo_rf0_b0        |
|                 |         |     |       | [4]: ldo_rf0_b0                                                |
|                 |         |     |       | b1b0: 00-2.85V 01-2.95V 10-2.75V<br>11-1.8V                    |
| LDO_RTC_VCTL    | [3:0]   | R/W | 4'h0  | LDO_RTC voltage control                                        |
|                 | -       |     |       | [3]: Ido_rtc_b1_rst, set this bit will clear Ido_rtc_b1        |
|                 |         |     |       | [2]: Ido_rtc_b1                                                |
|                 |         |     |       | [1]: Ido_rtc_b0_rst, set this bit will clear Ido_rtc_b0        |
|                 |         |     |       | [0]: Ido_rtc_b0                                                |
|                 |         |     |       |                                                                |



#### 10.1.1.8 LDO\_VCTRL1

| 0x001C |    |        | LDO                   | voltag | e cont                    | rol1 (r | eset 0 | x0000_ | _0000) |    |    |    | LDO_VCTRL1    |    |    |    |
|--------|----|--------|-----------------------|--------|---------------------------|---------|--------|--------|--------|----|----|----|---------------|----|----|----|
| Bit    | 31 | 30     | 29                    | 28     | 27                        | 26      | 25     | 24     | 23     | 22 | 21 | 20 | 19            | 18 | 17 | 16 |
| Name   |    |        | Reserved              |        |                           |         |        |        |        |    |    |    |               |    |    |    |
| Туре   |    |        |                       | 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   | L  | DO_SDI | O <mark>0</mark> _VCT | L      | LDO_VB_VCTL LDO_SIM1_VCTL |         |        |        |        |    |    |    | LDO_SIM0_VCTL |    |    |    |
| Туре   |    | 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  |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                           |
|----------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [31:16] | RO   | 16'h0          | Reserved                                                                                                                                                                                                                              |
| LDO_SDIOO_VCTL | [15:12] | R/W  | 4'h0           | LDO_SDIOO voltage control  [15]: Ido_sdioO_b1_rst, set this bit will clear Ido_sdioO_b1  [14]: Ido_sdioO_b1  [13]: Ido_sdioO_b0_rst, set this bit will clear Ido_sdioO_b0  [12]: Ido_sdioO_b0  b1b0: 00-2.8V 01-3.0V 10-2.5V  11-1.8V |
| LDO_VB_VCTL    | [11:8]  | R/W  | 4'h0           | LDO_VB voltage control  [11]: Ido_vb_b1_rst, set this bit will clear Ido_vb_b1  [10]: Ido_vb_b1  [9]: Ido_vb_b0_rst, set this bit will clear Ido_vb_b0  [8]: Ido_vb_b0  b1b0: 00-3.3V 01-3.4V 10-3.2V  11-2.9V                        |
| LDO_SIM1_VCTL  | [7:4]   | R/W  | 4'h0           | LDO_SIM1 voltage control                                                                                                                                                                                                              |



|               |       |     |      | [7]: Ido_sim1_b1_rst, set this bit will clear Ido_sim1_b1 [6]: Ido_sim1_b1 [5]: Ido_sim1_b0_rst, set this bit will clear Ido_sim1_b0 [4]: Ido_sim1_b0 b1b0: 00-1.8V 01-2.9V 10-3.0V 11-3.1V                                |
|---------------|-------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LDO_SIMO_VCTL | [3:0] | R/W | 4'h0 | LDO_SIM0 voltage control  [3]: Ido_sim0_b1_rst, set this bit will clear Ido_sim0_b1  [2]: Ido_sim0_b1  [1]: Ido_sim0_b0_rst, set this bit will clear Ido_sim0_b0  [0]: Ido_sim0_b0  b1b0: 00-1.8V 01-2.9V 10-3.0V  11-3.1V |

### 10.1.1.9 LDO\_VCTRL2

| 0x0020 |    |         | LDO voltage control2 (reset 0x0000_0000) |    |                              |    |    |    |     |    |    |                |     | LDO_VCTRL2 |    |    |  |
|--------|----|---------|------------------------------------------|----|------------------------------|----|----|----|-----|----|----|----------------|-----|------------|----|----|--|
| Bit    | 31 | 30      | 29                                       | 28 | 27                           | 26 | 25 | 24 | 23  | 22 | 21 | 20             | 19  | 18         | 17 | 16 |  |
| Name   |    |         | Reserved                                 |    |                              |    |    |    |     |    |    |                |     |            |    |    |  |
| Туре   |    |         |                                          | 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   | L  | .DO_USI | BH_VCT                                   | L  | LDO_CAMA_VCTL LDO_CAMD1_VCTL |    |    |    |     |    |    | LDO_CAMD0_VCTL |     |            |    |    |  |
| Туре   |    | 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  |  |

| Field Name    | Bit     | Туре | Reset<br>Value | Description              |
|---------------|---------|------|----------------|--------------------------|
|               | [31:16] | RO   | 16'h0          | Reserved                 |
| LDO_USBH_VCTL | [15:12] | R/W  | 4'h0           | LDO_USBH voltage control |



|                |        |     |      | [15]: Ido_usbh_b1_rst, set this bit will clear Ido_usbh_b1 [14]: Ido_usbh_b1 [13]: Ido_usbh_b0_rst, set this bit will clear Ido_usbh_b0 [12]: Ido_usbh_b0 b1b0: 00-3.3V 01-3.4V 10-3.2V 11-3.1V                                   |
|----------------|--------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LDO_CAMA_VCTL  | [11:8] | R/W | 4'h0 | LDO_CAMA voltage control [11]: Ido_cama_b1_rst, set this bit will clear Ido_cama_b1 [10]: Ido_cama_b1 [9]: Ido_cama_b0_rst, set this bit will clear Ido_cama_b0 [8]: Ido_cama_b0 b1b0: 00-2.8V 01-3.0V 10-2.5V 11-1.8V            |
| LDO_CAMD1_VCTL | [7:4]  | R/W | 4'h0 | LDO_CAMD1 voltage control  [7]: Ido_camd1_b1_rst, set this bit will clear Ido_camd1_b1  [6]: Ido_camd1_b1  [5]: Ido_camd1_b0_rst, set this bit will clear Ido_camd1_b0  [4]: Ido_camd1_b0  b1b0: 00-2.8V 01-3.8V 10-1.8V  11-1.2V |
| LDO_CAMD0_VCTL | [3:0]  | R/W | 4'h0 | LDO_CAMD0 voltage control  [3]: Ido_camd0_b1_rst, set this bit will clear Ido_camd0_b1  [2]: Ido_camd0_b1  [1]: Ido_camd0_b0_rst, set this bit will clear Ido_camd0_b0  [0]: Ido_camd0_b0  b1b0: 00-1.8V 01-2.8V 10-1.5V  11-1.3V |



### 10.1.1.10 LDO\_VCTRL3

| 0x0024 |    |        | LDO      | voltag | e cont                        | rol3 (r | eset 0 | x0000_ | _0000) |    |    |    |                | LD | O_VC | TRL3 |
|--------|----|--------|----------|--------|-------------------------------|---------|--------|--------|--------|----|----|----|----------------|----|------|------|
| Bit    | 31 | 30     | 29       | 28     | 27                            | 26      | 25     | 24     | 23     | 22 | 21 | 20 | 19             | 18 | 17   | 16   |
| Name   |    |        | Reserved |        |                               |         |        |        |        |    |    |    |                |    |      |      |
| Туре   |    |        |          | 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   | L  | DO_SDI | O1_VCT   | L      | LDO_VDD25_VCTL LDO_VDD18_VCTL |         |        |        |        |    |    | ī  | LDO_VDD28_VCTL |    |      |      |
| Туре   |    | 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    |

| Field Name     | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                           |
|----------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | [31:16] | RO   | 16'h0          | Reserved                                                                                                                                                                                                                              |
| LDO_SDIO1_VCTL | [15:12] | R/W  | 4'h0           | LDO_SDIO1 voltage control  [15]: Ido_sdio1_b1_rst, set this bit will clear Ido_sdio1_b1  [14]: Ido_sdio1_b1  [13]: Ido_sdio1_b0_rst, set this bit will clear Ido_sdio1_b0  [12]: Ido_sdio1_b0  b1b0: 00-2.8V 01-3.0V 10-2.5V  11-1.8V |
| LDO_VDD25_VCTL | [11:8]  | R/W  | 4'h0           | LDO_VDD25 voltage control [11]: Ido_vdd25_b1_rst, set this bit will clear Ido_vdd25_b1 [10]: Ido_vdd25_b1 [9]: Ido_vdd25_b0_rst, set this bit will clear Ido_vdd25_b0 [8]: Ido_vdd25_b0 b1b0: 00-2.5V 01-2.75V 10-3.0V 11-2.9V        |
| LDO_VDD18_VCTL | [7:4]   | R/W  | 4'h0           | LDO_VDD18 voltage control                                                                                                                                                                                                             |



|                |       |     |      | [11]: Ido_vdd18_b1_rst, set this bit will clear Ido_vdd18_b1 [10]: Ido_vdd18_b1 [9]: Ido_vdd18_b0_rst, set this bit will clear Ido_vdd18_b0 [8]: Ido_vdd18_b0 b1b0: 00-1.8V 01-2.8V 10-1.5V 11-1.2V                            |
|----------------|-------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LDO_VDD28_VCTL | [3:0] | R/W | 4'h0 | LDO_VDD28 voltage control [11]: Ido_vdd28_b1_rst, set this bit will clear Ido_vdd28_b1 [10]: Ido_vdd28_b1 [9]: Ido_vdd28_b0_rst, set this bit will clear Ido_vdd28_b0 [8]: Ido_vdd28_b0 b1b0: 00-2.8V 01-3.0V 10-2.65V 11-1.8V |

### 10.1.1.11 LDO\_VCTRL4

| 0x0028 |    | LDO voltage control4 (reset 0x0000_0000) LDO_VCTRL |         |                                    |     |    |    |    |    |    | TRL4          |    |    |    |     |    |  |  |
|--------|----|----------------------------------------------------|---------|------------------------------------|-----|----|----|----|----|----|---------------|----|----|----|-----|----|--|--|
| Bit    | 31 | 30                                                 | 29      | 28                                 | 27  | 26 | 25 | 24 | 23 | 22 | 21            | 20 | 19 | 18 | 17  | 16 |  |  |
| Name   |    | Reserved                                           |         |                                    |     |    |    |    |    |    |               |    |    |    |     |    |  |  |
| Туре   |    | 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   |    | LDO_SIN                                            | M3_VCTL | 3_VCTL LDO_SIM2_VCTL LDO_WIF1_VCTL |     |    |    |    |    | -  | LDO_WIF0_VCTL |    |    |    |     |    |  |  |
| Туре   |    | 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  |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description |
|------------|---------|------|----------------|-------------|
|            | [31:16] | RO   | 16'h0          | Reserved    |



| -             |         |     |      |                                                            |
|---------------|---------|-----|------|------------------------------------------------------------|
| LDO_SIM3_VCTL | [15:12] | R/W | 4'h0 | LDO_SIM3 voltage control                                   |
|               |         |     |      | [15]: Ido_sim3_b1_rst, set this bit will clear Ido_sim3_b1 |
|               |         |     |      | [14]: ldo_sim3_b1                                          |
|               |         |     |      | [13]: Ido_sim3_b0_rst, set this bit will clear Ido_sim3_b0 |
|               |         |     |      | [12]: ldo_sim3_b0                                          |
|               |         |     |      | b1b0: 00-2.8V 01-3V 10-1.8V<br>11-1.2V                     |
| LDO_SIM2_VCTL | [11:8]  | R/W | 4'h0 | LDO_SIM2 voltage control                                   |
|               |         |     |      | [11]: ldo_sim2_b1_rst, set this bit will clear ldo_sim2_b1 |
|               |         |     |      | [10]: ldo_sim2_b1                                          |
|               |         |     |      | [9]: Ido_sim2_b0_rst, set this bit will clear Ido_sim2_b0  |
|               |         |     |      | [8]: Ido_sim2_b0                                           |
|               |         |     |      | b1b0: 00-2.8V 01-3V 10-1.8V                                |
|               |         |     |      | 11-1.2V                                                    |
| LDO_WIF1_VCTL | [7:4]   | R/W | 4'h0 | LDO_WIF1 voltage control                                   |
|               |         |     |      | [7]: Ido_wif1_b1_rst, set this bit will clear Ido_wif1_b1  |
|               |         |     |      | [6]: ldo_wif1_b1                                           |
|               |         |     |      | [5]: Ido_wif1_b0_rst, set this bit will clear Ido_wif1_b0  |
| 1             |         |     |      | [4]: Ido_wif1_b0                                           |
|               |         |     |      | b1b0: 00-2.8V 01-3.3V 10-1.8V                              |
|               |         |     |      | 11-1.2V                                                    |
| LDO_WIF0_VCTL | [3:0]   | R/W | 4'h0 | LDO_WIF0 voltage control                                   |
| 0.0           |         |     |      | [3]: Ido_wif0_b1_rst, set this bit will clear Ido_wif0_b1  |
|               |         |     |      | [2]: ldo_wif0_b1                                           |
|               |         |     |      | [1]: Ido_wif0_b0_rst, set this bit will clear Ido_wif0_b0  |
|               |         |     |      | [0]: Ido_wif0_b0                                           |
|               |         |     |      | b1b0: 00-2.8V 01-3.3V 10-1.8V                              |



## 10.1.1.12 LDO\_SLP\_CTRL0

Description: LDO sleep control0

| 0x002C |                                        |                  | LDO sleep control0 (reset 0x0000_A7FF) |                         |                         |                           |                                        |                                 |                                       |                         |                                        |                                       | LDO_SLP_CTRL0                          |                                        |                                       |                        |
|--------|----------------------------------------|------------------|----------------------------------------|-------------------------|-------------------------|---------------------------|----------------------------------------|---------------------------------|---------------------------------------|-------------------------|----------------------------------------|---------------------------------------|----------------------------------------|----------------------------------------|---------------------------------------|------------------------|
| Bit    | 31                                     | 30               | 29                                     | 28                      | 27                      | 26                        | 25                                     | 24                              | 23                                    | 22                      | 21                                     | 20                                    | 19                                     | 18                                     | 17                                    | 16                     |
| Name   |                                        | Reserved         |                                        |                         |                         |                           |                                        |                                 |                                       |                         |                                        |                                       |                                        |                                        |                                       |                        |
| Туре   |                                        |                  |                                        |                         |                         |                           |                                        | R                               | 0                                     |                         |                                        |                                       |                                        |                                        |                                       |                        |
| 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   | FSM<br>_LD<br>OSD<br>IO1_<br>BP_<br>EN | Res<br>erve<br>d | FSM _LD OVD D25 _BP _EN                | FSM _LD OVD D18 _BP _EN | FSM _LD OVD D28 _BP _EN | FSM _LD OAV DDB B_B P_E N | FSM<br>_LD<br>OSD<br>IOO_<br>BP_<br>EN | FSM<br>_LD<br>OVB<br>_BP<br>_EN | FSM<br>_LD<br>OCA<br>MA_<br>BP_<br>EN | FSM _LD OCA MD1 _BP _EN | FSM<br>_LD<br>OCA<br>MD0<br>_BP<br>_EN | FSM<br>_LD<br>OUS<br>BH_<br>BP_<br>EN | FSM<br>_LD<br>O_S<br>IM1_<br>BP_<br>EN | FSM<br>_LD<br>O_S<br>IMO_<br>BP_<br>EN | FSM<br>_LD<br>O_R<br>F1_<br>BP_<br>EN | FSM _LD O_R FO_ BP_ EN |
| Туре   | R/W                                    | RO               | R/W                                    | R/W                     | R/W                     | R/W                       | R/W                                    | R/W                             | R/W                                   | R/W                     | R/W                                    | R/W                                   | R/W                                    | R/W                                    | R/W                                   | R/W                    |
| Reset  | 1                                      | 0                | 1                                      | 0                       | 0                       | 1                         | 1                                      | 1                               | 1                                     | 1                       | 1                                      | 1                                     | 1                                      | 1                                      | 1                                     | 1                      |

| Field Name         | Bit     | Туре | Reset<br>Value | Description                                                                                |
|--------------------|---------|------|----------------|--------------------------------------------------------------------------------------------|
|                    | [31:16] | RO   | 16'h0          | Reserved                                                                                   |
| FSM_LDOSDIO1_BP_EN | [15]    | R/W  | 1'h1           | When set, LDOSDIO1 automatically power down in chip sleep mode(FSM_SLPPD_EN should be set) |
|                    | [14]    | RO   | 1'h0           | Reserved                                                                                   |
| FSM_LDOVDD25_BP_EN | [13]    | R/W  | 1'h1           | When set, LDOVDD25 automatically power down in chip sleep mode(FSM_SLPPD_EN should be set) |
| FSM_LDOVDD18_BP_EN | [12]    | R/W  | 1'h0           | When set, LDOVDD18 power down if FSM_SLPPD_EN is active.                                   |
| FSM_LDOVDD28_BP_EN | [11]    | R/W  | 1'h0           | When set, LDOVDD28 power down if FSM_SLPPD_EN is active.                                   |



| ·                   |      |     |      |                                                                                            |
|---------------------|------|-----|------|--------------------------------------------------------------------------------------------|
| FSM_LDOAVDDBB_BP_EN | [10] | R/W | 1'h1 | When set, LDOAVDDBB will power down if XTLEN is low(FSM_SLPPD_EN should be set);           |
| FSM_LDOSDIO0_BP_EN  | [9]  | R/W | 1'h1 | When set, LDOSDIO0 automatically power down in chip sleep mode(FSM_SLPPD_EN should be set) |
| FSM_LDOVB_BP_EN     | [8]  | R/W | 1'h1 | When set, LDOVB automatically power down in chip sleep mode(FSM_SLPPD_EN should be set)    |
| FSM_CAMA_BP_EN      | [7]  | R/W | 1'h1 | When set, LDOCAMA automatically power down in chip sleep mode(FSM_SLPPD_EN should be set)  |
| FSM_CAMD1_BP_EN     | [6]  | R/W | 1'h1 | When set, LDOCAMD1 automatically power down in chip sleep mode(FSM_SLPPD_EN should be set) |
| FSM_CAMD0_BP_EN     | [5]  | R/W | 1'h1 | When set, LDOCAMD0 automatically power down in chip sleep mode(FSM_SLPPD_EN should be set) |
| FSM_USBH_BP_EN      | [4]  | R/W | 1'h1 | When set, LDOUSB automatically power down in chip sleep mode(FSM_SLPPD_EN should be set)   |
| FSM_SIM1_BP_EN      | [3]  | R/W | 1'h1 | When set, LDOSIM1 automatically power down in chip sleep mode(FSM_SLPPD_EN should be set)  |
| FSM_SIM0_BP_EN      | [2]  | R/W | 1'h1 | When set, LDOSIM0 automatically power down in chip sleep mode(FSM_SLPPD_EN should be set)  |
| FSM_RF1_BP_EN       | [1]  | R/W | 1'h1 | When set, LDORF1 will power down if XTLEN is low(FSM_SLPPD_EN                              |



|               |     |     |      | should be set);                                                               |
|---------------|-----|-----|------|-------------------------------------------------------------------------------|
| FSM_RF0_BP_EN | [0] | R/W | 1'h1 | When set, LDORF0 will power down if XTLEN is low(FSM_SLPPD_EN should be set); |

## 10.1.1.13 LDO\_SLP\_CTRL1

Description: LDO sleep control1

| 0x0030 |                          |          | LDO     | sleep | contro            | l1 (res                 | et 0x0 | 000_7    | 01F) |   |   |                                       |                    | LDO_S              | SLP_C                          | TRL1                           |
|--------|--------------------------|----------|---------|-------|-------------------|-------------------------|--------|----------|------|---|---|---------------------------------------|--------------------|--------------------|--------------------------------|--------------------------------|
| Bit    | 31                       | 30       | 29      | 28    | 27                | 27 26 25 24 23 22 21 20 |        |          |      |   |   |                                       |                    | 18                 | 17                             | 16                             |
| Name   |                          | Reserved |         |       |                   |                         |        |          |      |   |   |                                       |                    |                    |                                |                                |
| Туре   |                          |          | 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   | FSM<br>_SL<br>PPD<br>_EN | ARME     | OCDC_PI | WR_O  |                   |                         |        | Reserved | i    |   |   | FSM<br>_DC<br>DCA<br>RM_<br>BP_<br>EN | FSM _SI M3_ BP_ EN | FSM _SI M2_ BP_ EN | FSM<br>_WI<br>F1_<br>BP_<br>EN | FSM<br>_WI<br>F0_<br>BP_<br>EN |
| Туре   | R/W                      |          | R/W     |       | RO RW RW RW RW RW |                         |        |          |      |   |   | R/W                                   |                    |                    |                                |                                |
| Reset  | 0                        | 1        | 1       | 1     | 0                 | 0                       | 0      | 0        | 0    | 0 | 0 | 1                                     | 1                  | 1                  | 1                              | 1                              |

| Field Name         | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                   |
|--------------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | [31:16] | RO   | 16'h0          | Reserved                                                                                                                                                                                      |
| FSM_SLPPD_EN       | [15]    | R/W  | 1'h0           | When set, LDOSIM0, LDOSIM1, LDOUSBH, LDOCAMD1, LDOCAMD0, LDOCAMA, LDOVB, LDOSDIO, LDOVDD25, LDOSDIO1, LDOWIF0, LDOWIF1, LDOSIM2, LDOSIM3, DCDCARM automatically power down in chip sleep mode |
| ARMDCDC_PWR_ON_DLY | [14:12] | R/W  | 3'h7           |                                                                                                                                                                                               |
|                    | [11:5]  | R/W  | 10'h0          | Reserved                                                                                                                                                                                      |



| FSM_DCDCARM_BP_EN | [4] | R/W | 1'h1 | When set, DCDCARM will power down (FSM_SLPPD_EN should be set); |
|-------------------|-----|-----|------|-----------------------------------------------------------------|
| FSM_SIM3_BP_EN    | [3] | R/W | 1'h1 | When set, LDOSIM3 will power down (FSM_SLPPD_EN should be set); |
| FSM_SIM2_BP_EN    | [2] | R/W | 1'h1 | When set, LDOSIM2 will power down (FSM_SLPPD_EN should be set); |
| FSM_WIF1_BP_EN    | [1] | R/W | 1'h1 | When set, LDOWIF1 will power down (FSM_SLPPD_EN should be set); |
| FSM_WIF0_BP_EN    | [0] | R/W | 1'h1 | When set, LDOWIF0 will power down (FSM_SLPPD_EN should be set); |

### 10.1.1.14 LDO\_SLP\_CTRL2

Description: LDO sleep control2

| 0x0034 |    |                                        | LDO sleep control2(reset 0x0000_FFFF) LDO_SLP_CTRL2 |    |    |    |    |    |    |    |    |    | TRL2 |    |    |    |
|--------|----|----------------------------------------|-----------------------------------------------------|----|----|----|----|----|----|----|----|----|------|----|----|----|
| Bit    | 31 | 30                                     | 29                                                  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18 | 17 | 16 |
| Name   |    |                                        | Reserved                                            |    |    |    |    |    |    |    |    |    |      |    |    |    |
| Туре   |    | 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   |    | ARMDCDC_ISO_ON_NUM ARMDCDC_ISO_OFF_NUM |                                                     |    |    |    |    |    |    |    |    |    |      |    |    |    |
| Туре   |    | R/W R/W                                |                                                     |    |    |    |    |    |    |    |    |    |      |    |    |    |
| Reset  | 1  | 1                                      | 1                                                   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1    | 1  | 1  | 1  |

| Field Name          | Bit     | Туре | Reset<br>Value | Description                                                         |
|---------------------|---------|------|----------------|---------------------------------------------------------------------|
|                     | [31:16] | RO   | 16'h0          | Reserved                                                            |
| ARMDCDC_ISO_ON_NUM  | [15:8]  | R/W  | 8'hff          | Set CLK32K cycles between pd & iso signal when ARMDCDC powered down |
| ARMDCDC_ISO_OFF_NUM | [7:0]   | R/W  | 8'hff          | Set CLK32K cycles between iso &                                     |



|  |  | pd signal when ARMDCDC powered |
|--|--|--------------------------------|
|  |  | on.                            |

### 10.1.1.15 DCDC\_CTRL

Description: DCDC control

| 0x0038 |      |       | DCD                   | C cont                            | rol (re                  | set 0x(             | 0000_0               | 000)            |                  |      |       |       |                  | D    | CDC_0  | CTRL |
|--------|------|-------|-----------------------|-----------------------------------|--------------------------|---------------------|----------------------|-----------------|------------------|------|-------|-------|------------------|------|--------|------|
| Bit    | 31   | 30    | 29                    | 28                                | 27                       | 26                  | 25                   | 24              | 23               | 22   | 21    | 20    | 19               | 18   | 17     | 16   |
| Name   |      |       |                       |                                   |                          |                     |                      | Rese            | erved            |      |       |       |                  |      |        |      |
| Туре   |      |       |                       |                                   |                          |                     |                      | R               | 0                |      |       |       |                  |      |        |      |
| 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   | Rese | erved | DC DC_ RES ERV E_R ST | DC DC_ RES ERV E                  | DC DC_ DE DTD ELA Y_R ST | DC DC_ DE DTD ELA Y | DC DC_ DE DTE N_R ST | DC DC_ DE DTE N | Res<br>erve<br>d | DCDC | CTL_4 | .0NM_ | Res<br>erve<br>d | DCD0 | C_CTL_ | 40NM |
| Туре   | R    | 0     | R/W                   | R/W R/W R/W R/W R/W RO R/W RO R/W |                          |                     |                      |                 |                  |      |       |       |                  |      |        |      |
| Reset  | 0    | 0     | 0                     | 0                                 | 0                        | 0                   | 0                    | 0               | 0                | 0    | 0     | 0     | 0                | 0    | 0      | 0    |

| Field Name         | Bit     | Туре | Reset<br>Value | Description                                                                                    |
|--------------------|---------|------|----------------|------------------------------------------------------------------------------------------------|
|                    | [31:14] | RO   | 18'h0          | Reserved                                                                                       |
| DCDC_RESERVE_RST   | [13]    | R/W  | 1'h0           | Set this bit will reset DCDC_RESERVE to 0. This bit has higher priority than DCDC_RESERVE.     |
| DCDC_RESERVE       | [12]    | R/W  | 1'h0           | DCDC reserve control bit                                                                       |
| DCDC_DEDTDELAY_RST | [11]    | R/W  | 1'h0           | Set this bit will reset DCDC_DEDTDELAY to 0. This bit has higher priority than DCDC_DEDTDELAY. |



| DCDC_DEDTDELAY    | [10]  | R/W | 1'h0 | DCDC decrease dead-time delay control bit                                                                                            |
|-------------------|-------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------|
| DCDC_DEDTEN_RST   | [9]   | R/W | 1'h0 | Set this bit will reset DCDC_DEDTEN to 0. This bit has higher priority than DCDC_DEDTEN.                                             |
| DCDC_DEDTEN       | [8]   | R/W | 1'h0 | DCDC decrease dead-time enable, High effective                                                                                       |
|                   | [7]   | RO  | 1'h0 | Reserved                                                                                                                             |
| DCDC_CTL_40NM_RST | [6:4] | R/W | 3'h0 | Set each bit will reset relative bit of DCDC_CTL_40NM                                                                                |
|                   | [3]   | RO  | 1'b0 | Reserved                                                                                                                             |
| DCDC_CTL_40NM     | [2:0] | R/W | 3'h0 | DC-DC converter control bits(process-40nm) 000: 0.65V 001: 0.7V 010: 0.8V 011: 0.9V 100: 1.0V 101: 1.1V(default) 110: 1.2V 111: 1.3V |

### 10.1.1.16 DCDC\_CTRL\_DS

Description: DCDC control in deep sleep.



| 0x0030    | ;  |              | DCD | C cor    | trol ir | n deep | slee | p(rese | et 0x0           | 000_0 | 300)              |    | D                | CDC_ | CTRL         | _DS   |
|-----------|----|--------------|-----|----------|---------|--------|------|--------|------------------|-------|-------------------|----|------------------|------|--------------|-------|
| Bit       | 31 | 30           | 29  | 28       | 27      | 26     | 25   | 24     | 23               | 22    | 21                | 20 | 19               | 18   | 17           | 16    |
| Nam<br>e  |    |              |     | Reserved |         |        |      |        |                  |       |                   |    |                  |      |              |       |
| Туре      |    |              |     | RO       |         |        |      |        |                  |       |                   |    |                  |      |              |       |
| Rese<br>t | 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      |    | DCDC_LVL_DLY |     |          |         |        |      |        | Res<br>erve<br>d |       | :_CTL_4<br>DS_RST |    | Res<br>erve<br>d | DCDC | _CTL_4<br>DS | -0NM_ |
| Туре      |    |              |     | R/       | W       |        |      |        | RO               | R/W   |                   |    | RO               | R/W  |              |       |
| Reset     | 0  | 0            | 0   | 0        | 0       | 0      | 1    | 1      | 0                | 0     | 0                 | 0  | 0                | 0    | 0            | 0     |

| Field Name           | Bit     | Туре | Reset<br>Value | Description                                                                                                                          |
|----------------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------|
|                      | [31:16] | RO   | 16'h0          | Reserved                                                                                                                             |
| DCDC_LVL_DLY         | [15:8]  | R/W  | 8'h3           | 40nm voltage drop count delay time                                                                                                   |
|                      | [7]     | RO   | 1'b0           | Reserved                                                                                                                             |
| DCDC_CTL_40NM_DS_RST | [6:4]   | R/W  | 3'h0           | Set each bit will reset relative bit of DCDC_CTL_40NM_DS                                                                             |
| 1 1 1                | [3]     | RO   | 1'b0           | Reserved                                                                                                                             |
| DCDC_CTL_40NM_DS     | [2:0]   | R/W  | 3'h0           | DC-DC converter control bits(process-40nm) 000: 0.65V 001: 0.7V 010: 0.8V 011: 0.9V(default) 100: 1.0V 101: 1.1V 110: 1.2V 111: 1.3V |



### 10.1.1.17 DCDC\_CTRL\_CAL

Description: DCDC calibration control

| 0x0040    | )  |             | DCD                                          | C cali                         | bratic | n cor | ntrol(r | eset 0 | x0000 | 0000 | D) |   | DC  | CDC_C | TRL_ | CAL |
|-----------|----|-------------|----------------------------------------------|--------------------------------|--------|-------|---------|--------|-------|------|----|---|-----|-------|------|-----|
| Bit       | 31 | 30          | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                                |        |       |         |        |       |      |    |   |     |       |      |     |
| Nam<br>e  |    | Reserved    |                                              |                                |        |       |         |        |       |      |    |   |     |       |      |     |
| Туре      |    |             |                                              |                                |        |       |         | R      | 0     |      |    |   |     |       |      |     |
| Rese<br>t | 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      | F  | Reserve     | d                                            | DCDC_CAL_RST Reserved DCDC_CAL |        |       |         |        |       |      |    |   |     |       |      |     |
| Туре      |    | RO          |                                              | R/W                            |        |       |         |        |       | RO   |    |   | R/W |       |      |     |
| Reset     | 0  | 0 0 0 0 0 0 |                                              |                                |        |       |         |        | 0     | 0    | 0  | 0 | 0   | 0     | 0    | 0   |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                                          |
|--------------|---------|------|----------------|--------------------------------------------------------------------------------------|
|              | [31:13] | RO   | 19'h0          | Reserved                                                                             |
| DCDC_CAL_RST | [12:8]  | R/W  | 5'h0           | Set each bit will reset relative bit of DCDC_CAL                                     |
|              | [7:5]   | RO   | 1'b0           | Reserved                                                                             |
| DCDC_CAL     | [4:0]   | R/W  | 5'h0           | DCDC calibration control bits,<br>(default 00000) Small adjust<br>voltage: 100/32 mv |

## 10.1.1.18 DCDCARM\_CTRL

Description: DCDCARM control



| 0x0044 |      |          | DCD                        | CARM                  | contro                        | ol (rese                 | et 0x00                   | 00_00                | 00)              |      |        |       |                  | D   | CDC_0 | CTRL |
|--------|------|----------|----------------------------|-----------------------|-------------------------------|--------------------------|---------------------------|----------------------|------------------|------|--------|-------|------------------|-----|-------|------|
| Bit    | 31   | 30       | 29                         | 28                    | 27                            | 26                       | 25                        | 24                   | 23               | 22   | 21     | 20    | 19               | 18  | 17    | 16   |
| Name   |      | Reserved |                            |                       |                               |                          |                           |                      |                  |      |        |       |                  |     |       |      |
| Туре   |      |          |                            |                       |                               |                          |                           | R                    | 0                |      |        |       |                  |     |       |      |
| 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   | Rese | erved    | DC DC AR M_ RES ERV E_R ST | DC DC AR M_ RES ERV E | DC DC AR M_ DE DTD ELA Y_R ST | DC DC AR M_ DE DTD ELA Y | DC DC AR M_ DE DTE N_R ST | DC DC AR M_ DE DTE N | Res<br>erve<br>d | DCDC | CARM_C | CTL_R | Res<br>erve<br>d | DCD | CARM_ | CTL  |
| Туре   | R    | 0        | R/W                        | R/W                   | R/W                           | R/W                      | R/W                       | R/W                  | RO               |      | R/W    |       | RO               |     | R/W   | ·    |
| Reset  | 0    | 0        | 0                          | 0                     | 0                             | 0                        | 0                         | 0                    | 0                | 0    | 0      | 0     | 0                | 0   | 0     | 0    |

| Field Name            | Bit     | Туре | Reset<br>Value | Description                                                                                          |
|-----------------------|---------|------|----------------|------------------------------------------------------------------------------------------------------|
|                       | [31:14] | RO   | 18'h0          | Reserved                                                                                             |
| DCDCARM_RESERVE_RST   | [13]    | R/W  | 1'h0           | Set this bit will reset  DCDCARM_RESERVE to 0. This bit has higher priority than  DCDCARM_RESERVE.   |
| DCDCARM_RESERVE       | [12]    | R/W  | 1'h0           | DCDCARM reserve control bit                                                                          |
| DCDCARM_DEDTDELAY_RST | [11]    | R/W  | 1'h0           | Set this bit will reset DCDCARM_DEDTDELAY to 0. This bit has higher priority than DCDCARM_DEDTDELAY. |
| DCDCARM_DEDTDELAY     | [10]    | R/W  | 1'h0           | DCDCARM decrease dead-time delay control bit                                                         |
| DCDCARM_DEDTEN_RST    | [9]     | R/W  | 1'h0           | Set this bit will reset DCDCARM_DEDTEN to 0. This bit has higher priority than                       |



|                 |       |     |      | DCDCARM_DEDTEN.                                                                                                            |
|-----------------|-------|-----|------|----------------------------------------------------------------------------------------------------------------------------|
| DCDCARM_DEDTEN  | [8]   | R/W | 1'h0 | DCDCARM decrease dead-time enable,high effective                                                                           |
|                 | [7]   | RO  | 1'h0 | Reserved                                                                                                                   |
| DCDCARM_CTL_RST | [6:4] | R/W | 3'h0 | Set each bit will reset relative bit of DCDCARM_CTL                                                                        |
|                 | [3]   | RO  | 1'b0 | Reserved                                                                                                                   |
| DCDCARM_CTL     | [2:0] | R/W | 3'h0 | DC-DC ARM converter control bits 000: 0.65V 001: 0.7V 010: 0.8V 011: 0.9V 100: 1.0V 101: 1.1V 110: 1.2V(default) 111: 1.3V |

#### 10.1.1.19 DCDCARM\_CTRL\_CAL

Description: DCDCARM calibration control

| 0x0048   | 1  |          | DCDCARM calibration control(reset 0x0000_0000) |                                           |    |     |   |   |    |   |   |   |     |   |   | M_CTRL_<br>CAL |  |  |
|----------|----|----------|------------------------------------------------|-------------------------------------------|----|-----|---|---|----|---|---|---|-----|---|---|----------------|--|--|
| Bit      | 31 | 30       | 29                                             | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |     |   |   |    |   |   |   |     |   |   |                |  |  |
| Nam<br>e |    | Reserved |                                                |                                           |    |     |   |   |    |   |   |   |     |   |   |                |  |  |
| Туре     |    |          |                                                | RO                                        |    |     |   |   |    |   |   |   |     |   |   |                |  |  |
| Rese     | 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     | F  | Reserve  | t                                              | DCDCARM_CAL_RST Reserved DCDCARM_CAL      |    |     |   |   |    |   |   |   |     |   |   |                |  |  |
| Туре     |    | RO       |                                                |                                           |    | R/W |   |   | RO |   |   |   | R/W |   |   |                |  |  |
| Reset    | 0  | 0        | 0                                              | 0                                         | 0  | 0   | 0 | 0 | 0  | 0 | 0 | 0 | 0   | 0 | 0 | 0              |  |  |



| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                             |
|-----------------|---------|------|----------------|-----------------------------------------------------------------------------------------|
|                 | [31:13] | RO   | 19'h0          | Reserved                                                                                |
| DCDCARM_CAL_RST | [12:8]  | R/W  | 5'h0           | Set each bit will reset relative bit of DCDCARM_CAL                                     |
|                 | [7:5]   | RO   | 1'b0           | Reserved                                                                                |
| DCDCARM_CAL     | [4:0]   | R/W  | 5'h0           | DCDCARM calibration control bits,<br>(default 00000) Small adjust<br>voltage: 100/32 mv |

#### 10.1.1.20 PLL\_CTRL

Description: PLL control

| 0x004C |    |                                    | PLL ( | contro                                    | l (rese | t 0x00 | 00_000 | 04)  |       | 1 |   |   |                   |                        | PLL_0                         | CTRL                  |
|--------|----|------------------------------------|-------|-------------------------------------------|---------|--------|--------|------|-------|---|---|---|-------------------|------------------------|-------------------------------|-----------------------|
| Bit    | 31 | 30                                 | 29    | 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |        |        |      |       |   |   |   |                   |                        |                               |                       |
| Name   |    |                                    |       |                                           |         |        |        | Rese | erved |   |   |   |                   |                        |                               |                       |
| Туре   |    |                                    |       |                                           |         |        |        | R    | 0     |   |   |   |                   |                        |                               |                       |
| 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   |    |                                    |       |                                           |         | Rese   | erved  |      |       |   |   |   | APL<br>LMN<br>_WE | APL<br>L_P<br>D_E<br>N | APL<br>L_F<br>ORC<br>E_P<br>D | APL L_F ORC E_P D_E N |
| Туре   |    | RO RW RW R/W R/W                   |       |                                           |         |        |        |      |       |   |   |   |                   |                        |                               |                       |
| Reset  | 0  | 0                                  | 0     | 0                                         | 0       | 0      | 0      | 0    | 0     | 0 | 0 | 0 | 0                 | 1                      | 0                             | 0                     |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                   |
|------------|--------|------|----------------|-----------------------------------------------|
|            | [31:4] | RO   | 28'h0          | Reserved                                      |
| APLL_MN_WE | [3]    | R/W  | 1'h0           | APLL MN register write enable                 |
| APLL_PD_EN | [2]    | R/W  | 1'h1           | If true, chip sleep will make APLL power down |



| APLL_FORCE_PD    | [1] | R/W | 1'h0 | APLL force power down                                                                                       |
|------------------|-----|-----|------|-------------------------------------------------------------------------------------------------------------|
|                  |     |     |      | This signal will be active only when APLL_FORCE_PD_EN is set;                                               |
| APLL_FORCE_PD_EN | [0] | R/W | 1'h0 | Enable software to power down APLL; This signal should be set at first so that APLL_FORCE_PD will be active |

#### 10.1.1.21 APLLMN

Description: APLL MN control

| 0x0050 |    |          | APLI  | MN c  | ontrol | (reset | 0x0000 | )_68C | 0) |    |       |    |    |    | APL | LMN |
|--------|----|----------|-------|-------|--------|--------|--------|-------|----|----|-------|----|----|----|-----|-----|
| Bit    | 31 | 30       | 29    | 28    | 27     | 26     | 25     | 24    | 23 | 22 | 21    | 20 | 19 | 18 | 17  | 16  |
| Name   |    | Reserved |       |       |        |        |        |       |    |    |       |    |    |    |     |     |
| Туре   |    |          | 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   |    |          | APLLM |       |        |        |        |       |    |    | APLLN |    |    |    |     |     |
| Туре   |    |          | R/W   | W R/W |        |        |        |       |    |    |       |    |    |    |     |     |
| Reset  | 0  | 1        | 1     | 0     | 1      | 0      | 0      | 0     | 1  | 1  | 0     | 0  | 0  | 0  | 0   | 0   |

| Field Name | Bit     | Туре | Reset<br>Value | Description |
|------------|---------|------|----------------|-------------|
|            | [31:16] | RO   | 16'h0          | Reserved    |
| APLLM      | [15:11] | R/W  | 5'hD           |             |
| APLLN      | [10:0]  | R/W  | 11'hC0         |             |

APLL frequency = 26 MHz \* N / M

ARM can only write this register when PLL\_CTRL [3], apllmn\_we is high.

#### 10.1.1.22 APLLWAIT

Description: APLL WAIT control



| 0x0054 |    |          | APLI | WAIT | contr | ol (res | et 0x0 | 032) | ) APLLWA  |    |    |    | WAIT |    |    |    |
|--------|----|----------|------|------|-------|---------|--------|------|-----------|----|----|----|------|----|----|----|
| Bit    | 31 | 30       | 29   | 28   | 27    | 26      | 25     | 24   | 23        | 22 | 21 | 20 | 19   | 18 | 17 | 16 |
| Name   |    | Reserved |      |      |       |         |        |      |           |    |    |    |      |    |    |    |
| Туре   |    | 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   |    |          |      | Rese | erved |         |        |      | APLL_WAIT |    |    |    |      |    |    |    |
| Туре   |    |          |      | R    | 0     |         |        |      | RW        |    |    |    |      |    |    |    |
| Reset  | 0  | 0        | 0    | 0    | 0     | 0       | 0      | 0    | 0         | 0  | 1  | 1  | 0    | 0  | 1  | 0  |

| Field Name | Bit    | Туре | Reset<br>Value | Description                                                                              |
|------------|--------|------|----------------|------------------------------------------------------------------------------------------|
|            | [31:8] | RO   | 24'h0          | Reserved                                                                                 |
| APLLWAIT   | [7:0]  | R/W  | 8'h32          | Number of 26 MHz cycles to wait for APLL to stabilize. The default is about 2 us (0x32). |

Note: ARM can only write this register when PLL\_CTRL [3], apllmn\_we is high.

#### 10.1.1.23 RTC\_CTRL

Description: RTC control

| 0x0058 |     |          | RTC   | contro | l (rese | t 0x00 | 00_00 | 00) |               |     |    |    |    | RTC_CTRL |    |    |  |
|--------|-----|----------|-------|--------|---------|--------|-------|-----|---------------|-----|----|----|----|----------|----|----|--|
| Bit    | 31  | 30       | 29    | 28     | 27      | 26     | 25    | 24  | 23            | 22  | 21 | 20 | 19 | 18       | 17 | 16 |  |
| Name   |     | Reserved |       |        |         |        |       |     |               |     |    |    |    |          |    |    |  |
| Туре   |     | 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   |     | VBATB    | K_RES |        |         | VBAT   | BK_V  |     | 32K_START_CUR |     |    |    |    |          |    |    |  |
| Туре   | R/W |          |       |        |         | R/     | W     |     |               | R/W |    |    |    |          |    |    |  |
| Reset  | 0   | 0        | 0     | 0      | 0       | 0      | 0     | 0   | 0             | 0   | 0  | 0  | 0  | 0        | 0  | 0  |  |



| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                    |
|---------------|---------|------|----------------|----------------------------------------------------------------|
|               | [31:16] | RO   | 16'h0          | Reserved                                                       |
| VBATBK_RES    | [15:12] | R/W  | 4'h0           | Backup battery output resistor program bits                    |
|               |         |      |                | [15]: vbatbk_res_b1_rst, set this bit will clear vbatbk_res_b1 |
|               |         |      |                | [14]: vbatbk_res_b1                                            |
|               |         |      |                | [13]: vbatbk_res_b0_rst, set this bit will clear vbatbk_res_b0 |
|               |         |      |                | [12]: vbatbk_res_b0                                            |
|               |         |      |                | b1b0: 00-200Ω 01-500Ω 10-1.5KΩ 11-2 KΩ                         |
| VBATBK_V      | [11:8]  | R/W  | 4'h0           | Backup battery output program bits                             |
|               |         |      |                | [15]: vbatbk_v_b1_rst, set this bit will clear vbatbk_v_b1     |
|               |         |      |                | [14]: vbatbk_v_b1                                              |
|               |         |      |                | [13]: vbatbk_v_b0_rst, set this bit will clear                 |
|               |         |      |                | vbatbk_v_b0                                                    |
|               |         |      |                | [12]: vbatbk_v_b0                                              |
|               |         |      |                | b1b0: 00-2.6 01-2.8 10-3.0 11-3.2                              |
| 32K_START_CUR | [7:0]   | R/W  | 8'h0           | This register field controls the 32 kHz                        |
|               |         |      |                | oscillator start up current. [7]: XOSC32K_CTRL[3]_RST          |
|               |         | J*   |                | [6]: XOSC32K_CTRL[3]                                           |
| \ X           |         |      |                | [5]: XOSC32K_CTRL[2]_RST                                       |
|               |         |      |                | [4]: XOSC32K_CTRL[2]                                           |
|               |         |      |                | [3]: XOSC32K_CTRL[1]_RST                                       |
|               |         |      |                | [2]: XOSC32K_CTRL[1]                                           |
| 0.0           |         |      |                | [1]: XOSC32K_CTRL[0]_RST                                       |
|               |         |      |                | [0]: XOSC32K_CTRL[0]                                           |

| XOS632K_CTRL[3:0 | Start up current |
|------------------|------------------|
| 0000             | 0.6 uA           |
| 0001             | 1.8 uA           |



| 0011 | 4.2 uA  |
|------|---------|
| 0111 | 7.8 uA  |
| 1111 | 13.8 uA |

### 10.1.1.24 TRF\_CTRL

Description: Transfer 26M buffer control

| 0x005C |             |       | Trans    | sfer 26             | M buff | fer cor | ntrol (r                             | eset O            | x0000_ | _0307)        |    |       |                         |                           | TRF_0                     | CTRL               |
|--------|-------------|-------|----------|---------------------|--------|---------|--------------------------------------|-------------------|--------|---------------|----|-------|-------------------------|---------------------------|---------------------------|--------------------|
| Bit    | 31          | 30    | 29       | 28                  | 27     | 26      | 25                                   | 24                | 23     | 22            | 21 | 20    | 19                      | 18                        | 17                        | 16                 |
| Name   |             |       | Reserved |                     |        |         |                                      |                   |        |               |    |       |                         |                           |                           |                    |
| Туре   |             | RO    |          |                     |        |         |                                      |                   |        |               |    |       |                         |                           |                           |                    |
| 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   | TRF_RESERVE |       |          |                     | Rese   | erved   | CLK<br>26M<br>_NO<br>RM<br>AL_<br>EN | TRF _RC _CA P_E N |        | DRIVE<br>_SEL |    | TRI_D | TRF _DC SET UPP ADB _EN | TRF _RE CT MO DEP ADB _PD | TRF _RE CT MO DEP ADA _PD | TRF _TR IMO DE_ PD |
| Туре   |             | R/W   |          |                     | R      | 0       | R/W                                  | R/W               | R/     | W             | R  | w     | R/W                     | R/W                       | R/W                       | R/W                |
| Reset  | 0           | 0 0 0 |          |                     | 0      | 0       | 1                                    | 1                 | 0      | 0             | 0  | 0     | 0                       | 1                         | 1                         | 1                  |

| Field Name       | Bit     | Туре | Reset<br>Value | Description                                                                                                      |
|------------------|---------|------|----------------|------------------------------------------------------------------------------------------------------------------|
|                  | [31:16] | RO   | 16'h0          | Reserved                                                                                                         |
| TRF_RESERVE      | [15:12] | R/W  | 4'h0           | 26Mhz Buffer Transfer Reserve bits                                                                               |
|                  | [11:10] | RO   | 2'h0           | Reserved                                                                                                         |
| CLK26M_NORMAL_EN | [9]     | R/W  | 1'h1           | CLK26M normal path enable:  1: CLK26M digital pad transfer 26M CLK;  0: CLK26M digital pad not transfer 26M CLK; |



| TRF_RC_CAP_EN       | [8]   | R/W | 1'h1 | PAD inner CAP select, 1: 1pf; 0:bypass                                   |
|---------------------|-------|-----|------|--------------------------------------------------------------------------|
| TRF_DRIVE_RC_SEL    | [7:6] | R/W | 2'h0 | PAD bypass resistor control REG,<br>00: 3K; 01: 2K, 10: 1K,<br>11:bypass |
| TRF_TRI_DR          | [5:4] | R/W | 2'h0 | Triangle wave 26Mhz buffer output wave                                   |
| TRF_DCSETUPPADB_EN  | [3]   | R/W | 1'h0 | PADB DC output enable, high effective                                    |
| TRF_RECTMODEPADB_PD | [2]   | R/W | 1'h1 | PADB Rectangle wave power down, high effective                           |
| TRF_RECTMODEPADA_PD | [1]   | R/W | 1'h1 | PADA Rectangle wave power down, high effective                           |
| TRF_TRIMODE_PD      | [0]   | R/W | 1'h1 | Triangle wave 26Mhz buffer power down, high effective                    |

### 10.1.1.25 CHGR\_CTRL0

Description: Charger control0

| 0x0060 |    |          | Char     | ger co        | ntrol0               | (reset                      | 0x000                | 0_000 | 0) |   |   |   | CHGR_CTRL0                           |                          |                    |                        |
|--------|----|----------|----------|---------------|----------------------|-----------------------------|----------------------|-------|----|---|---|---|--------------------------------------|--------------------------|--------------------|------------------------|
| Bit    | 31 | 30       | 29       | 28            | 27                   | 26                          | 26 25 24 23 22 21 20 |       |    |   |   |   |                                      |                          | 17                 | 16                     |
| Name   |    |          | Reserved |               |                      |                             |                      |       |    |   |   |   |                                      |                          |                    |                        |
| Туре   |    | 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   |    | Reserved | d        | RE<br>CH<br>G | CH GR_ PW M_E N_R ST | CH<br>GR_<br>PW<br>M_E<br>N | CHGR_RTCCTL          |       |    |   |   |   | USB<br>_50<br>OMA<br>_EN<br>_RS<br>T | USB<br>_50<br>OMA<br>_EN | ADA PTE R_E N_R ST | ADA<br>PTE<br>R_E<br>N |
| Туре   |    | RO       |          | R/W           | R/W                  | R/W                         | RW                   |       |    |   |   |   | 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                      |



| Field Name       | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | [31:13] | RO   | 19'h0          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RECHG            | [12]    | R/W  | 1'h0           | Main battery recharge control                                                                                                                                                                                                                                                                                                                                                                                                    |
| CHGR_PWM_EN_RST  | [11]    | R/W  | 1'h0           | When set, limited current charger is disabled. This bit has higher priority than CHGR_PWM_EN.                                                                                                                                                                                                                                                                                                                                    |
| CHGR_PWM_EN      | [10]    | R/W  | 1'h0           | Limited current charger enable                                                                                                                                                                                                                                                                                                                                                                                                   |
| CHGR_RTCCTL      | [9:4]   | R/W  | 6'h0           | CHGR_RTCCTRL[4:0], charger control. This value will be stored in RTC domain register and will not clear after chip power down.  Bit[5]  0: keep the design on 6610  1: the V&I curve is sharp than 6610 in CV mode.  Bit[4]: Charger power down  Bit[3:2]: Adapter charger current  00: 400mA ( default)  01: 600mA  10: 800mA  11: 1000mA  Bit[1:0]: USB charging current  00: 300mA (default)  01: 400mA  10: 500mA  11: 500mA |
| USB_500MA_EN_RST | [3]     | R/W  | 1'h0           | When set, 500MA USB charge mode is disabled. This bit has higher priority than USB_500MA_EN.                                                                                                                                                                                                                                                                                                                                     |
| USB_500MA_EN     | [2]     | R/W  | 1'h0           | 500MA USB charge mode enable.                                                                                                                                                                                                                                                                                                                                                                                                    |
| ADATPER_EN_RST   | [1]     | R/W  | 1'h0           | When set, adapter charge mode is disabled. This bit has higher priority than ADAPTER_EN.                                                                                                                                                                                                                                                                                                                                         |
| ADATPER_EN       | [0]     | R/W  | 1'h0           | Adapter charge mode enable                                                                                                                                                                                                                                                                                                                                                                                                       |



#### 10.1.1.26 CHGR\_CTRL1

Description: Charger control1

| 0x0064 |    |          | Char | ger co | ntrol1  | (reset | 0x000 | 0_000 | 0) |          |     |    |    | СН | GR_C | TRL1 |
|--------|----|----------|------|--------|---------|--------|-------|-------|----|----------|-----|----|----|----|------|------|
| Bit    | 31 | 30       | 29   | 28     | 27      | 26     | 25    | 24    | 23 | 22       | 21  | 20 | 19 | 18 | 17   | 16   |
| Name   |    | Reserved |      |        |         |        |       |       |    |          |     |    |    |    |      |      |
| Туре   |    | 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   |    |          |      | F      | Reserve | d      |       |       |    | CHGR_CTL |     |    |    |    |      |      |
| Туре   |    |          |      |        | RO      |        |       |       |    |          | R/W |    |    |    |      |      |
| Reset  | 0  | 0        | 0    | 0      | 0       | 0      | 0     | 0     | 0  | 0        | 0   | 0  | 0  | 0  | 0    | 0    |

| Field Name | Bit    | Туре | Reset<br>Value | Description                   |
|------------|--------|------|----------------|-------------------------------|
|            | [31:7] | RO   | 25'h0          | Reserved                      |
| CHGR_CTL   | [6:0]  | R/W  | 7'h0           | Charger control bits          |
|            |        |      |                | Bit[6] is the CHGR_PWM signal |
|            |        |      |                | Bit[5]: Battery sense offset  |
|            |        |      |                | 0: VL=4v                      |
|            |        |      |                | 1: VL=4.1v                    |
|            |        |      |                | Bit[4:0]: Battery sense DAC   |

#### 10.1.1.27 LED\_CTRL

Description: LED control



| 0x0068 |    |          | LED | contro                   | l (rese          | t 0x00            | 00_00   | 00) |    |                   |                       |    |    |       | LED_0 | CTRL |
|--------|----|----------|-----|--------------------------|------------------|-------------------|---------|-----|----|-------------------|-----------------------|----|----|-------|-------|------|
| Bit    | 31 | 30       | 29  | 28                       | 27               | 26                | 25      | 24  | 23 | 22                | 21                    | 20 | 19 | 18    | 17    | 16   |
| Name   |    |          |     | Reserved                 |                  |                   |         |     |    |                   |                       |    |    |       |       |      |
| Туре   |    |          |     | 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   |    | Reserved | i   | KPL<br>ED_<br>PD_<br>RST | KPL<br>ED_<br>PD | ŀ                 | KPLED_V |     |    | WH TLE D_P D_R ST | WH<br>TLE<br>D_P<br>D |    | W  | HTLED | V     |      |
| Туре   |    | RO       |     | R/W                      | R/W              | R/W               |         |     | RO | R/W               |                       |    |    | R/W   |       |      |
| Reset  | 0  | 0        | 0   | 0                        | 0                | 0                 | 0       | 0   | 0  | 0                 | 0                     | 0  | 0  | 0     | 0     | 0    |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                                     |
|---------------|---------|------|----------------|-----------------------------------------------------------------------------------------------------------------|
|               | [31:13] | RO   | 19'h0          | Reserved                                                                                                        |
| KPLED_PD_RST  | [12]    | R/W  | 1'h0           | Set this bit will power on the keypad LED.  This bit has higher priority than KPLED_PD.                         |
| KPLED_PD      | [11]    | R/W  | 1'h0           | Keypad LED power down                                                                                           |
| KPLED_V       | [10:8]  | R/W  | 3'h0           | Keypad LED current control bit. 8 steps  Min current: 5mA ("000")  Max current: 40mA("111")                     |
|               | [7]     | RO   | 1'h0           | Reserved                                                                                                        |
| WHTLED_PD_RST | [6]     | R/W  | 1'h0           | Set this bit will power on the white LED. This bit has higher priority than WHTLED_PD.(WDG reset not active)    |
| WHTLED_PD     | [5]     | R/W  | 1'h0           | White LED power down(WDG reset not active);                                                                     |
| WHTLED_V      | [4:0]   | R/W  | 5'h0           | White LED current control bit. 32 steps.  Min current: 1/2mA ("00000")  One step is 1/2mA(WDG reset not active) |



### 10.1.1.28 VIBRATOR\_CTRL0

Description: Vibrator control0(Note: this register could only be access when VIBR\_WR\_PROT released)

| 0x006C |    |         | Vibra   | itor co  | ntrol0 | (reset  | 0x000   | 0_000 | 0) |       |       |    | ٧              | IBRAT           | OR_C                   | TRL0                    |
|--------|----|---------|---------|----------|--------|---------|---------|-------|----|-------|-------|----|----------------|-----------------|------------------------|-------------------------|
| Bit    | 31 | 30      | 29      | 28       | 27     | 26      | 25      | 24    | 23 | 22    | 21    | 20 | 19             | 18              | 17                     | 16                      |
| Name   |    |         |         | Reserved |        |         |         |       |    |       |       |    |                |                 |                        |                         |
| Туре   |    |         |         | RO       |        |         |         |       |    |       |       |    |                |                 |                        |                         |
| Reset  | 0  | 0       | 0       |          |        |         |         |       |    |       |       |    |                |                 |                        |                         |
| Bit    | 15 | 14      | 13      | 12       | 11     | 10      | 9       | 8     | 7  | 6     | 5     | 4  | 3              | 2               | 1                      | 0                       |
| Name   | V  | IBR_ST/ | ABLE_V_ | В        |        | VIBR_IN | NIT_V_A |       |    | VIBR_ | _V_BP |    | VIB R_P D_R ST | VIB<br>R_P<br>D | VIB<br>R_B<br>P_E<br>N | RTC<br>_VIB<br>R_E<br>B |
| Туре   |    | 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     | 0  | 0              | 0               | 0                      | 0                       |

| Field Name      | Bit     | Туре | Reset<br>Value | Description                                                                                                  |
|-----------------|---------|------|----------------|--------------------------------------------------------------------------------------------------------------|
|                 | [31:16] | RO   | 16'h0          | Reserved                                                                                                     |
| VIBR_STABLE_V_B | [15:12] | R/W  | 4'h0           | Vibrator stable current control bit                                                                          |
| VIBR_INIT_V_A   | [11:8]  | R/W  | 4'h0           | Vibrator initial current control bit                                                                         |
| VIBR_V_BP       | [7:4]   | R/W  | 4'h0           | Current Control bit. 8 steps  Min current: 20mA ("0000")  Max current: 170mA("1111")                         |
| VIBR_PD_RST     | [3]     | R/W  | 1'h0           | Set this bit will power on the vibrator. This bit has higher priority than VIBR_PD.                          |
| VIBR_PD         | [2]     | R/W  | 1'h0           | Vibrator power down                                                                                          |
| VIBR_BP_EN      | [1]     | R/W  | 1'h0           | Vibrator current control circuit bypass enable: software control current directly through VIBR_BP_V register |
| RTC_VIBR_EB     | [0]     | R/W  | 1'h0           | Vibrator current control circuit 32K clock enable                                                            |



### 10.1.1.29 VIBRATOR\_CTRL1

Description: Vibrator control1 (Note: this register could only be access when VIBR\_WR\_PROT released)

| 0x0070 |    |                             | Vibra                                        | itor co | ntrol1 | (reset | 0x000 | 0_000 | 0)     |      |   |   | ٧ | IBRAT | OR_C | TRL1 |
|--------|----|-----------------------------|----------------------------------------------|---------|--------|--------|-------|-------|--------|------|---|---|---|-------|------|------|
| Bit    | 31 | 30                          | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |         |        |        |       |       |        |      |   |   |   |       |      |      |
| Name   |    | Reserved                    |                                              |         |        |        |       |       |        |      |   |   |   |       |      |      |
| Туре   |    |                             |                                              |         |        |        |       | R     | 0      |      |   |   |   |       |      |      |
| 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   |    |                             |                                              |         |        |        | VIBR_ | CONVE | RT_V_C | OUNT |   |   |   |       |      |      |
| Туре   |    |                             | R/W                                          |         |        |        |       |       |        |      |   |   |   |       |      |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                              |         |        |        |       |       |        |      |   |   |   |       |      |      |

| Field Name           | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                        |
|----------------------|---------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | [31:16] | RO   | 16'h0          | Reserved                                                                                                                                                                                           |
| VIBR_CONVERT_V_COUNT | [15:0]  | R/W  | 16'h0          | Vibrator current control bit convert threshold: After Vibrator power on, the current control bit will load the stable register when a 16-bit counter's value >= the threshold set by this register |

10.1.1.30 AUDIO\_CTRL

Description: Audio general control



| 0x0074 |                                 |    | Audi                               | o gene | ral co | ntrol (ı | reset 0 | x0000 | _0080) | )  |        |     |                         | Αl                     | JDIO_0                         | CTRL                          |
|--------|---------------------------------|----|------------------------------------|--------|--------|----------|---------|-------|--------|----|--------|-----|-------------------------|------------------------|--------------------------------|-------------------------------|
| Bit    | 31                              | 30 | 29                                 | 28     | 27     | 26       | 25      | 24    | 23     | 22 | 21     | 20  | 19                      | 18                     | 17                             | 16                            |
| Name   |                                 |    | Reserved                           |        |        |          |         |       |        |    |        |     |                         |                        |                                |                               |
| Туре   |                                 | RO |                                    |        |        |          |         |       |        |    |        |     |                         |                        |                                |                               |
| Reset  | 0                               | 0  | 0                                  | 0      | 0      | 0        | 0       | 0     | 0      | 0  | 0      | 0   | 0                       | 0                      | 0                              | 0                             |
| Bit    | 15                              | 14 | 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |        |        |          |         |       |        |    |        |     |                         |                        |                                |                               |
| Name   | VB_<br>ARM<br>_SO<br>FT_<br>RST |    | PA_RESERVE                         |        |        |          |         |       |        |    | NEINRE | _\$ | LINE<br>INR<br>E_E<br>N | VBM CLK _SO URC E_S EL | VBM<br>CLK<br>_AR<br>M_A<br>CC | VBM<br>CLK<br>_AR<br>M_E<br>N |
| Туре   | R/W                             |    |                                    |        | RO     |          |         |       | R/W    |    | R/W    |     | R/W                     | R/W                    | R/W                            | R/W                           |
| Reset  | 0                               | 0  | 0                                  | 0      | 0      | 0        | 0       | 0     | 1      | 0  | 0      | 0   | 0                       | 0                      | 0                              | 0                             |

| Field Name        | Bit     | Туре | Reset | Description                                                        |
|-------------------|---------|------|-------|--------------------------------------------------------------------|
|                   |         |      | Value |                                                                    |
|                   | [31:16] | RO   | 16h0  | Reserved                                                           |
| VB_ARM_SOFT_RST   | [15]    | R/W  | 1'h0  | ARM soft reset for dolphin                                         |
| PA_RESERVE        | [14:8]  | R/W  | 7'h0  | PA reserve interface                                               |
| HEADDETECT_PD     | [7]     | R/W  | 1'h1  | Head detection power down                                          |
| LINEINRE_S        | [6:4]   | R/W  | 3'h0  | Line in recorder gain program                                      |
| LINEINRE_EN       | [3]     | R/W  | 1'h0  | Line in recorder enable, high effective                            |
| VBMCLK_SOURCE_SEL | [2]     | R/W  | 1'h0  | Source of 12M input clock for audio codec                          |
|                   |         |      |       | 1: Select external clock from pin                                  |
|                   |         |      |       | 0: Select internal clock on chip                                   |
| VBMCLK_ARM_ACC    | [1]     | R/W  | 1'h0  | ARM or DSP control audio codec MCLK and RST;                       |
|                   |         |      |       | 1: Controlled by ARM;                                              |
|                   |         |      |       | 0: Controlled by DSP;                                              |
| VBMCLK_ARM_EN     | [0]     | R/W  | 1'h0  | Activate 12M input clock for audio codec if VBMCLK_ARM_ACC is true |



|  |  | 1: enable VBMCLK  |
|--|--|-------------------|
|  |  | 0: disable VBMCLK |

### 10.1.1.31 AUDIO\_PA\_CTRL0

Description: Audio PA control0

| 0x0078 |    |          | Audi | o PA c           | ontrol            | 0 (rese  | et 0x00 | 00_01 | 80)      |    |    |    | А                 | UDIO                   | PA_C              | TRL0      |  |  |  |
|--------|----|----------|------|------------------|-------------------|----------|---------|-------|----------|----|----|----|-------------------|------------------------|-------------------|-----------|--|--|--|
| Bit    | 31 | 30       | 29   | 28               | 27                | 26       | 25      | 24    | 23       | 22 | 21 | 20 | 19                | 18                     | 17                | 16        |  |  |  |
| Name   |    |          |      |                  |                   | Reserved |         |       |          |    |    |    |                   |                        |                   |           |  |  |  |
| Туре   |    |          |      |                  |                   |          |         | R     | 0        |    |    |    |                   |                        |                   |           |  |  |  |
| 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   |    | Reserved | i    | PA_<br>OCP<br>_I | PA_<br>OTP<br>_PD | Р        | A_OTP_  | Т     | PA_PGA_V |    |    |    | PA_<br>VCM<br>_EN | PA_<br>STO<br>P_E<br>N | PA_<br>EN_<br>RST | PA_<br>EN |  |  |  |
| Туре   |    | RO       |      | R/W              | R/W               | R/W      |         |       |          | R  | W  |    | R/W               | R/W                    | R/W               | R/W       |  |  |  |
| Reset  | 0  | 0        | 0    | 0                | 0                 | 0        | 0       | 1     | 1        | 0  | 0  | 0  | 0                 | 0                      | 0                 | 0         |  |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description                                                                                                                                 |
|------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------|
|            | [31:13] | RO   | 19h'0          | Reserved                                                                                                                                    |
| PA_OCP_I   | [12]    | R/W  | 1'h0           | PA over current protection circuit current select: 0: 500mA (default) 1: 700mA                                                              |
| PA_OTP_PD  | [11]    | R/W  | 1'h0           | PA over temperature protection circuit power down signal:  0: power on(default) 1: power down                                               |
| PA_OTP_T   | [10:8]  | R/W  | 3'h1           | PA over temperature protection circuit temperature select:  000: 104C -> 74C  001:128C -> 98C(default)  010: 152C -> 122C 011: 175C -> 146C |



|            |       |     |      | 100: 6C -> -24C                                  | 101: 30C -> 0C    |
|------------|-------|-----|------|--------------------------------------------------|-------------------|
|            |       |     |      | 110: 55C -> 25C                                  | 111: 79C -> 49C   |
| PA_PGA_V   | [7:4] | R/W | 4'h8 | PA PGA select:                                   |                   |
|            |       |     |      | 0000: mute                                       | 0001: -21db       |
|            |       |     |      | 0010: -18db                                      | 0011: -15db       |
|            |       |     |      | 0100: -12db                                      | 0101: -9db        |
|            |       |     |      | 0110: -6db                                       | 0111: -3db        |
|            |       |     |      | 1000: 0db(default)                               | 1001: 3db         |
|            |       |     |      | 1010: 6db                                        | 1011: 9db         |
|            |       |     |      | 1100: 12db                                       | 1101: 15db        |
|            |       |     |      | 1110: 18db                                       | 1111: 21db        |
| PA_VCM_EN  | [3]   | R/W | 1'h0 | PA vcom voltage fas signal:                      | t start up enable |
|            |       |     |      | 0: disable(default)                              | 1: enable         |
| PA_STOP_EN | [2]   | R/W | 1'h0 | PA stop enable signa                             | al:               |
|            |       |     |      | 0: disable(default)                              | 1: enable         |
| PA_EN_RST  | [1]   | R/W | 1'h0 | Set this bit will disable higher priority than P |                   |
| PA_EN      | [0]   | R/W | 1'h0 | PA enable                                        |                   |

## 10.1.1.32 AUDIO\_PA\_CTRL1

Description: Audio PA control1



| 0x007C |                         |                        | Audi | o PA c | ontrol             | 1 (rese         | et 0x00                       | 00_10             | 40)                      |    |        |    | А                | UDIO                    | PA_C                     | TRL1             |
|--------|-------------------------|------------------------|------|--------|--------------------|-----------------|-------------------------------|-------------------|--------------------------|----|--------|----|------------------|-------------------------|--------------------------|------------------|
| Bit    | 31                      | 30                     | 29   | 28     | 27                 | 26              | 25                            | 24                | 23                       | 22 | 21     | 20 | 19               | 18                      | 17                       | 16               |
| Name   |                         | Reserved               |      |        |                    |                 |                               |                   |                          |    |        |    |                  |                         |                          |                  |
| Туре   |                         | 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   | PA_<br>ABO<br>CP_<br>PD | PA_<br>DOC<br>P_P<br>D | PA_D | TRI_F  | PA_<br>DEM<br>I_EN | PA_<br>D_E<br>N | PA_<br>LDO<br>_EN<br>_RS<br>T | PA_<br>LDO<br>_EN | PA_<br>LDO<br>OCP<br>_PD | Р  | A_LDO_ | v  | Res<br>erve<br>d | PA_<br>SW<br>OCP<br>_PD | PA_<br>SW_<br>EN_<br>RST | PA_<br>SW_<br>EN |
| Туре   | R/W                     | R/W                    | R/W  | R/W    | R/W                | R/W             | R/W                           | R/W               | R/W                      |    | R/W    |    | RO               | R/W                     | R/W                      | R/W              |
| Reset  | 0                       | 0                      | 0    | 1      | 0                  | 0               | 0                             | 0                 | 0                        | 1  | 0      | 0  | 0                | 0                       | 0                        | 0                |

| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                                                             |
|---------------|---------|------|----------------|---------------------------------------------------------------------------------------------------------|
|               | [31:16] | RO   | 16h'0          | Reserved                                                                                                |
| PA_ABOCP_PD   | [15]    | R/W  | 1'h0           | PA class-AB mode over current protection circuit power down signal:  0: power on(default) 1: power down |
| PA_DOCP_PD    | [14]    | R/W  | 1'h0           | PA class-D mode over current protection circuit power down signal:  0: power on(default) 1: power down  |
| PA_DTRI_F     | [13:12] | R/W  | 2'h1           | PA class-D mode Switching frequency select:  00: 300kHz 10: 870kHz 11: 1.1MHz                           |
| PA_DEMI_EN    | [11]    | R/W  | 1'h0           | PA class-D mode reduce EMI enable signal:  0: disable(default) 1: enable                                |
| PA_D_EN       | [10]    | R/W  | 1'h0           | PA class-AB mode enable signal: 0: class-AB(default) 1: class-D                                         |
| PA_LDO_EN_RST | [9]     | R/W  | 1'h0           | Set this bit will disable LDO_PA. This bit                                                              |



|              |       |     |      | has higher priority than PA_LDO_EN.                                                           |
|--------------|-------|-----|------|-----------------------------------------------------------------------------------------------|
| PA_LDO_EN    | [8]   | R/W | 1'h0 | LDO_PA enable                                                                                 |
| PA_LDOOCP_PD | [7]   | R/W | 1'h0 | LDO_PA over current protection circuit power down signal:  0: power on(default) 1: power down |
| PA_LDO_V     | [6:4] | R/W | 3'h4 | LDO_PA output voltage select:  000: 2.9V                                                      |
|              | [3]   | RO  | 1'h0 | Reserved                                                                                      |
| PA_SWOCP_PD  | [2]   | R/W | 1'h0 | PA power switch over current protection power down signal: 0: power on(default) 1: power down |
| PA_SW_EN_RST | [1]   | R/W | 1'h0 | Set this bit will disable PA power switch.                                                    |
| PA_SW_EN     | [0]   | R/W | 1'h0 | PA power switch enable, 0: disable(default) 1: enable                                         |

## 10.1.1.33 ANA\_MIXED\_CTRL

Description: analog mixed control



| 0x0080 |                          |          | Anale    | og mix | ed co | ntrol (r | eset 0 | x0000 | _0020) |                  |    |      | А                       | NA_M            | IXED_0                  | CTRL       |
|--------|--------------------------|----------|----------|--------|-------|----------|--------|-------|--------|------------------|----|------|-------------------------|-----------------|-------------------------|------------|
| Bit    | 31                       | 30       | 29       | 28     | 27    | 26       | 25     | 24    | 23     | 22               | 21 | 20   | 19                      | 18              | 17                      | 16         |
| Name   |                          | Reserved |          |        |       |          |        |       |        |                  |    |      |                         |                 |                         |            |
| Туре   |                          | 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   | PTE<br>ST_<br>PD_<br>SET |          | Reserved |        |       |          |        |       |        | CLK<br>BT_<br>EN |    | 6M_R | UV<br>HO_<br>EN_<br>RST | UV<br>HO_<br>EN | OTP<br>_EN<br>_RS<br>_T | OTP<br>_EN |
| Туре   | R/W                      |          | RO       |        |       |          |        |       |        | R/W              | R/ | w    | R/W                     | R/W             | R/W                     | R/W        |
| Reset  | 0                        | 0        | 0        | 0      | 0     | 0        | 0      | 0     | 0      | 0                | 1  | 0    | 0                       | 0               | 0                       | 0          |

| Field Name       | Bit    | Туре | Reset | Description                                  |
|------------------|--------|------|-------|----------------------------------------------|
|                  |        |      | Value |                                              |
|                  | [31:16 | RO   | 160   | Reserved                                     |
| PTEST_PD_SET     | [15]   | R/W  | 1'b0  | PTEST power down set under PTEST mode        |
|                  | [14:8] | RO   | 7h0   | Reserved                                     |
| VIBR_PWR_ERR_CLR | [7]    | R/W  | 1'h0  | Vibrator current control circuit error clear |
| CLKBT_EN         | [6]    | R/W  | 1'h0  | Bluetooth 26MHz output enable                |
|                  |        |      |       | "1" 26M clock enable.                        |
|                  |        |      |       | "0" 26M clock disable. (default)             |
| CLK26M_REGS0     | [5:4]  | R/W  | 2'h10 | Output voltage swing register of CLK         |
|                  |        |      |       | (default CLK26M_RegS0[1:0]=10) for           |
|                  |        |      |       | 10pF load,                                   |
|                  |        |      |       | 11: 2V                                       |
| •                |        |      |       | 10: 1.6 (default)                            |
|                  |        |      |       | 01: 0.9                                      |
|                  |        |      |       | 00: 0.5                                      |
| UVHO_EN_RST      | [3]    | R/W  | 1'h0  | When set, UVHO is disabled. This bit has     |



|            |     |     |      | higher priority than UVHO_EN.                                                                      |
|------------|-----|-----|------|----------------------------------------------------------------------------------------------------|
| UVHO_EN    | [2] | R/W | 1'h0 | When set, UVHO is enabled.                                                                         |
| OTP_EN_RST | [1] | R/W | 1'h0 | When set, OTP (Over Temperature Protection) is disabled. This bit has higher priority than OTP_EN. |
| OTP_EN     | [0] | R/W | 1'h0 | When set, OTP is enabled.                                                                          |

### 10.1.1.34 ANA\_STATUS

Description: analog circuit status

| 0x0084 |                          |          | Anal | og circ | cuit sta | atus (re             | eset 0x         | (0000_                | 0300) |    |      |            |                 |                        | ANA              | _STA             |
|--------|--------------------------|----------|------|---------|----------|----------------------|-----------------|-----------------------|-------|----|------|------------|-----------------|------------------------|------------------|------------------|
| Bit    | 31                       | 30       | 29   | 28      | 27       | 26                   | 25              | 24                    | 23    | 22 | 21   | 20         | 19              | 18                     | 17               | 16               |
| Name   |                          | Reserved |      |         |          |                      |                 |                       |       |    |      |            |                 |                        |                  |                  |
| Туре   |                          | 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   | VIB<br>R_P<br>WR_<br>ERR |          | Rese | erved   |          | BO<br>ND<br>OPT<br>2 | VIB<br>R_P<br>D | WH<br>TLE<br>D_P<br>D | PA_O  |    | PA_O | TP_FL<br>G | CHG<br>R_O<br>N | CHG<br>R_S<br>TDB<br>Y | BON<br>DOP<br>T1 | BON<br>DOP<br>T0 |
| Туре   | RO                       |          | R    | 0       |          | RO                   | RO              | RO                    | R     | 0  | R    | 0          | RO              | RO                     | RO               | RO               |
| Reset  | 0                        | 0        | 0    | 0       | 0        | 0                    | 1               | 1                     | 0     | 0  | 0    | 0          | 0               | 0                      | 0                | 0                |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                   |
|--------------|---------|------|----------------|-----------------------------------------------|
|              | [31:16] | RO   | 16'h0          | Reserved                                      |
| VIBR_PWR_ERR | [15]    | RO   | 1'h0           | Vibrator current control circuit error status |
|              | [14:11] | RO   | 4'h0           | Reserved                                      |
| BONDOPT2     | [10]    | RO   | 1'h0           | DCDC ARM OPTION INPUT                         |
|              |         |      |                | 1: External ARM DCDC                          |
|              |         |      |                | 0: Internal ARM DCDC                          |
| VIBR_PD      | [9]     | RO   | 1'h1           | Vibrator power down status                    |



| WHTLED_PD   | [8]   | RO | 1'h1 | White LED power down status                                                                 |
|-------------|-------|----|------|---------------------------------------------------------------------------------------------|
| PA_OCP_FLAG | [7:6] | RO | 2'h0 | PA over current protection circuit alert signal:  00: normal  01/10/11: over current        |
| PA_OTP_OTP  | [5:4] | RO | 2'h0 | PA over temperature protection circuit alert signal:  00: normal 01/10/11: over temperature |
| CHGR_ON     | [3]   | RO | 1'h0 | Charger voltage high indicator                                                              |
| CHGR_STDBY  | [2]   | RO | 1'h0 | Charging procedure completed                                                                |
| BONDOPT1    | [1]   | RO | 1'h0 | LDO power on sequence option:  1: LDO power on at same time  0: LDO power on sequence       |
| BONDOPT0    | [0]   | RO | 1'h0 | DCDC OPTION INPUT  1: External DCDC  0: Internal DCDC                                       |

#### 10.1.1.35 RST\_STATUS

Description: Reset status

| 0x0088 |    |        | Rese     | t statu                               | Reset status(0x0000_0000) |                  |   |   |   |   |   |     |    |                  | RST_STATUS |   |  |  |
|--------|----|--------|----------|---------------------------------------|---------------------------|------------------|---|---|---|---|---|-----|----|------------------|------------|---|--|--|
| Bit    | 31 | 30     | 29       | 9 28 27 26 25 24 23 22 21 20 19 18 17 |                           |                  |   |   |   |   |   |     | 16 |                  |            |   |  |  |
| Name   |    |        | Reserved |                                       |                           |                  |   |   |   |   |   |     |    |                  |            |   |  |  |
| Туре   |    |        |          |                                       |                           |                  |   | R | 0 |   |   |     |    |                  |            |   |  |  |
| 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   | AL | L_HRST | _MONIT   | OR                                    |                           | POR_HRST_MONITOR |   |   |   |   |   |     |    | WDG_HRST_MONITOR |            |   |  |  |
| Туре   |    | R/     | /W       |                                       | R/W                       |                  |   |   |   |   |   | R/W |    |                  |            |   |  |  |
| Reset  | 0  | 0      | 0        | 0                                     | 0                         | 0                | 0 | 0 | 0 | 0 | 0 | 0   | 0  | 0                | 0          | 0 |  |  |

| Field Name | Bit     | Туре | Reset<br>Value | Description |
|------------|---------|------|----------------|-------------|
|            | [31:12] | RO   | 20'h0          | Reserved    |



| ALL_HRST_MONITOR | [15:12] | R/W | 4'h0 | When power on reset or Watch dog reset or Chip pin reset active, this register is reset to 0; |
|------------------|---------|-----|------|-----------------------------------------------------------------------------------------------|
| POR_HRST_MONITOR | [11:4]  | R/W | 8'h0 | When power on reset active, this register is reset to 0;                                      |
| WDG_HRST_MONITOR | [3:0]   | R/W | 4'h0 | When WDG reset active, this register is reset to 0;                                           |

### 10.1.1.36 MCU\_WR\_PROT

Description: MCU write protect register

| 0x008C |    |                           | MCU | write          | protec | t regis | ter (re | set 0x | 0000_0 | 0000) |    |    |    | MCU | _WR_F | PROT |
|--------|----|---------------------------|-----|----------------|--------|---------|---------|--------|--------|-------|----|----|----|-----|-------|------|
| Bit    | 31 | 30                        | 29  | 28             | 27     | 26      | 25      | 24     | 23     | 22    | 21 | 20 | 19 | 18  | 17    | 16   |
| Name   |    | Reserved                  |     |                |        |         |         |        |        |       |    |    |    |     |       |      |
| Туре   |    |                           | 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   |    |                           |     | MCU_PROT[15:0] |        |         |         |        |        |       |    |    |    |     |       |      |
| Туре   |    |                           | wo  |                |        |         |         |        |        |       |    |    |    |     |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |     |                |        |         |         |        |        |       |    |    |    |     |       |      |

| Field Name  | Bit     | Туре | Reset<br>Value | Description                                                                                                                                                                                                 |
|-------------|---------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | [31:16] | RO   | 16'h0          | Reserved                                                                                                                                                                                                    |
| MCU_WR_PROT | [15:0]  | wo   | 16'h0          | Write Protection of APB Arch Clock Enable Write 0xc3d4 to release 'arch_eb' bit protection, write others value to protect. Bit[0] can be read as status of apb_arch_wr_prot 0- is proteced; 1- is released. |



10.1.1.37 VIBR\_WR\_PROT

Description: VIBR register write protection

| 0x0090 |    |                           | VIBR                                        | regist | er writ | e prot | ection | (reset | 0x000  | 00_000 | 0) |   |   | VIBR | _WR_F | PROT |
|--------|----|---------------------------|---------------------------------------------|--------|---------|--------|--------|--------|--------|--------|----|---|---|------|-------|------|
| Bit    | 31 | 30                        | 0 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |        |         |        |        |        |        |        |    |   |   |      |       |      |
| Name   |    | Reserved                  |                                             |        |         |        |        |        |        |        |    |   |   |      |       |      |
| Туре   |    |                           |                                             |        |         |        |        | R      | 0      |        |    |   |   |      |       |      |
| 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   |    |                           |                                             |        |         |        | VIE    | BR_WR_ | PROT[1 | 5:0]   |    |   |   |      |       |      |
| Туре   |    |                           |                                             | wo     |         |        |        |        |        |        |    |   |   |      |       |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                             |        |         |        |        |        |        |        |    |   |   |      |       |      |

| Field Name   | Bit     | Туре | Reset<br>Value | Description                                                                                          |
|--------------|---------|------|----------------|------------------------------------------------------------------------------------------------------|
|              | [31:16] | RO   | 16'h0          | Reserved                                                                                             |
| VIBR_WR_PROT | [15:0]  | WO   | 16'h0          | Write Protection of VIBRATOR_CTRL0 and VIBRATOR_CTRL1                                                |
|              |         |      |                | Write 0xa1b2 to release VIBRATOR_CTRL0 and VIBRATOR_CTRL1 protection, write others value to protect. |
| 1            |         |      |                | Bit[0] can be read as status of vibr_wr_prot                                                         |
|              |         |      |                | 0- is proteced; 1- is released.                                                                      |

10.1.1.38 INT\_GPI\_DEBUG

Description: analog interrupt debug



| 0x0094        |        |          | Anale                       | og inte             | errupt a          | and GI                   | PI debu                  | ug (res                | set 0x0                         | 000_0               | 000)                     |                |                          | INT_G                    | PI_DE          | BUG                |
|---------------|--------|----------|-----------------------------|---------------------|-------------------|--------------------------|--------------------------|------------------------|---------------------------------|---------------------|--------------------------|----------------|--------------------------|--------------------------|----------------|--------------------|
| Bit           | 31     | 30       | 29                          | 28                  | 27                | 26                       | 25                       | 24                     | 23                              | 22                  | 21                       | 20             | 19                       | 18                       | 17             | 16                 |
| Name          |        | Reserved |                             |                     |                   |                          |                          |                        |                                 |                     |                          |                |                          |                          |                |                    |
| Туре          |        |          | 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          | Rese   | erved    | HEA DMI C_D ETE CTI ON_ DEB | HEA D_B UTT ON_ DEB | PBI<br>NT_<br>DEB | CHG<br>R_O<br>VI_D<br>EB | CHG<br>R_I<br>NT_<br>DEB | GPI<br>_DE<br>B_E<br>N | CHG<br>RW<br>DG_<br>INT_<br>DEB | EIC_<br>INT_<br>DEB | TPC<br>_INT<br>_DE<br>_B | WD G_I NT_ DEB | RTC<br>_INT<br>_DE<br>_B | GPI<br>O_I<br>NT_<br>DEB | ADC _INT _DE B | INT_<br>DEB<br>_EN |
| Type<br>Reset | 0<br>0 | 0        | R/W<br>0                    | R/W                 | R/W<br>0          | R/W                      | R/W                      | R/W                    | R/W<br>0                        | R/W<br>0            | R/W<br>0                 | R/W<br>0       | R/W<br>0                 | R/W<br>0                 | R/W<br>0       | R/W<br>0           |

| Field Name            | Bit     | Туре | Reset<br>Value | Description                                                             |
|-----------------------|---------|------|----------------|-------------------------------------------------------------------------|
|                       |         |      | value          |                                                                         |
|                       | [31:14] | RO   | 18'h0          | Reserved                                                                |
| HEADMIC_DETECTION_DEB | [13]    | R/W  | 1'h0           | When GPI_DEG_EN set, this bit will replace HEADMIC_DETECTION for GPI[5] |
| HEAD_BUTTON_DEB       | [12]    | R/W  | 1'h0           | When GPI_DEG_EN set, this bit will replace HEAD_BUTTON for GPI[4]       |
| PBINT_DEB             | [11]    | R/W  | 1'h0           | When GPI_DEG_EN set, this bit will replace PBINT for GPI[3]             |
| CHGR_OVI_DEB          | [10]    | R/W  | 1'h0           | When GPI_DEG_EN set, this bit will replace CHGR_OVI for GPI[6]          |
| CHGR_INT_DEB          | [9]     | R/W  | 1'h0           | When GPI_DEG_EN set, this bit will replace CHGR_INT for GPI[2]          |
| GPI_DEB_EN            | [8]     | R/W  | 1'h0           | GPI debug enable                                                        |
| CHGRWDG_INT_DEB       | [7]     | R/W  | 1'h0           | When INT_DEB_EN set, this bit will replace chgrwdg_irq for              |



|              |     |     |      | interrupt controller                                                         |
|--------------|-----|-----|------|------------------------------------------------------------------------------|
| EIC_INT_DEB  | [6] | R/W | 1'h0 | When INT_DEB_EN set, this bit will replace eic_irq for interrupt controller  |
| TPC_INT_DEB  | [5] | R/W | 1'h0 | When INT_DEB_EN set, this bit will replace tpc_irq for interrupt controller  |
| WDG_INT_DEB  | [4] | R/W | 1'h0 | When INT_DEB_EN set, this bit will replace wdg_irq for interrupt controller  |
| RTC_INT_DEB  | [3] | R/W | 1'h0 | When INT_DEB_EN set, this bit will replace rtc_irq for interrupt controller  |
| GPIO_INT_DEB | [2] | R/W | 1'h0 | When INT_DEB_EN set, this bit will replace gpio_irq for interrupt controller |
| ADC_INT_DEB  | [1] | R/W | 1'h0 | When INT_DEB_EN set, this bit will replace adc_irq for interrupt controller  |
| INT_DEB_EN   | [0] | R/W | 1'h0 | Interrupt debug enable                                                       |

### 10.1.1.39 HWRST\_RTC

Description: RTC test reg

| 0x0098 |    |               | RTC   | test re | g(0x00 | 00_00 | 00) |    |    |    |    |        |        | Н  | WRST | RTC |
|--------|----|---------------|-------|---------|--------|-------|-----|----|----|----|----|--------|--------|----|------|-----|
| Bit    | 31 | 30            | 29    | 28      | 27     | 26    | 25  | 24 | 23 | 22 | 21 | 20     | 19     | 18 | 17   | 16  |
| Name   |    | Reserved      |       |         |        |       |     |    |    |    |    |        |        |    |      |     |
| Туре   |    | 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   |    |               | Н     | WRST_I  | RTC_RE | G     |     |    |    |    | F  | IWRST_ | RTC_SE | Т  |      |     |
| Туре   |    |               | RO RW |         |        |       |     |    |    |    |    |        |        |    |      |     |
| Reset  | -  | 0 0 0 0 0 0 0 |       |         |        |       |     |    |    |    | 0  |        |        |    |      |     |



| Field Name    | Bit     | Туре | Reset<br>Value | Description                                                |
|---------------|---------|------|----------------|------------------------------------------------------------|
|               | [31:16] | RO   | 16'h0          | Reserved                                                   |
| HWRST_RTC_REG | [15:8]  | RO   | -              | Value will change according to HWRST_RTC_SET in RTC domain |
| HWRST_RTC_SET | [7:0]   | R/W  | 8'h0           | Software set this register to test RTC clock               |

## 10.1.1.40 IF\_SPR\_CTRL

Description: IF\_SPR pin control

| 0x009C |    |                           | Two | IF_SPI | R pin c | ontrol | (reset  | 0x000 | 00_000 | 2) |    |     |    | IF_SPR_CTRL |      |      |
|--------|----|---------------------------|-----|--------|---------|--------|---------|-------|--------|----|----|-----|----|-------------|------|------|
| Bit    | 31 | 30                        | 29  | 28     | 27      | 26     | 25      | 24    | 23     | 22 | 21 | 20  | 19 | 18          | 17   | 16   |
| Name   |    | Reserved                  |     |        |         |        |         |       |        |    |    |     |    |             |      |      |
| Туре   |    | RO                        |     |        |         |        |         |       |        |    |    |     |    |             |      |      |
| 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    |
|        |    |                           |     |        |         |        |         |       |        |    |    |     |    | IF_S        | IF_S | IF_S |
| Name   |    |                           |     |        |         | F      | Reserve | d     |        |    |    |     |    | PR_I        | PR_  | PR_  |
|        |    | N OE OUT                  |     |        |         |        |         |       |        |    |    | OUT |    |             |      |      |
| Туре   |    | RO R/W R/W                |     |        |         |        |         |       |        |    |    |     |    |             |      |      |
| Reset  | 0  | 0 0 0 0 0 0 0 0 0 0 0 0 0 |     |        |         |        |         |       |        |    |    |     |    |             |      |      |

| Field-Name | Bit    | Туре | Reset<br>Value | Description              |
|------------|--------|------|----------------|--------------------------|
|            | [31:3] | RO   | 29'h0          | Reserved                 |
| IF_SPR_IN  | [2]    | RO   | 1'h0           | IF_SPR pin input data    |
| IF_SPR_OE  | [1]    | R/W  | 1'h1           | IF_SPR pin output enable |
| IF_SPR_OUT | 0]     | R/W  | 1'h0           | IF_SPR pin output data   |



### 10.1.1.41 CHIP\_ID\_LOW

Description: 8810 chip ID low 16 bits

| 0x00F8 |    |             | 8810 chip ID low 16 bits(reset 0x0000_A000) CHIP_ID_LOW |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|----|-------------|---------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit    | 31 | 30          | 29                                                      | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |    | Reserved    |                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Туре   |    | 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   |    | CHIP_ID_LOW |                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Туре   |    | RO          |                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset  | 1  | 0           | 1                                                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Field Name  | Bit     | Туре | Reset<br>Value | Description              |
|-------------|---------|------|----------------|--------------------------|
|             | [31:16] | RO   | 16'h0          | Reserved                 |
| CHIP_ID_LOW | [15: 0] | RO   | 16'hA000       | 8810 chip ID low 16 bits |

#### 10.1.1.42 CHIP\_ID\_HIGH

Description: 8810 chip ID high 16 bits

| 0x00FC | 8810 chip ID high 16 bits(reset 0x0000_8810) CHIP_ID_HIGH |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|-----------------------------------------------------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit    | 31                                                        | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | Reserved                                                  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Туре   | 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   |                                                           | CHIP_ID_HIGH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Туре   | RO                                                        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset  | 1                                                         | 0            | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  |

| Field Name   | Bit | Type  | Reset | Description |
|--------------|-----|-------|-------|-------------|
| Ticia Hairie |     | , ype | Neset | Description |



|              |         |    | Value    |                           |
|--------------|---------|----|----------|---------------------------|
|              | [31:16] | RO | 16'h0    | Reserved                  |
| CHIP_ID_HIGH | [15: 0] | RO | 16'h8810 | 8810 chip ID high 16 bits |



# **Appendix**

## **Acronyms and Abbreviations**

| Field | Symbol | Acronyous and Abbreviations         |
|-------|--------|-------------------------------------|
| Α     |        |                                     |
|       | AAC    | Advanced Audio Coding               |
|       | ADC    | Analog Digital Converter            |
|       | ADM    | Memory Address and data is Mutiple  |
|       | ADP    | Memory Address and data is Parallel |
|       | AES    | Advanced Encryption Standard        |
|       | AFC    | Auto Frequency Calibration          |
|       | AGC    | Auto Gain Calibration               |
|       | AHB    | Advanced Hign performance Bus       |
|       | ALC    | Auto Level Control                  |
|       | ALU    | Arithmetic and Logical Unit         |
|       | AMR    | Adaptive Multi-Rate                 |
|       | APC    | Auto Phase Calibration              |
|       | ARF    | Addressing Register File            |
|       | AST    | Action start time                   |
|       | ASU    | Add Subtract Unit                   |
| В     |        |                                     |
|       | BMU    | Bit Manipulation Unit               |
|       | BPINT  | Breakpoint Interrupt                |
|       | BSM    | Bit Streaming Module                |
|       | BSW    | Band-Switch Word                    |
|       | BTL    | Bridge Tied Load                    |
| С     |        |                                     |
|       | CDM    | Charged-device model                |
|       | CIA    | Common Information Area             |
|       | CIF    | common intermediate format          |
|       | CIS    | Card Information Structure          |
|       | CMD    | Command                             |
|       | CSRs   | Control and Status Registers        |
| D     |        |                                     |
|       | DAAU   | Data Address and Arithmetic Unit    |
|       | DAC    | Digital Analog Converter            |
|       | DAI    | Digital Audio Interface             |
|       |        |                                     |



| Field | Symbol | Acronyous and Abbreviations            |
|-------|--------|----------------------------------------|
|       | DBK    | De-Blocking                            |
|       | DCAM   | Digital Camera                         |
|       | DCS    | Digital Cellular System                |
|       | DCT    | Discrete Cosine Transformation         |
|       | DDR    | Double Data Rate                       |
|       | DEC    | Decode                                 |
|       | DFF    | D type flip-flop                       |
|       | DFT    | Design For Test                        |
|       | DLCH   | Down Link Channel                      |
|       | DMA    | Direct Memory Access                   |
|       | DMEM   | DDR Memory                             |
|       | DQS    | Bidirectional data strobe              |
|       | DR     | Dynamic Range                          |
|       | DRM    | Digital Rights Management              |
|       | DSP    | Digital Signal Processor               |
| Е     |        |                                        |
|       | ECC    | Error Checking Code                    |
|       | EFR    | Enhanced Full Rate                     |
|       | EMC    | External Memory Controller             |
|       | ENC    | Encode                                 |
| F     |        |                                        |
|       | FBR    | Function Basic Registers               |
|       | FFT    | Fast Fourier Transformation            |
|       | FIFO   | First In First Out                     |
|       | FIQ    | Fast Interrupt Request                 |
|       | FIR    | Finite Impulse Response                |
|       | FMO    | Flexible Macroblock Ordering           |
|       | FR     | Full Rate                              |
|       | FSM    | Finite State Machine                   |
| G     |        |                                        |
|       | GEA    | Gprs Encryption Algorithm              |
|       | GIF    | Graphics Interchange Format            |
|       | GMSK   | Gaussian-filtered Minimum Shift Keying |
|       | GPIO   | General Perpose Input/Output           |
| Н     |        |                                        |
|       | НВМ    | Human body model                       |
|       | HPF    | High Pass Filter                       |
|       | HR     | Half Rate                              |
|       | HSDPA  | High Speed Downlink Packet Access      |
|       | HSUPA  | High Speed Uplink Packet Access        |
|       |        |                                        |



| Field | Symbol | Acronyous and Abbreviations            |
|-------|--------|----------------------------------------|
| 1     |        |                                        |
|       | ICU    | Interrupt Control Unit                 |
|       | IDCT   | Inverse Discrete Cosine Transformation |
|       | IFFT   | Inverse Fast Fourier Transformation    |
|       | I2C    | Inter-Integrated Circuit               |
|       | IIR    | Infinite Impulse Response              |
|       | IIS    | Integrate Interface of Sound           |
|       | IPRED  | Intra Prediction                       |
|       | IQT    | Integer Quantization Tranform          |
|       | IRQ    | Interrupt Request                      |
| J     |        |                                        |
|       | JDA    | Joint-Detection Accelerator            |
|       | JPEG   | Joint Photographics Expert Group       |
|       | JTAG   | Joint Test Cction Group                |
| L     |        |                                        |
|       | LCDC   | Liquid Crystal Display Controller      |
|       | LRO    | Left Right ouput                       |
|       | LSB    | least Significant Bit                  |
|       | LSE    | Least Square Equalizer                 |
| М     |        |                                        |
|       | MAP    | Maximum A Posteriori                   |
|       | MBC    | Macro Block Compensation               |
|       | MCA    | Motion Compensation Accelerator        |
|       | MCS    | Mobile Control Station                 |
|       | MCU    | Micro Control Unit                     |
|       | MEA    | Motion Estimation Accelerator          |
|       | MM     | Machine Model                          |
|       | MPEG   | Motion Photographics Expert Group      |
|       | MSB    | Most Significant Bit                   |
|       | MSL    | Moisture Sensitivity Level             |
| N     |        |                                        |
|       | NSEQ   | None Sequencial                        |
| 0     |        |                                        |
|       | OCR    | Optical CharacterRrecognition          |
|       | OSD    | On-Screen Display                      |
|       | OTP    | Over Temperature Protection            |
| Р     |        |                                        |
|       | PBINT  | Power Button Interrupt                 |
|       | PCM    | Pulse Code Modulation                  |
|       | PGM    | Program                                |
|       |        |                                        |



| Field | Symbol | Acronyous and Abbreviations                           |
|-------|--------|-------------------------------------------------------|
|       | PIU    | Processor Interface Unit                              |
|       | PLL    | Phase Locked Loop                                     |
|       | PNG    | Portal Network Graphic                                |
|       | PSRR   | Power Supply Rejection Ratio                          |
|       | PTEST  | Production Test                                       |
| Q     |        |                                                       |
|       | QAM    | Quadracture Amplitude Modulation                      |
|       | QBC    | Quarter Bit Clock                                     |
|       | QCIF   | Quarter Common Intermediate Format                    |
|       | QPSK   | Quarternary Phase Shift Keying                        |
|       | QVGA   | quarter Video Graphics Array                          |
| R     |        |                                                       |
|       | RCA    | Relative Card Address                                 |
|       | RFT    | RF Timing                                             |
|       | RFU    | Reserved for Future Use                               |
|       | RISC   | Reduced Instruction Set Computer                      |
|       | RLC    | Radio Link Control                                    |
|       | RMA    | Rate Matching Accelerator                             |
|       | RTC    | Real Time Clock                                       |
| S     |        |                                                       |
|       | SBI    | Serial Bus Interface                                  |
|       | SCL    | Serial Clock ILne                                     |
|       | SDA    | Serial Data Address                                   |
|       | SDIO   | Secure Digital Input/Ouput                            |
|       | SDR    | Single Data Rate                                      |
|       | SID    | Signal ID                                             |
|       | SIM    | Subscriber Identity Module                            |
|       | SIMD   | Single Instruction Multiple Data                      |
|       | SMEM   | SDR Memory                                            |
|       | SNR    | Signal to Noise Ratio                                 |
|       | SPI    | Serial Peripheral Interface                           |
|       | SRAM   | Static RAM                                            |
| Т     |        |                                                       |
|       | тсусхо | Temperature-Compensated Voltage Controlled Oscillator |
|       | TFCI   | Transport Format Combination Indicator                |
|       | THD    | Total Harmonic Distortion                             |
|       | TPC    | Touch Panel Controller                                |
|       | TTI    | Transmission Time Interval                            |
|       |        |                                                       |



| Field | Symbol | Acronyous and Abbreviations                 |
|-------|--------|---------------------------------------------|
|       | UART   | Universal Asynchronous Reveiver/Transmitter |
|       | UID    | Unique ID                                   |
|       | USB    | Univeral Serial Bus                         |
|       | UVLO   | Under Voltage Lock Out                      |
| V     |        |                                             |
|       | VDB    | Video Data Bus                              |
|       | VINT   | Vector Interrupt                            |
|       | VLC    | Variable Length Code                        |
|       | VLD    | Variable Length Decode                      |
|       | VLIW   | Very Long Instruction Word                  |
| W     |        |                                             |
|       | WDT    | Watchdog Timer                              |
|       | WQVGA  | Wide Quarter Video Graphics Array           |