# Jone eittel 126. com internat JZ4770



# JZ4770 Mobile Application Processor

# **Peripherals Programming Manual**

Copyright © 2005-2011 Ingenic Semiconductor Co. Ltd. All rights reserved.

# Disclaimer

This documentation is provided for use with Ingenic products. No license to Ingenic property rights is granted. Ingenic assumes no liability, provides no warranty either expressed or implied relating to the usage, or intellectual property right infringement except as provided for by Ingenic Terms and Conditions of Sale.

Ingenic products are not designed for and should not be used in any medical or life sustaining or supporting equipment.

All information in this document should be treated as preliminary. Ingenic may make changes to this document without notice. Anyone relying on this documentation should contact Ingenic for the current interna documentation and errata.

Ingenic Semiconductor Co., Ltd.

Room 108, Building A, Information Center, Zhongguancun Software Park 8 Dongbeiwang West Road, Haidian District, Beijing, China, Tel: 86-10-82826661 Fax: 86-10-82825845 Http://www.ingenic.cn



# CONTENTS

| 1 Gen  | eral-Purpose I/O Ports                          | 1  |
|--------|-------------------------------------------------|----|
| 1.1 C  | Dverview                                        |    |
| 1.1.1  | GPIO Port A Summary                             | 2  |
| 1.1.2  | GPIO Port B Summary                             | 3  |
| 1.1.3  | GPIO Port C Summary                             | 4  |
| 1.1.4  | GPIO Port D Summary                             | 5  |
| 1.1.5  | GPIO Port E Summary                             | 6  |
| 1.1.6  | GPIO Port F Summary                             | 7  |
| 1.2 R  | Registers Description                           | 9  |
| 1.2.1  | PORT PIN Level Registers (PxPIN)                | 13 |
| 1.2.2  | PORT Interrupt Registers (PxINT)                |    |
| 1.2.3  | PORT Interrupt Set Registers (PxINTS)           |    |
| 1.2.4  | PORT Interrupt Clear Registers (PxINTC)         |    |
| 1.2.5  | PORT Mask Registers (PxMSK)                     |    |
| 1.2.6  | PORT Mask Set Registers (PxMSKS)                |    |
| 1.2.7  | PORT Mask Clear Registers (PxMSKC)              |    |
| 1.2.8  | PORT PAT1/Direction Registers (PxPAT1)          | 17 |
| 1.2.9  | PORT PAT1/Direction Set Registers (PxPAT1S)     | 17 |
| 1.2.10 | ) PORT PAT1/Direction Clear Registers (PxPAT1C) |    |
| 1.2.11 | PORT PAT0/Data Registers (PxPAT0)               |    |
| 1.2.12 | 2 PORT PAT0/Data Set Registers (PxPAT0S)        | 19 |
| 1.2.13 | B PORT PAT0/Data Clear Registers (PxPAT0C)      |    |
| 1.2.14 | PORT FLAG Registers (PxFLG)                     |    |
| 1.2.15 | 5 PORT FLAG Clear Registers (PxFLGC)            |    |
| 1.2.16 | PORT PULL Disable Registers (PxPE)              | 21 |
| 1.2.17 | PORT PULL Set Registers (PxPES)                 | 21 |
| 1.2.18 | B PORT PULL Clear Registers (PxPEC)             | 22 |
| 1.3 P  | Program Guide                                   |    |
| 1.3.1  | Port Function Guide                             |    |
| 2 I2C  | Controller                                      | 24 |
| 2.1 C  | Dverview                                        |    |
| 2.1.1  | Features                                        |    |
| 2.1.2  | Pin Description                                 |    |
| 2.2 R  | Registers                                       |    |
| 2.2.1  | Registers Memory Map                            |    |
| 2.2.2  | Registers and Fields Description                |    |
| 2.3 C  | Dperating Flow                                  |    |
| 2.3.1  | I2C Behavior                                    |    |
| 2.3.2  | Master Mode Operation                           | 50 |
|        |                                                 | i  |

ii



| <ul> <li>2.3.4 Disabling I2C</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 51 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 3.1       Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 54 |
| <ul> <li>3.2 Pin Description</li> <li>3.3 Register Description</li> <li>3.3.1 SSI Data Register (SSIDR)</li> <li>3.3.2 SSI Control Register0 (SSICR0)</li> <li>3.3.3 SSI Control Register1 (SSICR1)</li> <li>3.3.4 SSI Status Register1 (SSISR)</li> <li>3.3.5 SSI Interval Time Control Register (SSIITR)</li> <li>3.3.6 SSI Interval Character-per-frame Control Register (SSIICR)</li> <li>3.3.7 SSI Clock Generator Register (SSIGR)</li> <li>3.4 Functional Description</li> </ul> | 56 |
| <ul> <li>3.2 Pin Description</li> <li>3.3 Register Description</li> <li>3.3.1 SSI Data Register (SSIDR)</li> <li>3.3.2 SSI Control Register0 (SSICR0)</li> <li>3.3.3 SSI Control Register1 (SSICR1)</li> <li>3.3.4 SSI Status Register1 (SSISR)</li> <li>3.3.5 SSI Interval Time Control Register (SSIITR)</li> <li>3.3.6 SSI Interval Character-per-frame Control Register (SSIICR)</li> <li>3.3.7 SSI Clock Generator Register (SSIGR)</li> <li>3.4 Functional Description</li> </ul> | 56 |
| <ul> <li>3.3 Register Description</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |
| <ul> <li>3.3.2 SSI Control Register0 (SSICR0)</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |
| <ul> <li>3.3.3 SSI Control Register1 (SSICR1)</li> <li>3.3.4 SSI Status Register1 (SSISR)</li></ul>                                                                                                                                                                                                                                                                                                                                                                                     | 58 |
| <ul> <li>3.3.4 SSI Status Register1 (SSISR)</li> <li>3.3.5 SSI Interval Time Control Register (SSIITR)</li> <li>3.3.6 SSI Interval Character-per-frame Control Register (SSIICR)</li> <li>3.3.7 SSI Clock Generator Register (SSIGR)</li> <li>3.4 Functional Description</li> </ul>                                                                                                                                                                                                     | 59 |
| <ul> <li>3.3.5 SSI Interval Time Control Register (SSIITR)</li> <li>3.3.6 SSI Interval Character-per-frame Control Register (SSIICR)</li> <li>3.3.7 SSI Clock Generator Register (SSIGR)</li> <li>3.4 Functional Description</li> </ul>                                                                                                                                                                                                                                                 | 61 |
| <ul> <li>3.3.6 SSI Interval Character-per-frame Control Register (SSIICR)</li> <li>3.3.7 SSI Clock Generator Register (SSIGR)</li> <li>3.4 Functional Description</li></ul>                                                                                                                                                                                                                                                                                                             | 64 |
| 3.3.7 SSI Clock Generator Register (SSIGR)                                                                                                                                                                                                                                                                                                                                                                                                                                              | 66 |
| 3.4 Functional Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 67 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 67 |
| 3.5 Data Formats                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |
| 3.5.1 Motorola's SPI Format Details                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 69 |
| 3.5.2 TI's SSP Format Details                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |
| 3.5.3 National Microwire Format Details                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 74 |
| 3.6 Interrupt Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 76 |
| <ul> <li>3.6 Interrupt Operation</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                              | 77 |
| 4.1 Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 77 |
| 4.2 Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 78 |
| 4.3 Structure                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 79 |
| 4.4 Register Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |
| 4.4.1 One-Wire Configure Register (OWCFG)                                                                                                                                                                                                                                                                                                                                                                                                                                               | 80 |
| 4.4.2 One-Wire Control Register (OWCTL)                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 81 |
| 4.4.3 One-Wire Status Register (OWSTS)                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 81 |
| 4.4.4 One-Wire Data Register (OWDAT)                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 82 |
| 4.4.5 One-Wire Clock Divide Register (OWDIV)                                                                                                                                                                                                                                                                                                                                                                                                                                            | 82 |
| 4.5 One-Wire Bus Protocol                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 83 |
| 4.5.1 Reset Timing and ACK Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 83 |
| 4.5.2 Write 0 Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 83 |
| 4.5.3 Write 1 Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 83 |
| 4.5.4 Read0 Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 84 |
| 4.5.5 Read1 Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 84 |
| 4.6 One-Wire Operation Guide                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 85 |
| 5 USB Host Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 5.1 Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 36 |
| 5.2 Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |
| 5.3 Register Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 86 |



| 5 | .4    | Introduction                                     | 89  |
|---|-------|--------------------------------------------------|-----|
| 6 | OT    | ΓG Controller                                    |     |
| 6 | .1    | Overview                                         |     |
| 6 | .2    | Pin Description                                  | 91  |
| 6 | .3    | Register Description                             |     |
| 6 | .4    | Common registers                                 | 97  |
|   | 6.4.  | .1 FAddr                                         |     |
|   | 6.4.2 | .2 Power                                         | 97  |
|   | 6.4.3 | .3 IntrTx                                        |     |
|   | 6.4.4 | .4 IntrRx                                        |     |
|   | 6.4.  | .5 IntrTxE                                       | 100 |
|   | 6.4.6 | .6 IntrRxE                                       | 101 |
|   | 6.4.7 | .7 IntrUSB                                       | 102 |
|   | 6.4.8 |                                                  |     |
|   | 6.4.9 |                                                  |     |
|   | 6.4.  |                                                  | 104 |
|   | 6.4.1 |                                                  |     |
|   | 6.4.  |                                                  | 106 |
| 6 | .5    | Indexed Register                                 | 108 |
|   | 6.5.1 |                                                  |     |
|   | 6.5.2 | .2 Count0                                        | 111 |
|   | 6.5.3 |                                                  |     |
|   | 6.5.4 | .4 NakLimit0 (Host Mode Only)                    | 112 |
|   | 6.5.5 |                                                  |     |
|   | 6.5.6 | .6 TxCSR                                         | 114 |
|   | 6.5.7 | .7 RxMaxP                                        | 118 |
|   | 6.5.8 | .8 <b>R</b> xCSR                                 | 120 |
|   | 6.5.9 | 9 RxCount                                        | 124 |
|   | 6.5.  | .10 TxType (Host Mode Only)                      | 125 |
|   | 6.5.  | .11 TxInterval (Host Mode Only)                  | 125 |
|   | 6.5.  | .12 RxType (Host Mode Only)                      | 126 |
|   | 6.5.  | .13 RxInterval                                   | 127 |
|   | 6.5.  | .14 FifoSize                                     | 128 |
|   | 6.5.  | .15 FIFOx                                        | 128 |
| 6 | .6    | Additional Multipoint Control / Status Registers | 129 |
|   | 6.6.  | .1 TxFuncAddr / RxFuncAddr                       | 129 |
|   | 6.6.2 | .2 TxHubAddr/RxHubAddr                           | 129 |
|   | 6.6.3 | .3 TxHubPort / RxHubPort                         | 130 |
| 6 | .7    | Additional Control/Status Registers              | 131 |
|   | 6.7.′ | .1 VControl                                      | 131 |
|   | 6.7.2 | .2 VStatus                                       | 131 |
|   | 6.7.3 | .3 Hwvers                                        | 132 |
| _ |       |                                                  | iii |

iv



| 6.8 Additional Configuration Registers                         |     |
|----------------------------------------------------------------|-----|
| 6.8.1 EPInfo                                                   |     |
| 6.8.2 RAMInfo                                                  |     |
| 6.8.3 LinkInfo                                                 | 134 |
| 6.8.4 VPLen                                                    | 134 |
| 6.8.5 HS_EOF1                                                  |     |
| 6.8.6 FS_EOF1                                                  | 135 |
| 6.8.7 LS_EOF1                                                  | 136 |
| 6.8.8 SoftRst                                                  |     |
| 6.9 Extended Registers                                         | 138 |
| 6.9.1 RqPktCnt                                                 | 138 |
| 6.9.2 RmtWkIntr                                                | 138 |
| 6.9.3 RmtWkIntrE                                               | 139 |
| 6.9.4 RxDPktBufDis                                             |     |
| 6.9.5 TxDPktBufDis                                             |     |
| 6.9.6 C_T_UCH                                                  |     |
| 6.9.7 C_T_HHSRTN                                               |     |
| 6.9.8 C_T_HSBT                                                 |     |
| 6.10 DMA Registers                                             | 144 |
| 6.10.1 DMA_INTR                                                | 144 |
| 6.10.2 DMA_CNTL                                                | 144 |
| 6.10.3 DMA_ADDR                                                | 145 |
| 6.10.4 DMA_COUNT                                               |     |
| 6.11 Transaction flows as a peripheral                         |     |
| 6.11.1 Control transactions                                    | 147 |
| 6.11.2 Bulk/Low-bandwidth interrupt transactions               |     |
| 6.11.3 Full-speed/Low-bandwidth isochronous transactions       |     |
| 6.11.4 High-bandwidth transactions (Isochronous and interrupt) |     |
| 6.12 Transaction flows as a host                               | 158 |
| 6.12.1 Control transactions                                    |     |
| 6.12.2 Bulk/Low-bandwidth interrupt transactions               |     |
| 6.12.3 Full-speed/Low-bandwidth isochronous transactions       |     |
| 6.12.4 High-bandwidth transactions (isochronous and interrupt) |     |
| 6.13 DMA operations                                            |     |
| 6.13.1 Single packet tx                                        |     |
| 6.13.2 Single packet rx                                        | 170 |
| 6.13.3 Multiple packet tx                                      |     |
| 6.13.4 Multiple packet rx                                      |     |
| 7 MMC/SD CE-ATA Controller                                     | 174 |
| 7.1 Overview                                                   |     |
| 7.2 Block Diagram                                              |     |
| 7.3 MMC/SD Controller Signal I/O Description                   |     |



۷

| 7.4 R  | egister Description                                                  | 177 |
|--------|----------------------------------------------------------------------|-----|
| 7.4.1  | MMC/SD Control Register (MSC_CTRL)                                   | 177 |
| 7.4.2  | MSC Status Register (MSC_STAT)                                       | 179 |
| 7.4.3  | MSC Clock Rate Register (MSC_CLKRT)                                  | 181 |
| 7.4.4  | MMC/SD Command and Data Control Register (MSC_CMDAT)                 | 181 |
| 7.4.5  | MMC/SD Response Time Out Register (MSC_RESTO)                        | 184 |
| 7.4.6  | MMC/SD Read Time Out Register (MSC_RDTO)                             | 184 |
| 7.4.7  | MMC/SD Block Length Register (MSC_BLKLEN)                            | 184 |
| 7.4.8  | MSC/SD Number of Block Register (MSC_NOB)                            | 185 |
| 7.4.9  | MMC/SD Number of Successfully-transferred Blocks Register (MSC_SNOB) | 185 |
| 7.4.10 | MMC/SD Interrupt Mask Register (MSC_IMASK)                           | 186 |
| 7.4.11 | MMC/SD Interrupt Register (MSC_IREG)                                 | 187 |
| 7.4.12 | MMC/SD Command Index Register (MSC_CMD)                              | 189 |
| 7.4.13 | MMC/SD Command Argument Register (MSC_ARG)                           | 189 |
| 7.4.14 | MMC/SD Response FIFO Register (MSC_RES)                              | 189 |
| 7.4.15 | MMC/SD Receive Data FIFO Register (MSC_RXFIFO)                       | 190 |
| 7.4.16 | MMC/SD Transmit Data FIFO Register (MSC_TXFIFO)                      | 190 |
| 7.4.17 |                                                                      | 190 |
| 7.5 N  | MC/SD Functional Description                                         | 192 |
| 7.5.1  | MSC Reset                                                            | 192 |
| 7.5.2  | MSC Card Reset                                                       | 192 |
| 7.5.3  | Voltage ValidationCOT                                                | 192 |
| 7.5.4  | Card Registry                                                        | 193 |
| 7.5.5  | Card Access                                                          | 194 |
| 7.5.6  | Protection Management                                                | 195 |
| 7.5.7  | Card Status                                                          | 199 |
| 7.5.8  | SD Status                                                            | 202 |
| 7.5.9  | ŚĘIJŎ                                                                | 203 |
| 7.5.10 | Clock Control                                                        | 205 |
| 7.5.11 | Application Specified Command Handling                               | 205 |
| 7.6 N  | MC/SD Controller Operation                                           | 207 |
| 7.6.1  | Data FIFOs                                                           | 207 |
| 7.6.2  | DMA and Program I/O                                                  | 208 |
| 7.6.3  | Start and Stop clock                                                 | 209 |
| 7.6.4  | Software Reset                                                       | 209 |
| 7.6.5  | Voltage Validation and Card Registry                                 | 210 |
| 7.6.6  | Single Data Block Write                                              | 211 |
| 7.6.7  | Single Block Read                                                    | 212 |
| 7.6.8  | Multiple Block Write                                                 | 212 |
| 7.6.9  | Multiple Block Read                                                  | 213 |
| 7.6.10 | Stream Write (MMC)                                                   | 214 |
| 7.6.11 | Stream Read (MMC)                                                    | 215 |
| 7.6.12 | Erase, Select/Deselect and Stop                                      | 216 |
|        |                                                                      |     |



|   | 7.6.13  | SDIO Suspend/Resume                                  | 216 |
|---|---------|------------------------------------------------------|-----|
|   | 7.6.14  | SDIO ReadWait                                        | 216 |
|   | 7.6.15  | Operation and Interrupt                              | 217 |
| 8 | UART    | Interface                                            | 219 |
| 8 | .1 Ove  | rview                                                | 219 |
|   | 8.1.1   | Features                                             | 219 |
|   | 8.1.2   | Pin Description                                      | 219 |
| 8 | .2 Reg  | ister Descriptions                                   | 220 |
|   | 8.2.1   | UART Receive Buffer Register (URBR)                  | 221 |
|   | 8.2.2   | UART Transmit Hold Register (UTHR)                   | 222 |
|   | 8.2.3   | UART Divisor Latch Low/High Register (UDLLR / UDLHR) | 222 |
|   | 8.2.4   | UART Interrupt Enable Register (UIER)                | 223 |
|   | 8.2.5   | UART Interrupt Identification Register (UIIR)        | 224 |
|   | 8.2.6   | UART FIFO Control Register (UFCR)                    |     |
|   | 8.2.7   | UART Line Control Register (ULCR)                    | 226 |
|   | 8.2.8   | UART Line Status Register (ULSR)                     | 227 |
|   | 8.2.9   | UART Modem Control Register (UMCR)                   | 229 |
|   | 8.2.10  | UART Modem Status Register (UMSR)                    | 230 |
|   | 8.2.11  | UART Scratchpad Register                             | 231 |
|   | 8.2.12  | Infrared Selection Register (ISR)                    |     |
|   | 8.2.13  | UART M Register (UMR)                                | 232 |
|   | 8.2.14  | UART Add Cycle Register (UACR)                       | 232 |
| 8 | .3 Ope  | ration                                               | 233 |
|   | 8.3.1   | UART Configuration                                   | 233 |
|   | 8.3.2   | Data Transmission                                    | 233 |
|   | 8.3.3   | Data Reception                                       | 233 |
|   | 8.3.4 🔨 | Receive Error Handling                               | 234 |
|   | 8.3.5   | Modem Transfer                                       | 234 |
|   | 8.3.6   | DMA Transfer                                         | 234 |
|   | 8.3.7   | Slow IrDA Asynchronous Interface                     | 235 |
|   | 8.3.8   | For any frequency clock to use the UART              | 235 |
| 9 | Smart   | Card Controller                                      | 238 |
| 9 | .1 Ove  | rview                                                | 238 |
| 9 | .2 Pin  | Description                                          | 239 |
| 9 | .3 Reg  | ister Description                                    | 240 |
|   | 9.3.1   | Transmit/Receive FIFO Data Register (SCCDR)          | 240 |
|   | 9.3.2   | FIFO Data Count Register (SCCFDR)                    | 240 |
|   | 9.3.3   | Control Register (SCCCR)                             |     |
|   | 9.3.4   | Status Register (SCCSR)                              |     |
|   | 9.3.5   | Transmission Factor Register (SCCTFR)                |     |
|   | 9.3.6   | Extra Guard Timer Register (SCCEGTR)                 | 243 |

vi



| 9.3.7     | ETU Counter Value Register (SCCECR)                                    |     |
|-----------|------------------------------------------------------------------------|-----|
| 9.3.8     | Reception Timeout Register (SCCRTOR)                                   |     |
| 10 TS Sla | ave Interface (TSSI)                                                   |     |
| 10.1 Ove  | erview                                                                 |     |
| 10.2 Pin  | Description                                                            |     |
| 10.3 Reg  | gister Description                                                     |     |
| 10.3.1    | TSSI Enable Register (TSENA)                                           |     |
| 10.3.2    | TSSI Configure Register (TSCFG)                                        |     |
| 10.3.3    | TSSI Control Register (TSCTRL)                                         |     |
| 10.3.4    | TSSI State Register (TSSTAT)                                           |     |
| 10.3.5    | TSSI FIFO Register (TSFIFO)                                            |     |
| 10.3.6    | TSSI PID Enable Register (TSPEN)                                       |     |
| 10.3.7    | TSSI Data Number Register (TSNUM)                                      |     |
| 10.3.8    | TSSI Data Trigger Register (TSDTR)                                     |     |
| 10.3.9    | TSSI PID Filter Registers (TSPID0~15)                                  |     |
| 10.3.10   | TSSI DMA Descriptor Address (TSDDA)<br>TSSI DMA Target Address (TSDTA) |     |
| 10.3.11   | TSSI DMA Target Address (TSDTA)                                        |     |
| 10.3.12   | TSSI DMA Identifier (TSDID)                                            |     |
| 10.3.13   | TSSI DMA Command (TSDCMD)                                              |     |
| 10.3.14   | TSST DMA Status (TSDST)                                                |     |
| 10.3.15   | TSSI Transfer Control Register (TSTC)                                  |     |
|           | SI Timing                                                              |     |
| 10.5 TSS  | SI Guide                                                               |     |
| 10.5.1    | TSSI Operation without PID Filtering Function                          |     |
| 10.5.2    | TSSI Operation with PID Filtering Function                             |     |
| 11 Etherr | net MAC Controller                                                     |     |
| 11.1 Ove  | svo-                                                                   |     |
| × 1       | AN support Ethernet Signals                                            |     |
|           | ck Diagram                                                             |     |
|           | A Module                                                               |     |
| 11.4.1    | Overview                                                               |     |
| 11.4.2    | Features                                                               |     |
| 11.4.3    | Register Map                                                           |     |
| 11.4.4    | Register Description                                                   |     |
| 11.5 FIF  | O Module                                                               |     |
| 11.5.1    | Overview                                                               |     |
| 11.5.2    | Features                                                               |     |
| 11.5.3    | Register Map                                                           |     |
| 11.5.4    | Register Description                                                   |     |
|           | Module                                                                 |     |
| 11.6.1    | Overview                                                               |     |
|           |                                                                        | vii |

viii



| 11.6.2    | Register Map                    |     |
|-----------|---------------------------------|-----|
| 11.6.3    | Register Description            |     |
| 11.7 RM   | II Module                       |     |
| 11.7.1    | Overview                        |     |
| 11.7.2    | Feature                         |     |
| 11.8 SAL  | _ Module                        |     |
| 11.8.1    | Overview                        |     |
| 11.8.2    | Register Map                    |     |
| 11.8.3    | Register Description            |     |
| 11.9 STA  | NT Module                       |     |
| 11.9.1    | Overview                        |     |
| 11.9.2    | Register Map                    |     |
| 11.9.3    | Register Description            |     |
|           | E Clave Interface (EELICE)      | 205 |
| 12 EFU5   | E Slave Interface (EFUSE)       |     |
| 12.1 Ove  | erview                          |     |
| 12.2 Reg  | jister Description              | 326 |
| 12.2.1    | EFUSE Control Register (EFSCTL) |     |
| 12.2.2    | EFUSE Data Register (EFUSEn)    |     |
| 12.3 Flow | N                               |     |
| 12.3.1    | Write EFUSE Flow                |     |
| 12.3.2    | Read EFUSE Flow                 |     |
| 100       | E Oldve Interface (EFOOL)       |     |

i



# TABLES

| Table 1-1 GPIO Port A summary                                | 2   |
|--------------------------------------------------------------|-----|
| Table 1-2 GPIO Port B summary                                | 3   |
| Table 1-3 GPIO Port C summary                                | 4   |
| Table 1-4 GPIO Port D summary                                | 5   |
| Table 1-5 GPIO Port E summary                                | 6   |
| Table 1-6 GPIO Port F summary                                | 7   |
| Table 1-7 GPIO Registers                                     | 9   |
| Table 2-1 I2C Pin Description                                | 24  |
| Table 2-2 Registers Memory Map-Address Base                  | 26  |
| Table 2-3 Registers Memory Map-Address Offset                | 26  |
| Table 3-1 Micro Printer Controller Pins Description          | 57  |
| Table 3-2 SSI Serial Port Registers                          | 58  |
| Table 3-3 SSI Interrupts                                     | 76  |
| Table 4-1 One-Wire Controller Pins Description               | 78  |
| Table 4-2 OWI Registers Description                          | 80  |
| Table 5-1 UHC Pins Description                               | 87  |
| Table 6-1 OTG Pins Description                               | 91  |
| Iable 6-2 UTU- Redisters Description                         | y 2 |
| Table 7-1 Command Token Format                               | 176 |
| Table 7-2 MMC/SD Data Token Format                           | 176 |
| Table 7-3 MMC/SD Controller Registers Description            | 177 |
| Table 7-4 Command Data Block Structure                       | 196 |
| Table 7-5 Card Status Description                            | 200 |
| Table 7-6 SD Status Structure                                | 203 |
| Table 7-7 How to stop multiple block write                   | 213 |
| Table 7-8 How to stop multiple block read                    | 214 |
| Table 7-9 The mapping between Commands and Steps             | 217 |
| Table 8-1 UART Pins Description                              | 219 |
| Table 8-2 UART Registers Description                         | 220 |
| Table 8-3 UART Interrupt Identification Register Description | 224 |
| Table 9-1 Smart Card Controller Pins Description             | 239 |
| Table 9-2 Smart Card Controller Registers Description        | 240 |
| Table 10-1 TSSI Pin Description                              | 246 |
| Table 10-2 TSSI Register Description                         | 247 |
| Table 11-1 Ethernet MII Signals                              | 261 |
| Table 11-2 Pin Map of MII and RMII Mode                      | 262 |
|                                                              |     |

Long\_eiffel@126.com internal used only

i



# FIGURES

| Figure 3-1 SPI Single Character Transfer Format (PHA = 0)                | 70    |
|--------------------------------------------------------------------------|-------|
| Figure 3-2 SPI Single Character Transfer Format (PHA = 1)                | 70    |
| Figure 3-3 SPI Back-to-Back Transfer Format                              | 71    |
| Figure 3-4 SPI Frame Interval Mode Transfer Format (ITFRM = 0, LFST = 0) | 72    |
| Figure 3-5 SPI Frame Interval Mode Transfer Format (ITFRM = 1, LFST = 1) | 73    |
| Figure 3-6 TI's SSP Single Transfer Format                               | 73    |
| Figure 3-7 TI's SSP Back-to-back Transfer Format                         | 74    |
| Figure 3-8 National Microwire Format 1 Single Transfer                   | 74    |
| Figure 3-9 National Microwire Format 1 Back-to-back Transfer             | 75    |
| Figure 3-10 National Microwire Format 2 Read Timing                      | 75    |
| Figure 3-11 National Microwire Format 2 Write Timing                     | 75    |
| Figure 7-1 MMC/SD CE-ATA Controller Block Diagram                        | . 175 |
| Figure 10-1 Timing waveform in parallel mode                             | . 258 |
| Figure 10-2 Timing waveform in serial mode                               | . 258 |
| - Pot                                                                    |       |
| 21 45                                                                    |       |
| internal use                                                             |       |
| om internal use                                                          |       |
| 26. COM internal use                                                     |       |
| 126. com internal use                                                    |       |
| scol@126.com internal use                                                |       |
| iffel@126.com internal use                                               |       |
| eiffel@126.com internal use                                              |       |
| 1008_eiffel@126.com internal use                                         |       |
| 10ng_eiffel@126.com internal use                                         |       |
| Figure 10-1 Timing waveform in parallel mode                             |       |

Long\_eiffel@126.com internal used only



#### **General-Purpose I/O Ports** 1

#### **Overview** 1.1

General Purpose I/O Ports (GPIO) is used in generating and capturing application-specific input and output signals. Each port can be programmed as an output, an input or function port that serves certain peripheral. As input, pull up/down can be enabled/disabled for the port and the port also can be configured as level or edge tripped interrupt source.

#### Features:

- Each port can be configured as an input, an output or an alternate function port
- Each port can be configured as an interrupt source of low/high level or rising/falling edge triggering. • Every interrupt source can be masked independently
- " The pull-u usi internal usi internal usi internal usi Each port has an internal pull-up or pull-down resistor connected. The pull-up/down resistor can • be disabled
- GPIO output 6 interrupts, 1 for every group, to INTC



# 1.1.1 GPIO Port A Summary

| Bit | ΡΑ | Pull   |             | Shared Fund  | ction Port Selecte | ed by                   |      |
|-----|----|--------|-------------|--------------|--------------------|-------------------------|------|
| Ν   | Ν  | (U/D)  | 0           | 1            | 2                  | 3                       | Note |
| 0   | 00 | U      | sd0(io)     | -            | -                  | -                       |      |
| 1   | 01 | U      | sd1(io)     | -            | -                  | -                       |      |
| 2   | 02 | U      | sd2(io)     | -            | -                  | -                       |      |
| 3   | 03 | U      | sd3(io)     | -            | -                  | -                       |      |
| 4   | 04 | U      | sd4(io)     | -            | -                  | -                       |      |
| 5   | 05 | U      | sd5(io)     | -            | -                  | -                       |      |
| 6   | 06 | U      | sd6(io)     | -            | -                  | -                       |      |
| 7   | 07 | U      | sd7(io)     | -            | -                  | -                       | 1    |
| 8   | 08 | U      | sd8(io)     | -            | -                  | -                       | 7    |
| 9   | 09 | U      | sd9(io)     | -            | -                  | - 2 01                  |      |
| 10  | 10 | U      | sd10(io)    | -            | -                  | 1500                    |      |
| 11  | 11 | U      | sd11(io)    | -            | - 1                | $\overline{\Omega_{r}}$ |      |
| 12  | 12 | U      | sd12(io)    | -            | - rhat             | -                       |      |
| 13  | 13 | U      | sd13(io)    | -            | J.Cr               | -                       |      |
| 14  | 14 | U      | sd14(io)    | -            | -                  | -                       |      |
| 15  | 15 | U      | sd15(io)    | -            | -                  | -                       |      |
| 16  | 16 | U      |             | 6.           |                    |                         |      |
|     |    | rst-pe | rd_(o)      | 4-           | -                  | -                       |      |
| 17  | 17 | U      | cfer        |              |                    |                         |      |
|     |    | rst-pe | we_(o)      | -            | -                  | -                       |      |
| 18  | 18 | U      |             |              |                    |                         |      |
|     |    | rst-pe | fre_(o)     | msc0_clk(o)  | ssi0_clk(o)        | -                       |      |
| 19  | 19 | U      |             |              |                    |                         |      |
|     |    | rst-pe | fwe_(o)     | msc0_cmd(io) | ssi0_ce0_(o)       | -                       |      |
| 20  | 20 | U      | msc0_d0(io) | ssi0_dr(i)   | -                  | -                       | 1    |
| 21  | 21 | U      |             |              |                    |                         |      |
|     |    | rst-pe | cs1_(0)     | msc0_d1(io)  | ssi0_dt(o)         | -                       |      |
| 22  | 22 | U      |             |              |                    |                         |      |
|     |    | rst-pe | cs2_(0)     | msc0_d2(io)  | -                  | -                       |      |
| 23  | 23 | U      |             |              |                    |                         |      |
|     | _  | rst-pe | cs3_(0)     | msc0_d3(io)  | -                  | -                       |      |
| 24  | 24 | U      |             |              |                    |                         |      |
|     |    | rst-pe | cs4_(0)     | -            | -                  | -                       |      |
| 25  | 25 | U      |             |              |                    |                         |      |
|     |    | rst-pe | cs5_(0)     | -            | -                  | -                       |      |
| 26  | 26 | U      | cs6_(0)     | rdwr_(o)     | -                  | -                       |      |

## Table 1-1 GPIO Port A summary

2

|    |    | rst-pe |          |         |   |   |      |
|----|----|--------|----------|---------|---|---|------|
| 27 | 27 | U      | wait_(i) | -       | - | - |      |
| 28 | 28 | U      | dreq0(i) | -       | - | - |      |
| 29 | 29 | U      | dack0(o) | owi(io) | - | - |      |
| 30 | 30 | -      | -        | -       | - | - | 6    |
| 31 | 31 | -      | -        | -       | - | - | 7,11 |

# 1.1.2 GPIO Port B Summary

| Bit | PB | Pull   |               | Shared Func | tion Port Selecte | d by         |      |
|-----|----|--------|---------------|-------------|-------------------|--------------|------|
| Ν   | Ν  | (U/D)  | 0             | 1           | 2                 | 3            | Note |
| 0   | 00 | D      |               |             |                   |              | 8    |
|     |    | rst-pe | sa0_cl(o)     | -           | -                 | $-10^{112}$  | 0    |
| 1   | 01 | D      |               |             |                   | 15ed         | 9    |
|     |    | rst-pe | sa1_al(o)     | -           |                   | 75           | 5    |
| 2   | 02 | U      | sa2(o)        | -           | - nal             | -            |      |
| 3   | 03 | U      | sa3(o)        | -           | F CI II           | -            |      |
| 4   | 04 | U      | sa4(o)        | dreq1(i)    | mii_crs(i)        | -            |      |
| 5   | 05 | U      | sa5(o)        | dack1(o)    | -                 | -            |      |
| 6   | 06 | U      | cim_pclk(i)   | G. CO       | -                 | -            |      |
| 7   | 07 | U      | cim_hsyn(i)   |             | -                 | -            |      |
| 8   | 08 | U      | colum         |             |                   |              |      |
|     |    | rst-pe | • cim_vsyn(i) | -           | -                 | -            |      |
| 9   | 09 | U C    | cim_mclk(o)   | -           | -                 | epd_pwc(o)   |      |
| 10  | 10 | 10     | cim_d0(i)     | -           | -                 | epd_pwr0(o)  |      |
| 11  | 11 | D      | cim_d1(i)     | -           | -                 | epd_pwr1(o)  |      |
| 12  | 12 | U      | cim_d2(i)     | -           | -                 | epd_sce2_(o) |      |
| 13  | 13 | U      | cim_d3(i)     | -           | -                 | epd_sce3_(o) |      |
| 14  | 14 | U      | cim_d4(i)     | -           | -                 | epd_sce4_(o) |      |
| 15  | 15 | U      | cim_d5(i)     | -           | -                 | epd_sce5_(o) |      |
| 16  | 16 | D      | cim_d6(i)     | -           | -                 | epd_pwr2(o)  |      |
| 17  | 17 | D      | cim_d7(i)     | -           | -                 | epd_pwr3(o)  |      |
| 18  | 18 | D      | cim_d8(i)     | dmic_clk(o) | -                 | epd_bd0(o)   |      |
| 19  | 19 | D      | cim_d9(i)     | dmic_in(i)  | -                 | epd_bd1(o)   |      |
| 20  | 20 | U      | msc2_d0(io)   | ssi0_dr(i)  | ssi1_dr(i)        | tsd0(i)      |      |
| 21  | 21 | U      | msc2_d1(io)   | ssi0_dt(o)  | ssi1_dt(o)        | tsd1(i)      |      |
| 22  | 22 | U      | tsd2(i)       | -           | -                 | -            |      |
| 23  | 23 | U      | tsd3(i)       | -           | -                 | -            |      |
| 24  | 24 | U      | tsd4(i)       | -           | -                 | -            |      |

#### Table 1-2 GPIO Port B summary



| 25 | 25 | U      | tsd5(i)      | -            | -            | -         |  |
|----|----|--------|--------------|--------------|--------------|-----------|--|
| 26 | 26 | U      | tsd6(i)      | -            | -            | -         |  |
| 27 | 27 | U      | tsd7(i)      | -            | -            | -         |  |
| 28 | 28 | U      | msc2_clk(o)  | ssi0_clk(o)  | ssi1_clk(o)  | tsclk(i)  |  |
| 29 | 29 | U      |              |              |              |           |  |
|    |    | rst-pe | msc2_cmd(io) | ssi0_ce0_(o) | ssi1_ce0_(o) | tsstr(i)  |  |
| 30 | 30 | U      | msc2_d2(io)  | ssi0_gpc(o)  | ssi1_gpc(o)  | tsfail(i) |  |
| 31 | 31 | U      |              |              |              |           |  |
|    |    | rst-pe | msc2_d3(io)  | ssi0_ce1_(o) | ssi1_ce1_(o) | tsfrm(i)  |  |

# 1.1.3 GPIO Port C Summary

| Bit | PC                          | Pull   |              | Shared Func | tion Port Selected | d by v on | )    |
|-----|-----------------------------|--------|--------------|-------------|--------------------|-----------|------|
| Ν   | Ν                           | (U/D)  | 0            | 1           | 2                  | 3         | Note |
| 0   | 00                          | U      | lcd_b0(o)    | lcd_rev(o)  | - 1                | 7.5       |      |
| 1   | 01                          | U      | lcd_b1(o)    | lcd_ps(o)   | - nal              | -         |      |
| 2   | 02                          | U      | lcd_b2(o)    | -           | FELLE              | -         |      |
| 3   | 03                          | U      | lcd_b3(o)    | -           | 1.00               | -         |      |
| 4   | 04                          | U      | lcd_b4(o)    | - 010       | -                  | -         |      |
| 5   | 05                          | U      | lcd_b5(o)    | G. CO       | -                  | -         |      |
| 6   | 06                          | U      | Icd_b6(o)    |             | -                  | -         |      |
| 7   | 07                          | U      | lcd_b7(0)    | -           | -                  | -         |      |
| 8   | 08                          | U      | lcd_pclk(o)  | -           | -                  | -         |      |
| 9   | 09                          | ູບ   ୧ | lcd_de(o)    | -           | -                  | -         |      |
| 10  | 10                          | 1a     |              |             |                    |           |      |
|     | $\mathcal{V}_{\mathcal{O}}$ | rst-pe | lcd_g0(o)    | lcd_spl(o)  | -                  | -         |      |
| 11  | 11                          | U      | lcd_g1(o)    | -           | -                  | -         |      |
| 12  | 12                          | U      | lcd_g2(o)    | -           | -                  | -         |      |
| 13  | 13                          | U      | lcd_g3(o)    | -           | -                  | -         |      |
| 14  | 14                          | U      | lcd_g4(o)    | -           | -                  | -         |      |
| 15  | 15                          | U      | lcd_g5(o)    | -           | -                  | -         |      |
| 16  | 16                          | U      | lcd_g6(o)    | -           | -                  | -         |      |
| 17  | 17                          | U      | lcd_g7(o)    | -           | -                  | -         |      |
| 18  | 18                          | U      | lcd_hsyn(io) | -           | -                  | -         |      |
| 19  | 19                          | U      | lcd_vsyn(io) | -           | -                  | -         |      |
| 20  | 20                          | U      | lcd_r0(o)    | lcd_cls(o)  | -                  | -         |      |
| 21  | 21                          | U      | lcd_r1(o)    | -           | -                  | -         |      |
| 22  | 22                          | U      | lcd_r2(o)    | -           | -                  | -         |      |
| 23  | 23                          | U      | lcd_r3(o)    | -           | -                  | -         |      |

#### Table 1-3 GPIO Port C summary

4

| 24 | 24 | U      | lcd_r4(o)     | - | - | - |  |
|----|----|--------|---------------|---|---|---|--|
| 25 | 25 | U      | lcd_r5(o)     | - | - | - |  |
| 26 | 26 | U      | lcd_r6(o)     | - | - | - |  |
| 27 | 27 | U      | lcd_r7(o)     | - | - | - |  |
| 28 | 28 | U      | uart2_rxd(i)  | - | - | - |  |
| 29 | 29 | U      | uart2_cts_(i) | - | - | - |  |
| 30 | 30 | U      |               |   |   |   |  |
|    |    | rst-pe | uart2_txd(o)  | - | - | - |  |
| 31 | 31 | U      |               |   |   |   |  |
|    |    | rst-pe | uart2_rts_(o) | - | - | - |  |

# 1.1.4 GPIO Port D Summary

| N                               | N         (L           00         -           01         -           02         -           03         -           04         -           05         -           06         -           07         - | Pull       J/D)       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U       U | 0<br>pcm0_do(o)<br>pcm0_clk(io)<br>pcm0_syn(io)<br>pcm0_di(i)<br>ps2_mclk(io)<br>ps2_mdata(io)<br>ps2_kclk(io) | Shared Funct<br>1<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- | tion Port Selected | 1 by <u>0</u><br>3<br>-<br>-<br>-<br>-<br>- | Note |
|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------------------|---------------------------------------------|------|
| 0<br>1<br>2<br>3<br>4<br>5<br>6 | 00           01           02           03           04           05           06           07                                                                                                        | U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U                                                                                                                                                                                                                       | pcm0_do(o)<br>pcm0_clk(io)<br>pcm0_syn(io)<br>pcm0_di(i)<br>ps2_mclk(io)<br>ps2_mdata(io)                      | -<br>-<br>- 11<br>- 011                                                            | -<br>ternal<br>-   | -                                           | Note |
| 1<br>2<br>3<br>4<br>5<br>6      | 01<br>02<br>03<br>04<br>05<br>06<br>07                                                                                                                                                               | U<br>U<br>U<br>U<br>U<br>U<br>U                                                                                                                                                                                                                                 | pcm0_clk(io)<br>pcm0_syn(io)<br>pcm0_di(i)<br>ps2_mclk(io)<br>ps2_mdata(io)                                    | -<br>- jr<br>011                                                                   | terna<br>-         | -                                           |      |
| 2<br>3<br>4<br>5<br>6           | 02<br>03<br>04<br>05<br>06<br>07                                                                                                                                                                     | U<br>U<br>U<br>U<br>U                                                                                                                                                                                                                                           | pcm0_syn(io)<br>pcm0_di(i)<br>ps2_mclk(io)<br>ps2_mdata(io)                                                    | - ir                                                                               | terr<br>-<br>-     | -                                           |      |
| 3<br>4<br>5<br>6                | 03<br>04<br>05<br>06<br>07                                                                                                                                                                           | U<br>U<br>U<br>U                                                                                                                                                                                                                                                | pcm0_di(i)<br>ps2_mclk(io)<br>ps2_mdata(io)                                                                    |                                                                                    | -                  | -                                           |      |
| 4<br>5<br>6                     | 04<br>05<br>06<br>07                                                                                                                                                                                 | U<br>U<br>U                                                                                                                                                                                                                                                     | ps2_mclk(io)<br>ps2_mdata(io)                                                                                  | $-cO^{\mu}$                                                                        | -                  |                                             |      |
| 5<br>6                          | 05<br>06<br>07                                                                                                                                                                                       | U<br>U                                                                                                                                                                                                                                                          | ps2_mdata(io)                                                                                                  | <u>6</u> .                                                                         | -                  | -                                           |      |
| 6                               | 06<br>07                                                                                                                                                                                             | U                                                                                                                                                                                                                                                               |                                                                                                                |                                                                                    |                    |                                             | 1    |
|                                 | 07                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                 | ps2_kclk(io)                                                                                                   |                                                                                    | -                  | -                                           |      |
| 7                               | -                                                                                                                                                                                                    | U -                                                                                                                                                                                                                                                             |                                                                                                                | -                                                                                  | -                  | -                                           |      |
|                                 | 08                                                                                                                                                                                                   | /                                                                                                                                                                                                                                                               | ps2_kdata(io)                                                                                                  | -                                                                                  | -                  | -                                           |      |
| 8                               |                                                                                                                                                                                                      | υC                                                                                                                                                                                                                                                              | scc_data(io)                                                                                                   | -                                                                                  | -                  | -                                           |      |
| 9                               | 09                                                                                                                                                                                                   | D                                                                                                                                                                                                                                                               | scc_clk(o)                                                                                                     | clk48m(i)                                                                          | -                  | -                                           |      |
| 10                              | 10                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | pwm6(io)                                                                                                       | -                                                                                  | -                  | -                                           |      |
| 11                              | 11                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | pwm7(io)                                                                                                       | -                                                                                  | -                  | -                                           |      |
| 12                              | 12                                                                                                                                                                                                   | D                                                                                                                                                                                                                                                               | uart3_rxd(i)                                                                                                   | bclk0(io)                                                                          | -                  | epd_pwr4(o)                                 |      |
| 13                              | 13                                                                                                                                                                                                   | D                                                                                                                                                                                                                                                               | Irclk0(io)                                                                                                     | -                                                                                  | -                  | epd_pwr5(o)                                 |      |
| 14                              | 14                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | -                                                                                                              | -                                                                                  | -                  | -                                           | 10   |
| 15                              | 15                                                                                                                                                                                                   | D                                                                                                                                                                                                                                                               |                                                                                                                |                                                                                    |                    |                                             |      |
|                                 | rs                                                                                                                                                                                                   | st-pe                                                                                                                                                                                                                                                           | exclk(o)                                                                                                       | -                                                                                  | -                  | -                                           |      |
| 16                              | 16                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | -                                                                                                              | -                                                                                  | -                  | -                                           |      |
| 17                              | 17                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | -                                                                                                              | -                                                                                  | -                  | -                                           | 2,5  |
| 18                              | 18                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | -                                                                                                              | -                                                                                  | -                  | -                                           | 3,5  |
| 19                              | 19                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | -                                                                                                              | -                                                                                  | -                  | -                                           | 4,5  |
| 20                              | 20                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | msc1_d0(io)                                                                                                    | ssi0_dr(i)                                                                         | ssi1_dr(i)         | -                                           |      |
| 21                              | 21                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | msc1_d1(io)                                                                                                    | ssi0_dt(o)                                                                         | ssi1_dt(o)         | -                                           |      |
| 22                              | 22                                                                                                                                                                                                   | U                                                                                                                                                                                                                                                               | msc1_d2(io)                                                                                                    | ssi0_gpc(o)                                                                        | ssi1_gpc(o)        | -                                           |      |

#### Table 1-4 GPIO Port D summary



| 23 | 23 | U      |               |              |               |   |  |
|----|----|--------|---------------|--------------|---------------|---|--|
|    |    | rst-pe | msc1_d3(io)   | ssi0_ce1_(o) | ssi1_ce1_(o)  | - |  |
| 24 | 24 | U      | msc1_clk(o)   | ssi0_clk(o)  | ssi1_clk(o) - |   |  |
| 25 | 25 | U      |               |              |               |   |  |
|    |    | rst-pe | msc1_cmd(io)  | ssi0_ce0_(o) | ssi1_ce0_(o)  | - |  |
| 26 | 26 | U      | uart1_rxd(i)  | mii_rxd2(i)  | -             | - |  |
| 27 | 27 | U      | uart1_cts_(i) | mii_rxd3(i)  | -             | - |  |
| 28 | 28 | U      |               |              |               |   |  |
|    |    | rst-pe | uart1_txd(o)  | mii_txd2(o)  | -             | - |  |
| 29 | 29 | U      |               |              |               |   |  |
|    |    | rst-pe | uart1_rts_(o) | mii_txd3(o)  | -             | - |  |
| 30 | 30 | U      | i2c0_sda(io)  | -            | -             | - |  |
| 31 | 31 | U      | i2c0_sck(io)  | -            | -             | - |  |

# 1.1.5 GPIO Port E Summary

hary 1 USEd only

| Table 1-5 GPIO Port E summary | 1 |
|-------------------------------|---|
|-------------------------------|---|

| Bit | PE | Pull       | Shared Function Port Selected by |                      |              |             |      |
|-----|----|------------|----------------------------------|----------------------|--------------|-------------|------|
| N   | N  | (U/D)      | 0                                |                      | 2            | 3           | Note |
| 0   | 00 | (0/D)<br>D | pwm0(io)                         |                      | ~ ~          | -           | Note |
| 1   | 00 | D          |                                  | $-c \Theta^{\mu\nu}$ | -            |             |      |
|     | -  |            | pwm1(o)                          | <u>6</u> .           | -            | -           |      |
| 2   | 02 | U          | pwm2(o)                          | -                    | -            | -           |      |
| 3   | 03 | U          | pwm3(io)                         | -                    | -            | -           |      |
| 4   | 04 | U          | pwm4(io)                         | -                    | -            | -           |      |
| 5   | 05 | ູບ 🥑       | 7.                               |                      |              |             |      |
|     |    | rst-pe     | pwm5(io)                         | uart3_txd(o)         | sclk_rstn(o) | -           |      |
| 6   | 06 | U          | aic0_sdati(i)                    | -                    | -            | epd_pwr6(o) |      |
| 7   | 07 | D          | aic0_sdato(o)                    | -                    | -            | epd_pwr7(o) |      |
| 8   | 08 | U          | uart3_cts_(i)                    | bclk0_ad(io)         | -            | -           |      |
| 9   | 09 | U          |                                  |                      |              |             |      |
|     |    | rst-pe     | uart3_rts_(o)                    | Irclk0_ad(io)        | -            | -           |      |
| 10  | 10 | D          |                                  |                      |              |             |      |
|     |    | rst-pe     | drvvbus(o)                       | -                    | -            | -           |      |
| 11  | 11 | U          | sdato1(o)                        | -                    | -            | -           |      |
| 12  | 12 | U          | sdato2(o)                        | bclk1_ad(io)         | -            | -           |      |
| 13  | 13 | U          | sdato3(o)                        | Irclk1_ad(io)        | -            | -           |      |
| 14  | 14 | U          | ssi0_dr(i)                       | ssi1_dr(i)           | -            | -           |      |
| 15  | 15 | U          | ssi0_clk(o)                      | ssi1_clk(o)          | -            | -           |      |
| 16  | 16 | U          |                                  |                      |              |             |      |
|     |    | rst-pe     | ssi0_ce0_(o)                     | ssi1_ce0_(o)         | -            | -           |      |

6



| 17    | 17     | U      | ssi0_dt(o)   | ssi1_dt(o)         | -                      | - |  |  |
|-------|--------|--------|--------------|--------------------|------------------------|---|--|--|
| 18    | 18     | U      |              |                    |                        |   |  |  |
|       |        | rst-pe | ssi0_ce1_(o) | ssi1_ce1_(o)       | -                      | - |  |  |
| 19    | 19     | U      | ssi0_gpc(o)  | ssi1_gpc(o)        | -                      | - |  |  |
| 20    | 20     | U      | msc0_d0(io)  | msc1_d0(io)        | msc2_d0(io)            | - |  |  |
| 21    | 21     | U      | msc0_d1(io)  | msc1_d1(io)        | msc2_d1(io)            | - |  |  |
| 22    | 22     | U      | msc0_d2(io)  | msc1_d2(io)        | msc2_d2(io)            | - |  |  |
| 23    | 23     | U      | msc0_d3(io)  | msc1_d3(io)        | 1_d3(io) msc2_d3(io) - |   |  |  |
| 24    | 24     | U      | msc0_d4(io)  | msc1_d4(io)        | msc2_d4(io)            | - |  |  |
| 25    | 25     | U      | msc0_d5(io)  | msc1_d5(io)        | msc2_d5(io)            | - |  |  |
| 26    | 26     | U      | msc0_d6(io)  | msc1_d6(io)        | msc2_d6(io)            | - |  |  |
| 27    | 27     | U      | msc0_d7(io)  | msc1_d7(io)        | msc2_d7(io)            | - |  |  |
| 28    | 28     | U      | msc0_clk(o)  | msc1_clk(o)        | msc2_clk(o)            | - |  |  |
| 29    | 29     | U      | msc0_cmd(io) | msc1_cmd(io)       | msc2_cmd(io)           | - |  |  |
| 30    | 30     | U      | i2c1_sda(io) | -                  | -                      | - |  |  |
| 31    | 31     | U      | i2c1_sck(io) | -                  | -                      | - |  |  |
| 1.1.6 | intern |        |              |                    |                        |   |  |  |
|       |        |        | Tab          | le 1-6 GPIO Port F | summary                |   |  |  |

# 1.1.6 GPIO Port F Summary

Table 1-6 GPIO Port F summary

| Bit | PF                          | Pull   |               | Shared Fund  | ction Port Selec | ted by |      |
|-----|-----------------------------|--------|---------------|--------------|------------------|--------|------|
| Ν   | Ν                           | (U/D)  | 0             | 1            | 2                | 3      | Note |
| 0   | 00                          | U      | uart0_rxd(i)  | gps_clk(i)   | -                | -      |      |
| 1   | 01                          | U      | : {1          |              |                  |        |      |
|     |                             | rst-pe | uart0_cts_(i) | gps_mag(i)   | -                | -      |      |
| 2   | 02                          | 10     |               |              |                  |        |      |
|     | $\mathcal{Y}_{\mathcal{O}}$ | rst-pe | uart0_rts_(o) | gps_sig(i)   | -                | -      |      |
| 3   | 03                          | U      |               |              |                  |        |      |
|     |                             | rst-pe | uart0_txd(o)  | -            | -                | -      |      |
| 4   | 04                          | D      | mii_txd0(o)   | -            | -                | -      |      |
| 5   | 05                          | D      | mii_txd1(o)   | -            | -                | -      |      |
| 6   | 06                          | D      | mii_txclk(i)  | -            | -                | -      |      |
| 7   | 07                          | D      | mii_rxclk(i)  | -            | -                | -      |      |
| 8   | 08                          | D      | mii_rxer(i)   | -            | -                | -      |      |
| 9   | 09                          | D      | mii_rxdv(i)   | -            | -                | -      |      |
| 10  | 10                          | D      | mii_rxd0(i)   | -            | -                | -      |      |
| 11  | 11                          | D      | mii_rxd1(i)   | -            | -                | -      |      |
| 12  | 12                          | U      | mii_txen(o)   | pcm1_do(o)   | -                | -      |      |
| 13  | 13                          | U      | mii_mdc(o)    | pcm1_clk(io) | -                | -      |      |
| 14  | 14                          | U      | mii_mdio(io)  | pcm1_syn(io) | -                | -      |      |
|     |                             |        |               |              |                  |        |      |



| 15 | 15 | U | mii_col(i) | pcm1_di(i) | -            | -          |  |
|----|----|---|------------|------------|--------------|------------|--|
| 16 | 16 | D | cim_d10(i) | -          | i2c2_sda(io) | epd_bd2(o) |  |
| 17 | 17 | D | cim_d11(i) | -          | i2c2_sck(io) | epd_bd3(o) |  |
| 18 | 18 | U | -          | -          | -            |            |  |
| 19 | 19 | D | -          | -          | -            |            |  |
| 20 | 20 | D | -          | -          | -            |            |  |
| 21 | 21 | U | -          | -          | -            |            |  |
| 22 | 22 | D | -          | -          | -            |            |  |

#### NOTES:

8

- 1 If NAND flash is used, this pin must be used as NAND FRB.
- 2 PD17: GPIO group D bit 17 is used as BOOT\_SEL0 input during boot.
- 3 PD18: GPIO group D bit 18 is used as BOOT\_SEL1 input during boot.
- 4 PD19: GPIO group D bit 19 is used as BOOT\_SEL2 input during boot.
- 5 BOOT\_SEL2, BOOT\_SEL1, BOOT\_SEL0 are used to select boot source and function during the processor boot.
- 6 PA30: GPIO group A bit 30 can only be used as input and interrupt, no pull-up and pull-down. It is also used to select the function between PS2 function and JTAG function of JTAG/UART3/PS2 Pins( TCK\_UART3\_RTS\_PS2\_MCLK, TMS\_UART3\_CTS\_PS2\_MDATA, TDI\_UART3\_RxD\_PS2\_KCLK and TDO\_UART3\_TXD\_PS2\_KDATA), which share the same set of pins.

When PA30.function1 is false, select JTAG function.

When PA30.function1 is true, select PS2 function.

7 PA31: GPIO group A bit 31. No corresponding pin exists for this GPIO.

It is only used to select the function between UART and JTAG of JTAG/UART3/PS2 Pins (TCK\_UART3\_RTS\_PS2\_MCLK,TMS\_UART3\_CTS\_PS2\_MDATA,TDI\_UART3\_RxD\_PS2\_KCLK and TDO\_UART3\_TxD\_PS2\_KDATA), which share the same set of pins, by using register PASEL [31].

When PA31.function1 is false, select JTAG function. When PA31.function1 is true, select UART function.

- 8 If NAND flash is used, this pin must be used as NAND CLE.
- 9 If NAND flash is used, this pin must be used as NAND ALE.
- 10 PD14 : this pin is generally used as RTCLK output. If this pin is intended to be used as GPIO or interrupt, CK32CTL(CKPCR[2:1] in RTC) should be configured to 2'b10.Please refer to RTC spec.
- 11 The pull enable of PA31 is used to control UART and JTAG of JTAG/UART3/PS2 Pins.



# 1.2 Registers Description

Table 1-7 summarized all memory-mapped registers, which can be programmed to operate GPIO port and alternate function port sharing configuration.

All registers are in 32-bits width. Usually, 1 bit in the register affects a corresponding GPIO port and every GPIO port can be operated independently.

| Name    | Description                          | RW  | Reset Value | Address    | Size |
|---------|--------------------------------------|-----|-------------|------------|------|
|         | GPIO PORT                            | ΓА  |             |            |      |
| PAPIN   | PORT A PIN Level Register            | R   | 0x????????  | 0x10010000 | 32   |
| PAINT   | PORT A Interrupt Register            | RW  | 0x0000000   | 0x10010010 | 32   |
| PAINTS  | PORT A Interrupt Set Register        | W   | 0x????????  | 0x10010014 | 32   |
| PAINTC  | PORT A Interrupt Clear Register      | W   | 0x????????  | 0x10010018 | 32   |
| PAMSK   | PORT A Interrupt Mask Register       | RW  | 0xFFFFFFFF  | 0x10010020 | 32   |
| PAMSKS  | PORT A Interrupt Mask Set Register   | W   | 0x???????   | 0x10010024 | 32   |
| PAMSKC  | PORT A Interrupt Mask Clear Register | W   | 0x????????  | 0x10010028 | 32   |
| PAPAT1  | PORT A Pattern 1 Register            | RW  | 0xFFFFFFFF  | 0x10010030 | 32   |
| PAPAT1S | PORT A Pattern 1 Set Register        | W C | 0x????????? | 0x10010034 | 32   |
| PAPAT1C | PORT A Pattern 1 Clear Register      | W   | 0x????????  | 0x10010038 | 32   |
| PAPAT0  | PORT A Pattern 0 Register            | RW  | 0x0000000   | 0x10010040 | 32   |
| PAPATOS | PORT A Pattern 0 Set Register        | W   | 0x????????  | 0x10010044 | 32   |
| PAPAT0C | PORT A Pattern O Clear Register      | W   | 0x????????  | 0x10010048 | 32   |
| PAFLG   | PORT A FLAG Register                 | R   | 0x0000000   | 0x10010050 | 32   |
| PAFLGC  | PORT A FLAG Clear Register           | W   | 0x????????  | 0x10010058 | 32   |
| PAPEN   | PORT A PULL Disable Register         | RW  | 0x00000000  | 0x10010070 | 32   |
| PAPENS  | PORT A PULL Disable Set Register     | W   | 0x????????  | 0x10010074 | 32   |
| PAPENC  | PORT A PULL Disable Clear Register   | W   | 0x????????  | 0x10010078 | 32   |
| PADRVL  |                                      | RW  | 0x0000000   | 0x10010080 | 32   |
| PADRVLS | -                                    | W   | 0x????????  | 0x10010084 | 32   |
| PADRVLC | -                                    | W   | 0x????????  | 0x10010088 | 32   |
| PADIR   | -                                    | RW  | 0x0000000   | 0x10010090 | 32   |
| PADIRS  | -                                    | W   | 0x????????  | 0x10010094 | 32   |
| PADIRC  | -                                    | W   | 0x????????  | 0x10010098 | 32   |
| PADRVH  | -                                    | RW  | 0x0000000   | 0x100100A0 | 32   |
| PADRVHS | -                                    | W   | 0x????????  | 0x100100A4 | 32   |
| PADRVHC | -                                    | W   | 0x????????  | 0x100100A8 | 32   |
|         |                                      |     |             |            |      |
|         | GPIO PORT                            | ГВ  |             |            |      |
| PBPIN   | PORT B PIN Level Register            | R   | 0x????????  | 0x10010100 | 32   |
| PBINT   | PORT B Interrupt Register            | RW  | 0x00000000  | 0x10010110 | 32   |

#### Table 1-7 GPIO Registers

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|                   |                                                            |         | 1                       | 1                        |          |
|-------------------|------------------------------------------------------------|---------|-------------------------|--------------------------|----------|
| PBINTS            | PORT B Interrupt Set Register                              | W       | 0x????????              | 0x10010114               | 32       |
| PBINTC            | PORT B Interrupt Clear Register                            | W       | 0x????????              | 0x10010118               | 32       |
| PBMSK             | PORT B Interrupt Mask Register                             | R       | 0xFFFFFFFF              | 0x10010120               | 32       |
| PBMSKS            | PORT B Interrupt Mask Set Register                         | W       | 0x????????              | 0x10010124               | 32       |
| PBMSKC            | PORT B Interrupt Mask Clear Register                       | W       | 0x????????              | 0x10010128               | 32       |
| PBPAT1            | PORT B Pattern 1 Register                                  | R       | 0xFFFFFFFF              | 0x10010130               | 32       |
| PBPAT1S           | PORT B Pattern 1 Set Register                              | W       | 0x????????              | 0x10010134               | 32       |
| PBPAT1C           | PORT B Pattern 1 Clear Register                            | W       | 0x????????              | 0x10010138               | 32       |
| PBPAT0            | PORT B Pattern 0 Register                                  | RW      | 0x0000000               | 0x10010140               | 32       |
| <b>PBPAT0S</b>    | PORT B Pattern 0 Set Register                              | W       | 0x????????              | 0x10010144               | 32       |
| <b>PBPAT0C</b>    | PORT B Pattern 0 Clear Register                            | W       | 0x????????              | 0x10010148               | 32       |
| PBFLG             | PORT B FLAG Register                                       | R       | 0x0000000               | 0x10010150               | 32       |
| PBFLGC            | PORT B FLAG Clear Register                                 | W       | 0x????????              | 0x10010158               | 32       |
| PBPEN             | PORT B PULL Disable Register                               | RW      | 0x0000000               | 0x10010170               | 32       |
| PBPENS            | PORT B PULL Disable Set Register                           | W       | 0x????????              | 0x10010174               | 32       |
| PBPENC            | PORT B PULL Disable Clear Register                         | W       | 0x????????              | 0x10010178               | 32       |
| PBDRVL            | -                                                          | RW      | 0x00000000              | 0x10010180               | 32       |
| PBDRVLS           | -                                                          | W       | 0x?????????             | 0x10010184               | 32       |
| PBDRVLC           | -                                                          | W       | 0x7777777               | 0x10010188               | 32       |
| PBDIR             | -                                                          | RWC     | 0x0000000               | 0x10010190               | 32       |
| PBDIRS            | -                                                          | Ŵ       | 0x????????              | 0x10010194               | 32       |
| PBDIRC            | - COm                                                      | W       | 0x????????              | 0x10010198               | 32       |
| PBDRVH            | - , 20.                                                    | RW      | 0x0000000               | 0x100101A0               | 32       |
| PBDRVHS           | - 1010                                                     | W       | 0x????????              | 0x100101A4               | 32       |
| PBDRVHC           | £ { e }                                                    | W       | 0x????????              | 0x100101A8               | 32       |
|                   | GPIO POR                                                   | ГС      |                         |                          |          |
| PCPIN             | PORT C PIN Level Register                                  | R       | 0x????????              | 0x10010200               | 32       |
| PCINT             | PORT C Interrupt Register                                  | RW      | 0x0000000               | 0x10010210               | 32       |
| PCINTS            | PORT C Interrupt Set Register                              | W       | 0x????????              | 0x10010214               | 32       |
| PCINTC            | PORT C Interrupt Clear Register                            | W       | 0x????????              | 0x10010218               | 32       |
| PCMSK             | PORT C Interrupt Mask Register                             | R       | 0xFFFFFFFF              | 0x10010220               | 32       |
| PCMSKS            | PORT C Interrupt Mask Set Register                         | W       | 0x????????              | 0x10010224               | 32       |
| PCMSKC            | PORT C Interrupt Mask Clear Register                       | W       | 0x????????              | 0x10010228               | 32       |
| PCPAT1            | PORT C Pattern 1 Register                                  | R       | 0xFFFFFFFF              | 0x10010230               | 32       |
| PCPAT1S           | PORT C Pattern 1 Set Register                              | W       | 0x????????              | 0x10010234               | 32       |
|                   | PORT C Pattern 1 Clear Register                            | W       | 0x????????              | 0x10010238               | 32       |
| PCPAT1C           |                                                            |         |                         |                          | 1        |
| PCPAT1C<br>PCPAT0 | PORT C Pattern 0 Register                                  | RW      | 0x00000000              | 0x10010240               | 32       |
|                   |                                                            | RW<br>W | 0x0000000<br>0x???????? | 0x10010240<br>0x10010244 | 32<br>32 |
| PCPAT0            | PORT C Pattern 0 Register                                  |         |                         |                          |          |
| PCPAT0<br>PCPAT0S | PORT C Pattern 0 Register<br>PORT C Pattern 0 Set Register | W       | 0x????????              | 0x10010244               | 32       |

10



| PCPEN   | PORT C PULL Disable Register         | RW | 0x0000000    | 0x10010270 | 32 |
|---------|--------------------------------------|----|--------------|------------|----|
| PCPENS  | PORT C PULL Disable Set Register     | W  | 0x????????   | 0x10010274 | 32 |
| PCPENC  | PORT C PULL Disable Clear Register   | W  | 0x????????   | 0x10010278 | 32 |
| PCDRVL  | -                                    | RW | 0x0000000    | 0x10010280 | 32 |
| PCDRVLS | -                                    | W  | 0x????????   | 0x10010284 | 32 |
| PCDRVLC | -                                    | W  | 0x????????   | 0x10010288 | 32 |
| PCDIR   | -                                    | RW | 0x0000000    | 0x10010290 | 32 |
| PCDIRS  | -                                    | W  | 0x????????   | 0x10010294 | 32 |
| PCDIRC  | -                                    | W  | 0x????????   | 0x10010298 | 32 |
| PCDRVH  | -                                    | RW | 0x0000000    | 0x100102A0 | 32 |
| PCDRVHS | -                                    | W  | 0x????????   | 0x100102A4 | 32 |
| PCDRVHC | -                                    | W  | 0x????????   | 0x100102A8 | 32 |
|         | GPIO POR                             | TD |              |            |    |
| PDPIN   | PORT D PIN Level Register            | R  | 0x????????   | 0x10010300 | 32 |
| PDINT   | PORT D Interrupt Register            | RW | 0x0000000    | 0x10010310 | 32 |
| PDINTS  | PORT D Interrupt Set Register        | W  | 0x????????   | 0x10010314 | 32 |
| PDINTC  | PORT D Interrupt Clear Register      | W  | 0x????????   | 0x10010318 | 32 |
| PDMSK   | PORT D Interrupt Mask Register       | R  | 0xFFFFFFFF   | 0x10010320 | 32 |
| PDMSKS  | PORT D Interrupt Mask Set Register   | W  | 0x?????????? | 0x10010324 | 32 |
| PDMSKC  | PORT D Interrupt Mask Clear Register | W  | 0x????????   | 0x10010328 | 32 |
| PDPAT1  | PORT D Pattern 1 Register            | R  | 0xFFFFFFF    | 0x10010330 | 32 |
| PDPAT1S | PORT D Pattern 1 Set Register        | W  | 0x????????   | 0x10010334 | 32 |
| PDPAT1C | PORT D Pattern 1 Clear Register      | W  | 0x????????   | 0x10010338 | 32 |
| PDPAT0  | PORT D Pattern 0 Register            | RW | 0x0000000    | 0x10010340 | 32 |
| PDPAT0S | PORT D Pattern 0 Set Register        | W  | 0x????????   | 0x10010344 | 32 |
| PDPAT0C | PORT D Pattern 0 Clear Register      | W  | 0x????????   | 0x10010348 | 32 |
| PDFLG   | BORT D FLAG Register                 | R  | 0x0000000    | 0x10010350 | 32 |
| PDFLGC  | PORT D FLAG Clear Register           | W  | 0x????????   | 0x10010358 | 32 |
| PDPEN   | PORT D PULL Disable Register         | RW | 0x0000000    | 0x10010370 | 32 |
| PDPENS  | PORT D PULL Disable Set Register     | W  | 0x????????   | 0x10010374 | 32 |
| PDPENC  | PORT D PULL Disable Clear Register   | W  | 0x????????   | 0x10010378 | 32 |
| PDDRVL  | -                                    | RW | 0x0000000    | 0x10010380 | 32 |
| PDDRVLS | -                                    | W  | 0x????????   | 0x10010384 | 32 |
| PDDRVLC | -                                    | W  | 0x????????   | 0x10010388 | 32 |
| PDDIR   | -                                    | RW | 0x0000000    | 0x10010390 | 32 |
| PDDIRS  | -                                    | W  | 0x????????   | 0x10010394 | 32 |
| PDDIRC  | -                                    | W  | 0x????????   | 0x10010398 | 32 |
| PDDRVH  | -                                    | RW | 0x0000000    | 0x100103A0 | 32 |
| PDDRVHS | -                                    | W  | 0x????????   | 0x100103A4 | 32 |
| PDDRVHC | -                                    | W  | 0x????????   | 0x100103A8 | 32 |
|         | GPIO POR                             | ΤE |              |            |    |



| r              |                                      |     |             |            |    |
|----------------|--------------------------------------|-----|-------------|------------|----|
| PEPIN          | PORT E PIN Level Register            | R   | 0x????????  | 0x10010400 | 32 |
| PEINT          | PORT E Interrupt Register            | RW  | 0x0000000   | 0x10010410 | 32 |
| PEINTS         | PORT E Interrupt Set Register        | W   | 0x????????  | 0x10010414 | 32 |
| PEINTC         | PORT E Interrupt Clear Register      | W   | 0x????????  | 0x10010418 | 32 |
| PEMSK          | PORT E Interrupt Mask Register       | R   | 0xFFFFFFFF  | 0x10010420 | 32 |
| PEMSKS         | PORT E Interrupt Mask Set Register   | W   | 0x????????  | 0x10010424 | 32 |
| PEMSKC         | PORT E Interrupt Mask Clear Register | W   | 0x????????  | 0x10010428 | 32 |
| PEPAT1         | PORT E Pattern 1 Register            | R   | 0xFFFFFFFF  | 0x10010430 | 32 |
| PEPAT1S        | PORT E Pattern 1 Set Register        | W   | 0x????????  | 0x10010434 | 32 |
| PEPAT1C        | PORT E Pattern 1 Clear Register      | W   | 0x????????  | 0x10010438 | 32 |
| PEPAT0         | PORT E Pattern 0 Register            | RW  | 0x00000000  | 0x10010440 | 32 |
| <b>PEPATOS</b> | PORT E Pattern 0 Set Register        | W   | 0x????????  | 0x10010444 | 32 |
| PEPAT0C        | PORT E Pattern 0 Clear Register      | W   | 0x????????  | 0x10010448 | 32 |
| PEFLG          | PORT E FLAG Register                 | R   | 0x0000000   | 0x10010450 | 32 |
| PEFLGC         | PORT E FLAG Clear Register           | W   | 0x????????  | 0x10010458 | 32 |
| PEPEN          | PORT E PULL Disable Register         | RW  | 0x0000000   | 0x10010470 | 32 |
| PEPENS         | PORT E PULL Disable Set Register     | W   | 0x???????   | 0x10010474 | 32 |
| PEPENC         | PORT E PULL Disable Clear Register   | W   | 0x????????? | 0x10010478 | 32 |
| PEDRVL         | -                                    | RW  | 0x00000000  | 0x10010480 | 32 |
| PEDRVLS        | -                                    | W C | 0x????????  | 0x10010484 | 32 |
| PEDRVLC        | -                                    | W   | 0x???????   | 0x10010488 | 32 |
| PEDIR          | - com                                | RW  | 0x0000000   | 0x10010490 | 32 |
| PEDIRS         | - , 9.0.                             | W   | 0x???????   | 0x10010494 | 32 |
| PEDIRC         | - 1014                               | W   | 0x????????  | 0x10010498 | 32 |
| PEDRVH         | - cfer                               | RW  | 0x0000000   | 0x100104A0 | 32 |
| PEDRVHS        | - 011                                | W   | 0x????????  | 0x100104A4 | 32 |
| PEDRVHC        | £                                    | W   | 0x????????  | 0x100104A8 | 32 |
|                | GPIO POR                             | ΓF  |             |            |    |
| PFPIN          | PORT F PIN Level Register            | R   | 0x????????  | 0x10010500 | 32 |
| PFINT          | PORT F Interrupt Register            | RW  | 0x00000000  | 0x10010510 | 32 |
| PFINTS         | PORT F Interrupt Set Register        | W   | 0x????????  | 0x10010514 | 32 |
| PFINTC         | PORT F Interrupt Clear Register      | W   | 0x????????  | 0x10010518 | 32 |
| PFMSK          | PORT F Interrupt Mask Register       | R   | 0xFFFFFFFF  | 0x10010520 | 32 |
| PFMSKS         | PORT F Interrupt Mask Set Register   | W   | 0x????????  | 0x10010524 | 32 |
| PFMSKC         | PORT F Interrupt Mask Clear Register | W   | 0x????????  | 0x10010528 | 32 |
| PFPAT1         | PORT F Pattern 1 Register            | R   | 0xFFFFFFFF  | 0x10010530 | 32 |
| PFPAT1S        | PORT F Pattern 1 Set Register        | W   | 0x????????  | 0x10010534 | 32 |
| PFPAT1C        | PORT F Pattern 1 Clear Register      | W   | 0x????????  | 0x10010538 | 32 |
| PFPAT0         | PORT F Pattern 0 Register            | RW  | 0x00000000  | 0x10010540 | 32 |
| PFPAT0S        | PORT F Pattern 0 Set Register        | W   | 0x????????  | 0x10010544 | 32 |
| PFPAT0C        | PORT F Pattern 0 Clear Register      | W   | 0x????????  | 0x10010548 | 32 |

12



| -       |                                    | 1  |            |            | 1  |
|---------|------------------------------------|----|------------|------------|----|
| PFFLG   | PORT F FLAG Register               | R  | 0x0000000  | 0x10010550 | 32 |
| PFFLGC  | PORT F FLAG Clear Register         | W  | 0x???????? | 0x10010558 | 32 |
| PFPEN   | PORT F PULL Disable Register       | RW | 0x0000000  | 0x10010570 | 32 |
| PFPENS  | PORT F PULL Disable Set Register   | W  | 0x???????? | 0x10010574 | 32 |
| PFPENC  | PORT F PULL Disable Clear Register | W  | 0x???????? | 0x10010578 | 32 |
| PFDRVL  | -                                  | RW | 0x0000000  | 0x10010580 | 32 |
| PFDRVLS | -                                  | W  | 0x???????  | 0x10010584 | 32 |
| PFDRVLC | -                                  | W  | 0x???????  | 0x10010588 | 32 |
| PFDIR   | -                                  | RW | 0x0000000  | 0x10010590 | 32 |
| PFDIRS  | -                                  | W  | 0x???????  | 0x10010594 | 32 |
| PFDIRC  | -                                  | W  | 0x???????  | 0x10010598 | 32 |
| PFDRVH  | -                                  | RW | 0x0000000  | 0x100105A0 | 32 |
| PFDRVHS | -                                  | W  | 0x???????  | 0x100105A4 | 32 |
| PFDRVHC | -                                  | W  | 0x???????? | 0x100105A8 | 32 |

NOTE: PX\*\*\*\* in the description of register as follows means PA\*\*\*\*, PB\*\*\*\*, PC\*\*\*\*, PD\*\* , PC USE \*\*, PE\*\*\*\* and PF\*\*\*\*.

# 1.2.1 PORT PIN Level Registers (PxPIN)

PAPIN, PBPIN, PCPIN, PDPIN, PEPIN and PFPIN are six 32-bit PORT PIN level registers. They are read-only registers.

|     |        |        | 1 - C  | 3PII<br>EPII | 1      |        | 1      | C (    | 5)     | <u>(</u> | 7      | 20     | )•     |        |        |        |        |        |        |        |        |        |        |        |        |               |        |        |        | 100 <sup>°</sup><br>:100 |        | - C           |
|-----|--------|--------|--------|--------------|--------|--------|--------|--------|--------|----------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---------------|--------|--------|--------|--------------------------|--------|---------------|
| Bit | 31     | 30     | 29     | 28           | 27     | 26     | 25     | 24     | 23     | 22       | 21     | 20     | 19     | 18     | 17     | 16     | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      | 7      | 6             | 5      | 4      | 3      | 2                        | 1      | 0             |
|     | PINL31 | PJNL30 | PINC29 | PINL28       | PINL27 | PINL26 | PINL25 | PINL24 | PINL23 | PINL22   | PINL21 | PINL20 | PINL19 | PINL18 | PINL17 | PINL16 | PINL15 | PINL14 | PINL13 | PINL12 | PINL11 | PINL10 | PINL09 | PINL08 | PINL07 | <b>PINL06</b> | PINL05 | PINL04 | PINL03 | PINL02                   | PINL01 | <b>DINLOO</b> |
| RST | 0      | 0      | 0      | 0            | 0      | 0      | 0      | 0      | 0      | 0        | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0             | 0      | 0      | 0      | 0                        | 0      | 0             |

| Bits | Name   | Description                                                             | R/W |
|------|--------|-------------------------------------------------------------------------|-----|
| n    | PINL n | Where n = 0 ~ 31 and PINL n = PINL0 ~ PINL31.                           | R   |
|      |        | The PORT PIN level can be read by reading PINL n bit in register PXPIN. |     |



## 1.2.2 PORT Interrupt Registers (PxINT)

PAINT, PBINT, PCINT, PDINT, PEINT and PFINT are six 32-bit interrupt registers.

|     | PAI   | NT,   | PE    | SINT  | <b>Г, Р</b> | CIN   | IT,   |       |       |       |       |       |       |       |       |       |       |       |       |       | 0x1         | <b>00</b> ′ | 100   | 10,                | <b>0</b> x1 | 100          | 101          | 10,        | <b>0</b> x1  | 100   | 102   | 10,   |
|-----|-------|-------|-------|-------|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------------|-------------|-------|--------------------|-------------|--------------|--------------|------------|--------------|-------|-------|-------|
|     | PD    | INT,  | , PE  | INT   | Γ, P        | FIN   | Т     |       |       |       |       |       |       |       |       |       |       |       |       |       | <b>0</b> x′ | 100         | 103   | <mark>310</mark> , | <b>0</b> x  | 1 <b>0</b> 0 | 1 <b>0</b> 4 | <b>110</b> | , <b>0</b> x | 100   | )10   | 510   |
| Bit | 31    | 30    | 29    | 28    | 27          | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    | 15    | 14    | 13    | 12    | 11          | 10          | 9     | 8                  | 7           | 6            | 5            | 4          | 3            | 2     | 1     | 0     |
|     | INT31 | INT30 | INT29 | INT28 | INT27       | INT26 | INT25 | INT24 | INT23 | INT22 | INT21 | INT20 | INT19 | INT18 | INT17 | INT16 | INT15 | INT14 | INT13 | INT12 | INT11       | INT10       | 60TNI | INT08              | INT07       | INT06        | INT05        | INT04      | INT03        | INT02 | INT01 | INT00 |
| RST | 0     | 0     | 0     | 0     | 0           | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0           | 0           | 0     | 0                  | 0           | 0            | 0            | 0          | 0            | 0     | 0     | 0     |

| Bits  | Name      | Description                                                     | R/W |
|-------|-----------|-----------------------------------------------------------------|-----|
| Ν     | INT n     | Where n = 0 ~ 31 and INT n = INT31 ~ INT00.                     | RW  |
|       |           | Interrupt enable.                                               |     |
|       |           | 0: Corresponding pin is used as device functions or normal gpio |     |
|       |           | 1: Corresponding pin is used as interrupt $\lambda$             |     |
|       |           | 1 USEU                                                          |     |
| 1.2.3 | PORT Inte | errupt Set Registers (PxINTS)                                   |     |
|       |           |                                                                 |     |

# 1.2.3 PORT Interrupt Set Registers (PxINTS)

PAINTS, PBINTS, PCINTS, PDINTS, PEINTS and PFINTS are six 32-bit interrupt set registers.

|     |        |        |        | PBII<br>PEII |              | ÷      |        |        |        |        | 0      | 6      | (      | C(     | 211    | 7      | Y      |        |        |        |        |        |        |        |        |        |        |        |        | 100 <sup>-</sup><br>100 |        |        |
|-----|--------|--------|--------|--------------|--------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-------------------------|--------|--------|
| Bit | 31     | 30     | 29     | 28           | 27           | 26     | 25     | 24     | 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2                       | 1      | 0      |
|     | INTS31 | INTS30 | INTS29 | A INTS28     | <b>NTS27</b> | INTS26 | INTS25 | INTS24 | INTS23 | INTS22 | INTS21 | INTS20 | INTS19 | INTS18 | INTS17 | INTS16 | INTS15 | INTS14 | INTS13 | INTS12 | INTS11 | INTS10 | INTS09 | INTS08 | INTS07 | INTS06 | INTS05 | INTS04 | INTS03 | INTS02                  | INTS01 | INTS00 |
| RST | ?      | ?      | ?      | ?            | ?            | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?                       | ?      | ?      |

| Bits | Name   | Description                                                | R/W |
|------|--------|------------------------------------------------------------|-----|
| Ν    | INTS n | Writing 1 to INTS n will set INT n to 1 in register PXINT. | W   |
|      |        | Writing 0 to INTS n will no use.                           |     |

14



#### 1.2.4 PORT Interrupt Clear Registers (PxINTC)

PAINTC, PBINTC, PCINTC, PDINTC, PEINTC and PFINTC are six 32-bit interrupt clear registers.

|     | PA     | INT    | C, F          | PBI    | NTC    | ), P   | CIN    | ιтс    | ,      |        |        |        |        |        |        |        |        |        |        |        | 0x1         | <b>00</b> ′ | 100    | 18,    | <b>0</b> x1 | 00     | 101    | 18,          | <b>0</b> x1 | 100 <sup>.</sup> | 102    | 18,    |
|-----|--------|--------|---------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-------------|-------------|--------|--------|-------------|--------|--------|--------------|-------------|------------------|--------|--------|
|     | PD     | INT    | <b>'C</b> , I | PEI    | NTC    | ), P   | FIN    | ΙТС    |        |        |        |        |        |        |        |        |        |        |        |        | <b>0</b> x′ | 100         | 103    | 18,    | <b>0</b> x  | 100    | 104    | <b>118</b> , | <b>0</b> x  | 100              | 105    | 518    |
| Bit | 31     | 30     | 29            | 28     | 27     | 26     | 25     | 24     | 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     | 15     | 14     | 13     | 12     | 11          | 10          | 9      | 8      | 7           | 6      | 5      | 4            | 3           | 2                | 1      | 0      |
|     | INTC31 | INTC30 | INTC29        | INTC28 | INTC27 | INTC26 | INTC25 | INTC24 | INTC23 | INTC22 | INTC21 | INTC20 | INTC19 | INTC18 | INTC17 | INTC16 | INTC15 | INTC14 | INTC13 | INTC12 | INTC11      | INTC10      | INTC09 | INTC08 | INTC07      | INTC06 | INTC05 | INTC04       | INTC03      | INTC02           | INTC01 | INTC00 |
| RST | ?      | ?      | ?             | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?      | ?           | ?           | ?      | ?      | ?           | ?      | ?      | ?            | ?           | ?                | ?      | ?      |

| Bits  | Name     | Description                                                   | R/W |
|-------|----------|---------------------------------------------------------------|-----|
| n     | INTC n   | Writing 1 to INTC n will set INT n to 0 in register PXINT.    | W   |
|       |          | Writing 0 to INTC n will no use.                              |     |
|       |          | 1 onl?                                                        |     |
| 1.2.5 | PORT Mas | sk Registers (PxMSK)                                          |     |
| DVNCK | DRMCK D  | CMSK DDMSK DEMSK and DEMSK are six 32 bit DOPT MASK registers |     |

## 1.2.5 PORT Mask Registers (PxMSK)

PAMSK, PBMSK, PCMSK, PDMSK, PEMSK and PFMSK are six 32-bit PORT MASK registers.



| Bits | Name  | Description                                          | R/W |
|------|-------|------------------------------------------------------|-----|
| n    | MSK n | Where n = 0 $\sim$ 31 and MSK n = MSK31 $\sim$ MSK0. | RW  |
|      |       | When PXINT n = 1:                                    |     |
|      |       | 0: Enable the pin as an interrupt source             |     |
|      |       | 1: Disable the pin as an interrupt source            |     |
|      |       | When PXINT n = 0:                                    |     |
|      |       | 0: Corresponding pin will be used as device function |     |
|      |       | 1: Corresponding pin will be used as gpio            |     |

16

#### 1.2.6 PORT Mask Set Registers (PxMSKS)

PAMSKS, PBMSKS, PCMSKS, PDMSKS, PEMSKS and PFMSKS are six 32-bit PORT MASK set registers.



| Bits  | Name     | Description                                                | R/W |
|-------|----------|------------------------------------------------------------|-----|
| n     | MSKS n   | Writing 1 to MSKS n will set MSK n to 1 in register PXMSK. | W   |
|       |          | Writing 0 to MSKS n will no use.                           |     |
|       |          | ed or                                                      |     |
| 1.2.7 | PORT Mas | sk Clear Registers (PxMSKC)                                |     |

#### 1.2.7 PORT Mask Clear Registers (PxMSKC)

PAMSKC, PBMSKC, PCMSKC, PDMSKC, PEMSKC and PFMSKC are six 32-bit PORT MASK clear registers.

|     |        |               |        |        |        |        |               |               |               |        |        |               |        |        |      |        | Y             |               |               |               |               |               |               |               |               |               |               |               |               |               |        |               |
|-----|--------|---------------|--------|--------|--------|--------|---------------|---------------|---------------|--------|--------|---------------|--------|--------|------|--------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|--------|---------------|
|     | PA     | MS            | KS,    | PB     | MS     | KC     | , P(          | CMS           | SKC           | ,      |        |               |        | ~(     | 20   | 7      |               |               |               |               | 0x1           | 001           | 00            | 28,           | 0x1           | 00            | 101           | 28,           | <b>0</b> x1   | 100           | 102    | <b>28</b> ,   |
|     | PD     | MS            | KC,    | PE     | MS     | KC     | , PI          | FMS           | SKC           | ;      | 0      | 6             |        | 0      |      |        |               |               |               |               | <b>0</b> x′   | 100           | 103           | 28,           | 0x            | 1 <b>0</b> 0  | 1 <b>0</b> 4  | 28            | <b>0</b> x    | 100           | 105    | 528           |
| Bit | 31     | 30            | 29     | 28     | 27     | 26     | 25            | 24            | 23            | 22     | 21     | 20            | 19     | 18     | 17   | 16     | 15            | 14            | 13            | 12            | 11            | 10            | 9             | 8             | 7             | 6             | 5             | 4             | 3             | 2             | 1      | 0             |
|     | MSKC31 | <b>MSKC30</b> | MSKC29 | MSKC28 | MSKC27 | MSKC26 | <b>MSKC25</b> | <b>MSKC24</b> | <b>MSKC23</b> | MSKC22 | MSKC21 | <b>MSKC20</b> | MSKC19 | MSKC18 | SKC1 | MSKC16 | <b>MSKC15</b> | <b>MSKC14</b> | <b>MSKC13</b> | <b>MSKC12</b> | <b>MSKC11</b> | <b>MSKC10</b> | <b>MSKC09</b> | <b>MSKC08</b> | <b>MSKC07</b> | <b>MSKC06</b> | <b>MSKC05</b> | <b>MSKC04</b> | <b>MSKC03</b> | <b>MSKC02</b> | MSKC01 | <b>MSKC00</b> |
| RST | ?      | ?             | ?      | ?      | ?      | ?      | ?             | ?             | ?             | ?      | ?      | ?             | ?      | ?      | ?    | ?      | ?             | ?             | ?             | ?             | ?             | ?             | ?             | ?             | ?             | ?             | ?             | ?             | ?             | ?             | ?      | ?             |
|     |        | $\sim$        |        |        |        |        |               |               |               |        |        |               |        |        |      |        |               |               |               |               |               |               |               |               |               |               |               |               |               |               |        |               |

| Bits | Name   | Description                                                | R/W |
|------|--------|------------------------------------------------------------|-----|
| n    | MSKC n | Writing 1 to MSKC n will set MSK n to 0 in register PXMSK. | W   |
|      |        | Writing 0 to MSKC n will no use.                           |     |



君正

#### 1.2.8 PORT PAT1/Direction Registers (PxPAT1)

PAPAT1, PBPAT1, PCPAT1, PDPAT1, PEPAT1 and PFPAT1 are six 32-bit PORT pattern1/direction registers.

#### 0x10010030, 0x10010130, 0x10010230, PAPAT1, PBPAT1, PCPAT1, PDPAT1, PEPAT1, PFPAT1 0x10010330, 0x10010430, 0x10010530 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 PAT119 PAT105 PAT125 **PAT108 PAT104 PAT103** PAT100 PAT130 **PAT126 PAT124** PAT120 **PAT114** 29 28 **PAT123 PAT122 PAT121** PAT109 **PAT107 PAT106 PAT102** PAT101 **PAT127** PAT111 <u>6</u> PAT110 PAT11 PAT11 PAT11 PAT11 PAT11 PAT11 PAT1 PAT1 PAT1 **RST** 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1

| Bits | Name   | Description                                                   | R/W |
|------|--------|---------------------------------------------------------------|-----|
| n    | PAT1 n | Where n = 0 ~ 31 and PAT1 n = PAT131 ~ PAT10.                 | RW  |
|      |        | When PINT n = 1 (Interrupt function):                         |     |
|      |        | 0: Level trigger interrupt                                    |     |
|      |        | 1: Edge trigger interrupt                                     |     |
|      |        | When PINT n = 0 and PMSK = 0 (Device function).               |     |
|      |        | 0: Corresponding pin is used as device 0 or device 1 function |     |
|      |        | 1: Corresponding pin is used as device 2 or device 3 function |     |
|      |        | When PINT n = 0 and PMSK = 0 (GPIO function):                 |     |
|      |        | 0: Corresponding pin is used as gpio output                   |     |
|      |        | 1: Corresponding pin is used as gpio input                    |     |
|      | •      | 10140                                                         |     |

## 1.2.9 PORT PAT1/Direction Set Registers (PxPAT1S)

PAPAT1S, PBPAT1S, PCPAT1S, PDPAT1S, PEPAT1S and PFPAT1S are six 32-bit PORT pattern1/direction set registers.

#### PAPAT1S, PBPAT1S, PCPAT1S, 0x10010034, 0x10010134, 0x10010234, PDPAT1S, PEPAT1S, PFPAT1S 0x10010334, 0x10010434, 0x10010534 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 6 8 7 5 4 3 2 1 0 1**S**08 **IS05 IS23** PAT1S19 PAT1S18 യ ഹ S00 **PAT1S25** 2 **PAT1S06** 1S04 S03 1S02 1S30 **IS29** 1S26 **IS24 IS22 PAT1S09** 1S07 1S01 **PAT1S20** PAT1S11 1S28 Ś S<sub>2</sub> S PAT1S1 PAT1S1 PAT1S1 PAT1S1 PAT1S1 $\overline{\mathbf{v}}$ δ PAT1 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? RST ? ? ? 2 ? 2 ? ? ? ? ? ? ?

| Bits | Name    | Description                                                   | R/W |
|------|---------|---------------------------------------------------------------|-----|
| n    | PAT1S n | Writing 1 to PAT1S n will set PAT1 n to 1 in register PXPAT1. | W   |
|      |         | Writing 0 to PAT1S n will no use.                             |     |



#### 1.2.10 PORT PAT1/Direction Clear Registers (PxPAT1C)

PAPAT1C, PBPAT1C, PCPAT1C, PPAT1C, PEPAT1C and PFPAT1C are six 32-bit PORT pattern1 or direction clear registers.

#### PAPAT1S, PBPAT1C, PCPAT1C, 0x10010038, 0x10010138, 0x10010238, PDPAT1C, PEPAT1C, PFPAT1C 0x10010338, 0x10010438, 0x10010538 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 PAT1C18 PAT1C05 PAT1C25 PAT1C17 PAT1C14 PAT1C08 PAT1C06 PAT1C04 PAT1C03 PAT1C00 PAT1C20 PAT1C09 PAT1C02 PAT1C28 PAT1C23 PAT1C22 PAT1C26 PAT1C3 PAT1C30 PAT1C2 PAT1C24 PAT1C2 PAT1C1 PAT1C1 PAT1C07 PAT1C0 PAT1C1 PAT1C1 PAT1C1 PAT1C2 PAT1C1 PAT1C1 RST ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?

| Bits   | Name     | Description                                                   | R/W |
|--------|----------|---------------------------------------------------------------|-----|
| n      | PAT1C n  | Writing 1 to PAT1C n will set PAT1 n to 0 in register PXPAT1. | W   |
|        |          | Writing 0 to PAT1C n will no use.                             |     |
|        |          | ced or                                                        |     |
| 1.2.11 | PORT PAT | 0/Data Registers (PxPAT0)                                     |     |

## 1.2.11 PORT PAT0/Data Registers (PxPAT0)

PAPATO, PBPATO, PCPATO, PDPATO, PEPATO and PFPATO are six 32-bit PORT Pattern 0 or DATA . com int registers.

#### PAPATO, PBPATO, PCPATO,

#### 0x10010040, 0x10010140, 0x10010240, 0x10010340. 0x10010440. 0x10010540

|     | PD     | PAT    | <b>'0</b> , I | PEF   | PAT    | 0, F   | PFP    | AT     | )      |        | 0      | 6      | (      |        |               |        |        |        |        |        | <b>0</b> x | 100    | 103    | <b>340</b> , | <b>0</b> x | 100    | 1 <b>0</b> 4 | 140    | , <b>0</b> x  | 100           | 105    | 540    |
|-----|--------|--------|---------------|-------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---------------|--------|--------|--------|--------|--------|------------|--------|--------|--------------|------------|--------|--------------|--------|---------------|---------------|--------|--------|
| Bit | 31     | 30     | 29            | 28    | 27     | 26     | 25     | 24     | 23     | 22     | 21     | 20     | 19     | 18     | 17            | 16     | 15     | 14     | 13     | 12     | 11         | 10     | 9      | 8            | 7          | 6      | 5            | 4      | 3             | 2             | 1      | 0      |
|     | PAT031 | PAT030 | PAT029        | AT028 | PAT027 | PAT026 | PAT025 | PAT024 | PAT023 | PAT022 | PAT021 | PAT020 | PAT019 | PAT018 | <b>PAT017</b> | PAT016 | PAT015 | PAT014 | PAT013 | PAT012 | PAT011     | PAT010 | PAT009 | PAT008       | PAT007     | PAT006 | PAT005       | PAT004 | <b>PAT003</b> | <b>PAT002</b> | PAT001 | PAT000 |
| RST | 0      | 0      | 0             | 0     | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0             | 0      | 0      | 0      | 0      | 0      | 0          | 0      | 0      | 0            | 0          | 0      | 0            | 0      | 0             | 0             | 0      | 0      |

| Bits | Name   | Description                                       | R/W |
|------|--------|---------------------------------------------------|-----|
| Ν    | PAT0 n | Where n = 0 ~ 31 and PAT0 n = PAT00 ~ PAT031.     | RW  |
|      |        | When PINTn = 1 and PPAT1 = 0:                     |     |
|      |        | 0: Port is low level triggered interrupt input    |     |
|      |        | 1: Port is low high triggered interrupt input     |     |
|      |        | When PINTn = 1 and PPAT1 = 1:                     |     |
|      |        | 0: Port is falling edge triggered interrupt input |     |
|      |        | 1: Port is rising edge triggered interrupt input  |     |
|      |        | When PINTn = 0 and PMSK = 0 and PPAT1 = 0:        |     |
|      |        | 0: Port is pin of device 0                        |     |
|      |        | 1: Port is pin of device 1                        |     |
|      |        | When PINTn = 0 and PMSK = 0 and PPAT1 = 1:        |     |
|      |        | 0: Port is pin of device 2                        |     |

#### 18

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| 1: Port is pin of device 3                 |  |
|--------------------------------------------|--|
| When PINTn = 0 and PMSK = 1 and PPAT1 = 0: |  |
| 0: Port is GPIO output 0                   |  |
| 1: Port is GPIO output 1                   |  |

#### 1.2.12 PORT PAT0/Data Set Registers (PxPAT0S)

PAPATOS, PBPATOS, PCPATOS, PDPATOS, PEPATOS and PFPATOS are six 32-bit PORT Pattern0 or DATA set registers.



| Bits | Name    | Description                                                   | R/W |
|------|---------|---------------------------------------------------------------|-----|
| n    | PAT0S n | Writing 1 to PAT0S n will set PAT0 n to 1 in register PXPAT0. | W   |
|      |         | Writing 0 to PAT0S n will no use $\sqrt{2}$                   |     |

# 1.2.13 PORT PAT0/Data Clear Registers (PxPAT0C)

PAPATOC, PBPATOC, PCPATOC, PDPATOC, PEPATOC and PFPATOC are six 32-bit PORT Pattern 0 or DATA clear registers.

|     | 1       | AT0C3<br>AT0C2<br>AT0C2<br>AT0C2<br>AT0C2<br>AT0C2<br>AT0C2<br>AT0C2<br>AT0C2<br>AT0C1<br>AT0C1<br>AT0C1<br>AT0C1<br>AT0C1<br>AT0C1<br>AT0C1<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0<br>AT0C0 |         |         |         |         |         |         |         |         |         |    |         |    |    |    |         |         |         |    |    |         |   |         |         |         |         |         |         |         |         |         |
|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|---------|----|---------|----|----|----|---------|---------|---------|----|----|---------|---|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| Bit | 31      | 30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 29      | 28      | 27      | 26      | 25      | 24      | 23      | 22      | 21      | 20 | 19      | 18 | 17 | 16 | 15      | 14      | 13      | 12 | 11 | 10      | 9 | 8       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|     | PAT0C31 | PAT0C30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | PAT0C29 | PAT0C28 | PAT0C27 | PAT0C26 | PAT0C25 | PAT0C24 | PAT0C23 | PAT0C22 | PAT0C21 | C  | PAT0C19 | G  | G  | C1 | PAT0C15 | PAT0C14 | PAT0C13 | 5  | C  | PAT0C10 | Ō | $\circ$ | PAT0C07 | $\circ$ | PAT0C05 | $\circ$ | PAT0C03 | PAT0C02 | PAT0C01 | PAT0C00 |
| ST  | ?       | ?                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?  | ?       | ?  | ?  | ?  | ?       | ?       | ?       | ?  | ?  | ?       | ? | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       |

| Bits | Name    | Description                                                   | R/W |
|------|---------|---------------------------------------------------------------|-----|
| n    | PAT0C n | Writing 1 to PAT0C n will set PAT0 n to 0 in register PXPAT0. | W   |
|      |         | Writing 0 to PAT0C n will no use.                             |     |



## 1.2.14 PORT FLAG Registers (PxFLG)

PAFLG, PBFLG, PCFLG, PDFLG, PEFLG and PFFLG are six 32-bit GPIO FLAG registers. They are read-only registers.

#### PAFLG, PBFLG, PCFLG, 0x10010050, 0x10010150, 0x10010250, PDFLG, PEFLG, PFFLG 0x10010350, 0x10010450, 0x10010550 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 FLAG04 σ α G ഹ c FLAG08 FLAG05 FLAG03 FLAG00 FLAG02 FLAG21 FLAG2( FLAG2 FLAG2: FLAG0( FLAG3 FLAG2 FLAG2 FLAG2 FLAG2 FLAG1 FLAGO **FLAGO** FLAG3 FLAG2 FLAG2 FLAG1 FLAG1 FLAG1 FLAG1 FLAG1 FLAG1 FLAG1 FLAG1 FLAG1 **FLAG0 RST** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

| Bits   | Name   | Description                                                                | R/W |
|--------|--------|----------------------------------------------------------------------------|-----|
| n      | FLAG n | Where n = 0 ~ 31 and FLAG n = FLAG00 ~ FLAG31.                             | R   |
|        |        | FLAG n is interrupt flag bit for checking the interrupt whether to happen. |     |
|        |        | When GPIO is used as interrupt function and the interrupt happened, the    |     |
|        |        | FLAG n in PXFLG will be set to 1. $\sqrt{\sqrt{2}}$                        |     |
| 1 2 15 |        | G Clear Registers (PxFLGC) Tternat                                         |     |

# 1.2.15 PORT FLAG Clear Registers (PxFLGC)

PAFLGC, PBFLGC, PCFLGC, PDFLGC, PEFLGC and PFFLGC are six 32-bit GPIO FLAG Clear registers. They are read-only registers.

| PAFLGC, PBFLGC, PCFLGC,<br>PDFLGC, PEFLGC, PFFLGC                                                                                                                                                                                                                    | 0x10010058, 0x10010158, 0x10010258,<br>0x10010358, 0x10010458,0x10010558               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 1                                                                                                                                                                                                       | 2 11 10 9 8 7 6 5 4 3 2 1 0                                                            |
| FLAGC31<br>FLAGC30<br>FLAGC29<br>FLAGC28<br>FLAGC28<br>FLAGC26<br>FLAGC24<br>FLAGC24<br>FLAGC21<br>FLAGC21<br>FLAGC21<br>FLAGC10<br>FLAGC10<br>FLAGC16<br>FLAGC16<br>FLAGC16<br>FLAGC16<br>FLAGC16<br>FLAGC16<br>FLAGC16<br>FLAGC16<br>FLAGC16<br>FLAGC16<br>FLAGC16 | LAGC1<br>LAGC1<br>LAGC0<br>LAGC0<br>LAGC0<br>LAGC0<br>LAGC0<br>LAGC0<br>LAGC0<br>LAGC0 |
| RST 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                            | 0 0 0 0 0 0 0 0 0 0 0 0                                                                |

| Bits | Name    | Description                                                              | R/W |
|------|---------|--------------------------------------------------------------------------|-----|
| n    | FLAGC n | When GPIO is used as interrupt function and when write 1 to the bit, the | R   |
|      |         | bit FLAG n in PXFLG will be cleared.                                     |     |

20



# 1.2.16 PORT PULL Disable Registers (PxPE)

PAPE, PBPE, PCPE, PDPE, PEPE and PFPE are six 32-bit PORT PULL disable registers.

|     | PAPE, | PBPE             | , PCF  | Έ,   |      |        |        |        |     |        |      |      |        |        |        |        | 0x1         | 001    | 00     | <b>70</b> , | 0x1        | <b>00</b> ′ | 101          | <b>70</b> ,  | <b>0</b> x1 | 100 <sup>,</sup> | 1 <mark>02</mark> | <b>70</b> , |
|-----|-------|------------------|--------|------|------|--------|--------|--------|-----|--------|------|------|--------|--------|--------|--------|-------------|--------|--------|-------------|------------|-------------|--------------|--------------|-------------|------------------|-------------------|-------------|
|     | PDPE, | PEPE             | , PFP  | Е    |      |        |        |        |     |        |      |      |        |        |        |        | <b>0</b> x′ | 100    | 103    | <b>70</b> , | <b>0</b> x | 100         | 1 <b>0</b> 4 | <b>170</b> , | <b>0</b> x  | 100              | 105               | 70          |
| Bit | 31 30 | 29 28            | 27 2   | 6 25 | 24   | 23 22  | 2 21   | 20     | 19  | 18     | 17   | 16   | 15     | 14     | 13     | 12     | 11          | 10     | 9      | 8           | 7          | 6           | 5            | 4            | 3           | 2                | 1                 | 0           |
|     |       | PULL29<br>PULL28 | PULL27 |      | ULL2 | PULL23 | PULL21 | PULL20 | JLL | PULL18 | JLL1 | JLL1 | PULL15 | PULL14 | PULL13 | PULL12 | PULL11      | PULL10 | PULL09 | PULL08      | PULL07     | PULL06      | PULL05       | PULL04       | PULL03      | PULL02           | PULL01            | PULL00      |
| RS  | 0 0   | 0 0              | 0 0    | ) () | 0    | 0 0    | 0      | 0      | 0   | 0      | 0    | 0    | 0      | 0      | 0      | 0      | 0           | 0      | 0      | 0           | 0          | 0           | 0            | 0            | 0           | 0                | 0                 | 0           |

| Bits   | Name   | Description                                                                                                                                                                                                                                                              | R/W |
|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Ν      | PULL n | Where n = 0 ~ 31 and PULL n = PULL0 ~ PULL31.                                                                                                                                                                                                                            | RW  |
|        |        | <ul> <li>PULL n is used for setting the port to be PULL UP or PULL DOWN enable.</li> <li>0: An internal pull up or pull down resistor connects to the port. Up or down is pin dependence</li> <li>1: No pull up or pull down resistor connects to the port US</li> </ul> |     |
| 1.2.17 |        | L Set Registers (PxPES)                                                                                                                                                                                                                                                  | 1   |

# 1.2.17 PORT PULL Set Registers (PxPES)

PAPES, PBPES, PCPES, PDPES, PEPES and PFPES are six 32-bit PORT PULL set registers. They are write-only registers.

# PAPES, PBPES, PCRES, PDPES, PEPES, PFPES

## 0x10010074, 0x10010174, 0x10010274, 0x10010374, 0x10010474, 0x10010574

| Bit | 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
|     | LS31 | LS30 | LS29 | LS28 | LS27 | LS26 | LS25 | LS24 | LS23 | LS22 | LS21 | LS20 | LS19 | LS18 | LS17 | LS16 | LS15 | LS14 | LS13 | LS12 | LS11 | LS10 | LS09 | LS08 | LS07 | LS06 | LS05 | LS04 | LS03 | LS02 | LS01 | LS00 |
|     | PUL  |
| RST | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    | ?    |

| Bits | Name    | Description                                                 | R/W |
|------|---------|-------------------------------------------------------------|-----|
| n    | PULLS n | Writing 1 to PULLS n will set PULL n to 1 in register PXPE. | W   |
|      |         | Writing 0 to PULLS n will no use.                           |     |

22



# 1.2.18 PORT PULL Clear Registers (PxPEC)

PAPEC, PBPEC, PCPEC, PDPEC, PEPEC and PFPEC are six 32-bit PORT PULL clear registers.

|     | PA      | PE      | 5, P    | BP      | EC,     | PC      | PE      | С,      |         |         |         |         |         |         |             |      |         |         |         |         | 0x1        | 001     | 00      | 78,         | 0x1        | <b>00</b> <sup>.</sup> | 101     | 78,     | <b>0</b> x1  | 100     | 102     | 78,     |
|-----|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|-------------|------|---------|---------|---------|---------|------------|---------|---------|-------------|------------|------------------------|---------|---------|--------------|---------|---------|---------|
|     | PD      | PE      | C, P    | PEP     | EC,     | PF      | PE      | С       |         |         |         |         |         |         |             |      |         |         |         |         | <b>0</b> x | 100     | 103     | <b>78</b> , | <b>0</b> x | 100                    | 104     | 178     | , <b>0</b> x | 100     | 0105    | 578     |
| Bit | 31      | 30      | 29      | 28      | 27      | 26      | 25      | 24      | 23      | 22      | 21      | 20      | 19      | 18      | 17          | 16   | 15      | 14      | 13      | 12      | 11         | 10      | 9       | 8           | 7          | 6                      | 5       | 4       | 3            | 2       | 1       | 0       |
|     | PULLC31 | PULLC30 | PULLC29 | PULLC28 | PULLC27 | PULLC26 | PULLC25 | PULLC24 | PULLC23 | PULLC22 | PULLC21 | PULLC20 | PULLC19 | PULLC18 | <b>ULLC</b> | NLLC | PULLC15 | PULLC14 | PULLC13 | PULLC12 | PULLC11    | PULLC10 | PULLC09 | PULLC08     | PULLC07    | PULLC06                | PULLC05 | PULLC04 | PULLC03      | PULLC02 | PULLC01 | PULLC00 |
| RST | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?       | ?           | ?    | ?       | ?       | ?       | ?       | ?          | ?       | ?       | ?           | ?          | ?                      | ?       | ?       | ?            | ?       | ?       | ?       |

| Bits | Name    | Description                                                                                                 | R/W |
|------|---------|-------------------------------------------------------------------------------------------------------------|-----|
| n    | PULLC n | Writing 1 to PULLC n will set PULL n to 0 in register PXPE.                                                 | W   |
|      |         | Writing 0 to PULLC n will no use.                                                                           | 1   |
|      | 078-6   | Writing 0 to PULLC n will no use.<br>Writing 0 to PULLC n will no use.<br>Writing 0 to PULLC n will no use. | 1   |
|      |         |                                                                                                             |     |



## 1.3 Program Guide

#### 1.3.1 Port Function Guide

| INT | MASK | PAT1 | PAT0 | Port Description                                                                     |
|-----|------|------|------|--------------------------------------------------------------------------------------|
| 1   | 0    | 0    | 0    | Port is low level triggered interrupt input.                                         |
| 1   | 0    | 0    | 1    | Port is high level triggered interrupt input.                                        |
| 1   | 0    | 1    | 0    | Port is fall edge triggered interrupt input.                                         |
| 1   | 0    | 1    | 1    | Port is rise edge triggered interrupt input.                                         |
| 1   | 1    | 0    | 0    | Port is low level triggered interrupt input. Interrupt is masked. Flag is recorded.  |
| 1   | 1    | 0    | 1    | Port is high level triggered interrupt input. Interrupt is masked. Flag is recorded. |
| 1   | 1    | 1    | 0    | Port is fall edge triggered interrupt input. Interrupt is masked. Flag is recorded.  |
| 1   | 1    | 1    | 1    | Port is rise edge triggered interrupt input. Interrupt is masked. Flag is recorded.  |
| 0   | 0    | 0    | 0    | Port is pin of device 0.                                                             |
| 0   | 0    | 0    | 1    | Port is pin of device 1.                                                             |
| 0   | 0    | 1    | 0    | Port is pin of device 2.                                                             |
| 0   | 0    | 1    | 1    | Port is pin of device 3.                                                             |
| 0   | 1    | 0    | 0    | Port is GPIO output 0.                                                               |
| 0   | 1    | 0    | 1    | Port is GPIO output 1.                                                               |
| 0   | 1    | 1    | ?    | Port is GPIO input.                                                                  |
|     |      | Γc   | D.D. | Port is GPIO input.                                                                  |



# 2 I2C Controller

#### 2.1 **Overview**

The I2C bus is a two-wire serial interface, consisting of a serial data line (SDA) and a serial clock (SCL). These wires carry information between the devices connected to the bus. Each device is recognized by a unique address and can operate as either a "transmitter" or "receiver," depending on the function of the device. Devices can also be considered as masters or slaves when performing data transfers. A master is the device that initializes/terminates a data transfer on the bus and generates clock signals to permit that transfer. During that time, any addressed device is considered as a slave. The I2C controller is software controlled. It behaves as a master or a slave. However, operating as a master and slave simultaneously is not supported.

#### 2.1.1 Features

- Two-wire I2C serial interface consists of a serial data line (SDA) and a serial clock (SCL) • 6. com internal
- Two speeds

.

- Standard mode (100 Kb/s)
- Fast mode (400 Kb/s)
- Device clock is identical with pclk
- Programmable SCL generator •
- Master or slave I2C operation •
- 7-bit addressing/10-bit addressing •
- 16-level transmit and receive FIFOs •
- Interrupt operation •
- The number of devices that you can connect to the same I2C-bus is limited only by the maximum • bus capacitance of 400pF
- APB interface
- 3 independent I2C channels (I2C0, I2C1, I2C2) •

#### 2.1.2 Pin Description

| Table | 2-1 | I2C | Pin | Description |  |
|-------|-----|-----|-----|-------------|--|
|-------|-----|-----|-----|-------------|--|

| Name | Width | ю  | Description      |
|------|-------|----|------------------|
| SDA  | 1-bit | 10 | I2C serial data  |
| SCL  | 1-bit | 10 | I2C serial clock |

Please note that dedicate pull-up resistors must be introduced on board-level. The low-to-high (rise time) transition is highly dependent on RC time constant of the bus.

Totally speaking, for standard-mode I2C-bus system, the pull up resistor depends on following 24



parameters:

- Supply voltage
- Bus capacitance
- Number of connected devices

For fast-mode I2C-bus system, switched pull-up circuit may be essential for strict speed and load requirement. (Refer to ' Philips Semiconductor, *THE*  $l^2$ *C-BUS SPECIFICATION*, Version 2.1. Jan, 2000')

Long\_eiffel@126.com internal used only



## 2.2 Registers

#### 2.2.1 Registers Memory Map

A read operation to an address location that contains unused bits results in a 0 value being returned on each of the unused bits.

Registers in I2C controller can be accessed by indicating 24-bit Address Base combined with 8-bit Address Offset.

| Name | Addr Base  | Description          |
|------|------------|----------------------|
| I2C0 | 0x10050000 | Address base of I2C0 |
| I2C1 | 0x10051000 | Address base of I2C1 |
| I2C2 | 0x10055000 | Address base of I2C2 |

#### Table 2-2 Registers Memory Map-Address Base

|           | -                      |                                   |        |     | OUr.    |  |  |
|-----------|------------------------|-----------------------------------|--------|-----|---------|--|--|
| Name      | Addr Offset            | Description                       | Width  | RW  | Reset   |  |  |
| I2CCON    | 0x00                   | I2C control                       | 8bits  | RW  | 0x6D    |  |  |
| I2CTAR    | 0x04                   | I2C target address                | 13bits | RW  | 0x0855  |  |  |
| I2CSAR    | 0x08                   | I2C slave address                 | 10bits | RW  | 0x055   |  |  |
| I2CDC     | 0x10                   | I2C data buffer and command       | 9bits  | RW  | 0x000   |  |  |
| I2CSHCNT  | 0x14                   | Standard speed I2C SCL high count | 16bits | RW  | 0x0190  |  |  |
| I2CSLCNT  | 0x18                   | Standard speed I2C SCL low count  | 16bits | RW  | 0x01D6  |  |  |
| I2CFHCNT  | 0x1C                   | Fast speed I2C SCL high count     | 16bits | RW  | 0x003C  |  |  |
| I2CFLCNT  | 0x20                   | Fast speed I2C SCL low count      | 16bits | RW  | 0x0082  |  |  |
| I2CINTST  | 0x2C                   | I2C Interrupt Status              | 12bits | R   | 0x000   |  |  |
| I2CINTM   | 0x30                   | I2C Interrupt Mask                | 12bits | R/W | 12'h8FF |  |  |
| 10        | /                      |                                   |        |     |         |  |  |
| I2CRXTL   | 0x38                   | I2C RxFIFO Threshold              | 4 bits | RW  | 0xF     |  |  |
| I2CTXTL   | 0x3C                   | I2C TxFIFO Threshold              | 4 bits | RW  | 0xF     |  |  |
| I2CCINT   | 0x40                   | Clear Interrupts                  | 1 bit  | R   | 0x0     |  |  |
| I2CCRXUF  | 0x44                   | Clear RXUF Interrupt              | 1 bit  | R   | 0x0     |  |  |
| I2CCRXOF  | 0x48                   | Clear RX_OVER Interrupt           | 1 bit  | R   | 0x0     |  |  |
| I2CCTXOF  | 0x4C                   | Clear TX_OVER Interrupt           | 1 bit  | R   | 0x0     |  |  |
| I2CCRXREQ | 0x50                   | Clear RDREQ Interrupt             | 1 bit  | R   | 0x0     |  |  |
| I2CCTXABT | 0x54                   | Clear TX_ABRT Interrupt           | 1 bit  | R   | 0x0     |  |  |
| I2CCRXDN  | 0x58                   | Clear RX_DONE Interrupt           | 1 bit  | R   | 0x0     |  |  |
| I2CCACT   | 0x5c                   | Clear ACTIVITY Interrupt          | 1 bit  | R   | 0x0     |  |  |
| I2CCSTP   | 0x60                   | Clear STOP Interrupt              | 1 bit  | R   | 0x0     |  |  |
| I2CCSTT   | 0x64                   | Clear START Interrupt             | 1 bit  | R   | 0x0     |  |  |
| I2CCGC    | 0x68                   | Clear GEN_CALL Interrupt          | 1 bit  | R   | 0x0     |  |  |
| I2CENB    | I2CENB 0x6C I2C Enable |                                   | 1 bit  | RW  | 0x0     |  |  |

#### Table 2-3 Registers Memory Map-Address Offset

26

JZ4770 Mobile Application Processor Peripherals Programming Manual

| I2CST              | 0x70           | I2C Status register                      | 7 bits    | R                           | 0x06        |
|--------------------|----------------|------------------------------------------|-----------|-----------------------------|-------------|
|                    |                |                                          |           |                             |             |
|                    |                |                                          |           |                             |             |
| I2CABTSRC          | 0x80           | I2C Transmit Abort Status Register       | 16 bits   | R                           | 0x0000      |
|                    |                |                                          |           |                             |             |
| I2CDMACR           | 0x88           | DMA Control Register                     | 2 bits    | R/W                         | 0x0         |
| I2CDMATDLR         | 0x8c           | DMA Transmit Data Level                  | 4 bits    | R/W                         | 0x0         |
| I2CDMARDLR         | 0x90           | DMA Receive Data Level                   | 4 bits    | R/W                         | 0x0         |
| I2CSDASU           | 0x94           | I2C SDA Setup Register                   | 8 bits    | RW                          | 0x64        |
| I2CACKGC           | 0x98           | I2C ACK General Call Register            | 1 bit     | RW                          | 0x1         |
| I2CENBST           | 0x9C           | I2C Enable Status Register               | 3 bits    | R                           | 0x0         |
| I2CSDAHD           | 0xD0           | I2C SDA HoID time Register               | 9 bits    | RW                          | 0x000       |
|                    |                |                                          |           |                             |             |
|                    |                |                                          |           |                             | 1           |
|                    |                |                                          |           | 5                           | 173         |
|                    |                |                                          |           | $\mathcal{L}_{\mathcal{O}}$ |             |
|                    | and the state  | Description                              | 1150      |                             |             |
| 2.2.2 Registe      | rs and Fields  | s Description                            | V.        |                             |             |
| 2.2.2.1 I2CCO      | N              | s Description                            |           |                             |             |
| I2C control regist | ter. Only STP⊦ | ILD can be written during I2C disable an | d enable, | others of                   | only can be |

#### 2.2.2 Registers and Fields Description

#### 2.2.2.1 I2CCON

I2C control register. Only STPHLD can be written during I2C disable and enable, others only can be written when I2C is disable.

| I2CCON | 126. |    |    |    |      |      |    |   |   |        |        |      |      | BA   | SE · | ⊦ <b>0</b> > | <b>(00</b> |
|--------|------|----|----|----|------|------|----|---|---|--------|--------|------|------|------|------|--------------|------------|
| Bit    |      | 15 | 14 | 13 | 12   | 11   | 10 | 9 | 8 | 7      | 6      | 5    | 4    | 3    | 2    | 1            | 0          |
|        |      |    |    | F  | Rese | erve | ed |   |   | STPHLD | SLVDIS | REST | MATP | SATP | CON  | 5            | QW         |
| RST    |      | 0  | 0  | 0  | 0    | 0    | 0  | 0 | 0 | 0      | 1      | 1    | 0    | 1    | 1    | 0            | 1          |

| Bits | Name     | Description                                                       | RW |  |  |  |  |  |  |
|------|----------|-------------------------------------------------------------------|----|--|--|--|--|--|--|
| 15:8 | Reserved | Writing has no effect, read as zero.                              | R  |  |  |  |  |  |  |
| 7    | STPHLD   | Stop Hold Enable bit.                                             | RW |  |  |  |  |  |  |
|      |          | 0: When tx fifo is empty, a STP condition will be generated       |    |  |  |  |  |  |  |
|      |          | 1: STP will never be generated until this bit changed to 0        |    |  |  |  |  |  |  |
|      |          | this bit in I2CCON can be written during I2C disable and enable   |    |  |  |  |  |  |  |
|      |          | status.                                                           |    |  |  |  |  |  |  |
| 6    | SLVDIS   | This bit controls whether I2C has its slave disabled after reset. | RW |  |  |  |  |  |  |
|      |          | 0: slave is enabled                                               |    |  |  |  |  |  |  |
|      |          | 1: slave is disabled                                              |    |  |  |  |  |  |  |
| 5    | REST     | Determines whether RESTART conditions may be sent when acting as  | RW |  |  |  |  |  |  |
|      |          | a master.                                                         |    |  |  |  |  |  |  |



| 12C1    |        | o. COIL                                                                                             | SE + 0x04 |
|---------|--------|-----------------------------------------------------------------------------------------------------|-----------|
| 2.2.2.2 | I2CTAR | 1: master enabled<br>international<br>a 26. com                                                     |           |
|         |        | 1: master enabled                                                                                   |           |
|         |        | 0: master disabled $\sqrt{\sqrt{5}}$                                                                |           |
| 0       | MD     | This bit controls whether the I2C master is enabled. $\sim e^{O}$                                   | RW        |
|         |        | will be automatically set to 2'b10 i.e. fast mode.                                                  |           |
|         |        | <b>NOTE:</b> when these two bits are set to 2'b00 or 2'b11, the speed mode                          | 4         |
|         |        | 2: fast mode (400 kbps)                                                                             |           |
|         | 0. 0   | 1: standard mode (100 kbps)                                                                         |           |
| 2:1     | SPD    | These bits control at which speed the I2C operates.                                                 | RW        |
|         |        | 1: 10-bit addressing                                                                                |           |
|         |        | 0: 7-bit addressing                                                                                 |           |
| 3       | SAIP   | When acting as a slave, this bit controls whether the I2C responds to<br>7-bit or 10-bit addresses. | RVV       |
| 3       | SATP   | 1: 10-bit addressing                                                                                | RW        |
|         |        | 0: 7-bit addressing                                                                                 |           |
|         |        | The function of this bit is handled by bit 12 of I2CTAR register.                                   |           |
|         |        | addressing mode when acting as a master.                                                            |           |
| 4       | MATP   | This bit controls whether the I2C starts its transfers in 7-bit or 10-bit                           | R         |
|         |        | 1: enable                                                                                           |           |
|         |        | 0: disable                                                                                          |           |

#### 2.2.2.2 I2CTAR

|     | I2CTAR | 26.00 |    |          |    |      |         |             |   |   |   |   |                  |     | BAS | SE · | + 0> | <b>(04</b> |
|-----|--------|-------|----|----------|----|------|---------|-------------|---|---|---|---|------------------|-----|-----|------|------|------------|
| Bit |        |       | 15 | 14       | 13 | 12   | 11      | 10          | 9 | 8 | 7 | 6 | 5                | 4   | 3   | 2    | 1    | 0          |
|     |        |       |    | Reserved |    | MATP | SPECIAL | GC_OR_START |   |   |   |   | 12C <sup>-</sup> | TAF | R   |      |      |            |
| RST |        |       | 0  | 0        | 0  | 0    | 1       | 0           | 0 | 0 | 0 | 1 | 0                | 1   | 0   | 1    | 0    | 1          |
|     |        |       |    |          |    |      |         |             |   |   |   |   |                  |     |     |      |      |            |

| Bits  | Name     | Description                                                            | R/W |
|-------|----------|------------------------------------------------------------------------|-----|
| 15:13 | Reserved | Writing has no effect, read as zero.                                   | R   |
| 12    | MATP     | This bit controls whether the I2C starts its transfers in 7- or 10-bit | RW  |
|       |          | addressing mode when acting as a master.                               |     |
|       |          | 0: 7-bit addressing                                                    |     |
|       |          | 1: 10-bit addressing                                                   |     |
|       |          | <b>NOTE:</b> this bit is initially set to 0.                           |     |
| 11    | SPECIAL  | This bit indicates whether software performs a General Call or         | RW  |
|       |          | START BYTE command.                                                    |     |
|       |          | 0: ignore the bit of GC_OR_START and use I2CTAR normally               |     |
|       |          | 1: perform special I2C command as specified in GC_OR_START bit         |     |

28



|     |        | <b>NOTE:</b> this bit is initially set to 1.                               |    |  |  |  |  |  |  |
|-----|--------|----------------------------------------------------------------------------|----|--|--|--|--|--|--|
| 10  | GC_OR_ | If bit 11 (SPECIAL) is set to 1, then this bit indicates whether a General | RW |  |  |  |  |  |  |
|     | START  | Call or START byte command is to be performed by the I2C.                  |    |  |  |  |  |  |  |
|     |        | 0: General Call Address – after issuing a General Call, only writes may    |    |  |  |  |  |  |  |
|     |        | be performed. Attempting to issue a read command results in setting        |    |  |  |  |  |  |  |
|     |        | bit 6 (TX_ABRT) of the I2CINTST register. The I2C remains in General       |    |  |  |  |  |  |  |
|     |        | Call mode until the SPECIAL bit value (bit 11) is cleared                  |    |  |  |  |  |  |  |
|     |        | 1: START BYTE                                                              |    |  |  |  |  |  |  |
| 9:0 | I2CTAR | This is the target address for any master transaction. When transmitting a | RW |  |  |  |  |  |  |
|     |        | General Call, these bits are ignored. To generate a START BYTE, the        |    |  |  |  |  |  |  |
|     |        | CPU needs to write only once into these bits.                              |    |  |  |  |  |  |  |
|     |        | If the I2CTAR and I2CSAR are the same, loopback exists but the             |    |  |  |  |  |  |  |
|     |        | FIFOs are shared between master and slave, so full loopback is not         |    |  |  |  |  |  |  |
|     |        | feasible. Only one direction loopback mode is supported (simplex), not     |    |  |  |  |  |  |  |
|     |        | duplex. A master cannot transmit to itself, but only to a slave.           |    |  |  |  |  |  |  |
|     |        |                                                                            |    |  |  |  |  |  |  |

NOTE: It is not necessary to perform any write to this register if I2C is enabled as an I2C slave only.

## 2.2.2.3 I2CSAR

| 2.2.2.3 I2CSAR | under any white to this register in 120 is chastering an 120 slave only.                                                                                      |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I2CSAR         | BASE + 0x00                                                                                                                                                   |
| Bit            | 15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         Reserved       I2CSAR |
| RST            | 0 0 0 0 0 0 0 0 1 0 1 0 1 0 1                                                                                                                                 |

|       | 115/     |                                                                       |     |
|-------|----------|-----------------------------------------------------------------------|-----|
| Bits  | Name     | Description                                                           | R/W |
| 15:10 | Reserved | Writing has no effect, read as zero.                                  | R   |
| 9:0   | I2CSAR   | The I2CSAR holds the slave address when the I2C is operating as a     | RW  |
|       |          | slave. For 7-bit addressing, only I2CSAR[6:0] is used.                |     |
|       |          | This register can be written only when the I2C interface is disabled. |     |
|       |          | Writes at other times have no effect.                                 |     |

NOTE: It is not necessary to perform any write to this register if I2C is enabled as an I2C master only.

## 2.2.2.4 I2CDC

I2C Rx/Tx Data Buffer and Command Register, which the CPU writes to when filling the TX FIFO and the CPU reads from when retrieving bytes from RX FIFO.



| I2CDC |  |   |
|-------|--|---|
|       |  | 1 |

|   |   |    |    |     |     |    |   |     |   |   |   | BASE + 0x10 |    |   |   |   |  |  |  |  |  |  |
|---|---|----|----|-----|-----|----|---|-----|---|---|---|-------------|----|---|---|---|--|--|--|--|--|--|
| 1 | 5 | 14 | 13 | 12  | 11  | 10 | 9 | 8   | 7 | 6 | 5 | 4           | 3  | 2 | 1 | 0 |  |  |  |  |  |  |
|   |   |    | Re | ser | ved |    |   | CMD |   |   |   | D           | ٩T |   |   |   |  |  |  |  |  |  |
| ( | 0 | 0  | 0  | 0   | 0   | 0  | 0 | 0   | 0 | 0 | 0 | 0           | 0  | 0 | 0 | 0 |  |  |  |  |  |  |

RST

Bit

| Bits | Name     | Description                                                                                                                                                                                                     | R/W |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 15:9 | Reserved | Writing has no effect, read as zero.                                                                                                                                                                            | R   |
| 8    | CMD      | This bit controls whether a read or a write is performed. This bit does not control the direction when the I2C acts as a slave. It controls only the direction when it acts as a master.<br>1: Read<br>0: Write | RW  |
| 7:0  | DAT      | This register contains the data to be transmitted or received on the 12C bus.                                                                                                                                   | RW  |

**NOTE:** this command only transfer 8-bit data combined with 1-bit CMD, extra bits on the bus will be eliminated. i.e. only 8-0 bits on the bus are accepted by [2C controller.

| 2.2.2.5 I2CSHCNT | . 26. COM | T  |    |    |    |    |    |     |     |     |    |   |   |    |    |     |            |
|------------------|-----------|----|----|----|----|----|----|-----|-----|-----|----|---|---|----|----|-----|------------|
| I2CSHCNT         | 1@140     |    |    |    |    |    |    |     |     |     |    |   |   | BA | SE | + 0 | <b>c14</b> |
| Bit              |           | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6  | 5 | 4 | 3  | 2  | 1   | 0          |
|                  |           |    |    |    |    |    |    | 120 | CSł | 101 | ۲٧ |   |   |    |    |     |            |
| RST              |           | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 1   | 1   | 0  | 0 | 1 | 0  | 0  | 0   | 0          |
| KOI              |           | 0  | 0  | U  | 0  | 0  | U  | 0   |     | 1   | 0  | 0 | 1 | 0  | 0  | U   | 0          |

| Bits | Name     | Description                                                           | R/W |
|------|----------|-----------------------------------------------------------------------|-----|
| 15:0 | I2CSHCNT | This register must be set before any I2C bus transaction can take     | RW  |
|      |          | place to ensure proper I/O timing. The register sets the SCL clock    |     |
|      |          | high-period count for standard speed.                                 |     |
|      |          | This register can be written only when the I2C interface is disabled. |     |
|      |          | Writes at other times have no effect.                                 |     |
|      |          | SCL high time of i2c is (I2CSHCNT + 8) i2c_clk periods.               |     |

**NOTE:** Minimum value allowed for the I2CSHCNT registers is 6. If the set value was less than 6, it will be automatically set to 6.

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

#### 2.2.2.6 I2CSLCNT

| I2CSLCNT |    |            |     |    |    |    |    |   |   |   |   |   |   | BA | SE | + 0> | <b>c18</b> |
|----------|----|------------|-----|----|----|----|----|---|---|---|---|---|---|----|----|------|------------|
| Bit      | 15 | <b>5</b> 1 | 4 1 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2  | 1    | 0          |
|          |    | I2CSLCNT   |     |    |    |    |    |   |   |   |   |   |   |    |    |      |            |
| RST      | 0  | )          | 0   | 0  | 0  | 0  | 0  | 0 | 1 | 1 | 1 | 0 | 1 | 0  | 1  | 1    | 0          |

| Bits | Name     | Description                                                              | R/W |
|------|----------|--------------------------------------------------------------------------|-----|
| 15:0 | I2CSLCNT | This register must be set before any I2C bus transaction can take place  | RW  |
|      |          | to ensure proper I/O timing. This register sets the SCL clock low period |     |
|      |          | count for standard speed.                                                |     |
|      |          | This register can be written only when the I2C interface is disabled.    |     |
|      |          | Writes at other times have no effect.                                    |     |
|      |          | SCL low time of i2c is (I2CSLCNT + 1) i2c_clk periods. $\chi$            |     |
|      | •        | , SCU                                                                    | •   |

NOTE: Minimum value that can be programmed in the I2CSLCNT registers is 8. If the set value was 6. com interna less than 8, it will be automatically set to 8.

#### 2.2.2.7 I2CFHCNT

| I2CFHCNT | 126. |    |    |    |    |    |    |    |     |   |   |   | I | BAS | SE · | ⊦ 0x | (1C |
|----------|------|----|----|----|----|----|----|----|-----|---|---|---|---|-----|------|------|-----|
| Bit      |      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7 | 6 | 5 | 4 | 3   | 2    | 1    | 0   |
|          |      |    |    |    |    |    |    | 10 |     |   |   |   |   |     |      |      |     |
|          |      |    |    |    |    |    |    | 12 | CFI |   |   |   |   |     |      |      |     |
| RST      |      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0 | 0 | 1 | 1 | 1   | 1    | 0    | 0   |

| Bits | Name     | Description                                                           | R/W |
|------|----------|-----------------------------------------------------------------------|-----|
| 15:0 | I2CFHCNT | This register must be set before any I2C bus transaction can take     | RW  |
|      |          | place to ensure proper I/O timing. This register sets the SCL clock   |     |
|      |          | high-period count for fast speed.                                     |     |
|      |          | This register can be written only when the I2C interface is disabled. |     |
|      |          | Writes at other times have no effect.                                 |     |

NOTE: Minimum value allowed for the I2CSHCNT registers is 6. If the set value was less than 6, it will be automatically set to 6.



#### 2.2.2.8 I2CFLCNT

| I2CFLCNT |          |    |    |    |    |    |   |   |   |   |   |   | BA | SE · | + 0> | <b>(20</b> |
|----------|----------|----|----|----|----|----|---|---|---|---|---|---|----|------|------|------------|
| Bit      | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2    | 1    | 0          |
|          | I2CFLCNT |    |    |    |    |    |   |   |   |   |   |   |    |      |      |            |
| RST      | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 1 | 0 | 0 | 0 | 0  | 0    | 1    | 0          |

| Bits | Name     | Description                                                              | R/W |
|------|----------|--------------------------------------------------------------------------|-----|
| 15:0 | I2CFLCNT | This register must be set before any I2C bus transaction can take place  | RW  |
|      |          | to ensure proper I/O timing. This register sets the SCL clock low period |     |
|      |          | count for fast speed.                                                    |     |
|      |          | This register can be written only when the I2C interface is disabled.    |     |
|      |          | Writes at other times have no effect.                                    |     |

NOTE: Minimum value that can be programmed in the I2CSLCNT registers is 8. If the set value was nternal less than 8, it will be automatically set to 8.

#### 2.2.2.9 I2CINTST

Each bit in this register has a corresponding mask bit in the I2CINTM register. These bits are cleared by reading the matching interrupt clear register.

| <b>I2CINTST</b> | ce1014 |    |      |       |      |      |      |      |      |       |       | E     | BAS  | 3E - | ⊦ 0x | 2C   |
|-----------------|--------|----|------|-------|------|------|------|------|------|-------|-------|-------|------|------|------|------|
| Bit             |        | 15 | 14   | 13 12 | 2 11 | 10   | 9    | 8    | 7    | 6     | 5     | 4     | 3    | 2    | 1    | 0    |
|                 |        | R  | esei | rved  | lGC  | ISTT | ISTP | IACT | RXDN | TXABT | RDREQ | TXEMP | TXOF | RXFL | RXOF | RXUF |
| RST             |        | 0  | 0    | 0 0   | 0    | 0    | 0    | 0    | 0    | 0     | 0     | 0     | 0    | 0    | 0    | 0    |

| Bits  | Name     | Description                                                                                                                                         | R/W |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 15:12 | Reserved | Writing has no effect, read as zero.                                                                                                                | R   |
|       |          | Set only when a General Call address is received and it is acknowledged.                                                                            |     |
| 11    | IGC      | It stays set until it is cleared either by disabling I2C or when the CPU reads bit 0 of the I2CCGC register. I2C stores the received data in the Rx | R   |
|       |          | buffer.                                                                                                                                             |     |
| 10    | ISTT     | Indicates whether a START or RESTART condition has occurred on the                                                                                  | R   |
|       |          | I2C interface regardless of whether I2C is operating in slave or master                                                                             |     |
|       |          | mode.                                                                                                                                               |     |
| 9     | ISTP     | Indicates whether a STOP condition has occurred on the I2C interface                                                                                | R   |
|       |          | regardless of whether I2C is operating in slave or master mode.                                                                                     |     |

32



| 0 | IACT  | This hit contures ISC activity and stave act until it is cleared. There are            | D |
|---|-------|----------------------------------------------------------------------------------------|---|
| 8 | IACT  | This bit captures I2C activity and stays set until it is cleared. There are            | R |
|   |       | four ways to clear it:                                                                 |   |
|   |       | 1 Disabling the I2C                                                                    |   |
|   |       | 2 Reading the I2CCACT register                                                         |   |
|   |       | 3 Reading the I2CCINT register                                                         |   |
|   |       | 4 System reset                                                                         |   |
|   |       | Once this bit is set, it stays set unless one of the four methods is used to           |   |
|   |       | clear it. Even if the I2C module is idle, this bit remains set until cleared,          |   |
|   |       | indicating that there was activity on the bus.                                         |   |
| 7 | RXDN  | When the I2C is acting as a slave-transmitter, this bit is set to 1 if the             | R |
|   |       | master does not acknowledge a transmitted byte. This occurs on the last                |   |
|   |       | byte of the transmission, indicating that the transmission is done.                    |   |
| 6 | TXABT | This bit indicates if I2C, as an I2C transmitter, is unable to complete the            | R |
|   |       | intended actions on the contents of the transmit FIFO. This situation can              |   |
|   |       | occur both as an I2C master or an I2C slave, and is referred to as a $\sqrt{\sqrt{2}}$ |   |
|   |       | "transmit abort". When this bit is set to 1, the I2CABTSRC register                    |   |
|   |       | indicates the reason why the transmit abort takes places, $\rho^{\circ}$               |   |
|   |       | NOTE: The I2C flushes/resets/empties the TX FIFO whenever this bit is                  |   |
|   |       | set. The TX FIFO remains in this flushed state until the register                      |   |
|   |       | I2CCTXABT is read. Once this read is performed, the TX FIFO is then                    |   |
|   |       | ready to accept more data bytes from the APB interface.                                |   |
| 5 | RDREQ | This bit is set to 1 when I2C is acting as a slave and another I2C master              | R |
| - |       | is attempting to read data from I2C. The I2C holds the I2C bus in a wait               |   |
|   |       | state (SCL=0) until this interrupt is serviced, which means that the slave             |   |
|   |       | has been addressed by a remote master that is asking for data to be                    |   |
|   |       | transferred. The processor must respond to this interrupt and then write               |   |
|   | 0     | the requested data to the I2CDC register. This bit is set to 0 just after the          |   |
|   | 200   | processor reads the I2CCRREQregister.                                                  |   |
| 4 | TXEMP | This bit is set to 1 when the transmit buffer is at or below the threshold             | R |
| - |       | value set in the I2C_TXTL register. It is automatically cleared by                     |   |
|   |       | hardware when the buffer level goes above the threshold.                               |   |
|   |       | nardware when the buller level goes above the threshold.                               |   |
|   |       | When the I2CENB bit 0 is 0, the TX FIFO is flushed and held in reset.                  |   |
|   |       | There the TX FIFO looks like it has no data within it, so this bit is set to 1,        |   |
|   |       |                                                                                        |   |
|   |       | provided there is activity in the master or slave state machines. When                 |   |
| 0 | туог  | there is no longer activity, then with I2CENB = 0, this bit is set to 0.               |   |
| 3 | TXOF  | Set during transmit if the transmit buffer is filled to                                | R |
|   |       | I2CTX_BUFFER_DEPTH and the processor attempts to issue another                         |   |
|   |       | I2C command by writing to the I2CDC register. When the module is                       |   |
|   |       | disabled, this bit keeps its level until the master or slave state machines            |   |
|   |       | go into idle, and when i2c_en goes to 0, this interrupt is cleared.                    |   |
| 2 | RXFL  | Set when the receive buffer reaches or goes above the I2C_RXTL                         | R |
|   |       | threshold in the I2C_RXTL register. It is automatically cleared by                     |   |

| 君止      |
|---------|
| Ingenic |

|                                       |      | hardware when buffer level goes below the threshold.                          |   |
|---------------------------------------|------|-------------------------------------------------------------------------------|---|
|                                       |      | It is automatically cleared by hardware when buffer level goes below the      |   |
|                                       |      | threshold. If the module is disabled (I2CENB[0]=0), the RX FIFO is            |   |
|                                       |      | flushed and held in reset; therefore the RX FIFO is not full. So this bit is  |   |
|                                       |      | cleared once the I2CENB bit 0 is programmed with a 0, regardless of the       |   |
|                                       |      | activity that continues.                                                      |   |
| 1                                     | RXOF | Set if the receive buffer is completely filled to 2 and an additional byte is | R |
|                                       |      | received from an external I2C device. The I2C acknowledges this, but          |   |
|                                       |      | any data bytes received after the FIFO is full are lost. If the module is     |   |
|                                       |      | disabled (I2CENB[0]=0), this bit keeps its level until the master or slave    |   |
|                                       |      | state machines go into idle, and when i2c_en goes to 0, this interrupt is     |   |
|                                       |      | cleared.                                                                      |   |
| 0                                     | RXUF | Set if the processor attempts to read the receive buffer when it is empty     | R |
|                                       |      | by reading from the I2CDC register.                                           |   |
|                                       |      | If the module is disabled (I2CENB[0]=0), this bit keeps its level until the   |   |
|                                       |      | master or slave state machines go into idle, and when i2c engoes to 0,        |   |
|                                       |      | this interrupt is cleared. $\sqrt{\sqrt{2}}$                                  |   |
|                                       |      | *ternal                                                                       |   |
| , , , , , , , , , , , , , , , , , , , |      | M                                                                             |   |
|                                       |      | vi                                                                            |   |

#### 2.2.2.10 I2CINTM

These bits mask their corresponding interrupt status bits. They are active low; a value of 0 prevents a bit from generating an interrupt.

**I2CINTM** 

Bit

RST

| BASE + 0x30 |     |      |    |      |       |       |       |       |        |        | x30    |       |       |       |       |
|-------------|-----|------|----|------|-------|-------|-------|-------|--------|--------|--------|-------|-------|-------|-------|
| 15          | 14  | 13   | 12 | 11   | 10    | 9     | 8     | 7     | 6      | 5      | 4      | 3     | 2     | 1     | 0     |
| R           | ese | erve | d  | MIGC | MISTT | MISTP | MIACT | MRXDN | MTXABT | MRDREQ | MTXEMP | MTXOF | MRXFL | MRXOF | MRXUF |
| 0           | 0   | 0    | 0  | 1    | 0     | 0     | 0     | 1     | 1      | 1      | 1      | 1     | 1     | 1     | 1     |

| Bits | Name    |
|------|---------|
| 5:12 | Reserve |

| Bits  | Name     | Description                                                      | R/W |
|-------|----------|------------------------------------------------------------------|-----|
| 15:12 | Reserved | Writing has no effect, read as zero.                             | R   |
| 11    | MIGC     | These bits mask their corresponding interrupt status bits in the | RW  |
| 10    | MISTT    | I2CINTST register.                                               | RW  |
| 9     | MISTP    |                                                                  | RW  |
| 8     | MIACT    |                                                                  | RW  |
| 7     | MRXDN    |                                                                  | RW  |
| 6     | MTXABT   |                                                                  | RW  |
| 5     | MRDREQ   |                                                                  | RW  |
| 4     | MTXEMP   |                                                                  | RW  |
| 3     | MTXOF    |                                                                  | RW  |

34

JZ4770 Mobile Application Processor Peripherals Programming Manual



#### 2.2.2.11 I2CRXTL

| I2CRXTL |    |    |    |    |    |     |      |   |   |   |   |   | BA | <b>ASE + 0x38</b><br>3 2 1 0 |    |   |  |  |
|---------|----|----|----|----|----|-----|------|---|---|---|---|---|----|------------------------------|----|---|--|--|
| Bit     | 15 | 14 | 13 | 12 | 11 | 10  | 9    | 8 | 7 | 6 | 5 | 4 | 3  | 2                            | 1  | 0 |  |  |
|         |    |    |    |    |    |     |      |   |   |   |   |   |    |                              |    |   |  |  |
|         |    |    |    |    | R  | ese | erve | d |   |   |   |   |    | RX                           | TL |   |  |  |
|         |    |    |    |    |    |     |      |   |   |   |   |   |    |                              |    |   |  |  |
| RST     | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0 | 0 | 0 | 0 | 0 | 1  | 1                            | 1  | 1 |  |  |

| Bits             | Name      | Description                                                            | R/W    |
|------------------|-----------|------------------------------------------------------------------------|--------|
| 15:5             | Reserved  | Writing has no effect, read as zero.                                   | R      |
| 3:0              | RXTL      | Receive FIFO Threshold Level.                                          | RW     |
|                  |           | Controls the level of entries that triggers the RxFIFO full interrupt. |        |
|                  |           | A value of n sets the threshold for (n+1) entries                      |        |
| <b>2.2.2.1</b> 2 | 2 I2CTXTL | om interne                                                             |        |
| 120              | туті      | b. Comparent page                                                      | . 0×20 |

#### 2.2.2.12 I2CTXTL

|     | I2CTXTL | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |    |    |    |    |    |     |      |   |   |   |   | E | BAS | SE - | ⊦ <b>0</b> > | 3 <b>C</b> |
|-----|---------|----------------------------------------|----|----|----|----|----|-----|------|---|---|---|---|---|-----|------|--------------|------------|
| Bit |         |                                        | 15 | 14 | 13 | 12 | 11 | 10  | 9    | 8 | 7 | 6 | 5 | 4 | 3   | 2    | 1            | 0          |
|     |         |                                        |    |    |    |    | R  | ese | erve | d |   |   |   |   |     | тх   | TL           |            |
| RST |         |                                        | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0 | 0 | 0 | 0 | 0 | 1   | 1    | 1            | 1          |
|     | 10100   |                                        |    |    |    |    |    |     |      |   |   |   |   |   |     |      |              |            |

| Bits | Name     | Description                                                            | R/W |
|------|----------|------------------------------------------------------------------------|-----|
| 15:5 | Reserved | Writing has no effect, read as zero.                                   | R   |
| 3:0  | TXTL     | Transmit FIFO Threshold Level.                                         | RW  |
|      |          | Controls the level of entries that trigger the TxFIFO empty interrupt. |     |
|      |          | A value of n sets the threshold for n entries.                         |     |

#### 2.2.2.13 I2CCINT

|     | I2CCINT |    |    |    |    |    |    |    |      |    |   |   |   | BA | SE · | + 0> | <b>x40</b> |
|-----|---------|----|----|----|----|----|----|----|------|----|---|---|---|----|------|------|------------|
| Bit |         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7  | 6 | 5 | 4 | 3  | 2    | 1    | 0          |
|     |         |    |    |    |    |    |    | Re | serv | ed |   |   |   |    |      |      | CINT       |
| RST |         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0 | 0 | 0 | 0  | 0    | 0    | 0          |
|     |         |    |    |    |    |    |    |    |      |    |   |   |   |    |      |      |            |



| Bits | Name     | Description                                                                    | R/W |
|------|----------|--------------------------------------------------------------------------------|-----|
| 15:1 | Reserved | Writing has no effect, read as zero.                                           | R   |
| 0    | CINT     | Read this register to clear the combined interrupt, all individual interrupts, | R   |
|      |          | and the I2CABTSRC register. This bit does not clear hardware clearable         |     |
|      |          | interrupts but software clearable interrupts. Refer to Bit 9 of the            |     |
|      |          | I2CABTSRC register for an exception to clearing I2CABTSRC.                     |     |

#### 2.2.2.14 I2CCRXUF

| I2CCRXUF | BASE + 0x                           | (44   |
|----------|-------------------------------------|-------|
| Bit      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0     |
|          | Reserved                            | CRXUF |
| RST      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0     | 0     |

| Bits | Name     | Description                                                                      | R/W |
|------|----------|----------------------------------------------------------------------------------|-----|
| 15:1 | Reserved | Writing has no effect, read as zero.                                             | R   |
| 0    | CRXUF    | Read this register to clear the RXUF interrupt (bit 0) of the I2CINTST register. | R   |

## 2.2.2.15 I2CCRXOF

36

|         |           | register. |      |     | 1  |       |      |    |    |     |      |    |   |   |   |    |      |      |            |
|---------|-----------|-----------|------|-----|----|-------|------|----|----|-----|------|----|---|---|---|----|------|------|------------|
| 2.2.2.1 | 5 I2CCRXC | )F        | 126. | com | Y  |       |      |    |    |     |      |    |   |   |   |    |      |      |            |
| 1200    | CRXOF     | .fter     |      |     |    |       |      |    |    |     |      |    |   |   |   | BA | SE · | + 0> | <b>(48</b> |
| Bit     |           |           |      |     | 15 | 14 13 | 3 12 | 11 | 10 | 9   | 8    | 7  | 6 | 5 | 4 | 3  | 2    | 1    | 0          |
|         |           |           |      |     |    |       |      |    | I  | Res | serv | ed |   |   |   |    |      |      | CRXOF      |
| RST     |           |           |      |     | 0  | 0 0   | 0    | 0  | 0  | 0   | 0    | 0  | 0 | 0 | 0 | 0  | 0    | 0    | 0          |

| Bits | Name     | Description                                                                      | R/W |
|------|----------|----------------------------------------------------------------------------------|-----|
| 15:1 | Reserved | Writing has no effect, read as zero.                                             | R   |
| 0    | CRXOF    | Read this register to clear the RXOF interrupt (bit 1) of the I2CINTST register. | R   |

#### 2.2.2.16 I2CCTXOF

# I2CCTXOF ISUBJE <th colspan="12""ISUB<

| Bits | Name     | Description                                                                         | R/W |
|------|----------|-------------------------------------------------------------------------------------|-----|
| 15:1 | Reserved | Writing has no effect, read as zero.                                                | R   |
| 0    | CTXOF    | Read this register to clear the TX_OVER interrupt (bit 3) of the I2CINTST register. | R   |

#### 2.2.2.17 I2CCRXREQ

#### I2CCRXREQ

| В | it. |
|---|-----|
| _ |     |

|    |    |    |    |    | 1  |    | U.  | 38  | 6 | ( | 01 | ر<br>BA | SE | + 0 | x50     |
|----|----|----|----|----|----|----|-----|-----|---|---|----|---------|----|-----|---------|
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7   | 6 | 5 | 4  | 3       | 2  | 1   | 0       |
|    |    |    |    |    |    | Re | ser | ved |   |   |    |         |    |     | CLRDREQ |
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0 | 0 | 0  | 0       | 0  | 0   | 0       |

RST

| Bits | Name     | Store Description                                              | R/W |
|------|----------|----------------------------------------------------------------|-----|
| 15:1 | Reserved | Writing has no effect, read as zero.                           | R   |
| 0    | CLRDREQ  | Read this register to clear the RDREQ interrupt (bit 5) of the | R   |
| 1    | OW       | I2CINTST register.                                             |     |

#### 2.2.2.18 I2CCTXABT

| I2CCTXABT |    |    |    |    |    |    |    |      |     |   |   |   | BA | SE | + 0) | x54    |
|-----------|----|----|----|----|----|----|----|------|-----|---|---|---|----|----|------|--------|
| Bit       | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7   | 6 | 5 | 4 | 3  | 2  | 1    | 0      |
|           |    |    |    |    |    |    | Re | ser\ | /ed |   |   |   |    |    |      | CTXABT |
| RST       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   | 0 | 0 | 0 | 0  | 0  | 0    | 0      |

| Bits Na  | ame         | Description                       | R/W |
|----------|-------------|-----------------------------------|-----|
| 15:1 Res | erved Writi | ting has no effect, read as zero. | R   |



| 0 | CTXABT | Read this register to clear the TX_ABRT interrupt (bit 6) of the      | R |
|---|--------|-----------------------------------------------------------------------|---|
|   |        | I2CINTST register, and the I2CABTSRC register.                        |   |
|   |        | This also releases the TX FIFO from the flushed/reset state, allowing |   |
|   |        | more writes to the TX FIFO.                                           |   |
|   |        | Refer to Bit 9 of the I2CABTSRC register for an exception to clearing |   |
|   |        | I2CABTSRC.                                                            |   |

#### 2.2.2.19 I2CCRXDN

| I2CCRXDN | BASE + 0x58                           |
|----------|---------------------------------------|
| Bit      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|          | Reserved                              |
| RST      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0     |

| Bits | Name      | Description                                                      |      | R/W |
|------|-----------|------------------------------------------------------------------|------|-----|
| 15:1 | Reserved  | Writing has no effect, read as zero.                             |      | R   |
| 0    | CRXDN     | Read this register to clear the RX_DONE interrupt (bit 7) of the |      | R   |
|      |           | I2CINTST register.                                               |      |     |
|      | D I2CCACT | · ffel@126. com                                                  | DAGE |     |

#### 2.2.2.20 I2CCACT

| I2CCACT | eiffer |    |      |    |    |    |    |    |     |     |   |   | I | BAS | SE - | ⊦ 0> | <b>(5C</b> |
|---------|--------|----|------|----|----|----|----|----|-----|-----|---|---|---|-----|------|------|------------|
| Bit     |        | 15 | 5 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7   | 6 | 5 | 4 | 3   | 2    | 1    | 0          |
|         |        |    |      |    |    |    |    | Re | ser | /ed |   |   |   |     |      |      | CACT       |
| RST     |        | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0 | 0 | 0 | 0   | 0    | 0    | 0          |

| Bits | Name     | Description                                                                   | R/W |
|------|----------|-------------------------------------------------------------------------------|-----|
| 15:1 | Reserved | Writing has no effect, read as zero.                                          | R   |
| 0    | CACT     | Reading this register clears the ACTIVITY interrupt if the I2C is not active  | R   |
|      |          | anymore. If the I2C module is still active on the bus, the ACTIVITY           |     |
|      |          | interrupt bit continues to be set. It is automatically cleared by hardware if |     |
|      |          | the module is disabled and if there is no further activity on the bus. The    |     |
|      |          | value read from this register to get status of the ACTIVITY interrupt (bit 8) |     |
|      |          | of the I2CINTST register.                                                     |     |

#### 2.2.2.21 I2CCSTP

| I2CCSTP | BASE + 0x60                           |
|---------|---------------------------------------|
| Bit     | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|         | Reserved                              |
| RST     | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0     |

| Bits | Name     | Description                                                                      | R/W |
|------|----------|----------------------------------------------------------------------------------|-----|
| 15:1 | Reserved | Writing has no effect, read as zero.                                             | R   |
| 0    | CSTP     | Read this register to clear the STOP interrupt (bit 9) of the I2CINTST register. | R   |

#### 2.2.2.22 I2CCSTT

#### **I2CCSTT**

Bit

|         |      |    |    |    |     | 38  | 6 | ( | 27 | 7) | Z  |     |      |
|---------|------|----|----|----|-----|-----|---|---|----|----|----|-----|------|
|         |      |    | 1  |    | V   | ~   |   |   |    | BA | SE | + 0 | x64  |
| 15 14 1 | 3 12 | 11 | 10 | 9  | 8   | 7   | 6 | 5 | 4  | 3  | 2  | 1   | 0    |
|         |      |    |    | Re | ser | ved |   |   |    |    |    |     | CSTT |

0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### RST

| Bits | Name     | Description                                                                        | R/W |
|------|----------|------------------------------------------------------------------------------------|-----|
| 15:1 | Reserved | Writing has no effect, read as zero.                                               | R   |
| 0    | CSTT. C  | Read this register to clear the START interrupt (bit 10) of the I2CINTST register. | R   |

#### 2.2.2.23 I2CCGC

| 120 | CCGC |  |  |    |    |    |    |    |    |    |     |     |   |   |   | BA | SE | + 0) | <b>68</b> |
|-----|------|--|--|----|----|----|----|----|----|----|-----|-----|---|---|---|----|----|------|-----------|
| Bit |      |  |  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7   | 6 | 5 | 4 | 3  | 2  | 1    | 0         |
|     |      |  |  |    |    |    |    |    |    | Re | ser | /ed |   |   |   |    |    |      | CGC       |
| RST |      |  |  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0 | 0 | 0 | 0  | 0  | 0    | 0         |

#### RSI

| Bits | Name     | Description                                                    | R/W |
|------|----------|----------------------------------------------------------------|-----|
| 15:1 | Reserved | Writing has no effect, read as zero.                           | R   |
| 0    | CGC      | Read this register to clear the GEN_CALL interrupt (bit 11) of | R   |
|      |          | I2CINTST register.                                             |     |



#### 2.2.2.24 I2CENB

| I2CENB BASE + 0x6 |                                       |  |  |  |  |  |  |  |  |
|-------------------|---------------------------------------|--|--|--|--|--|--|--|--|
| Bit               | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
|                   | Reserved                              |  |  |  |  |  |  |  |  |
| RST               | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |  |  |  |  |  |  |  |  |

| Bits | Name     | Description                                                                              | R/W |  |  |  |  |  |  |
|------|----------|------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| 15:1 | Reserved | Writing has no effect, read as zero.                                                     | R   |  |  |  |  |  |  |
| 0    | I2CENB   | Controls whether the I2C is enabled.                                                     | R   |  |  |  |  |  |  |
|      |          | 0: Disables I2C (TX and RX FIFOs are held in an erased state)                            |     |  |  |  |  |  |  |
|      |          | 1: Enables I2C                                                                           |     |  |  |  |  |  |  |
|      |          | Software can disable I2C while it is active. However, it is important that               |     |  |  |  |  |  |  |
|      |          | care be taken to ensure that I2C is disabled properly.                                   |     |  |  |  |  |  |  |
|      |          | When I2C is disabled, the following occurs: $\sqrt{\sqrt{5}}$                            |     |  |  |  |  |  |  |
|      |          | <ul> <li>The TX FIFO and RX FIFO get flushed.</li> </ul>                                 |     |  |  |  |  |  |  |
|      |          | <ul> <li>Status bits in the I2CINTST register are still active until I2C goes</li> </ul> |     |  |  |  |  |  |  |
|      |          | into IDLE state.                                                                         |     |  |  |  |  |  |  |
|      |          | If the module is transmitting, it stops as well as deletes the contents of               |     |  |  |  |  |  |  |
|      |          | he transmit buffer after the current transfer is complete. If the module is              |     |  |  |  |  |  |  |
|      |          | receiving, the I2C stops the current transfer at the end of the current byte             |     |  |  |  |  |  |  |
|      |          | nd does not acknowledge the transfer.                                                    |     |  |  |  |  |  |  |

2.2.2.25 I2CST This is a read-only register used to indicate the current transfer status and FIFO status. The status register may be read at any time. None of the bits in this register request an interrupt.

When the I2C is disabled by writing 0 in bit 0 of the I2CENB register:

- Bits 1 and 2 are set to 1
- Bits 3 and 4 are set to 0 \_

When the master or slave state machine goes to idle and ic\_en=0:

Bits 5 and 6 are set to 0 \_

| I2CST | BASE + 0x70                                                   |
|-------|---------------------------------------------------------------|
| Bit   | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                         |
|       | Reserved RFF Reserved ACT |
| RST   | 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0                                 |

40

JZ4770 Mobile Application Processor Peripherals Programming Manual



| Bits | Name     | Description                                                                     | R/W |
|------|----------|---------------------------------------------------------------------------------|-----|
| 15:7 | Reserved | Writing has no effect, read as zero.                                            | R   |
| 6    | SLVACT   | Slave FSM Activity Status.                                                      | R   |
|      |          | 0: Slave FSM is in IDLE state                                                   |     |
|      |          | 1: Slave FSM is not in IDLE state                                               |     |
| 5    | MSTACT   | Master FSM Activity Status.                                                     | R   |
|      |          | 0: Master FSM is in IDLE state                                                  |     |
|      |          | 1: Master FSM is not in IDLE state                                              |     |
| 4    | RFF      | Receive FIFO Completely Full. When the receive FIFO is completely full,         | R   |
|      |          | this bit is set. When the receive FIFO contains one or more empty               |     |
|      |          | location, this bit is cleared.                                                  |     |
|      |          | 0: Receive FIFO is not full                                                     |     |
|      |          | 1: Receive FIFO is full                                                         |     |
| 3    | RFNE     | Receive FIFO Not Empty. This bit is set when the receive FIFO contains          | R   |
|      |          | one or more entries; it is cleared when the receive FIFO is empty.              |     |
|      |          | 0: Receive FIFO is empty                                                        |     |
|      |          | 1: Receive FIFO is not empty                                                    |     |
| 2    | TFE      | Transmit FIFO Completely Empty. When the transmit FIFO is completely            | R   |
|      |          | empty, this bit is set. When it contains one or more valid entries, this bit is |     |
|      |          | cleared. This bit field does not request an interrupt.                          |     |
|      |          | 0: Transmit FIFO is not empty $\sqrt{5}$                                        |     |
|      |          | 1: Transmit FIFO is empty                                                       |     |
| 1    | TFNF     | Transmit FIFO Not Full. Set when the transmit FIFO contains one or              | R   |
|      |          | more empty locations, and is cleared when the FIFO is full.                     |     |
|      |          | 0: Transmit FIFO is full                                                        |     |
|      |          | 1: Transmit FIFO is not full                                                    |     |
| 0    | ACT 🤇 🤇  | I2C Activity Status.                                                            | R   |
| 1    | 018-     | The OR of SLVACT and MSTACT bits.                                               |     |

#### 2.2.2.26 I2CABTSRC

This register has 16 bits that indicate the source of the TX\_ABRT bit. Except for Bit 9, this register is cleared whenever the I2CCTXABT register or the I2CCINT register is read. To clear Bit 9, the source of the SBYTE\_NORSTRT must be fixed first; RESTART must be enabled (I2CCON[5]=1), the SPECIAL bit must be cleared (I2CTAR[11]), or the GC\_OR\_START bit must be cleared (I2CTAR[10]). Once the source of the SBYTE\_NORSTRT is fixed, then this bit can be cleared in the same manner as other bits in this register. If the source of the SBYTE\_NORSTRT is not fixed before attempting to clear this bit, Bit 9 clears for one cycle and is then re-asserted.



| I2CABTSRC BASE + 0x80 |            |             |                 |          |                 |                     |                      |                 |              |                |                 |              |                    |                    |                    |                    |
|-----------------------|------------|-------------|-----------------|----------|-----------------|---------------------|----------------------|-----------------|--------------|----------------|-----------------|--------------|--------------------|--------------------|--------------------|--------------------|
| Bit                   | 15         | 14          | 13              | 12       | 11              | 10                  | 9                    | 8               | 7            | 6              | 5               | 4            | 3                  | 2                  | 1                  | 0                  |
|                       | SLVRD INTX | SLV_ARBLOST | SLVFLUSH_TXFIFO | ARB_LOST | ABRT_MASTER_DIS | ABRT_10B_RD_NORSTRT | <b>SBYTE_NORSTRT</b> | ABRT_HS_NORSTRT | SBYTE_ACKDET | ABRT_HS_ACKDET | ABRT_GCALL_READ | ABRT_GCALL_N | ABRT_TXDATA_N OACK | ABRT_10ADDR2_NOACK | ABRT_10ADDR1_N0ACK | ABRT_7B_ADDR_NOACK |
| RST                   | 0          | 0           | 0               | 0        | 0               | 0                   | 0                    | 0               | 0            | 0              | 0               | 0            | 0                  | 0                  | 0                  | 0                  |

RST

| Bits   | Name       | Description                                                           | R/W |
|--------|------------|-----------------------------------------------------------------------|-----|
| 15     | SLVRD_INTX | 1: When the processor side responds to a slave mode request for       | R   |
|        |            | data to be transmitted to a remote master and user writes a 1 in      |     |
|        |            | CMD (bit 8) of I2CDC register.                                        |     |
| 14     | SLV_ARBLOS | 1: Slave lost the bus while transmitting data to a remote master.     | R   |
|        | Т          | I2CABTSRC[12] is set at the same time. NOTE: Even though              |     |
|        |            | the slave never "owns" the bus, something could go wrong on           |     |
|        |            | the bus. This is a fail safe check. For instance, during a data       |     |
|        |            | transmission at the low-to-high transition of SCL, if what is on      |     |
|        |            | the data bus is not what is supposed to be transmitted, then I2C      |     |
|        |            | no longer own the bus.                                                |     |
|        |            | Reset value: 0x0.                                                     |     |
| 13     | SLVFLUSH_T | 1: Slave has received a read command and some data exists in the      | R   |
|        | XFIFO C    | TX FIFO so the slave issues a TX_ABRT interrupt to flush old          |     |
|        | ng         | data in TX FIFO.                                                      |     |
| $\sum$ |            | Reset value: 0x0.                                                     |     |
| 12     | ARB_LOST   | 1: Master has lost arbitration, or if I2CABTSRC[14] is also set, then | R   |
|        |            | the slave transmitter has lost arbitration.                           |     |
|        |            | <b>NOTE:</b> I2C can be both master and slave at the same time.       |     |
|        |            | Reset value: 0x0.                                                     |     |
| 11     | ABRT_MASTE | 1: User tries to initiate a Master operation with the Master mode     | R   |
|        | R_DIS      | disabled.                                                             |     |
|        |            | Reset value: 0x0.                                                     |     |
| 10     | ABRT_10B_R | 1: The restart is disabled (I2CRESTART_EN bit (I2CCON[5]) = 0)        | R   |
|        | D_NORSTRT  | and the master sends a read command in 10-bit addressing              |     |
|        |            | mode.                                                                 |     |
|        |            | Reset value: 0x0.                                                     |     |
| 9      | SBYTE_NOR  | To clear Bit 9, the source of the SBYTE_NORSTRT must be fixed         | R   |
|        | STRT       | first; restart must be enabled (I2CCON[5]=1), the SPECIAL bit must    |     |
|        |            | be cleared (I2CTAR[11]), or the GC_OR_START bit must be               |     |

42

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|   | •                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
|---|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|   |                        | cleared (I2CTAR[10]). Once the source of the SBYTE_NORSTRT<br>is fixed, then this bit can be cleared in the same manner as other<br>bits in this register. If the source of the SBYTE_NORSTRT is not<br>fixed before attempting to clear this bit, bit 9 clears for one cycle<br>and then gets re-asserted. 1: The restart is disabled<br>(I2CRESTART_EN bit (I2CCON[5]) = 0) and the user is trying to<br>send a START Byte.<br>Reset value: 0x0. |   |
| 8 | ABRT_HS_NO<br>RSTRT    | 1: The restart is disabled (I2CRESTART_EN bit (I2CCON[5]) = 0)<br>and the user is trying to use the master to transfer data in High<br>Speed mode.<br>Reset value: 0x0.                                                                                                                                                                                                                                                                            | R |
| 7 | SBYTE_ACKD<br>ET       | <ol> <li>Master has sent a START Byte and the START Byte was<br/>acknowledged (wrong behavior).</li> <li>Reset value: 0x0.</li> </ol>                                                                                                                                                                                                                                                                                                              | R |
| 6 | ABRT_HS_AC<br>KDET     | 1: Master is in High Speed mode and the High Speed Master code<br>was acknowledged (wrong behavior).<br>Reset value: 0x0.                                                                                                                                                                                                                                                                                                                          | R |
| 5 | ABRT_GCALL<br>_READ    | 1: I2C in master mode sent a General Call but the user<br>programmed the byte following the General Call to be a read from<br>the bus (I2CDC[9] is set to 1).<br>Reset value: 0x0.                                                                                                                                                                                                                                                                 | R |
| 4 | ABRT_GCALL<br>_NOACK   | 1: I2C in master mode sent a General Call and no slave on the bus acknowledged the General Call.<br>Reset value: 0x0.                                                                                                                                                                                                                                                                                                                              | R |
| 3 | ABRT_TXDAT<br>A_NOACK  | <ul> <li>1: This is a master-mode only bit. Master has received an<br/>acknowledgement for the address, but when it sent data byte(s)<br/>following the address, it did not receive an acknowledgement<br/>from the remote slave(s).</li> <li>Reset value: 0x0.</li> </ul>                                                                                                                                                                         | R |
| 2 | ABRT_10ADD<br>R2_NOACK | 1: Master is in 10-bit address mode and the second address byte of<br>the 10-bit address was not acknowledged by any slave.<br>Reset value: 0x0.                                                                                                                                                                                                                                                                                                   | R |
| 1 | ABRT_10ADD<br>R1_NOACK | 1: Master is in 10-bit address mode and the first 10-bit address byte was not acknowledged by any slave.<br>Reset value: 0x0.                                                                                                                                                                                                                                                                                                                      | R |
| 0 | ABRT_7B_AD<br>DR_NOACK | <ol> <li>Master is in 7-bit addressing mode and the address sent was not<br/>acknowledged by any slave.</li> <li>Reset value: 0x0.</li> </ol>                                                                                                                                                                                                                                                                                                      | R |
|   |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |



#### 2.2.2.27 **I2CDMACR**

The register is used to enable the DMA Controller interface operation. There is a separate bit for transmit and receive. This can be programmed regardless of the state of i2c enable.

| I2CDMACR | I2CDMACR BASE + 0 |  |  |  |          |    |    |    |    |    |   | + 0> | <b>(88</b> |   |   |   |      |      |   |   |
|----------|-------------------|--|--|--|----------|----|----|----|----|----|---|------|------------|---|---|---|------|------|---|---|
| Bit      |                   |  |  |  | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7          | 6 | 5 | 4 | 3    | 2    | 1 | 0 |
|          |                   |  |  |  | Reserved |    |    |    |    |    |   |      |            |   |   |   | TDEN | RDEN |   |   |
| RST      |                   |  |  |  | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0    | 0          | 0 | 0 | 0 | 0    | 0    | 0 | 0 |

| Bits | Name     | Description                                         | R/W |
|------|----------|-----------------------------------------------------|-----|
| 15:2 | Reserved | Writing has no effect, read as zero.                | R   |
| 1    | TDEN     | Transmit DMA Enable.                                | R/W |
|      |          | This bit enables/disables the transmit DMA channel. |     |
|      |          | 0: Transmit DMA disabled                            |     |
|      |          | 1: Transmit DMA enabled                             |     |
| 0    | RDEN     | Receive DMA Enable.                                 | R/W |
|      |          | This bit enables/disables the receive DMA channel.  |     |
|      |          | 0: Receive DMA disabled                             |     |
|      |          | 1: Receive DMA enabled                              |     |

## 2.2.2.28

I2CDMATDLR 0126. The register is used to config dma transmit data level.

| I2CDMACR | BASE + 0x8c                           |
|----------|---------------------------------------|
| Bit      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|          | Reserved TDLR                         |
| RST      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0   |

Bits Name R/W Description 15:5 Reserved Writing has no effect, read as zero. R 4:0 TDLR DMA Transmit Data Level. R/W This bit field controls the level at which a DMA request is made by the transmit logic. The dma\_tx\_req signal is generated when the number of valid data entries in the transmit FIFO is equal to or below this field value.

JZ4770 Mobile Application Processor Peripherals Programming Manual



#### 2.2.2.29 **I2CDMARDLR**

The register is used to config dma receive data level.

#### 

| 12  | I2CDMACR BASE + 0x9 |    |          |    |    |    |    |   |   |   | <b>(90</b> |      |   |   |   |   |   |
|-----|---------------------|----|----------|----|----|----|----|---|---|---|------------|------|---|---|---|---|---|
| Bit |                     | 15 | 14       | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5    | 4 | 3 | 2 | 1 | 0 |
|     |                     |    | Reserved |    |    |    |    |   |   |   |            | RDLR |   |   |   |   |   |
| RST |                     | 0  | 0        | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0          | 0    | 0 | 0 | 0 | 0 | 0 |

| Bits    | Name     | Description                                                                                                                                                                                                                                                | R/W |  |  |  |  |  |
|---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|
| 15:5    | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                       | R   |  |  |  |  |  |
| 4:0     | RDLR     | <b>MA Receive Data Level</b> .<br>Is bit field controls the level at which a DMA request is made by the<br>ceive logic. The dma_rx_req is generated when the number of valid<br>ta entries in the receive FIFO is equal to or more than this field value + |     |  |  |  |  |  |
| 2.2.2.3 | 0 I2CS   | DASU ternal used                                                                                                                                                                                                                                           |     |  |  |  |  |  |

#### 2.2.2.30 **I2CSDASU**

This register controls the amount of time delay (in terms of number of i2c clk clock periods) introduced in the rising edge of SCL, relative to SDA changing, when I2C services a read request in a slave-transmitter operation. The relevant I2C requirement is tSU:DAT (NOTE 2) as detailed in the I2C Bus Specification.

NOTE: The length of setup time is calculated using [(I2CSDASU - 1) \* (ic\_clk\_period)], so if the user requires 10 ic clk periods of setup time, they should program a value of 11.

A Fast-mode I2C-bus device can be used in a Standard-mode I2C-bus system, but the requirement  $t_{SU:DAT} >= 250$  ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line  $t_{r max} + t_{SU;DAT} = 1000 + 250 = 1250$  ns (according to the Standard-mode I2C-bus specification) before the SCL line is released. (Refer to ' Philips Semiconductor, THE PC-BUS SPECIFICATION, Version 2.1. Jan, 2000')

| I2CSDASU | BASE - |    |    |     |      |    |   |   |   |   | + 0> | x94 |     |   |   |   |
|----------|--------|----|----|-----|------|----|---|---|---|---|------|-----|-----|---|---|---|
| Bit      | 15     | 14 | 13 | 12  | 11   | 10 | 9 | 8 | 7 | 6 | 5    | 4   | 3   | 2 | 1 | 0 |
|          |        |    | R  | ese | erve | d  |   |   |   |   |      | SDA | ASL | J |   |   |
| RST      | 0      | 0  | 0  | 0   | 0    | 0  | 0 | 0 | 0 | 1 | 1    | 0   | 0   | 1 | 0 | 0 |



| Bits | Name     | Description                                                             | R/W |
|------|----------|-------------------------------------------------------------------------|-----|
| 15:8 | Reserved | Writing has no effect, read as zero.                                    | R   |
| 7:0  | SDASU    | SDA Setup. It is recommended that if the required delay is 1000ns, then | R/W |
|      |          | for an i2c_clk frequency of 10 MHz, I2CSDASU should be programmed       |     |
|      |          | to a value of 11.                                                       |     |

#### 2.2.2.31 **I2CACKGC**

The register controls whether I2C responds with an ACK or NACK when it receives an I2C General Call address.



| Bits    | Name     | Description 1                                                            | R/W |
|---------|----------|--------------------------------------------------------------------------|-----|
| Bito    | Hame     |                                                                          | 1   |
| 15:1    | Reserved | Writing has no effect, read as zero                                      | R   |
| 0       | ACKGC    | ACK General Call. When set to 1, 12C responds with an ACK (by asserting  | R/W |
|         |          | ic_data_oe) when it receives a General Call. When set to 0, the I2C does |     |
|         |          | not generate General Call interrupts.                                    |     |
| 2.2.2.3 | 2 I2CE   | NBST                                                                     |     |

#### 2.2.2.32 **I2CENBST**

The register is used to report the I2C hardware status when the I2CENB register is set from 1 to 0; that is, when 12C is disabled.

If I2CENB has been set to 1, bits 2:1 are forced to 0, and bit 0 is forced to 1.

If I2CENB has been set to 0, bits 2:1 is only be valid as soon as bit 0 is read as '0'.

| I2CENBST |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Bit      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|          | Reserved SLVRDLST SLV |  |  |  |  |  |  |  |
| RST      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |

| Bits | Name     | Description                          | R/W |
|------|----------|--------------------------------------|-----|
| 15:3 | Reserved | Writing has no effect, read as zero. | R   |
|      |          |                                      |     |

46

JZ4770 Mobile Application Processor Peripherals Programming Manual



| 2 | SLVRDLST | Slave Received Data Lost. This bit indicates if a Slave-Receiver<br>operation has been aborted with at least one data byte received from<br>an I2C transfer due to the setting of I2CENB from 1 to 0.<br>When read as 1, I2C is deemed to have been actively engaged in an<br>aborted I2C transfer (with matching address) and the data phase of the<br>I2C transfer has been entered, even though a data byte has been<br>responded with a NACK. <b>NOTE:</b> If the remote I2C master terminates<br>the transfer with a STOP condition before the I2C has a chance to<br>NACK a transfer, and I2CENB has been set to 0, then this bit is also set<br>to 1. When read as 0, I2C is deemed to have been disabled without<br>being actively involved in the data phase of a Slave-Receiver transfer.<br><b>NOTE:</b> The CPU can safely read this bit when IC_EN (bit 0) is read as<br>0.<br>Reset value: 0x0.                                                                                                                                                                                                                                                                                     | R |
|---|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 1 | SLVDISB  | <ul> <li>Slave Disabled While Busy (Transmit, Receive). This bit indicates if a potential or active Slave operation has been aborted due to the setting of the I2CENB register from 1 to 0. This bit is set when the CPU writes a 0 to the I2CENB register while: (a) I2C is receiving the address byte of the Slave-Transmitter operation from a remote master;</li> <li>OR, (b) address and data bytes of the Slave-Receiver operation from a remote master.</li> <li>When read as 1, I2C is deemed to have forced a NACK during any part of an I2C transfer, irrespective of whether the I2C address matches the slave address set in I2C (I2CSAR register) OR if the transfer is completed before I2CENB is set to 0 but has not taken effect.</li> <li>NOTES:</li> <li>1 If the remote I2C master terminates the transfer with a STOP condition before the I2C has a chance to NACK a transfer, and I2CENB has been set to 0, then this bit will also be set to 1. When read as 0, I2C is deemed to have been disabled when there is master activity, or when the I2C bus is idle.</li> <li>2 The CPU can safely read this bit when IC_EN (bit 0) is read as 0. Reset value: 0x0.</li> </ul> | R |
| 0 | I2CEN    | <ul> <li>ic_en Status. This bit always reflects the value driven on the output port ic_en.</li> <li>When read as 1, I2C is deemed to be in an enabled state.</li> <li>When read as 0, I2C is deemed completely inactive.</li> <li><b>NOTE:</b> The CPU can safely read this bit anytime. When this bit is read as 0, the CPU can safely read SLVRDLST (bit 2) and SLVDISB (bit 1).</li> <li>Reset value: 0x0.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R |



#### 2.2.2.33 I2CSDAHD

This register controls the amount of delay (in terms of i2c\_clk cycles) that introduced in the falling edge of SCL, relative to SDA changing. It works when I2C services a read request in master-transmitter operation.

The length of hold time is calculated using:  $T_{delay} = (I2CSDAHD + 1) * (i2c_clk perild)$ .

| I2CSDAHD | BASE + 0xD0                           |
|----------|---------------------------------------|
| Bit      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|          | R HDENB                               |
| RST      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0     |

Bits Name Description R/W 15:9 Reserved Reserved. N/A 8 HDENB RW I2C Hold Enable. 0: The actual hold time is 1 \* (i2c\_clk period) 1: The actual hold time is (SDAHD +1)?(i2c\_clk period). 7:0 I2C Hold Time. SDAHD RW In terms of number of i2c\_clk clock periods

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



#### 2.3 **Operating Flow**

This section provides information on the following topics:

- "Slave Mode Operation"
- "Master Mode Operation"
- "Disabling I2C"
- **NOTE:** It is important to note that the I2C should only be set to operate as an I2C Master, or I2C Slave, but not both simultaneously. This is achieved by ensuring that bit 6 (I2CSLAVE DISABLE) and 0 (I2CMASTER MODE) of the I2CCON register are never set to 0 and 1, respectively.

#### 2.3.1 I2C Behavior

The I2C can be controlled via software to be either:

- An I2C master only, communicating with other I2C slaves.
- OR
- An I2C slave only, communicating with one more I2C masters.

sed only The master is responsible for generating the clock and controlling the transfer of data. The slave is responsible for either transmitting or receiving data to/from the master. The device that is receiving data, which can be either a master or a slave, sends the acknowledgement of data. As mentioned previously, the I2C protocol also allows multiple masters to reside on the I2C bus and uses an arbitration procedure to determine bus ownership

Each slave has a unique address that is determined by the system designer. When a master wants to communicate with a slave, the master transmits a START/RESTART condition that is then followed by the slave's address and a control bit (R/W) to determine if the master wants to transmit data or receive data from the slave. The slave then sends an acknowledgement (ACK) pulse after the address.

If the master (master-transmitter) is writing to the slave (slave-receiver), the receiver gets one byte of data. This transaction continues until the master terminates the transmission with a STOP condition. If the master is reading from a slave (master-receiver), the slave transmits (slave-transmitter) a byte of data to the master, and the master then acknowledges the transaction with the ACK pulse. This transaction continues until the master terminates the transmission by not acknowledging (NACK) the transaction after the last byte is received, and then the master issues a STOP condition or addresses another slave after issuing a RESTART condition.





#### 2.3.2 Master Mode Operation

This section includes the following topics:

- "Initial Configuration"
- "Dynamic I2CTAR or I2C10BITADDR\_MASTER Update"
- "Master Transmit and Master Receive"

### 2.3.2.1 Configuration

To use the I2C as a master perform the following steps:

- Disable the I2C by writing 0 to the I2CENB register. And wait for the I2CENBST.I2CEN = 0.
- 2 Write to the I2CCON register to set the speed mode supported (bits 2:1). Please note that the MATP (bit4) is NOT writable. The addressing mode is controlled by Register I2CTAR.
- Set the expected SCL frequency. I2CCON.SPD = 2'b01, only I2CSHCNT and I2CSLCNT are 3 are I ernal used only needed to be configured; I2CCON.SPD = 2'b10, only I2CFHCNT and I2CFLCNT are needed to be configured.

Supposed:

- T<sub>scl</sub> I2C SCL period :
- T<sub>i2c clk</sub> : I2C device clock period
- T<sub>min scl I</sub>: Protocol minimum SCL low time

T<sub>min scl h</sub>: Protocol minimum SCL high time

Then can get the equation:

 $T_{scl} = T_{i2c \ clk} * ((I2C*HCNT + 8) + (I2C*LCNT + 1))$ 

And the following conditions should be met:

(I2C\*HCNT + 8) \* T<sub>i2c</sub> clk > = T<sub>min scl h</sub>  $(I2C*LCNT + 1) * T_{i2c_{clk}} >= T_{min_{scl_{l}}}$ 12C\*HCNT>=6 12C\*LCNT >= 8

- Write to the I2CTAR register the address of the I2C device to be addressed. It also indicates 4 whether a General Call or a START BYTE command is going to be performed by I2C. The addressing mode that master starts, either 7-bit or 10-bit addressing, is controlled by the I2C10BITADDR\_MASTER bit field (bit 12).
- 5 Enable the I2C by writing a 1 into I2CENB register. And wait for the I2CENBST.I2CEN = 1.
- 6 Now write the transfer direction and data to be sent to the I2CDC register (This can be done by DMA). If the I2CDC register is written before the I2C is enabled, the data and commands are lost as the buffers are kept cleared when I2C is not enabled.
- NOTE: For multiple I2C transfers, perform additional writes to the TX FIFO such that the TX FIFO does not become empty during the I2C transaction. If the TX FIFO is completely emptied at any stage and I2CCON.STPHLD is 0, then further writes to the TX FIFO results in an independent I2C transaction.



#### 2.3.2.2 Dynamic I2CTAR or I2C10BITADDR\_MASTER Update

The I2C supports dynamic updating of the I2CTAR (bits 9:0) and I2C10BITADDR\_MASTER (bit 12) bit fields of the I2CTAR register. You can dynamically write to the I2CTAR register provided the following conditions are met:

1 I2C is not enabled (I2CENB=0);

OR

2 I2C is enabled (I2CENB=1);

AND I2C is NOT engaged in any Master (tx, rx) operation (I2CST[5]=0); AND I2C is enabled to operate in Master mode (I2CCON[0]=1); AND there are NO entries in the TX FIFO (I2CST[2]=0).

#### 2.3.2.3 Master Transmit and Master Receive

The I2C supports switching back and forth between reading and writing dynamically. To transmit data, write the data to be transferred to lower byte of the I2C Rx/Tx Data Buffer and Command Register (I2CDC). The *CMD* bit (I2CDC[8]) should be written to 0 for I2C write operations.

Subsequently, a read command may be issued by writing "don't cares" to the lower byte of the I2CDC register, and a 1 should be written to the *CMD* bit.

## 2.3.3 Slave Mode Operation

This section includes the following procedures:

- "Initial Configuration"
- "Slave-Transmitter Operation for a Single Byte"
- \"Slave-Receiver Operation for a Single Byte"
- "Slave-Transfer Operation For Bulk Transfers"

#### 2.3.3.1 Initial Configuration

To use the I2C as a slave, perform the following steps:

- 1 Disable the I2C by writing a '0' to bit 0 of the I2CENB register.
- 2 Write to the I2CSAR register (bits 9:0) to set the slave address. This is the address to which the I2C responds.
- 3 Write to the I2CCON register to specify which type of addressing is supported (7- or 10-bit by setting bit 3). Enable the I2C in slave-only mode by writing a '0' into bit 6 (I2CSLAVE\_DISABLE) and a '0' to bit 0 (MASTER\_MODE).

**NOTE:** Slaves and masters do not have to be programmed with the same type of addressing 7- or 10-bit address. For instance, a slave can be programmed with 7-bit addressing



and a master with 10-bit addressing, and vice versa.

- 4 Enable the I2C by writing a '1' in bit 0 of the I2CENB register.
  - **NOTE:** Depending on the reset values chosen, steps 2 and 3 may not be necessary because the reset values can be configured. For instance, if the device is only going to be a master, there would be no need to set the slave address because you can configure I2C to have the slave disabled after reset and to enable the master after reset. The values stored are static and do not need to be reprogrammed if the I2C is disabled.

#### 2.3.3.2 Slave-Transmitter Operation for a Single Byte

When another I2C master device on the bus addresses the I2C and requests data, the I2C acts as a slave-transmitter and the following steps occur:

- 1 The other I2C master device initiates an I2C transfer with an address that matches the slave address in the I2CSAR register of the I2C.
- 2 The I2C acknowledges the sent address and recognizes the direction of the transfer to indicate that it is acting as a slave-transmitter.
- 3 The I2C asserts the RDREQ interrupt (bit 5 of the I2CINTST register) and holds the SCL line low. It is in a wait state until software responds. If the RDREQ interrupt has been masked, due to I2CINTM[5] register (MRDREQ bit field) being set to 0, then it is recommended that a hardware and/or software timing routine be used to instruct the CPU to perform periodic reads of the I2CINTST register.
  - a Reads that indicate [2CINTST[5] (RDREQ bit field) being set to 1 must be treated as the equivalent of the RDREQ interrupt being asserted.
  - b Software must then act to satisfy the I2C transfer.
  - c The timing interval used should be in the order of 10 times the fastest SCL clock period
  - Whe I2C can handle. For example, for 400 kb/s, the timing interval is 25us.
  - **NOTE:** The value of 10 is recommended here because this is approximately the amount of time required for a single byte of data transferred on the I2C bus.
- 4 If there is any data remaining in the TX FIFO before receiving the read request, then the I2C asserts a TX\_ABRT interrupt (bit 6 of the I2CINTST register) to flush the old data from the TX FIFO.
  - **NOTE:** Because the I2C's TX FIFO is forced into a flushed/reset state whenever a TX\_ABRT event occurs, it is necessary for software to release the I2C from this state by reading the I2CCTXABT register before attempting to write into the TX FIFO. See register I2CINTST for more details. If the TX\_ABRT interrupt has been masked, due to of I2CINTM[6] register (MTX\_ABRT bit field) being set to 0, then it is recommended that re-using the timing routine (described in the previous step), or a similar one, be used to

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



read the I2CINTST register.

- a Reads that indicate bit 6 (TXABT) being set to 1 must be treated as the equivalent of the TX ABRT interrupt being asserted.
- b There is no further action required from software.
- c The timing interval used should be similar to that described in the previous step for the I2CINTST[5] register.
- 5 Software writes to the I2CDC register with the data to be written (by writing a '0' in bit 8).
- 6 Software must clear the RDREQ and TX ABRT interrupts (bits 5 and 6, respectively) of the I2CINTST register before proceeding.

If the RDREQ and/or TX ABRT interrupts have been masked, then clearing of the I2CINTST register will have already been performed when either the RDREQ or TXABT bit has been read as 1.

- 7 The I2C releases the SCL and transmits the byte.
- 8 The master may hold the I2C bus by issuing a RESTART condition or release the bus by used on issuing a STOP condition.

#### 2.3.3.3 Slave-Receiver Operation for a Single Byte

When another I2C master device on the bus addresses the I2C and is sending data, the I2C acts as a slave-receiver and the following steps occur:

- 1 The other I2C master device initiates an I2C transfer with an address that matches the I2C's slave address in the I2CSAR register.
- 2 The I2C acknowledges the sent address and recognizes the direction of the transfer to indicate that the I2C is acting as a slave-receiver.
- 3 I2C receives the transmitted byte and places it in the receive buffer.
  - NOTE: If the RX FIFO is completely filled with data when a byte is pushed, then an overflow occurs and the I2C continues with subsequent I2C transfers. Because a NACK is not generated, software must recognize the overflow when indicated by the I2C (by the RXOF bit in the I2CINTST register) and take appropriate actions to recover from lost data. Hence, there is a real time constraint on software to service the RX FIFO before the latter overflow as there is no way to re-apply pressure to the remote transmitting master. You must select a deep enough RX FIFO depth to satisfy the interrupt service interval of their system.
- 4 I2C asserts the RX\_FULL interrupt (I2CINTST[2] register).

If the RX\_FULL interrupt has been masked, due to setting I2CINTM[2] register to 0 or setting I2CTX\_TL to a value larger than 0, then it is recommended that a timing routine (described in "Slave-Transmitter Operation for a Single Byte" on page 57) be implemented for periodic reads of the "I2CST" on page 136 register. Reads of the I2CST register, with bit 3 (RFNE) set at 1, must then be treated by software as the equivalent of the RX\_FULL interrupt being asserted.

5 Software may read the byte from the I2CDC register (bits 7:0).



6 The other master device may hold the I2C bus by issuing a RESTART condition or release the bus by issuing a STOP condition.

#### 2.3.3.4 Slave-Transfer Operation For Bulk Transfers

In the standard I2C protocol, all transactions are single byte transactions and the programmer responds to a remote master read request by writing one byte into the slave's TX FIFO.

When a slave (slave-transmitter) is issued with a read request (RDREQ) from the remote master (master-receiver), at a minimum there should be at least one entry placed into the slave-transmitter's TX FIFO.

I2C is designed to handle more data in the TX FIFO so that subsequent read requests can take that data without raising an interrupt to get more data. Ultimately, this eliminates the possibility of significant latencies being incurred between raising the interrupt for data each time had there been a restriction of having only one entry placed in the TX FIFO.

This mode only occurs when I2C is acting as a slave-transmitter. If the remote master acknowledges the data sent by the slave-transmitter and there is no data in the slave's TX FIFO, the I2C holds the I2C SCL line low while it raises the read request interrupt (RDREQ) and waits for data to be written into the TX FIFO before it can be sent to the remote master.

If the RDREQ interrupt is masked, due to bit 5 (MRDREQ) of the I2CINTST register being set to 0, then it is recommended that a timing routine be used to activate periodic reads of the I2CINTST register. Reads of I2CINTST that return bit 5 (RDREQ) set to 1 must be treated as the equivalent of the RDREQ interrupt referred to in this section.

The RDREQ interrupt is raised upon a read request, and like interrupts, must be cleared when exiting the interrupt service handling routine (ISR). The ISR allows you to either write 1 byte or more than 1 byte into the TX FIFO. During the transmission of these bytes to the master, if the master acknowledges the last byte. Then the slave must raise the RDREQ again because the master is requesting for more data.

#### 2.3.4 Disabling I2C

The register I2CENBST is added to allow software to unambiguously determine when the hardware has completely shutdown in response to the I2CENB register being set from 1 to 0.

#### 2.3.4.1 Procedure

1 Define a timer interval (ti2c\_poll) equal to the 10 times the signaling period for the highest I2C transfer speed used in the system and supported by I2C. For example, if the highest I2C transfer mode is 400 kb/s, then this ti2c\_poll is 25us.

JZ4770 Mobile Application Processor Peripherals Programming Manual



- 2 Define a maximum time-out parameter, MAX\_T\_POLL\_COUNT, such that if any repeated polling operation exceeds this maximum value, an error is reported.
- 3 Execute a blocking thread/process/function that prevents any further I2C master transactions to be started by software, but allows any pending transfers to be completed. NOTE: This step can be ignored if I2C is programmed to operate as an I2C slave only.
- 4 The variable POLL\_COUNT is initialized to zero.
- 5 Set I2CENB to 0.
- 6 Read the I2CENBST register and test the I2C\_EN bit (bit 0). Increment POLL\_COUNT by one. If POLL\_COUNT >= MAX\_T\_POLL\_COUNT, exit with the relevant error code.

Long eitfel@126.com internal used only

7 If I2CENBST[0] is 1, then sleep for ti2c\_poll and proceed to the previous step. Otherwise, exit with a relevant success code.



## **3** Synchronous Serial Interface

#### 3.1 Overview

The SSI is a full-duplex synchronous serial interface and can connect to a variety of external analog-to-digital (A/D) converters, audio and telecom codecs, and other devices that use serial protocols for transferring data. The SSI supports National's Microwire, Texas Instruments Synchronous Serial Protocol (SSP), and Motorola's Serial Peripheral Interface (SPI) protocol.

The SSI operates in master mode (the attached peripheral functions as a slave) and supports serial bit rates from 7.2 KHz to 54 MHz. Serial data formats may range from 2 to 17 bits in length. The SSI provides 128 entries deep x 17 bits wide transmit and receive data FIFOs.

The FIFOs may be loaded or emptied by the Central Processor Unit (CPU) using programmed I/O, or used on DMA transfers while receiving or transmitting.

Features:

- 3 protocols support: National's Microwire, TI's SSP, and Motorola's SPI •
- Full-duplex or transmit-only or receive-only operation .
- Programmable transfer order: MSB first or LSB first
- 128 entries deep x 17 bits wide transmit and receive data FIFOs •
- Configurable normal transfer mode or Interval transfer mode
- Programmable clock phase and polarity for Motorola's SSI format •
- Two slave select signal (SSI\_CE\_ / SSI\_CE2\_) supporting up to 2 slave devices
- Back-to-back character transmission/reception mode
- Loop back mode for testing



## 3.2 Pin Description

| Name     | I/O    | Description                                     |
|----------|--------|-------------------------------------------------|
| SSI_CLK  | Output | Serial bit-rate clock                           |
| SSI_CE_  | Output | First slave select enable                       |
| SSI_CE2_ | Output | Second slave select enable                      |
| SSI_GPC  | Output | General purpose control signal to external chip |
| SSI_DT   | Output | Transmit data (serial data out)                 |
| SSI_DR   | Input  | Receive data (serial data in)                   |

#### **Table 3-1 Micro Printer Controller Pins Description**

SSI\_CLK is the bit-rate clock driven from the SSI to the peripheral. SSI\_CLK is toggled only when data is actively being transmitted and received.

SSI\_CE\_ or SSI\_CE2\_ are the framing signal, indicating the beginning and the end of a serialized data word.

SSI\_DT and SSI\_DR are the Transmit and Receive serial data lines.

SSI\_GPC is general-purpose control signal, synchronized with SSI\_CLK, can be used for LCD control.



## 3.3 Register Description

The SSI has seven registers: one data, two control, one status, one bit-rate control, and two interval control registers. The table lists these registers.

| Name    | RW | Reset Value | Address Offset | Access Size |
|---------|----|-------------|----------------|-------------|
| SSIDR0  | RW | 0x??        | 0x10043000     | 32          |
| SSICR00 | RW | 0x0000      | 0x10043004     | 16          |
| SSICR10 | RW | 0x00087860  | 0x10043008     | 32          |
| SSISR0  | RW | 0x0000098   | 0x1004300C     | 32          |
| SSIITR0 | RW | 0x0000      | 0x10043010     | 16          |
| SSIICR0 | RW | 0x00        | 0x10043014     | 8           |
| SSIGR0  | RW | 0x0000      | 0x10043018     | 16 🔨 🔨      |
| SSIDR1  | RW | 0x??        | 0x10044000     | 32          |
| SSICR01 | RW | 0x0000      | 0x10044004     | 16          |
| SSICR11 | RW | 0x00087860  | 0x10044008     | 32          |
| SSISR1  | RW | 0x0000098   | 0x1004400C     | 32          |
| SSIITR1 | RW | 0x0000      | 0x10044010     | 16          |
| SSIICR1 | RW | 0x00        | 0x10044014     | 8           |
| SSIGR1  | RW | 0x0000      | 0x10044018     | 16          |

#### **Table 3-2 SSI Serial Port Registers**

NOTE: There two SSI controller. SSIO whose base address is 0x100430xx and SSI1 whose base address is 0x100440xx.

#### SSI Data Register (SSIDR) 3.3.1

#### **SSIDR**

#### 0x10043000, 0x10044000 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

|     |   |   |   |   |   |   | Re | serv | /ed |   |   |   |   |   |   | GPC/D16 |   |   |   |   | Т | ran | smi | it/Re | ecei | ive | Dat | ta |   |   |   |   |
|-----|---|---|---|---|---|---|----|------|-----|---|---|---|---|---|---|---------|---|---|---|---|---|-----|-----|-------|------|-----|-----|----|---|---|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0    | 0   | 0 | 0 | 0 | 0 | 0 | 0 | ?       | ? | ? | ? | ? | ? | ?   | ?   | ?     | ?    | ?   | ?   | ?  | ? | ? | ? | ? |

| Bits  | Name      | Description                                                                | RW |
|-------|-----------|----------------------------------------------------------------------------|----|
| 31:17 | Reserved  | Writing has no effect, read as zero.                                       | R  |
| 16    | GPC/D16   | This bit can be used as normal data bus bit 16 or GPC bit alternatively.   | RW |
|       |           | When it is used as normal data bus bit, it's readable / writable; when     |    |
|       |           | SSI_GPC is used, it is GPC bit for SSI_GPC pin output and it's write-only. |    |
| 15:0  | Transmit/ | Data word to be written to/read from Transmit/Receive FIFO.                | RW |

58

JZ4770 Mobile Application Processor Peripherals Programming Manual



|      |              |                                                     | · · · · ·                  |    |
|------|--------------|-----------------------------------------------------|----------------------------|----|
|      | Receive      | When the transfer frame length is less than 17-     | bit, received data is      |    |
|      | Data         | automatically right justified in the receive-FIFO   | and the upper unused bits  |    |
|      |              | are filled with '0'. For transmission, the upper up | nused bits of the data     |    |
|      |              | written into SSIDR is ignored by the transmit log   | ic. (NOTE: "upper unused   |    |
|      |              | bits" does not include the SSIDR.GPC bit.           |                            |    |
|      |              | National microwire format includes format 1 ar      | nd format2, when national  |    |
|      |              | microwire format 2 is selected, Bit 16 of SSID      | R is defined as read/write |    |
|      |              | operation judge bit, if it is 0, bit 15~0 represent | one read command; if it is |    |
|      |              | 1, bit 15~0 represent one write command an          | d following is the written |    |
|      |              | data. So the maximum length of one command          | d (is defined in MCOM) is  |    |
|      |              | 16, the maximum length of one written or read       | data (is defined in FLEN)  |    |
|      |              | can be 17.                                          |                            |    |
|      |              | Transmit-FIFO only contain one read operation       | command once, or one       |    |
|      |              | write operation command and its data once, after    | er transmit-FIFO is empty, |    |
|      |              | next command can be filled in transmit-FIFO.        | 19                         |    |
|      |              |                                                     | 7 OIL                      |    |
| ~ ~  |              |                                                     | , ceu                      |    |
| 3.3. | 2 SSI Contro | rol Register0 (SSICR0)                              | 1 40                       |    |
|      |              | an C                                                | al used of                 |    |
|      | SSICR0       | * el l'                                             | 0x10043004, 0x100          | 44 |
| Bit  |              | 15 14 13 12 11                                      | 10 9 8 7 6 5 4 3 2         | 1  |
|      |              |                                                     |                            |    |

# 3.3.2 SSI Control Register0 (SSICR0)

#### 0x10043004, 0x10044004

|      | - X |     |      |      |      |       |       |         |      |   |          | , •    |        |        | ••••   |
|------|-----|-----|------|------|------|-------|-------|---------|------|---|----------|--------|--------|--------|--------|
| 15   | 14  | 13  | 12   | 11   | 10   | 9     | 8     | 7       | 6    | 5 | 4        | 3      | 2      | 1      | 0      |
| SSIE | TIE | RIE | TEIE | REIE | гоор | RFINE | RFINC | EACLRUN | FSEL | 5 | Reserved | TFMODE | TFLUSH | RFLUSH | DISREV |
| 0    | 0   | 0   | 0    | 0    | 0    | 0     | 0     | 0       | 0    | 0 | 0        | 0      | 0      | 0      | 0      |

#### RST

| Bits | Name | Description                                                                    | RW |
|------|------|--------------------------------------------------------------------------------|----|
| 15   | SSIE | This bit is used to enable/disable SSI module. 0: disable; 1: enable.          | RW |
|      |      | Clearing SSIE will not reset SSI FIFO, SSICR0, SSICR1, SSIGR, SSIITR           |    |
|      |      | and SSIICR automatically. Software should ensure the FIFOs/registers are       |    |
|      |      | properly configured and be flush/reset manually when necessary before          |    |
|      |      | enabling SSI.                                                                  |    |
| 14   | TIE  | This bit enables/disables the transmit-FIFO half-empty interrupt TXI.          | RW |
|      |      | 0: disable; 1: enable.                                                         |    |
| 13   | RIE  | This bit enables/disables the receive-FIFO half-full interrupt RXI.            | RW |
|      |      | 0: disable; 1: enable.                                                         |    |
| 12   | TEIE | This bit enables/disables the transmit-error interrupt TEI.                    | RW |
|      |      | 0: disable; 1: enable.                                                         |    |
| 11   | REIE | This bit enables/disables the receive-error interrupt REI.                     | RW |
|      |      | 0: disable; 1: enable.                                                         |    |
| 10   | LOOP | Used for test purpose. In loop mode, the output of SSI transmit shift register | RW |
|      |      | is connected to input of SSI receive shift register internally. The data       |    |

|     |          | received should be the sam                                        | ne                                                                | as the dat  | a transmit   | ted. And do not output  |    |  |  |  |  |
|-----|----------|-------------------------------------------------------------------|-------------------------------------------------------------------|-------------|--------------|-------------------------|----|--|--|--|--|
|     |          | any valid signals on the pin                                      | s.                                                                |             |              |                         |    |  |  |  |  |
|     |          | 0: normal SSI mode; 1: LOO                                        | Эŀ                                                                | ⊃ mode.     |              |                         |    |  |  |  |  |
| 9   | RFINE    | This bit enables/disables                                         |                                                                   | The receive | e finish coi | ndition list below:     | RW |  |  |  |  |
|     |          | receive finish control                                            |                                                                   | RFINE       | RFINC        | Receive Finish          |    |  |  |  |  |
|     |          | function.                                                         |                                                                   |             |              | Condition               |    |  |  |  |  |
|     |          | 0: disable; 1: enable.                                            |                                                                   | 0           | х            | Same as transmit        |    |  |  |  |  |
|     |          | For SSICR1.FMAT = B'10                                            |                                                                   |             |              | completion condition    |    |  |  |  |  |
|     |          | (National Microwire                                               |                                                                   |             |              | (transmit-fifo is empty |    |  |  |  |  |
|     |          | format 1 is selected),                                            | t 1 is selected), and SSICR1.UNFIN =                              |             |              |                         |    |  |  |  |  |
|     |          | SSICR0.RFINE must be                                              |                                                                   |             |              |                         |    |  |  |  |  |
|     |          | 0.                                                                | 1 0 Receive continue                                              |             |              |                         |    |  |  |  |  |
| 8   | RFINC*   | Receive finish control bit.                                       | ceive finish control bit. 1 1 Receive finish                      |             |              |                         |    |  |  |  |  |
|     |          | 0: receive continue                                               |                                                                   |             |              |                         |    |  |  |  |  |
|     |          | 1: receive finished                                               |                                                                   |             | only         |                         |    |  |  |  |  |
| 7   | EACLRU   | 0: don't auto clear under fla                                     | g,                                                                | software    | clear unde   | r ce <sup>0</sup>       | RW |  |  |  |  |
|     | Ν        | 1: software auto clear unde                                       | r f                                                               | flag when t | fifo don't e | empty                   |    |  |  |  |  |
| 6   | FSEL     | This bit sets the frame signation                                 | al                                                                | to be used  | d for slave  | select. The unselected  | RW |  |  |  |  |
|     |          | frame signal always output                                        | in                                                                | valid level | err          |                         |    |  |  |  |  |
|     |          | 0: SSI_CE_ is selected                                            |                                                                   | 12          |              |                         |    |  |  |  |  |
|     |          | 1: SSI_CE2_ is selected                                           | -                                                                 | M T         |              |                         |    |  |  |  |  |
| 5:4 | Reserved | Writing has no effect, read                                       | as                                                                | zero.       |              |                         | R  |  |  |  |  |
| 3   | TFMODE   | : new fifo empty mode                                             |                                                                   |             |              |                         |    |  |  |  |  |
|     |          | 1: old fifo empty mode                                            |                                                                   |             |              |                         |    |  |  |  |  |
| 2   | TFLUSH   | Flush the transmit FIFO when set to 1. Always return 0 when read. |                                                                   |             |              |                         |    |  |  |  |  |
| 1   | RFLUSH   | ilush the receive FIFO when set to 1. Always return 0 when read.  |                                                                   |             |              |                         |    |  |  |  |  |
| 0   | DISREV   | This bit enables/disables re                                      | his bit enables/disables receive function. 0: enable; 1: disable. |             |              |                         |    |  |  |  |  |

#### NOTE:

\*: When transmitting finished or for receive-only operation, transmit function can be disabled and this bit is used to control receiving completion, and the SSI will consume less power.

When the finish condition is set, the receiving will complete after present character is completely shifted in, then the SSI will stop the SSI\_CLK and negate the SSI\_CE\_ / SSI\_CE2\_ if necessary. To make sure present transfer is completed, user must read and get SSISR.END = 1 (or SSISR.BUSY = 0).





# 3.3.3 SSI Control Register1 (SSICR1)

|     | SSI   | CR | 1     |    |     |     |      |       |       |          |    |    |    |    |    |    |    |    |    |    |    |     |   |   | 0x | 100 | 430 | <b>)08</b> | , <b>0</b> x | 100 | )44( | 800 |
|-----|-------|----|-------|----|-----|-----|------|-------|-------|----------|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|----|-----|-----|------------|--------------|-----|------|-----|
| Bit | 31    | 30 | 29 2  | 28 | 27  | 26  | 25   | 24    | 23    | 22       | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7  | 6   | 5   | 4          | 3            | 2   | 1    | 0   |
|     | FRMHI |    | TFVCK |    | тсі | KFI | LFST | ITFRM | NIJNN | Reserved | FM | AT |    | тт | RG |    |    | MC | OM |    | F  | RTR | G |   |    | FL  | EN  |            | permesed     |     | PHA  | POL |
| RST | 0     | 0  | 0     | 0  | 0   | 0   | 0    | 0     | 0     | 0        | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0   | 0 | 0 | 0  | 1   | 1   | 0          | 0            | 0   | 0    | 0   |

| Bits  | Name  |                   | Description                                |                | RW |
|-------|-------|-------------------|--------------------------------------------|----------------|----|
| 31:30 | FRMHL | Frame valid level | select, FRMHL [1: 0] correspond to SSI     | _CE2_ and      | RW |
|       |       | SSI_CE_ respec    | tively.                                    |                |    |
|       |       | FRMHL[1:0]        | Description                                |                |    |
|       |       | 00                | SSI_CE_ is low level valid and             | Initial value  |    |
|       |       |                   | SSI_CE2_ is low level valid                | $on_{T}$       | )  |
|       |       | 01                | SSI_CE_ is high level valid and            | $\partial$     |    |
|       |       |                   | SSI_CE2_ is low level valid $\sqrt{c}$     |                |    |
|       |       | 10                | SSI_CE_ is low level valid and             |                |    |
|       |       |                   | SSI_CE2_ is high level valid               |                |    |
|       |       | 11                | SSI_CE_ is high level valid and            |                |    |
|       |       |                   | SSI_CE2_ is high level valid               |                |    |
| 29:28 | TFVCK | Time from frame   | valid to clock start, that provide program | mable time     | RW |
|       |       | delay from frame  | (SSI_CE_ /SSI_CE2_) assert edge to S       | SI_CLK leading |    |
|       |       | edge. When TFV    | CK = B'00, the time is fixed half SSI_CL   | K or one       |    |
|       |       | SSI_CLK cycle a   | ccording to SSICR1.POL and SSICR1.P        | HA             |    |
|       | 0     | configuration.    |                                            |                |    |
|       | 20-   | For SSICR1.FMA    | AT = B'01, SSICR1.TFVCK is ignored.        |                |    |
| 1     | 0110  | TFVCK[1:0]        | Description                                |                |    |
|       |       | 00                | Ignore (default half or one SSI_CLK        | Initial value  |    |
|       |       |                   | cycle delay time)                          |                |    |
|       |       | 01                | 1 more SSI_CLK cycle delay time is         |                |    |
|       |       |                   | added                                      |                |    |
|       |       | 10                | 2 more SSI_CLK cycle delay time is         |                |    |
|       |       |                   | added                                      |                |    |
|       |       | 11                | 3 more SSI_CLK cycle delay time is         |                |    |
|       |       |                   | added                                      |                |    |
| 27:26 | TCKFI | Time from clock   | stop to frame invalid, provide programma   | ble time delay | RW |
|       |       | from SSI_CLK la   | st edge to frame (SSI_CE_ /SSI_CE2_) r     | negate edge.   |    |
|       |       | When TCKFI = B    | '00, the time is fixed one SSI_CLK or half | SSI_CLK cycle  |    |
|       |       | according to SSI  | CR1.POL and SSICR1.PHA configuration       | า.             |    |
|       |       | For SSICR1.FMA    | AT = B'01, SSICR1.TFVCK is ignored.        |                |    |
|       |       | TCKFI[1:0]        | Description                                |                |    |



|       |          | 00                  | Ignore (default half or one SSI_CLK                      | Initial value    |       |
|-------|----------|---------------------|----------------------------------------------------------|------------------|-------|
|       |          |                     | cycle delay time)                                        |                  |       |
|       |          | 01                  | 1 more SSI_CLK cycle delay time is                       |                  |       |
|       |          |                     | added                                                    |                  |       |
|       |          | 10                  | 2 more SSI_CLK cycle delay time is                       |                  |       |
|       |          |                     | added                                                    |                  |       |
|       |          | 11                  | 3 more SSI_CLK cycle delay time is                       |                  |       |
|       |          |                     | added                                                    |                  |       |
| 25    | LFST     | Set to LSB first o  | r MSB first when transfer. 0: MSB first; 1               | : LSB first.     | RW    |
| 24    | ITFRM    | Frame during inte   | erval, selects if the Frame (SSI_CE_/SS                  | I_CE2_) signal   | RW    |
|       |          | is negated or not   | during interval time at Interval Mode (SS                | ICR1.FMAT =      |       |
|       |          | B'00 and SSIITR     | .IVLTM $\neq$ H'0000). It's ignored at Normal            | Mode.            |       |
|       |          | 0: SSI_CE_/SSI      | _CE2_ de-asserts during interval time at                 | Interval Mode    |       |
|       |          | 1: SSI_CE_/SSI      | _CE2_ keeps asserted during interval tim                 | ne at Interval   |       |
|       |          | Mode                |                                                          | 273              |       |
| 23    | UNFIN    | This bit controls w | whether the SSI finishes transmission or                 | wait for data    | RW    |
|       |          | filling (underrun h | appen) after all data in transmit-FIFO are               | sent out during  |       |
|       |          | transfer. This bit  | must be cleared to 0 when SSICR1.FMA                     | T = B'01. (TI's  |       |
|       |          | SSP format)         | 1 Brow                                                   |                  |       |
|       |          | 0: Transmit-FIFO    | empty means end of transmission                          |                  |       |
|       |          | 1: Transmission     | didn't finish when transmit-FIFO is empty                | , SSI underrun   |       |
|       |          | error would or      | ccur and <mark>SSI</mark> waits for data filling; SSI_CI | LK and           |       |
|       |          | SSI_CE_/SS          | CE2_keeps asserted, SSI_CLK stop a                       | t the current    |       |
|       |          | level               | 0.                                                       |                  |       |
|       |          | NOTE: For trans     | mit-FIFO empty before any transfer after                 | SSI enabled, if  |       |
|       |          | SSICR1.UNFIN =      | = 1 or SSICR0.RFINE = 0, SSI will wait til               | II transmit-FIFO |       |
|       | , e      | isn't empty then s  | start to transfer and no underrun error wil              | l occur; if      |       |
|       | n8-      | SSICR1.UNFIN =      | = 0 and SSICR0.RFINE = 1, after transmi                  | t-FIFO become    |       |
|       |          | empty, SSI will st  | art a receive-only transfer.                             |                  |       |
| 22    | Reserved | Writing has no ef   | fect, read as zero.                                      |                  | R     |
| 21:20 | FMAT     | These bits set the  | e operating transfer format.                             |                  | RW    |
|       |          | FMAT[1:0]           | Description                                              |                  |       |
|       |          | 00                  | Motorola's SPI format                                    | Initial value    |       |
|       |          | 01                  | TI's SSP format                                          |                  |       |
|       |          | 10                  | National Microwire 1 format                              |                  |       |
|       |          | 11                  | National Micowire 2 format                               |                  |       |
| 19:16 | TTRG     |                     | e the transmit-FIFO half-empty threshol                  | d value. which   | RW    |
|       |          |                     | ss characters left in transmit-FIFO, the S               |                  |       |
|       |          | be set to '1'.      |                                                          |                  |       |
|       |          | 0000: less than o   | r equal to 1                                             |                  |       |
|       |          | n: less than or eq  |                                                          |                  |       |
| 15:12 | МСОМ     |                     | MAT = B'10 or B'11 (National Microwire f                 | format 1 or 2 is | RW    |
| 10.12 |          |                     |                                                          |                  | 1.144 |

62



|             |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | t decides the length of command from 1-b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | oit to 16-bit. The                                                                                                                                                 |    |
|-------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|             |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                    |    |
|             |                          | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | or read data is defined in FLEN. For SSIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | CR1.FMAT ≠                                                                                                                                                         |    |
|             |                          | B'10 or B'11, this<br>MCOM[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                        | bit is ignored. Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                    |    |
|             |                          | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                    |    |
|             |                          | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 2-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                    |    |
|             |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                    |    |
|             |                          | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 3-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                    |    |
|             |                          | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                    |    |
|             |                          | 0100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 5-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                    |    |
|             |                          | 0101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 6-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                    |    |
|             |                          | 0110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 7-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                    |    |
|             |                          | 0111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 8-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Initial value                                                                                                                                                      |    |
|             |                          | 1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 9-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                    |    |
|             |                          | 1001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 10-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                    |    |
|             |                          | 1010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 11-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                    |    |
|             |                          | 1011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 12-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | $\lambda$                                                                                                                                                          |    |
|             |                          | 1100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 13-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ee.                                                                                                                                                                |    |
|             |                          | 1101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 14-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                    |    |
|             |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                    |    |
|             |                          | 1110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 15-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                    |    |
|             |                          | 1110<br>1111                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 16-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                    |    |
| 11:8        | RTRG                     | 1111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ue, which when                                                                                                                                                     | RW |
| 11:8        | RTRG<br>(SSI1)           | 1111<br>These bits define                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 16-bit command selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                    | RW |
| 11:8        |                          | 1111<br>These bits define                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 16-bit command selected<br>e the receive-FIFO half-full threshold valu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                    | RW |
| 11:8        |                          | 1111<br>These bits define<br>equal or more ch                                                                                                                                                                                                                                                                                                                                                                                                                                          | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>naracters received in receive-FIFO, the SS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                    | RW |
| 11:8        |                          | 1111<br>These bits define<br>equal or more ch<br>be set to '1'.                                                                                                                                                                                                                                                                                                                                                                                                                        | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>naracters received in receive-FIFO, the SS<br>or equal to 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                    | RW |
| 11:8<br>9:8 |                          | 1111<br>These bits define<br>equal or more ch<br>be set to '1'.<br>0000: more than<br>n: more than or e                                                                                                                                                                                                                                                                                                                                                                                | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>naracters received in receive-FIFO, the SS<br>or equal to 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SISR.RFHF will                                                                                                                                                     | RW |
|             | (SSI1)                   | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define                                                                                                                                                                                                                                                                                                                             | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>naracters received in receive-FIFO, the SS<br>or equal to 1<br>equal to nx8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SISR.RFHF will                                                                                                                                                     |    |
|             | (SSI1)<br>RTRG           | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define                                                                                                                                                                                                                                                                                                                             | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>naracters received in receive-FIFO, the SS<br>or equal to 1<br>equal to nx8<br>e the receive-FIFO half-full threshold value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SISR.RFHF will                                                                                                                                                     |    |
|             | (SSI1)<br>RTRG           | 1111<br>These bits define<br>equal or more ch<br>be set to '1'.<br>0000: more than<br>n: more than or e<br>These bits define<br>equal or more ch                                                                                                                                                                                                                                                                                                                                       | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>naracters received in receive-FIFO, the SS<br>or equal to 1<br>equal to nx8<br>e the receive-FIFO half-full threshold value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SISR.RFHF will                                                                                                                                                     |    |
|             | (SSI1)<br>RTRG           | 1111<br>These bits define<br>equal or more ch<br>be set to '1'.<br>0000: more than<br>n: more than or e<br>These bits define<br>equal or more ch<br>be set to "1".                                                                                                                                                                                                                                                                                                                     | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>naracters received in receive-FIFO, the SS<br>or equal to 1<br>equal to nx8<br>e the receive-FIFO half-full threshold value<br>naracters received in receive-FIFO, the SS                                                                                                                                                                                                                                                                                                                                                                                                                                               | SISR.RFHF will                                                                                                                                                     |    |
|             | (SSI1)<br>RTRG           | 1111These bits define<br>equal or more ch<br>be set to '1'.0000: more than<br>n: more than or e<br>equal or more ch<br>be set to "1".These bits define<br>equal or more ch<br>be set to "1".RTRG[1:0]                                                                                                                                                                                                                                                                                  | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>haracters received in receive-FIFO, the SS<br>or equal to 1<br>equal to nx8<br>e the receive-FIFO half-full threshold value<br>haracters received in receive-FIFO, the SS<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                | SISR.RFHF will<br>e, which when<br>SISR.RFHF will                                                                                                                  |    |
|             | (SSI1)<br>RTRG           | 1111These bits define<br>equal or more ch<br>be set to '1'.0000: more than<br>n: more than or e<br>These bits define<br>equal or more ch<br>be set to "1".RTRG[1:0]<br>00                                                                                                                                                                                                                                                                                                              | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>haracters received in receive-FIFO, the SS<br>or equal to 1<br>equal to nx8<br>e the receive-FIFO half-full threshold value<br>haracters received in receive-FIFO, the SS<br>Description<br>more than or equal to 1                                                                                                                                                                                                                                                                                                                                                                                                     | SISR.RFHF will<br>e, which when<br>SISR.RFHF will                                                                                                                  |    |
|             | (SSI1)<br>RTRG           | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define         equal or more ch         be set to "1".         RTRG[1:0]         00         01                                                                                                                                                                                                                                     | 16-bit command selected         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         or equal to 1         equal to nx8         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         Description         more than or equal to 1         more than or equal to 4                                                                                                                                                                                                                    | SISR.RFHF will<br>e, which when<br>SISR.RFHF will                                                                                                                  |    |
|             | (SSI1)<br>RTRG           | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define         equal or more ch         be set to "1".         RTRG[1:0]         00         01         10         11                                                                                                                                                                                                               | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>haracters received in receive-FIFO, the SS<br>or equal to 1<br>equal to nx8<br>e the receive-FIFO half-full threshold value<br>haracters received in receive-FIFO, the SS<br>Description<br>more than or equal to 1<br>more than or equal to 4<br>more than or equal to 8                                                                                                                                                                                                                                                                                                                                               | SISR.RFHF will<br>e, which when<br>SISR.RFHF will<br>Initial value                                                                                                 |    |
| 9:8         | (SSI1)<br>RTRG<br>(SSI0) | 1111These bits define<br>equal or more ch<br>be set to '1'.0000: more than<br>n: more than or e<br>These bits define<br>equal or more ch<br>be set to "1".RTRG[1:0]00011011These bits set the                                                                                                                                                                                                                                                                                          | 16-bit command selected         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         or equal to 1         equal to nx8         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         Description         more than or equal to 1         more than or equal to 4         more than or equal to 8         more than or equal to 14                                                                                                                                                   | SISR.RFHF will<br>e, which when<br>SISR.RFHF will<br>Initial value                                                                                                 | RW |
| 9:8         | (SSI1)<br>RTRG<br>(SSI0) | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define         equal or more ch         be set to "1".         These bits define         equal or more ch         be set to "1".         RTRG[1:0]         00         01         10         11         These bits set the         The maximum data                                                                                 | 16-bit command selected         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         or equal to 1         equal to nx8         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         e the receive for equal to 1         more than or equal to 1         more than or equal to 4         more than or equal to 8         more than or equal to 14         e bit length of every character to be transm                                                                             | SISR.RFHF will<br>e, which when<br>SISR.RFHF will<br>Initial value<br>mitted/received.<br>or data length                                                           | RW |
| 9:8         | (SSI1)<br>RTRG<br>(SSI0) | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define         equal or more ch         be set to "1".         These bits define         equal or more ch         be set to "1".         RTRG[1:0]         00         01         10         11         These bits set the         The maximum da         longer than 17 bit                                                        | 16-bit command selected         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         or equal to 1         equal to nx8         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS <b>Description</b> more than or equal to 1         more than or equal to 4         more than or equal to 8         more than or equal to 14         e bit length of every character to be transmata length can be configured is 17 bits. For                                                           | SISR.RFHF will<br>e, which when<br>SISR.RFHF will<br>Initial value<br>mitted/received.<br>or data length<br>ured length), the                                      | RW |
| 9:8         | (SSI1)<br>RTRG<br>(SSI0) | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define         equal or more ch         be set to "1".         These bits define         equal or more ch         be set to "1".         RTRG[1:0]         00         01         10         11         These bits set the         The maximum da         longer than 17 bi         software should of                              | 16-bit command selected         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         or equal to 1         equal to nx8         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS <b>Description</b> more than or equal to 1         more than or equal to 4         more than or equal to 8         more than or equal to 14         e bit length of every character to be transmata length can be configured is 17 bits. For the SSICR1.FLEN configure                                 | SISR.RFHF will<br>e, which when<br>SISR.RFHF will<br>Initial value<br>mitted/received.<br>or data length<br>ured length), the<br>SPC pin is used,                  | RW |
| 9:8         | (SSI1)<br>RTRG<br>(SSI0) | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define         equal or more than         equal or more than         These bits define         equal or more than         be set to "1".         RTRG[1:0]         00         01         10         11         These bits set the         The maximum da         longer than 17 bi         software should         the FLEN should | 16-bit command selected         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         or equal to 1         equal to nx8         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS         e the receive-FIFO half-full threshold value         haracters received in receive-FIFO, the SS <b>Description</b> more than or equal to 1         more than or equal to 4         more than or equal to 14         e bit length of every character to be transmata length can be configured is 17 bits. For ts (multiples of the SSICR1.FLEN configure         ensure properly processing. When SSI_G | SISR.RFHF will<br>e, which when<br>SISR.RFHF will<br>Initial value<br>mitted/received.<br>or data length<br>ured length), the<br>SPC pin is used,<br>. When TI SSP | RW |
| 9:8         | (SSI1)<br>RTRG<br>(SSI0) | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define         equal or more than         equal or more than         These bits define         equal or more than         be set to "1".         RTRG[1:0]         00         01         10         11         These bits set the         The maximum da         longer than 17 bi         software should         the FLEN should | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>haracters received in receive-FIFO, the SS<br>or equal to 1<br>equal to nx8<br>e the receive-FIFO half-full threshold value<br>haracters received in receive-FIFO, the SS<br>Description<br>more than or equal to 1<br>more than or equal to 4<br>more than or equal to 4<br>more than or equal to 4<br>more than or equal to 14<br>e bit length of every character to be transmata<br>length can be configured is 17 bits. For<br>ts (multiples of the SSICR1.FLEN configure<br>ensure properly processing. When SSI_G<br>In't be configured as B'1111 (17-bit data).                                                  | SISR.RFHF will<br>e, which when<br>SISR.RFHF will<br>Initial value<br>mitted/received.<br>or data length<br>ured length), the<br>SPC pin is used,<br>. When TI SSP | RW |
| 9:8         | (SSI1)<br>RTRG<br>(SSI0) | 1111         These bits define         equal or more ch         be set to '1'.         0000: more than         n: more than or e         These bits define         equal or more th         be set to "1".         RTRG[1:0]         00         01         10         11         These bits set the         The maximum da         longer than 17 bi         software should or         the FLEN should         mode is selected                                                       | 16-bit command selected<br>e the receive-FIFO half-full threshold valu<br>haracters received in receive-FIFO, the SS<br>or equal to 1<br>equal to nx8<br>e the receive-FIFO half-full threshold value<br>haracters received in receive-FIFO, the SS<br>Description<br>more than or equal to 1<br>more than or equal to 4<br>more than or equal to 4<br>more than or equal to 4<br>more than or equal to 14<br>e bit length of every character to be transmata<br>length can be configured is 17 bits. For<br>ts (multiples of the SSICR1.FLEN configure<br>ensure properly processing. When SSI_G<br>In't be configured as B'1111 (17-bit data).                                                  | SISR.RFHF will<br>e, which when<br>SISR.RFHF will<br>Initial value<br>mitted/received.<br>or data length<br>ured length), the<br>SPC pin is used,<br>. When TI SSP | RW |



|     | 1        |                     | 1                                               | · · ·           | ,1 |
|-----|----------|---------------------|-------------------------------------------------|-----------------|----|
|     |          | 0001                | 3-bit data                                      |                 |    |
|     |          | 0010                | 4-bit data                                      |                 |    |
|     |          | 0011                | 5-bit data                                      |                 |    |
|     |          | 0100                | 6-bit data                                      |                 |    |
|     |          | 0101                | 7-bit data                                      |                 |    |
|     |          | 0110                | 8-bit data                                      | Initial value   |    |
|     |          | 0111                | 9-bit data                                      |                 |    |
|     |          | 1000                | 10-bit data                                     |                 |    |
|     |          | 1001                | 11-bit data                                     |                 |    |
|     |          | 1010                | 12-bit data                                     |                 |    |
|     |          | 1011                | 13-bit data                                     |                 |    |
|     |          | 1100                | 14-bit data                                     |                 |    |
|     |          | 1101                | 15-bit data                                     |                 |    |
|     |          | 1110                | 16-bit data                                     | 1 ~ 1           |    |
|     |          | 1111                | 17-bit data                                     |                 |    |
| 3:2 | Reserved | Writing has no et   | ffect, read as zero.                            | 2               | R  |
| 1   | PHA      | This bit sets the p | phase of the SSI_CLK from the beginning         | of a data frame | RW |
|     |          | for Motorola's SF   | PI format (SSICR1.FMAT = B'00),                 |                 |    |
|     |          | 0: The leading e    | dge of SSI_CLK is used to sample data fr        | rom SSI_DR      |    |
|     |          | after the SSI_0     | CE_/SSI_CE2_ goes valid, it is initial val      | ue              |    |
|     |          | 1: The leading e    | dge of SSI_CLK is used to drive data onto       | o SSI_DT after  |    |
|     |          | the SSI_CE_ /       | SSI_CE2_ goes valid                             |                 |    |
| 0   | POL      | This bit sets SSI   | CLK's idle state polarity for Motorola's S      | PI format.      | RW |
|     |          | (SSICR1.FMAT        | <b>≤</b> B'00).                                 |                 |    |
|     |          |                     | os low level when idle, when SSI_CE_/S          |                 |    |
|     | 0        | Valid the leadir    | ng clock edge is a rising edge, it is initial v | value           |    |
|     | 200      |                     | os high level when idle, when SSI_CE_ /S        | SSI_CE2_ goes   |    |
| 1   | Olici    | valid the leadir    | ng clock edge is a falling edge                 |                 |    |

# 3.3.4 SSI Status Register1 (SSISR)

|     | SSI | SR |    |     |      |    |    |    |    |    |    |     |      |    |    |    |    |    |    |     |      |    |   |   | <b>0</b> x1 | 100  | 430 | 0C, | 0x   | 100  | 440  | <b>)0C</b> |
|-----|-----|----|----|-----|------|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|-----|------|----|---|---|-------------|------|-----|-----|------|------|------|------------|
| Bit | 31  | 30 | 29 | 28  | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11   | 10 | 9 | 8 | 7           | 6    | 5   | 4   | 3    | 2    | 1    | 0          |
|     |     |    | R  | ese | erve | d  |    |    |    |    | TF | IFC | )-NI | JM |    |    |    |    | RF | IFC | )-NI | JM |   |   | END         | BUSY | TFF | RFE | TFHE | RFHF | UNDR | OVER       |
| RST | 0   | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0 | 0 | 1           | 0    | 0   | 1   | 1    | 0    | 0    | 0          |

| Bits  | Name     | Description                          | RW |
|-------|----------|--------------------------------------|----|
| 31:24 | Reserved | Writing has no effect, read as zero. | R  |

64



| 23:16 | TFIFO-NUM | These bits indicate the Characters Number in Transmit-FIFO.               | R  |
|-------|-----------|---------------------------------------------------------------------------|----|
| 15:8  | RFIFO-NUM | These bits indicate the Characters Number in Transmit-FIFO.               | R  |
| 7     | END       | This bit indicates transfer end status. It is the inverse of SSISR.BUSY   | R  |
|       |           | when transfer is in process, but it'll keep cleared at interval time      |    |
|       |           | before transfer is completed. It'll be set when transfer finished.        |    |
| 6     | BUSY      | This bit indicates SSI's working status.                                  | R  |
|       |           | 0: SSI is idle or at interval time                                        |    |
|       |           | 1: Transmission and/or reception is in process                            |    |
| 5     | TFF       | This bit denotes transmit-FIFO is full or not.                            | R  |
|       |           | 0: Transmit-FIFO is not full                                              |    |
|       |           | 1: Transmit-FIFO is full                                                  |    |
| 4     | RFE       | This bit denotes receive-FIFO is empty or not.                            | R  |
|       |           | 0: Receive-FIFO is not empty                                              |    |
|       |           | 1: Receive-FIFO is empty                                                  |    |
| 3     | TFHE      | This bit denotes whether the characters number in transmit-FIFQ           | R  |
|       |           | being less or equal to SSICR1.TTRG.                                       |    |
|       |           | 0: The data in transmit-FIFO is more than the condition set by            |    |
|       |           | SSICR1.TTRG                                                               |    |
|       |           | 1: The data in transmit-FIFO meets the condition set by                   |    |
|       |           | SSICR1.TTRG, If SSICR0.TIE = 17 it will generate SSI TXI interrupt        |    |
| 2     | RFHF      | This bit denotes whether the characters number in receive-FIFO            | R  |
|       |           | being more or equal to the number set by SSICR1.RTRG.                     |    |
|       |           | 0: The data in receive-FIFO is less than the condition set by             |    |
|       |           | SSICR1.RTRG                                                               |    |
|       |           | 1: The data in receive-FIFO meets the condition set by                    |    |
|       |           | SSICR1.RTRG, If SSICR0.RIE = 1, it will generate SSI RXI                  |    |
|       | er        | interrupt                                                                 |    |
| 1     | UNDR      | Transmit-FIFO underrun status. When underrun happens, SSI set this        | RW |
|       |           | bit and keeps the current status of SSI_CLK and SSI_CE_/SSI_CE2_,         |    |
|       |           | waiting for transmit-FIFO filling.                                        |    |
|       |           | 0: Underrun has not occurred                                              |    |
|       |           | 1: Underrun has occurred, when SSICR0.TEIE is set, it will generate       |    |
|       |           | SSI TEI interrupt. Write '0' to clear this bit, writing '1' has no effect |    |
| 0     | OVER      | Receive-FIFO overrun status, new received data will lose.                 | RW |
|       |           | 0: Overrun has not occurred                                               |    |
|       |           | 1: Overrun has occurred; When SSICR0.REIE is set, it will generate        |    |
|       |           | SSI REI interrupt. Write '0' to clear this bit, writing '1' has no effect |    |



# 3.3.5 SSI Interval Time Control Register (SSIITR)



| Bits | Name   | Description                                                                               | RW |  |  |  |
|------|--------|-------------------------------------------------------------------------------------------|----|--|--|--|
| 15   | CNTCLK | Counting clock source select.                                                             | RW |  |  |  |
|      |        | 0: Use SSI bit clock (SSI_CLK) as the interval counter clock source                       |    |  |  |  |
|      |        | 1: Use 32K clock as the interval counter clock source                                     |    |  |  |  |
| 14:0 | IVLTM  | Interval time set, set the cycle number of counting clock source for                      | RW |  |  |  |
|      |        | desired interval time. When SSIITR.IVLTM = 0x0000, normal mode is                         |    |  |  |  |
|      |        | selected, and SSIITR.CNTCLK and SSIICR are ignored. When                                  |    |  |  |  |
|      |        | SSIITR.IVLTM $\neq$ 0x0000, interval mode is selected. The interval time is               |    |  |  |  |
|      |        | calculated as follows:                                                                    |    |  |  |  |
|      |        | Interval time ≈ [CNTCLK clock period] * [Value of IVLTM]                                  |    |  |  |  |
|      |        | 1 DU                                                                                      |    |  |  |  |
|      |        | The actual interval time is as follow:                                                    |    |  |  |  |
|      |        | When SSIITR.CNTCLK = 0:                                                                   |    |  |  |  |
|      |        | Interval time = [CNTCLK clock period] * [Value of IVLTM] + 3 *                            |    |  |  |  |
|      |        | effelter device_clock period                                                              |    |  |  |  |
|      | e      | When SSIITR.CNTCLK = 1:                                                                   |    |  |  |  |
|      | ng-    | Interval time $\geq$ [CNTCLK clock period] * [Value of IVLTM + 1] + 1 *                   |    |  |  |  |
| )    |        | device_clock period;                                                                      |    |  |  |  |
|      |        | Interval time ≤ [CNTCLK clock period] * [Value of IVLTM + 2] + 2 *<br>device_clock period |    |  |  |  |

66



# 3.3.6 SSI Interval Character-per-frame Control Register (SSIICR)

| SSIICR 0x10043014, 0x1 |   |          |   |     |   | 100 | 44( | )14 |
|------------------------|---|----------|---|-----|---|-----|-----|-----|
| Bit                    | 7 | 6        | 5 | 4   | 3 | 2   | 1   | 0   |
|                        |   | Reserved |   | ICC |   |     |     |     |
| RST                    | 0 | 0        | 0 | 0   | 0 | 0   | 0   | 0   |

| Bits                                                                                                                              | Name     | Description                                                                                                                                                                                                                                                                                                                                      | RW |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|--|--|--|--|
| 7:3                                                                                                                               | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                                             | R  |  |  |  |  |  |
| 2:0                                                                                                                               | ICC      | Sets the fixed number of characters to be transmitted / received each<br>time during SSI_CLK changing (and SSI_CE_ / SSI_CE2_ asserting) in<br>interval mode for SSICR1.FMAT = B'00 (Motorola's SPI format is<br>selected). SSIICR is ignored for SSICR1.FMAT $\neq$ B'00.<br>The desired transfer number of characters-per-frame is (SSIICR set | RW |  |  |  |  |  |
| The desired transfer number of characters-per-frame is (SSIICR set value + 1).         3.3.7 SSI Clock Generator Register (SSIGR) |          |                                                                                                                                                                                                                                                                                                                                                  |    |  |  |  |  |  |

## 3.3.7 SSI Clock Generator Register (SSIGR)

| SSIGR | com |    |    |      |     |     |    |   |   | <b>0</b> x | 100 | 9430 | 018 | , 0x | 100 | )44( | 018 |
|-------|-----|----|----|------|-----|-----|----|---|---|------------|-----|------|-----|------|-----|------|-----|
| Bit   |     | 15 | 14 | 13 1 | 12  | 11  | 10 | 9 | 8 | 7          | 6   | 5    | 4   | 3    | 2   | 1    | 0   |
|       |     |    |    | Re   | ese | rve | d  |   |   |            |     |      | С   | σv   |     |      |     |
|       |     |    |    |      |     |     |    |   |   |            |     |      |     |      |     |      |     |
| RST   |     | 0  | 0  | 0    | 0   | 0   | 0  | 0 | 0 | 0          | 0   | 0    | 0   | 0    | 0   | 0    | 0   |

| Bits | Name     | Description                                                                                                                                                                                                                                                                                                                                            | RW |
|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 15:8 | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                                                   | R  |
| 7:0  | CGV      | Sets the frequency of serial bit clock (SSI_CLK). The serial bit clock<br>(SSI_CLK) is generated by dividing device-clock as follows:<br>F <sub>SSI_CLK</sub> = [Frequency of device clock] / (2 * (CGV + 1))<br>Device clock is generated in CPM module. The value in SSIGR can be<br>set from 0 to 255, and initialized to 0x0000 on power-on reset. | RW |

68



## 3.4 Functional Description

Serial data is transferred between the processor and external peripheral through FIFO buffers in the SSI. Data transfers to system memory are handled by either the CPU (using programmed I/O) or by DMA. Operation is full duplex - separate buffers and serial data paths permit simultaneous transfers to and from the external peripheral.

Programmed I/O transmits and receives data directly between the CPU and the transmit/receive FIFO's. The DMA controller transfers data during transmit and receive operations between memory and the FIFO's.

Transmit data is written by the CPU or DMA to the SSI's transmit FIFO. The SSI then takes the data from the FIFO, serializes it, and transmits it via the SSI\_DT signal to the peripheral. Data from the peripheral is received via the SSI\_DR signal, converted to parallel words and is stored in the Receive FIFO. Read operations automatically target the receive FIFO, while write operations write data to the transmit FIFO. Both the transmit and receive FIFO buffers are 128 entries deep by 17 bits wide. As the received data fills the receive FIFO, a programmable threshold triggers an interrupt to the Interrupt Controller. If enabled, an interrupt service routine responds by identifying the source of the interrupt and then performs one or several read operations from the inbound (receive) FIFO buffer.



## 3.5 Data Formats

Four signals are used to transfer data between the processor and external peripheral. The SSI supports three formats: Motorola SPI, Texas Instruments SSP, and National Microwire. Although they have the same basic structure the three formats have significant differences, as described below:

- 1 SSI\_CE\_/SSI\_CE2\_ varies for each protocol as follows:
  - For SPI and Microwire formats, SSI\_CE\_/SSI\_CE2\_ functions as a chip select to enable the external device (target of the transfer), and is held active-low during the data transfer.
  - For SSP format, this signal is pulsed high for one serial bit-clock period at the start of each frame.
- 2 SSI\_CLK varies for each protocol as follows:
  - For Microwire, both transmit and receive data sources switch data on the falling edge of SSI\_CLK, and sample incoming data on the rising edge.
  - For SSP, transmit and receive data sources switch data on the rising edge of SSI\_CLK, and sample incoming data on the falling edge.
  - For SPI, the user has the choice of which edge of SSI\_CLK to use for switching outgoing data, and for sampling incoming data. In addition, the user can move the phase of SSI\_CLK, shifting its active state one-half period earlier or later at the start and end of a frame.

While SSP and SPI are full-duplex protocols, Microwire uses a half-duplex master-slave messaging protocol. At the start of a frame, a 1 or 2-byte control message is transmitted from the controller to the peripheral. The peripheral does not send any data. The peripheral interprets the message and, if it is a READ request, responds with requested data, one clock after the last bit of the requesting message.

The serial clock (SSI\_CLK) only toggles during an active frame. At other times it is held in an inactive or idle state, as defined by its specified protocol.

## 3.5.1 Motorola's SPI Format Details

## 3.5.1.1 General Single Transfer Formats

The figures below show the timing of general single transfer format.







Figure 3-2 SPI Single Character Transfer Format (PHA = 1)

For SSICR1.PHA = 0, when SSICR1.TFVCK = B'00, hardware ensures the first clock edge appears one SSI\_CLK period after SSI\_CE\_ / SSI\_CE2\_ goes valid; when SSICR1.TCKFI = B'00, hardware ensures the SSI\_CE\_ / SSI\_CE2\_ negated half SSI\_CLK period after last clock change edge; when SSICR1.TFVCK  $\neq$  B'00 or SSICR1.TCKFI  $\neq$  B'00, 1/2/3 more clock cycles are inserted.

For SSICR1.PHA = 1, when SSICR1.TFVCK = B'00, hardware ensures the first clock edge appears half SSI\_CLK period after SSI\_CE\_ / SSI\_CE2\_ goes valid; when SSICR1.TCKFI = B'00, hardware ensures the SSI\_CE\_ / SSI\_CE2\_ negated one SSI\_CLK period after last clock change edge; when SSICR1.TFVCK  $\neq$  B'00 or SSICR1.TCKFI  $\neq$  B'00, 1/2/3 more clock cycles are inserted.

<sup>70</sup> 



Data is sampled from SSI\_DR at every rising edge (when PHA = 0, POL = 0 or PHA = 1, POL = 1) or at every falling edge (when PHA = 0, POL = 1 or PHA = 1, POL = 0). According to SPI protocol, input data on SSI\_DR should be stable at every sample clock edge.

Drive data onto SSI\_DT at every rising edge (when PHA = 0, POL = 1 or PHA = 1, POL = 0) or at every falling edge (when PHA = 0, POL = 0 or PHA = 1, POL = 1).

## 3.5.1.2 Back-to-Back Transfer Formats



For Motorola's SPI format transfers those continuous characters are exchanged during SSI\_CE\_ / SSI\_CE2\_ being valid, the timing is illustrated in the figure (SSICR1.LFST = 0).

Back-to-back transfer is performed as transmit-only/full-duplex operation when transmit-FIFO is not empty before the completion of the last character's transfer or performed as receive-only operation.

72



#### 3.5.1.3 Frame Interval Mode Transfer Format

When in interval mode (SSIITR. IVLTM  $\neq$  '0'), SSI always wait for an interval time (SSIITR.IVLTM), transfer fixed number of characters (SSIICR), then repeats the operation.

When SSICR0.RFINE = 1, if transmit-FIFO is still empty after the interval time, receive-only transfer will occur.

During interval-wait time, SSI stops SSI\_CLK, and when SSICR1.ITFRM = 0 it negates the SSI\_CE\_ / SSI\_CE2\_, when SSICR1.ITFRM = 1 it keeps asserting the SSI\_CE\_ / SSI\_CE2\_.

For transfers finished with transmit-FIFO empty, if the SSI transmit-FIFO is empty before fixed number of characters being loaded to transfer (SSICR1.UNFIN must be 1), then the SSI will set SSISR.UNDR = 1; if enabled, it'll send out a SSI underrun interrupt. At the same time, SSI will hold the SSI\_CE\_ / SSI\_CE2\_ and SSI\_CLK signals at current status and wait for the transmit-FIFO filling. The SSI will continue transfer after transmit-FIFO being filled. The SSI always stops after completion of fixed number of characters' transfer (SSICR1.UNFIN must be 0) with transmit-FIFO empty.

For transfers finished by SSICR0.RFINC being valid set, the SSI will stop after finished current character transfer and needn't wait for a whole completion of fixed number of characters' transfer.

Two Interval transfer mode are illustrated in the following figures. In these timing diagram, SSICR1.PHA = 0, SSICR1.POL = 0 and SSIICR = 0.



Figure 3-4 SPI Frame Interval Mode Transfer Format (ITFRM = 0, LFST = 0)





Figure 3-5 SPI Frame Interval Mode Transfer Format (ITFRM = 1, LFST = 1)

## 3.5.2 TI's SSP Format Details

sed only In this format, each transfer begins with SSI\_CE\_ pulsed high for one SSI\_CLK period. Then both master and slave drive data at SSI\_CLK's rising edge and sample data at the falling edge. Data are transferred with MSB first or LSB first. At the end of the transfer, SSI\_DT retains the value of the last bit sent through the next idle period.



Figure 3-6 TI's SSP Single Transfer Format





Figure 3-7 TI's SSP Back-to-back Transfer Format

## 3.5.3 National Microwire Format Details

It supports format 1 and format 2. If format 1 is selected, both master and slave drive data at SSI\_CLK falling edge and sample data at the rising edge. If format 2 is selected, master drive and sample data at SSI\_CLK falling edge, slave drive and sample data at SSI\_CLK rising edge. SSI\_CLK goes high midway through the command's most significant bit (or LSB) and continues to toggle at the bit rate. One bit clock (format 1) or half one bit clock (format 2) period after the last command bit, the external slave must return the serial data requested, with most significant bit first (or LSB first) on SSI\_DR. SSI\_CE\_ / SSI\_CE2 de-asserts high half clock (SSI\_CLK) period (and 1/2/3 additional clock periods) later. Format 1 support back-to-back transfer, the start and end of back-to-back transfers are similar to those of a single transfer. However, SSI\_CE\_ / SSI\_CE2 remains asserted throughout the transfer. The end of a character data on SSI\_DR is immediately followed by the start of the next command byte on SSI\_DT.



Figure 3-8 National Microwire Format 1 Single Transfer

74

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

JZ4770 Mobile Application Processor Peripherals Programming Manual









Figure 3-11 National Microwire Format 2 Write Timing

76



## 3.6 Interrupt Operation

In SSI, there are TXI, RXI, TEI and REI total 4 interrupts, all these interrupts are combined together to make one SSI interrupt, which can be masked by writing '1' into corresponding mask bit in INTC interrupt mask register (IMR).

| Operation | Condition                       | Flag Bit   | Mask Bit    | Interrupt | DMAC<br>Activation |
|-----------|---------------------------------|------------|-------------|-----------|--------------------|
| Transmit  | T-FIFO is half-empty<br>or less | SSISR.TFHE | SSICR0.TIE  | ТХІ       | Possible           |
|           | Transmit underrun error         | SSISR.UNDR | SSICR0.TEIE | TEI       | Impossible         |
| Receive   | R-FIFO is half-full or more     | SSISR.RFHF | SSICR0.RIE  | RXI       | Possible           |
|           | Receive overrun error           | SSISR.OVER | SSICR0.REIE | REI       | Impossible         |

#### **Table 3-3 SSI Interrupts**

Either SSISR.TFHE or SSISR.RFHF can activate DMA transferring when corresponding individual interrupt mask bit in SSICR0 is cleared (masked) and DMA is enabled and configured.



# **4 One-Wire Bus Interface**

## 4.1 Overview

The OWI has the following features:

- Support 1-wire bus protocol
- Support Overdrive speed mode and Regular speed mode
- Data is transferred with the LSB first
- Support bit operate mode and byte operate mode
- OWI is the only master on the bus

78



# 4.2 Pin Description

#### Table 4-1 One-Wire Controller Pins Description

| Name  | I/O          | Description          |
|-------|--------------|----------------------|
| OWDAT | Input/Output | One-Wire Data signal |

Long\_eiffel@126.com internal used only



## 4.3 Structure





# 4.4 Register Description

| Name  | Description           | RW | Reset Value | Address    | Access Size |
|-------|-----------------------|----|-------------|------------|-------------|
| OWCFG | Configure Register    | RW | 0x00        | 0x10072000 | 8           |
| OWCTL | Control Register      | RW | 0x00        | 0x10072004 | 8           |
| OWSTS | Status Register       | RW | 0x00        | 0x10072008 | 8           |
| OWDAT | Data Register         | RW | 0x00        | 0x1007200C | 8           |
| OWDIV | Clock Divide Register | RW | 0x00        | 0x10072010 | 8           |

## 4.4.1 One-Wire Configure Register (OWCFG)



| Bits | Name                | Description                                                               | RW |
|------|---------------------|---------------------------------------------------------------------------|----|
| 7    | MODE                | OWI mode select.                                                          | RW |
|      |                     | 0: Regular speed mode                                                     |    |
|      |                     | 1: Overdrive speed mode                                                   |    |
| 6    | RDDATA 🗙            | Receive a byte from one-wire bus. This bit is cleared when receive data   | RW |
|      | $\langle 0 \rangle$ | is complete. The value of received data is stored in OWDAT, and is        |    |
| 1    | ng                  | valid after RDDATA is self-cleared.                                       |    |
|      |                     | 0:Do nothing/Receive data is completed                                    |    |
|      |                     | 1:Receive data from one-wire bus and stored in OWDAT                      |    |
| 5    | WRDATA              | Transmit the data in OWDAT. This bit is cleared when the transmission     | RW |
|      |                     | of data is complete.                                                      |    |
|      |                     | 0: Do nothing/Transmission of data completed                              |    |
|      |                     | 1: Transmit the data in OWDAT                                             |    |
| 4    | RDST                | Read status. This bit is valid after the WR1/RD bit is self-cleared.      | R  |
|      |                     | 0: 0 was sampled during a read                                            |    |
|      |                     | 1: 1 was sampled during a read                                            |    |
| 3    | WR1/RD              | Write 1/ Read. This bit is cleared when the write of the bit is complete. | RW |
|      |                     | The valve of one wire can be read, since the Write 1 and Read timing      |    |
|      |                     | are identical. The value of the read bit is stored in RDST, and is valid  |    |
|      |                     | after WR1/RD is self-cleared.                                             |    |
|      |                     | 0: Do nothing/Write 1 sequence completed                                  |    |

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

0 0 0 0 0 0 0 0



|   |     | 1: Generate Write 1 sequence on line                                   |    |  |  |  |  |
|---|-----|------------------------------------------------------------------------|----|--|--|--|--|
| 2 | WR0 | Write 0 on line. This bit is cleared after the presence is determined. | RW |  |  |  |  |
|   |     | 0: Do nothing/Write 0 sequence completed                               |    |  |  |  |  |
|   |     | 1: Generate Write 0 sequence on line                                   |    |  |  |  |  |
| 1 | RST | Reset presence pulse. This bit is cleared after the presence is        | RW |  |  |  |  |
|   |     | determined.                                                            |    |  |  |  |  |
|   |     | 0: Do nothing. Reset pulse completed                                   |    |  |  |  |  |
|   |     | 1: Generate reset pulse and sample slaves presence pulse               |    |  |  |  |  |
| 0 | ENA | Enable of OWI operation.                                               | RW |  |  |  |  |
|   |     | 1: Write 1 to this bit to enable the OWI operation                     |    |  |  |  |  |
|   |     | 0: Write 0 to this bit to disable the OWI operation                    |    |  |  |  |  |

NOTE: To make the OWI operate normally, only one of the RST, RDDATA, WRDATA, WR1/RD and WR0 is equal to 1.

## 4.4.2 One-Wire Control Register (OWCTL)



#### RST

| Bits | Name     | Description                               | RW |
|------|----------|-------------------------------------------|----|
| 7:3  | Reserved | Writing has no effect, read as zero.      | R  |
| 2    | EBYTE    | Enable byte write / read interrupt.       | RW |
| 1    | EBIT     | Enable bit write / read interrupt.        | RW |
| 0    | ERST     | Enable reset sequence finished interrupt. | RW |

## 4.4.3 One-Wire Status Register (OWSTS)

| Bit 7 6 5 4 3 2 1 0<br>LSa Served<br>LSa Served |     | OWSTS |  |     |   |          |   | 0x10     | 0720    | 800     |
|-------------------------------------------------|-----|-------|--|-----|---|----------|---|----------|---------|---------|
| PST PST T RDY                                   | Bit | Bit   |  | 7   | 6 | 5        | 4 | 32       | 1       | 0       |
|                                                 |     |       |  | PST |   | Reserved |   | BYTE RDY | BIT_RDY | PST_RDY |
| RST 0 0 0 0 0 0 0 0 0 0                         | RS  | RST   |  | 0   | 0 | 0        | 0 | 0 0      | 0       | 0       |



| Bits | Name     | Description                                                           | RW |
|------|----------|-----------------------------------------------------------------------|----|
| 7    | PST      | Whether the 1-wire bus has device or not. This bit is valid after the | RW |
|      |          | RST bit is self-cleared.                                              |    |
|      |          | 1:The 1-wire bus has device on it                                     |    |
|      |          | 0:The 1-wire bus has no device on it                                  |    |
| 6:3  | Reserved | Writing has no effect, read as zero.                                  | R  |
| 2    | BYTE_RDY | Have received or transmitted a data.                                  | RW |
| 1    | BIT_RDY  | Have received or transmitted a bit.                                   | RW |
| 0    | PST_RDY  | Have finished a reset pulse.                                          | RW |

## 4.4.4 One-Wire Data Register (OWDAT)



| Bits | Name | Description                                                        | RW |
|------|------|--------------------------------------------------------------------|----|
| 7:0  | DATA | Store the received data and is valid after RDDATA is self-cleared. | RW |
|      |      | Prepare the transmission data for transmitting.                    |    |
|      |      | CO1@1.40                                                           |    |

# 4.4.5 One-Wire Clock Divide Register (OWDIV)



| Bits | Name     | Description                                                    | RW |
|------|----------|----------------------------------------------------------------|----|
| 7:6  | Reserved | Writing has no effect, read as zero.                           | R  |
| 5:0  | CLKDIV   | Controls the divider used to create the DEV_CLK based upon the | RW |
|      |          | CPM_OWI_SYSCLK.                                                |    |
|      |          | When the OWI work in the regular speed mode:                   |    |
|      |          | 1 MHz = DEV_CLK = CPM_OWI_SYSCLK / (CLKDIV + 1).               |    |
|      |          | When the OWI work in the overdrive speed mode:                 |    |
|      |          | 4 MHz = DEV_CLK = CPM_OWI_SYSCLK / (CLKDIV + 1).               |    |

82

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



## 4.5 One-Wire Bus Protocol

## 4.5.1 Reset Timing and ACK Timing



|                      | RSTH  | RSTL  | RSTS |
|----------------------|-------|-------|------|
| Regular Speed mode   | 512us | 512us | 68us |
| Overdrive Speed mode | 64us  | 64us  | 8us  |

## 4.5.2 Write 0 Timing



| • {                  | 10    |       |
|----------------------|-------|-------|
| e1,                  | SLOT  | LOW0  |
| Regular Speed mode   | 128us | 100us |
| Overdrive Speed mode | 16us  | 12us  |

## 4.5.3 Write 1 Timing



|                      | SLOT  | LOW1   |
|----------------------|-------|--------|
| Regular Speed mode   | 128us | 5us    |
| Overdrive Speed mode | 16us  | 1.25us |



# 4.5.4 Read0 Timing



|                      | SLOT  | LOWR   | RDS    |
|----------------------|-------|--------|--------|
| Regular Speed mode   | 128us | 5us    | 13us   |
| Overdrive Speed mode | 16us  | 1.25us | 1.75us |

## 4.5.5 Read1 Timing

84



| : {                  | SLOT  | LOWR   | RDS    |
|----------------------|-------|--------|--------|
| Regular Speed mode   | 128us | 5us    | 13us   |
| Overdrive Speed mode | 16us  | 1.25us | 1.75us |



## 4.6 One-Wire Operation Guide

#### • Interrupt operation guide:

- 1 Write the frequency divider to I2CGR.
- 2 Set OWSTS to clear the flag.
- 3 Set OWCTL to enable the operation interrupt.
- 4 Select OWI mode (Regular speed mode or Overdrive speed mode).
- 5 Set RST, RDDATA, WRDATA, WR1/RD or WR0 to choose one kind of operation.
- 6 Set ENA to enable OWI.
- 7 Wait till the interrupt happened, and the operation is finished.
- 8 If you want to disable OWI when OWI is working, you should set ENA to 0 and till ENA is really set to 0, then you can do next operation.

#### • CPU operation guide:

- 1 Write the frequency divider to I2CGR.
- 2 Select OWI mode (Regular speed mode or Overdrive speed mode).
- 3 Set RST, RDDATA, WRDATA, WR1/RD or WR0 to choose one kind of operation.
- 4 Set ENA to enable OWI.
- 5 Wait the ENA is cleared, and the operation is finished
- 6 If you want to disable OWI when OWI is working, you should set ENA to 0 and till ENA is really set to 0, then you can do next operation.



# **5 USB Host Controller**

## 5.1 Overview

This chapter describes the Universal Serial Bus host controller (UHC) implemented in the XBurst processor.

The Universal Serial Bus (USB) supports serial data exchanges between a host computer and a variety of simultaneously accessible peripherals. The attached peripherals share USB bandwidth through a host-scheduled, token-based protocol. Peripherals can be attached, configured, used, and detached, while the host and other peripherals continue operation.

Familiarity with the Universal Serial Bus Specification, Revision 1.1 and the OHCI specification are USB Rev. 1.1 compatible Supports both low-speed and full-speed USB devices Certain Open Host Controller Interface (OHCI) Rev 1.0 compared necessary to fully understand the material contained in this section.

Features:

- •
- •
- •

86



# 5.2 Pin Description

| Name  | Туре  | Description             |
|-------|-------|-------------------------|
| DPLS0 | Inout | Data Positive to Port 0 |
| DPLS1 | Inout | Data Positive to Port 1 |
| DMNS0 | Inout | Data Minus to Port 0    |
| DMNS1 | Inout | Data Minus to Port 1    |

#### Table 5-1 UHC Pins Description

Long\_eiffel@126.com internal used only



## 5.3 Register Description

The Host Controller (HC) contains a set of on-chip operational registers which are mapped into a noncacheable portion of the system addressable space. These registers are used by the Host Controller Driver (HCD). According to the function of these registers, they are divided into four partitions, specifically for Control and Status, Memory Pointer, Frame Counter and Root Hub. All of the registers should be read and written as words.

| Register Name      | Description                           | RW  | Reset Value | Address    | Access<br>Size |
|--------------------|---------------------------------------|-----|-------------|------------|----------------|
| HcRevision         |                                       | R   | 0x00000010  | 0x13430000 | 32             |
| HcControl          |                                       | RW  | 0x00000000  | 0x13430004 | 32             |
| HcCommandStatus    | Status group                          | RW  | 0x00000000  | 0x13430008 | 32             |
| HcInterruptStatus  |                                       | RW  | 0x00000000  | 0x1343000C | 32             |
| HcInterruptEnable  |                                       | RW  | 0x0000000   | 0x13430010 | 32             |
| HcInterruptDisable |                                       | RW  | 0x0000000   | 0x13430014 | 32             |
| HcHCCA             |                                       | RW  | 0x0000000   | 0x13430018 | 32             |
| HcPeriodCurrentED  |                                       | R   | 0x00000000  | 0x1343001C | 32             |
| HcControlHeadED    | Memory pointer<br>group               | RW  | 0x0000000   | 0x13430020 | 32             |
| HcControlCurrentED |                                       | RW  | 0x00000000  | 0x13430024 | 32             |
| HcBulkHeadED       |                                       | RW  | 0x00000000  | 0x13430028 | 32             |
| HcBulkCurrentED    |                                       | RW  | 0x00000000  | 0x1343002C | 32             |
| HcDoneHead         |                                       | R   | 0x0000000   | 0x13430030 | 32             |
| HcFmInterval       | . 96.                                 | RW  | 0x00002EDF  | 0x13430034 | 32             |
| HcFmRemaining      | Frame counter                         | R   | 0x00000000  | 0x13430038 | 32             |
| HcFmNumber         | $\mathcal{L} \mathcal{O} \mathcal{L}$ | R   | 0x00000000  | 0x1343003C | 32             |
| HcPeriodicStart    | group                                 | RW  | 0x00000000  | 0x13430040 | 32             |
| HcLSThreshold      |                                       | RW  | 0x00000628  | 0x13430044 | 32             |
| HcRhDescriptorA    |                                       | R/W | 0x02000902  | 0x13430048 | 32             |
| HcRhDescriptorB    |                                       | RW  | 0x00060000  | 0x1343004C | 32             |
| HcRhStatus         | Root hub group                        | RW  | 0x00000000  | 0x13430050 | 32             |
| HcRhPortStatus 1   |                                       | RW  | 0x00000100  | 0x13430054 | 32             |
| HcRhPortStatus 2   |                                       | RW  | 0x00000100  | 0x13430058 | 32             |

**NOTE:** Open HCI – Open Host Controller Specification for USB for details of the each register.

88



## 5.4 Introduction

The Host Controller is the device which is located between the USB bus and the Host Controller Driver in the OpenHCI architecture. The Host Controller is charged with processing all of the Data Type lists built by the Host Controller Driver. Additionally, the USB Root Hub is attached to the Host Controller.

The main functions as following:

- **USB States**: the Host Controller Operation with respect to the possible USB Bus states.
- Frame Management: all aspects of managing the 1-ms USB Frame. •
- List Processing: the main function of the Host Controller. the detailed processing of the • HCD-built Data Type lists.
- Interrupt Processing: the interrupt events tracked by the Host Controller and how the Host Long eitfel@126.com internal used only Controller provides interrupts for those events.



# 6 OTG Controller

## 6.1 Overview

This chapter describes the USB On-The-Go (OTG) implemented in the processor.

The Universal Serial Bus (USB) supports serial data exchanges between a host computer and a variety of simultaneously accessible portable peripherals. Many of these portable devices would benefit a lot from being able to communicate to each other over the USB interface. And OTG make this possible. An OTG device can plays the role of both host and device.

Familiarity with the *Universal Serial Bus Specification*, Revision 1.1 and OTG supplement are necessary to fully understand the material contained in this section.

Features:

- Complies with the USB 2.0 standard for high-speed (480 Mbps) functions and with the On-The-Go supplement to the USB 2.0 specification
- Operates either as the function controller of a high- /full-speed USB peripheral or as the host/peripheral in point-to-point or multi-point communications with other USB functions
- Supports Session Request Protocol (SRP) and Host Negotiation Protocol (HNP)
- UTMI+ Level 3 Transceiver Interface
- Soft connect/disconnect
- 5 DMA channels
- Supports control, interrupt, ISO and bulk transfer



# 6.2 Pin Description

| Table 6-1 OTG Pins Description |  |
|--------------------------------|--|
|--------------------------------|--|

| Name    | Туре  | Description        |
|---------|-------|--------------------|
| DP      | Inout | Data Positive      |
| DM      | Inout | Data Minus         |
| ID      | Inout | Identification     |
| drvvbus | Out   | Charge pump enable |

Long\_eiffel@126.com internal used only



# 6.3 Register Description

The OTG Controller (OTGC) contains a set of on-chip operational registers which are mapped into a noncacheable portion of the system addressable space. These registers are used by the OTG Controller Driver.

| Nomo             | Description                       | RW  |     | Reset     | Adduces    | Access |
|------------------|-----------------------------------|-----|-----|-----------|------------|--------|
| Name             |                                   | CPU | USB | Value     | Address    | Size   |
| FAddr            | Function address register         | RW  | R   | 8'h00     | 0x13440000 | 8      |
| Power            | Power management register         | RW  | RW  | 8'h20     | 0x13440001 | 8      |
| IntrTx           | Interrupt register for Endpoint 0 | R   | S   | 16'h00    | 0x13440002 | 16     |
|                  | plus TX Endpoints 1 to 15         |     |     | 00        |            |        |
| IntrRx           | Interrupt register for Rx         | R   | S   | 16'h00    | 0x13440004 | 16     |
|                  | Endpoints 1 to 15                 |     |     | 00        |            | 73     |
| IntrTxE          | Interrupt enable register for     | RW  | R   | 16'hffff  | 0x13440006 | 16     |
|                  | IntrTx                            |     |     |           | Seu        |        |
| IntrRxE          | Interrupt enable register for     | RW  | R   | 16'hfff   | 0x13440008 | 16     |
|                  | IntrRx                            |     | ~~~ | e         |            |        |
| IntrUSB          | Interrupt register for common     | R   | S   | 8'h00     | 0x1344000a | 8      |
|                  | USB interrupts                    | 711 |     |           |            |        |
| IntrUSBE         | Interrupt enable register for     | RW  | R   | 8'h06     | 0x1344000b | 8      |
|                  | IntrUSB                           |     |     |           |            |        |
| Frame            | Frame Number                      | R   | W   | 16'h00    | 0x1344000c | 16     |
|                  | efer-                             |     |     | 00        |            |        |
| Index            | Index register for selecting the  | RW  | R   | 4'h0      | 0x1344000e | 4      |
| 20               | endpoint status and control       |     |     |           |            |        |
| 10110            | registers                         |     |     |           |            |        |
| TestMode         | Enables the USB 2.0 test          | RW  | R   | 8'h00     | 0x1344000f | 8      |
|                  | modes                             |     |     |           |            |        |
| TxMaxP           | Maximum packet size for           | RW  | R   | 16'h00    | 0x13440010 | 16     |
|                  | peripheral TX endpoint (Index     |     |     | 00        |            |        |
|                  | register set to select Endpoints  |     |     |           |            |        |
|                  | 1 – 15 only)                      |     |     |           |            |        |
| CSR0L/H          | Control Status register for       | RW  | RW  | 16'h00    | 0x13440012 | 16     |
|                  | Endpoint 0 (Index register set    |     |     | 00        |            |        |
| <b>T</b> 0051 #1 | to select Endpoint 0)             |     |     |           |            |        |
| TxCSRL/H         | Control Status register for       |     |     |           |            |        |
|                  | peripheral TX endpoint (Index     |     |     |           |            |        |
|                  | register set to select Endpoints  |     |     |           |            |        |
| DuMauD           | 1 – 15)                           |     |     | 4.021-0.0 | 0.40440044 | 10     |
| RxMaxP           | Maximum packet size for           | RW  | R   | 16'h00    | 0x13440014 | 16     |

#### Table 6-2 OTG Registers Description

92

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|            | peripheral Rx endpoint (Index<br>register set to select Endpoints<br>1 – 15 only)                                                                                                                   |    |      | 00           |            |    |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------|--------------|------------|----|
| RxCSRL/H   | Control Status register for<br>peripheral Rx endpoint (Index<br>register set to select Endpoints<br>1 – 15 only)                                                                                    | RW | RW   | 16'h00<br>00 | 0x13440016 | 16 |
| Count0     | Number of received bytes in<br>Endpoint 0 FIFO (Index<br>register set to select Endpoint<br>0)                                                                                                      | R  | W    | 7'h00        | 0x13440018 | 7  |
| RxCount    | Number of bytes to be read<br>from peripheral Rx endpoint<br>FIFO (Index register set to<br>select Endpoints 1 – 15)                                                                                |    |      |              |            | 17 |
| Туре0      | Defines the speed of Endpoint<br>0 (Index register set to select<br>Endpoint 0)                                                                                                                     | RW | R    | 8'h0         | 0x1344001a | 8  |
| ТхТуре     | Sets the transaction protocol,<br>speed and peripheral endpoint<br>number for the host TX<br>endpoint (Index register set to<br>select Endpoints $1 - 45$ )                                         | in | terr | 8'h0         |            |    |
| NakLimit0  | Sets the NAK response<br>timeout on Endpoint 0 (Index<br>register set to select Endpoint<br>0)                                                                                                      | RW | R    | 8'h00        | 0x1344001b | 8  |
| TxInterval | Sets the polling interval for<br>Interrupt/ISOC transactions or<br>the NAK response timeout on<br>Bulk transactions for host TX<br>endpoint (Index register set to<br>select Endpoints 1 – 15 only) |    |      |              |            |    |
| RxТуре     | Sets the transaction protocol,<br>speed and peripheral endpoint<br>number for the host Rx<br>endpoint (Index register set to<br>select Endpoints 1 – 15 only)                                       | RW | R    | 8'h00        | 0x1344001c | 8  |



| Dydataayol | Coto the polling interval for         |       | П  | 0'600  | 0.12440014 | 0        |
|------------|---------------------------------------|-------|----|--------|------------|----------|
| RxInterval | Sets the polling interval for         | RW    | R  | 8'h00  | 0x1344001d | 8        |
|            | Interrupt/ISOC transactions or        |       |    |        |            |          |
|            | the NAK response timeout on           |       |    |        |            |          |
|            | Bulk transactions for host Rx         |       |    |        |            |          |
|            | endpoint (Index register set to       |       |    |        |            |          |
|            | select Endpoints 1 – 15 only)         |       | _  |        |            | -        |
| ConfigData | Returns details of core               | R     | R  | 8'h??  | 0x1344001f | 8        |
|            | configuration (Index register         |       |    |        |            |          |
|            | set to select Endpoint 0)             |       |    |        |            |          |
| FifoSize   | Returns the configured size of        |       |    |        |            |          |
|            | the selected Rx FIFO and TX           |       |    |        |            |          |
|            | FIFOs (Endpoints 1 – 15 only)         |       |    |        |            |          |
| FIFOx      | FIFOs for Endpoints 0 – 15            | RW    | -  | 32'h?? | 0x13440020 | 32       |
| DevCtl     | OTG device control register           | RW    | RW | 8'h80  | 0x13440060 | 8        |
| MISC       | Miscellaneous Register                | RW    | RW | 8'h00  | 0x13440061 | 8        |
| VControl   | UTMI+ PHY Vendor registers            | R     | R  | 4'h?   | 0x13440068 | 4        |
| Vstatus    | UTMI+ PHY Vendor registers            | R     | R  | 8'h??  | 0x1344006a | 8        |
| HWVers     | Hardware Version Number               | R     | R  | 16'h?? | 0x1344006c | 16       |
|            | Register                              |       |    | 2?     |            |          |
| EPInfo     | Information about numbers of          | R ,   | R  | 8'h??  | 0x13440078 | 8        |
|            | TX and Rx endpoints                   | JV.   |    |        |            |          |
| RAMInfo    | Information about the width of        | R     | R  | 8'h??  | 0x13440079 | 8        |
|            | the RAM and the number of             |       |    |        |            |          |
|            | DMA channels                          |       |    |        |            |          |
| LinkInfo   | Information about delays to be        | RW    | R  | 8'h5c  | 0x1344007a | 8        |
|            | applied                               |       |    |        |            |          |
| VPLen      | Duration of the VBus pulsing          | RW    | R  | 8'h3c  | 0x1344007b | 8        |
| 1008       | charge                                |       |    |        |            |          |
| HS_EOF1    | Time buffer available on              | RW    | R  | 8'h80  | 0x1344007c | 8        |
| _          | High-Speed transactions               |       |    |        |            |          |
| FS_EOF1    | Time buffer available on              | RW    | R  | 8'h77  | 0x1344007d | 8        |
| -          | Full-Speed transactions               |       |    |        |            |          |
| LS_EOF1    | Time buffer available on              | RW    | R  | 8'h72  | 0x1344007e | 8        |
| _          | Low-Speed transactions                |       |    | -      |            | -        |
| SoftRst    | Soft reset                            | RW    | R  | 8'h00  | 0x1344007f | 8        |
| TxFuncAddr | Transmit Endpoint <i>n</i> Function   | RW    | R  | 7'h00  | 0x13440080 | 7        |
|            | Address (Host Mode only)              |       |    |        | +8*n       |          |
| TxHubAddr  | Transmit Endpoint <i>n</i> Hub        | RW    | R  | 8'h00  | 0x13440082 | 8        |
|            | Address (Host Mode only)              |       |    |        | +8*n       | Ĩ        |
| TxHubPort  | Transmit Endpoint <i>n</i> Hub Port   | RW    | R  | 7'h00  | 0x13440083 | 7        |
|            | (Host Mode only)                      | 1.1.1 |    | 7 1100 | +8*n       | <b>'</b> |
| RxFuncAddr | · · · · · · · · · · · · · · · · · · · | RW    | R  | 7'h00  | 0x13440084 | 7        |
| TAFUNCAUUI | Receive Endpoint <i>n</i> Function    |       | Г  | 7 1100 | 0713440004 | 1        |

94



|              |                                    |      |              |        | . 0 *       |    |
|--------------|------------------------------------|------|--------------|--------|-------------|----|
|              | Address (Host Mode only)           |      |              |        | +8*n        |    |
| RxHubAddr    | Receive Endpoint <i>n</i> Hub      | RW   | R            | 8'h00  | 0x13440086  | 8  |
|              | Address (Host Mode only)           |      |              |        | +8*n        |    |
| RxHubPort    | Receive Endpoint <i>n</i> Hub Port | RW   | R            | 7'h00  | 0x13440087  | 7  |
|              | (Host Mode only)                   |      |              |        | +8*n        |    |
| DMA_INTR     | DMA Interupt register              | RW   | S            | 8'h00  | 0x13440200  | 8  |
| DMA_CNTL     | DMA Control Register for DMA       | RW   | R            | 11'h00 | 0x13440204  | 11 |
|              | channel n (channel 1 thru 8)       |      |              |        | +(n-1)*0x10 |    |
| DMA_ADDR     | DMA Address Register for           | RW   | RW           | 32'h00 | 0x13440208  | 32 |
|              | DMA channel n (channel 1 thru      |      |              | 00000  | +(n-1)*0x10 |    |
|              | 8)                                 |      |              | 0      |             |    |
| DMA_COUNT    | DMA Count Register for DMA         | RW   | RW           | 32'h00 | 0x1344020c  | 32 |
|              | channel n (channel 1 thru 8)       |      |              | 00000  | +(n-1)*0x10 |    |
|              |                                    |      |              | 0      |             |    |
| RqPktCount   | Number of requested packets        | RW   | RW           | 16'h00 | 0x13440300  | 16 |
|              | for Receive Endpoint n             |      |              | 00     | +4*n        |    |
|              | (Endpoints 1 – 15 only)            |      |              |        | $ce^{O}$    |    |
| RmtWkIntr    | Usb remote wake up interrupt       | R    | S            | 1'b0   | 0x13440398  | 1  |
|              | register                           |      |              | 181    |             |    |
| RmtWkIntrE   | Usb remote wake up interrupt       | RW ) | R            | 1'b0   | 0x1344039c  | 1  |
|              | register enable                    | 11   | $\mathbf{V}$ |        |             |    |
| RxDPktBufDis | Double Packet Buffer Disable 🕥     | RW   | R            | 16'h00 | 0x13440340  | 16 |
|              | register for Rx Endpoints Ho       |      |              | 00     |             |    |
|              | 15                                 |      |              |        |             |    |
| TxDPktBufDis | Double Packet Buffer Disable       | RW   | R            | 16'h00 | 0x13440342  | 16 |
|              | register for TX Endpoints 1 to     |      |              | 00     |             |    |
| ~            | 15                                 |      |              |        |             |    |
| C_T_UCH      | This register sets the Chirp       | RW   | -            | 16'h?  | 0x13440344  | 16 |
| - 70,        | Timeout Timer                      |      |              |        |             |    |
| C_T_HSRTN    | This register sets the delay       | RW   | -            | 16'h?  | 0x13440346  | 16 |
|              | from the end of High Speed         |      |              |        |             |    |
|              | resume signaling to enable         |      |              |        |             |    |
|              | UTM normal operating mode          |      |              |        |             |    |
| C_T_HSBT     | HS Timeout Adder                   | RW   | R            | 4'h0   | 0x13440348  | 4  |
|              | 1                                  |      |              |        |             | 1  |

#### NOTE:

In the following bit descriptions:

'r' means that the bit is read only 'rw' means that the bit can be both read and written. 'set' means that the bit can only be written to set it 'r/set' means that the bit can be read or set but it can't be cleared.

'clear' means that the bit can only be written to clear it 'r/clear' means that the bit can be read or cleared but it can't be set.

96



'self-clearing' means the bit will be cleared automatically when the associated action has been executed.

Long\_eiffel@126.com internal used only



## 6.4 Common registers

## 6.4.1 FAddr

FAddr is an 8-bit register that should be written with the 7-bit address of the peripheral part of the transaction.

When the MUSBHDRC is being used in Peripheral mode (DevCtl.D2=0), this register should be written with the address received through a SET ADDRESS command, which will then be used for decoding the function address in subsequent token packets.

## NOTE: Peripheral Mode Only!!



| Bits  |       | Name    | Description           | CPU | USB |
|-------|-------|---------|-----------------------|-----|-----|
| 7     | -     |         | Unused. Always 0.     | R   | -   |
| 6:0   | FAddr |         | The function address. | RW  | R   |
| 6.4.2 | Power | ca1@128 |                       |     |     |

## 6.4.2 Power

Power is an 8-bit register that is used for controlling Suspend and Resume signaling, and some basic operational aspects of the MUSBHDRC.



98



| Bits | Name       | Description                                                                    | CPU | USB |
|------|------------|--------------------------------------------------------------------------------|-----|-----|
| 7    | ISO Update | When set by the CPU, the MUSBHDRC will wait for an SOF token                   | P:  | P:  |
|      |            | from the time TxPktRdy is set before sending the packet. If an IN              | RW  | R   |
|      |            | token is received before an SOF token, then a zero length data                 | H:  | H:  |
|      |            | packet will be sent.                                                           | -   | -   |
|      |            | NOTE: Only valid in Peripheral Mode. Also, this bit only affects               |     |     |
|      |            | endpoints performing Isochronous transfers.                                    |     |     |
| 6    | Soft Conn  | If Soft Connect/Disconnect feature is enabled, then the USB                    | P:  | P:  |
|      |            | D+/D- lines are enabled when this bit is set by the CPU and                    | RW  | R   |
|      |            | tri-stated when this bit is cleared by the CPU.                                | H:  | H:  |
|      |            | NOTE: Only valid in Peripheral Mode.                                           | -   | -   |
| 5    | HS Enab    | When set by the CPU, the MUSBHDRC will negotiate for                           | P:  | P:  |
|      |            | High-speed mode when the device is reset by the hub. If not set,               | RW  | R   |
|      |            | the device will only operate in Full-speed mode.                               | H:  | H:  |
|      |            |                                                                                | RW  | R   |
| 4    | HS Mode    | When set, this read-only bit indicates High-speed mode $\sqrt{-0}$             | P:  | P:  |
|      |            | successfully negotiated during USB reset. In Peripheral Mode,                  | R   | RW  |
|      |            | becomes valid when USB reset completes (as indicated by USB                    | H:  | H:  |
|      |            | reset interrupt). In Host Mode, becomes valid when Reset bit is                | R   | RW  |
|      |            | cleared. Remains valid for the duration of the session.                        |     |     |
|      |            | <b>NOTE:</b> Allowance is made for <b>Tiny</b> -J signaling in determining the |     |     |
|      |            | transfer speed to select.                                                      |     |     |
| 3    | Reset      | This bit is set when Reset signaling is present on the bus.                    | P:  | P:  |
|      |            | NOTE: This bit is Read/Write from the CPU inHost Mode but                      | R   | RW  |
|      |            | Read-Only in Peripheral Mode.                                                  | H:  | H:  |
|      | •          | ft <sup>e</sup>                                                                | RW  | RW  |
| 2    | Resume     | Set by the CPU to generate Resume signaling when the function                  | P:  | P:  |
|      | ng-        | is in Suspend mode. The CPU should clear this bit after 10 ms (a               | RW  | R   |
| )    | Or         | maximum of 15 ms) to end Resume signaling. In Host mode, this                  | H:  | H:  |
|      |            | bit is also automatically set when Resume signaling from the                   | RW  | R   |
|      |            | target is detected while the MUSBHDRC is suspended.                            |     |     |
| 1    | Suspend    | In Host mode, this bit is set by the CPU to enter Suspend mode.                | P:  | P:  |
|      | Mode       | In Peripheral mode, this bit is set on entry into Suspend mode. It             | R   | RW  |
|      |            | is cleared when the CPU reads the interrupt register, or sets the              | H:  | H:  |
|      |            | Resume bit above.                                                              | set | clr |
| 0    | Enable     | Set by the CPU to enable the SUSPENDM output.                                  | P:  | P:  |
|      | SuspendM   |                                                                                | RW  | R   |
|      |            |                                                                                | H:  | H:  |
|      |            |                                                                                | RW  | R   |



## 6.4.3 IntrTx

IntrTx is a 16-bit read-only register that indicates which interrupts are currently active for Endpoint 0 and the Tx Endpoints 1–15.

**NOTE:** Bits relating to endpoints that have not been configured will always return 0. Note also that all active interrupts are cleared when this register is read.

| IntrTx | 0x13440002                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit    | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|        | EP15TX<br>EP14TX<br>EP14TX<br>EP14TX<br>EP14TX<br>EP14TX<br>EP11TX<br>EP11TX<br>EP11TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EP1TX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPTTX<br>EPT |
| RST    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

|      |           |                           | NY  | J   |
|------|-----------|---------------------------|-----|-----|
| Bits | Name      | Description 🔨 🤇           | CPU | USB |
| 15   | EP15Tx    | Tx Endpoint 15 interrupt. | R   | Set |
| 14   | EP14Tx    | Tx Endpoint 14 interrupt. | R   | Set |
| 13   | EP13Tx    | Tx Endpoint 13 interrupt  | R   | Set |
| 12   | EP12Tx    | Tx Endpoint 12 interrupt. | R   | Set |
| 11   | EP11Tx    | Tx Endpoint 11 interrupt. | R   | Set |
| 10   | EP10Tx    | Tx Endpoint 10 interrupt. | R   | Set |
| 9    | EP9Tx     | Tx Endpoint 9 interrupt.  | R   | Set |
| 8    | EP8Tx     | Tx Endpoint 8 interrupt.  | R   | Set |
| 7    | EP7Tx cfe | Tx Endpoint 7 interrupt.  | R   | Set |
| 6    | EP6Tx     | Tx Endpoint 6 interrupt.  | R   | Set |
| 5    | EP5Tx     | Tx Endpoint 5 interrupt.  | R   | Set |
| 4 🔨  | EP4Tx     | Tx Endpoint 4 interrupt.  | R   | Set |
| 3    | EP3Tx     | Tx Endpoint 3 interrupt.  | R   | Set |
| 2    | EP2Tx     | Tx Endpoint 2 interrupt.  | R   | Set |
| 1    | EP1Tx     | Tx Endpoint 1 interrupt.  | R   | Set |
| 0    | EP0       | Tx Endpoint 0 interrupt.  | R   | Set |

## 6.4.4 IntrRx

IntrRx is a 16-bit read-only register that indicates which of the interrupts for Rx Endpoints 1 - 15 are currently active.

**NOTE:** Bits relating to endpoints that have not been configured will always return 0. Note also that all active interrupts are cleared when this register is read.



| INTRRX |        |        |        |        |        |        |       |       |              |       |       | C     | )x1:  | 304   | 000   | 4 |
|--------|--------|--------|--------|--------|--------|--------|-------|-------|--------------|-------|-------|-------|-------|-------|-------|---|
| Bit    | 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     | 7            | 6     | 5     | 4     | 3     | 2     | 1     | 0 |
|        | EP15Rx | EP14Rx | EP13Rx | EP12Rx | EP11Rx | EP10Rx | EP9Rx | EP8Rx | <b>EP7Rx</b> | XH943 | EP5Rx | EP4Rx | EP3Rx | EP2Rx | EP1Rx |   |
| RST    | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     | 0            | 0     | 0     | 0     | 0     | 0     | 0     | 0 |

#### R

| Bits | Name   | Description               | CPU | USB |
|------|--------|---------------------------|-----|-----|
| 15   | EP15Rx | Rx Endpoint 15 interrupt. | R   | Set |
| 14   | EP14Rx | Rx Endpoint 14 interrupt. | R   | Set |
| 13   | EP13Rx | Rx Endpoint 13 interrupt. | R   | Set |
| 12   | EP12Rx | Rx Endpoint 12 interrupt. | R   | Set |
| 11   | EP11Rx | Rx Endpoint 11 interrupt. | R   | Set |
| 10   | EP10Rx | Rx Endpoint 10 interrupt. | R   | Set |
| 9    | EP9Rx  | Rx Endpoint 9 interrupt.  | R   | Set |
| 8    | EP8Rx  | Rx Endpoint 8 interrupt.  | R   | Set |
| 7    | EP7Rx  | Rx Endpoint 7 interrupt.  | R   | Set |
| 6    | EP6Rx  | Rx Endpoint 6 interrupt.  | R   | Set |
| 5    | EP5Rx  | Rx Endpoint 5 interrupt.  | R   | Set |
| 4    | EP4Rx  | Rx Endpoint 4 interrupt.  | R   | Set |
| 3    | EP3Rx  | Rx Endpoint 3 interrupt.  | R   | Set |
| 2    | EP2Rx  | Rx Endpoint 2 interrupt.  | R   | Set |
| 1    | EP1Rx  | Rx Endpoint 1 interrupt.  | R   | Set |
| 0    | - cfer | Unused, always returns 0. | R   | R   |
|      | elli   |                           |     |     |

## 6.4.5 IntrTxE

IntrTxE is a 16-bit register that provides interrupt enable bits for the interrupts in IntrTx. On reset, the bits corresponding to Endpoint 0 and the Tx endpoints included in the design are set to 1, while the remaining bits are set to 0.

NOTE: Bits relating to endpoints that have not been configured will always return 0.

| IntrTxE | 0x13440                                                                                                                                                                                                                 | 006 |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit     | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1                                                                                                                                                                                     | 0   |
|         | EP15Tx<br>EP14Tx<br>EP14Tx<br>EP13Tx<br>EP13Tx<br>EP13Tx<br>EP10Tx<br>EP10Tx<br>EP10Tx<br>EP10Tx<br>EP10Tx<br>EP10Tx<br>EP1Tx<br>EP1Tx<br>EP1Tx<br>EP1Tx<br>EP1Tx<br>EP1Tx<br>EP1Tx<br>EP1Tx<br>EP1Tx<br>EP1Tx<br>EP1Tx | EPO |
| RST     | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                                                                                                                                                                       | 1   |

#### 100

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| Bits | Name   | Description                      | CPU | USB |
|------|--------|----------------------------------|-----|-----|
| 15   | EP15Tx | Tx Endpoint 15 interrupt enable. | RW  | R   |
| 14   | EP14Tx | Tx Endpoint 14 interrupt enable. | RW  | R   |
| 13   | EP13Tx | Tx Endpoint 13 interrupt enable. | RW  | R   |
| 12   | EP12Tx | Tx Endpoint 12 interrupt enable. | RW  | R   |
| 11   | EP11Tx | Tx Endpoint 11 interrupt enable. | RW  | R   |
| 10   | EP10Tx | Tx Endpoint 10 interrupt enable. | RW  | R   |
| 9    | EP9Tx  | Tx Endpoint 9 interrupt enable.  | RW  | R   |
| 8    | EP8Tx  | Tx Endpoint 8 interrupt enable.  | RW  | R   |
| 7    | EP7Tx  | Tx Endpoint 7 interrupt enable.  | RW  | R   |
| 6    | EP6Tx  | Tx Endpoint 6 interrupt enable.  | RW  | R   |
| 5    | EP5Tx  | Tx Endpoint 5 interrupt enable.  | RW  | R   |
| 4    | EP4Tx  | Tx Endpoint 4 interrupt enable.  | RW  | R   |
| 3    | EP3Tx  | Tx Endpoint 3 interrupt enable.  | RW  | R   |
| 2    | EP2Tx  | Tx Endpoint 2 interrupt enable.  | RW  | R   |
| 1    | EP1Tx  | Tx Endpoint 1 interrupt enable.  | RW  | R   |
| 0    | EP0    | Tx Endpoint 0 interrupt enable.  | RW  | R   |

## 6.4.6 IntrRxE

terna IntrRxE is a 16-bit register that provides interrupt enable bits for the interrupts in IntrRx. On reset, the bits corresponding to the Rx endpoints included in the design are set to 1, while the remaining bits are set to 0.

NOTE: Bits relating to endpoints that have not been configured will always return 0.

IntrRxE 0x13440008 Bit 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 EP14Rx EP15Rx EP13Rx EP12Rx EP11Rx EP10Rx **EP9Rx** EP8Rx **EP7Rx** EP6Rx EP4Rx **EP5Rx EP3Rx** EP2Rx EP1Rx RST 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0

| Bits | Name   | Description                      | CPU | USB |
|------|--------|----------------------------------|-----|-----|
| 15   | EP15Rx | Rx Endpoint 15 interrupt enable. | RW  | R   |
| 14   | EP14Rx | Rx Endpoint 14 interrupt enable. | RW  | R   |
| 13   | EP13Rx | Rx Endpoint 13 interrupt enable. | RW  | R   |
| 12   | EP12Rx | Rx Endpoint 12 interrupt enable. | RW  | R   |
| 11   | EP11Rx | Rx Endpoint 11 interrupt enable. | RW  | R   |
| 10   | EP10Rx | Rx Endpoint 10 interrupt enable. | RW  | R   |

101

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| r |       |                                 |    |   |
|---|-------|---------------------------------|----|---|
| 9 | EP9Rx | Rx Endpoint 9 interrupt enable. | RW | R |
| 8 | EP8Rx | Rx Endpoint 8 interrupt enable. | RW | R |
| 7 | EP7Rx | Rx Endpoint 7 interrupt enable. | RW | R |
| 6 | EP6Rx | Rx Endpoint 6 interrupt enable. | RW | R |
| 5 | EP5Rx | Rx Endpoint 5 interrupt enable. | RW | R |
| 4 | EP4Rx | Rx Endpoint 4 interrupt enable. | RW | R |
| 3 | EP3Rx | Rx Endpoint 3 interrupt enable. | RW | R |
| 2 | EP2Rx | Rx Endpoint 2 interrupt enable. | RW | R |
| 1 | EP1Rx | Rx Endpoint 1 interrupt enable. | RW | R |
| 0 | -     | Unused, always returns 0.       | R  | R |

## 6.4.7 IntrUSB

IntrUSB is an 8-bit read-only register that indicates which USB interrupts are currently active. All active interrupts will be cleared when this register is read.



#### RST

|      | $(0, 1^{-1})$ |                                                | <b>r</b> |     |
|------|---------------|------------------------------------------------|----------|-----|
| Bits | Name          | Description                                    | CPU      | USB |
| 7    | Vbus Error    | Set when VBus drops below the VBus Valid       | R        | Set |
|      | O E           | threshold during a session. Only valid when    |          |     |
| 1    | 0118-         | MUSBHDRC is 'A' device.                        |          |     |
| 6    | Sess Req      | Set when Session Request signaling has         | R        | Set |
|      |               | been detected. Only valid when                 |          |     |
|      |               | MUSBHDRC is 'A' device.                        |          |     |
| 5    | Discon        | Set in Host mode when a device disconnect      | R        | Set |
|      |               | is detected. Set in Peripheral mode when a     |          |     |
|      |               | session ends. Valid at all transaction speeds. |          |     |
| 4    | Conn          | Set when a device connection is detected.      | R        | Set |
|      |               | Only valid in Host mode. Valid at all          |          |     |
|      |               | transaction speeds.                            |          |     |
| 3    | SOF           | Set when a new frame starts.                   | R        | Set |
| 2    | Reset         | Set in Peripheral mode when Reset signaling    | R        | Set |
|      |               | is detected on the D2 e bus.                   |          |     |
|      | Babble        | Set in Host mode when babble is detected.      |          |     |

## JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

## 102



| 1 | Resume  | Set when Resume signaling is detected on  | R | Set |
|---|---------|-------------------------------------------|---|-----|
|   |         | the bus while the MUSBHDRC is in Suspend  |   |     |
|   |         | mode.                                     |   |     |
| 0 | Suspend | Set when Suspend signaling is detected on | R | Set |
|   |         | the bus. Only valid in Peripheral mode.   |   |     |

## 6.4.8 IntrUSBE

IntrUSBE is an 8-bit register that provides interrupt enable bits for each of the interrupts in IntrUSB.



| Vbus Error                                                                                  |                                                    |                                                                                                                                                                                                       | USB                                                                                                                                                                                                                                                        |
|---------------------------------------------------------------------------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                             | Interrupt enable.                                  | RW                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                          |
| Sess Req                                                                                    | Interrupt enable,                                  | RW                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                          |
| Discon                                                                                      | Interrupt enable.                                  | RW                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                          |
| Conn                                                                                        | Interrupt enable.                                  | RW                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                          |
| SOF                                                                                         | Interrupt enable.                                  | RW                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                          |
| Reset                                                                                       | Interrupt enable.                                  | RW                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                          |
| Babble .                                                                                    |                                                    |                                                                                                                                                                                                       |                                                                                                                                                                                                                                                            |
| Resume                                                                                      | Interrupt enable.                                  | RW                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                          |
| Suspend                                                                                     | Interrupt enable.                                  | RW                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                          |
| C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C | Discon<br>Conn<br>SOF<br>Reset<br>Babble<br>Resume | Discon     Interrupt enable.       Conn     Interrupt enable.       SOF     Interrupt enable.       Reset     Interrupt enable.       Babble     Interrupt enable.       Resume     Interrupt enable. | Discon     Interrupt enable.     RW       Conn     Interrupt enable.     RW       SOF     Interrupt enable.     RW       Reset     Interrupt enable.     RW       Babble     FT     Interrupt enable.     RW       Resume Off     Interrupt enable.     RW |

## 6.4.9 Frame

Frame is a 16-bit read-only register that holds the last received frame number.

| Frame |                | 0x1344000C              |
|-------|----------------|-------------------------|
| Bit   | 15 14 13 12 11 | 10 9 8 7 6 5 4 3 2 1 0  |
|       | 0              | Frame Number            |
| RST   | 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 |

| Bits  | Name         | Description   | CPU | USB |
|-------|--------------|---------------|-----|-----|
| 15:11 | -            | Always 0.     | R   | W   |
| 10:0  | Frame Number | Frame number. | R   | W   |
|       |              |               |     | 103 |

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



### 6.4.10 Index

Each Tx endpoint and each Rx endpoint have their own set of control/status registers located between 100h – 1FFh. In addition one set of Tx control/status and one set of Rx control/status registers appear at 10h - 19h. Index is a 4-bit register that determines which endpoint control/status registers are accessed.

Before accessing an endpoint's control/status registers at 10h - 19h, the endpoint number should be written to the Index register to ensure that the correct control/status registers appear in the memory map.



| Bits                                                                                               | Name              | Description        | CPU | USB |  |  |
|----------------------------------------------------------------------------------------------------|-------------------|--------------------|-----|-----|--|--|
| 3:0                                                                                                | Selected Endpoint | Selected endpoint. | RW  | R   |  |  |
| inter                                                                                              |                   |                    |     |     |  |  |
| 6.4.11 TestMode                                                                                    |                   |                    |     |     |  |  |
| Testmode is an 9 bit register that is primarily used to put the MUSPHDPC into one of the four test |                   |                    |     |     |  |  |

## 6.4.11 TestMode

104

Testmode is an 8-bit register that is primarily used to put the MUSBHDRC into one of the four test modes for High-speed operation described in the USB 2.0 specification – in response to a SET FEATURE: TESTMODE command. It is not used in normal operation.

**NOTE:** Only one of Bits D0 – D6 should be set at any time.





| Bits | Name        | Description                                                             | CPU | USB |
|------|-------------|-------------------------------------------------------------------------|-----|-----|
| 7    | Force_Host  | The CPU sets this bit to instruct the core to                           | RW  | R   |
|      |             | enter Host mode when the Session bit is set,                            |     |     |
|      |             | regardless of whether it is connected to any                            |     |     |
|      |             | peripheral. The state of the CID input,                                 |     |     |
|      |             | HostDisconnect and LineState signals are                                |     |     |
|      |             | ignored. The core will then remain in Host                              |     |     |
|      |             | mode until the Session bit is cleared, even if                          |     |     |
|      |             | a device is disconnected, and if the                                    |     |     |
|      |             | Force_Host bit remains set, will re-enter                               |     |     |
|      |             | Host mode the next time the Session bit is                              |     |     |
|      |             | set. While in this mode, the status of the                              |     |     |
|      |             | HOSTDISCON signal from the PHY may be                                   |     |     |
|      |             | read from bit 7 of the DevCtl register. The                             |     |     |
|      |             | operating speed is determined from the                                  | 11  |     |
|      |             | Force_HS and Force_FS bits as follows:                                  | DIT |     |
|      |             | Force_HS Force_FS Operating Speed                                       |     |     |
|      |             | 0 0 Low Speed<br>0 1 Full Speed                                         |     |     |
|      |             | 0         1         Full Speed           1         0         High Speed |     |     |
|      |             | 1 1 Undefined                                                           |     |     |
| 6    | FIFO_Access | The CPU sets this bit to transfer the packet in                         | Set | R   |
|      |             | the Endpoint 0 Tx FIFO to the Endpoint 0 Rx                             |     |     |
|      | ~ 6         | FIFO. It is cleared automatically.                                      |     |     |
| 5    | Force_FS    | The CPU sets this bit either in conjunction                             | RW  | R   |
|      | c c l la r  | with bit 7 above or to force the MUSBHDRC                               |     |     |
|      | Force_FS    | into Full-speed mode when it receives a USB                             |     |     |
|      | er          | reset.                                                                  |     |     |
| 4    | Force_HS    | The CPU sets this bit either in conjunction                             | RW  | R   |
|      | t t         | with bit 7 above or to force the MUSBHDRC                               |     |     |
|      |             | into High-speed mode when it receives a                                 |     |     |
|      |             | USB reset.                                                              |     |     |
| 3    | Test_Packet | (High-speed mode) The CPU sets this bit to                              | RW  | R   |
|      |             | enter the Test_Packet test mode. In this                                |     |     |
|      |             | mode, the MUSBHDRC repetitively                                         |     |     |
|      |             | transmits on the bus a 53-byte test packet,                             |     |     |
|      |             | the form of which is defined in the Universal                           |     |     |
|      |             | Serial Bus Specification Revision 2.0,                                  |     |     |
|      |             | Section 7.1.20 (and in the MUSBHDRC                                     |     |     |
|      |             | Programmer's Guide).                                                    |     |     |
|      |             | NOTE: The test packet has a fixed format                                |     |     |
|      |             | and must be loaded into the Endpoint 0 FIFO                             |     |     |
|      |             | before the test mode is entered.                                        |     |     |

| 2 | Test_K       | (High-speed mode) The CPU sets this bit to    | RW | R |
|---|--------------|-----------------------------------------------|----|---|
|   |              | enter the Test_K test mode. In this mode, the |    |   |
|   |              | MUSBHDRC transmits a continuous K on          |    |   |
|   |              | the bus.                                      |    |   |
| 1 | Test_J       | (High-speed mode) The CPU sets this bit to    | RW | R |
|   |              | enter the Test_J test mode. In this mode, the |    |   |
|   |              | MUSBHDRC transmits a continuous J on the      |    |   |
|   |              | bus.                                          |    |   |
| 0 | Test_SE0_NAK | (High-speed mode) The CPU sets this bit to    | RW | R |
|   |              | enter the Test_SE0_NAK test mode. In this     |    |   |
|   |              | mode, the MUSBHDRC remains in                 |    |   |
|   |              | High-speed mode but responds to any valid     |    |   |
|   |              | IN token with a NAK.                          |    |   |

## 6.4.12 DevCtl

DevCtl is an 8-bit register that is used to select whether the MUSBHDRC is operating in Peripheral mode or in Host mode, and for controlling and monitoring the USB VBus line.



RST

|      | 200                   |                                              |     |     |
|------|-----------------------|----------------------------------------------|-----|-----|
| Bits | O <sup>LLO</sup> Name | Description                                  | CPU | USB |
| 7    | B-Device              | This Read-only bit indicates whether the     | R   | RW  |
|      |                       | MUSBHDRC is operating as the 'A' device      |     |     |
|      |                       | or the 'B' device. 0 => 'A' device; 1 => 'B' |     |     |
|      |                       | device. Only valid while a session is in     |     |     |
|      |                       | progress.                                    |     |     |
|      |                       | NOTE: If the core is in Force_Host mode      |     |     |
|      |                       | (i.e. a session has been started with        |     |     |
|      |                       | Testmode.D7 = 1), this bit will indicate the |     |     |
|      |                       | state of the HOSTDISCON input signal from    |     |     |
|      |                       | the PHY.                                     |     |     |
|      |                       |                                              |     |     |





| high-speed device has been detected being connected to the port. (High-speed devices are distinguished from full-speed by checking for high-speed chirps when the device is reset.) Only valid in Host mode.       R         5       LSDev       This Read-only bit is set when a low-speed device has been detected being connected to the port. Only valid in Host mode.       R         4:3       VBus       These Read-only bit is necode the current VBus level as follows:       R         2       Host Mode       This Read-only bit is set when the MUSBHDRC is acting as a Host.       R         1       Host Req       When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device only)       R         0       Session       When operating as an 'A' device, this bit is set or cleared by the CPU to start or end a session starts/ends. It is also set by the CPU to initiate the Session starts/ends. It is also set by the CPU to initiate the Session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a session starts/ends. It is also set by the CPU to start or end a s | RW                        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| are distinguished from full-speed by<br>checking for high-speed chirps when the<br>device is reset.) Only valid in Host mode.R5LSDevThis Read-only bit is set when a low-speed<br>device has been detected being connected<br>to the port. Only valid in Host mode.R4:3VBusThese Read-only bits encode the current<br>VBus level as follows:R2Host ModeThis Read-only bit is set when the<br>MUSBHDRC is acting as a Host.R1Host ReqWhen set, the MUSBHDRC will initiate the<br>Host Negotiation when Suspend mode is<br>entered. It is cleared when Host Negotiation<br>is completed. See Section 15. ('B' device<br>only)R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW                        |
| are distinguished from full-speed by<br>checking for high-speed chirps when the<br>device is reset.) Only valid in Host mode.R5LSDevThis Read-only bit is set when a low-speed<br>device has been detected being connected<br>to the port. Only valid in Host mode.R4:3VBusThese Read-only bits encode the current<br>VBus level as follows:R2Host ModeThis Read-only bit is set when the<br>MUSBHDRC is acting as a Host.R1Host ReqWhen set, the MUSBHDRC will initiate the<br>Host Negotiation when Suspend mode is<br>entered. It is cleared when Host Negotiation<br>is completed. See Section 15. ('B' device<br>only)R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW                        |
| a       checking for high-speed chirps when the device is reset.) Only valid in Host mode.         5       LSDev       This Read-only bit is set when a low-speed device has been detected being connected to the port. Only valid in Host mode.       R         4:3       VBus       These Read-only bits encode the current VBus level as follows:       R <sup>1</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW                        |
| a       device is reset.) Only valid in Host mode.         5       LSDev       This Read-only bit is set when a low-speed device has been detected being connected to the port. Only valid in Host mode.       R         4:3       VBus       These Read-only bits encode the current VBus level as follows:       R         0       0       Below SessionEnd       R         0       0       Below SessionEnd       N         1       Host Mode       This Read-only bit is set when the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device only)       R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW                        |
| 5       LSDev       This Read-only bit is set when a low-speed device has been detected being connected to the port. Only valid in Host mode.       R         4:3       VBus       These Read-only bits encode the current VBus level as follows:       R <sup>1</sup> <td< td=""><td>RW</td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW                        |
| 4:3       VBus       These Read-only valid in Host mode.         4:3       VBus       These Read-only bits encode the current VBus level as follows:       R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RVV                       |
| 4:3       VBus       These Read-only bits encode the current VBus level as follows:       R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _                         |
| 4:3       VBus       These Read-only bits encode the current VBus level as follows:       R         0       0       Below SessionEnd       R         0       1       Above SessionEnd, below AValid       R         1       Host Mode       This Read-only bit is set when the MUSBHDRC is acting as a Host.       R         1       Host Req       When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device only)       R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                           |
| VBus level as follows:       VBus level as follows:         D4       D3         0       0         0       1         Above SessionEnd, below AValid         1       0         Above AValid, below AValid         1       1         Above VBusValid         1       Host Mode         This Read-only bit is set when the MUSBHDRC is acting as a Host.         NUSBHDRC is acting as a Host.         1       Host Req         When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                           |
| D4       D3       Meaning         0       0       Below SessionEnd         0       1       Above SessionEnd, below AValid         1       0       Above AValid, below VBusValid         1       1       0         2       Host Mode       This Read-only bit is set when the MUSBHDRC is acting as a Host.       R         1       Host Req       When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device only)       R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW                        |
| 0       0       Below SessionEnd         0       1       Above SessionEnd, below AValid         1       0       Above SessionEnd, below AValid         1       0       Above AValid, below VBusValid         1       1       0         2       Host Mode       This Read-only bit is set when the MUSBHDRC is acting as a Host.       R         1       Host Req       When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device Only)       R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                           |
| 0       0       Below SessionEnd         0       1       Above SessionEnd, below AValid         1       0       Above VBusValid         1       1       0         2       Host Mode       This Read-only bit is set when the MUSBHDRC is acting as a Host.       R         1       Host Req       When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device only)       R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |
| 1       0       Above AValid, below VBusValid         1       1       Above AValid, below VBusValid         1       1       Above VBusValid         2       Host Mode       This Read-only bit is set when the MUSBHDRC is acting as a Host.       R         1       Host Req       When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device Only)       RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                           |
| 1       1       Above VBusValid         2       Host Mode       This Read-only bit is set when the MUSBHDRC is acting as a Host.       R         1       Host Req       When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device only)       RV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                           |
| 2       Host Mode       This Read-only bit is set when the MUSBHDRC is acting as a Host.       R         1       Host Req       When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device only)       RV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | $\langle \langle \rangle$ |
| MUSBHDRC is acting as a Host.         Host Req         When set, the MUSBHDRC will initiate the<br>Host Negotiation when Suspend mode is<br>entered. It is cleared when Host Negotiation<br>is completed. See Section 15. ('B' device<br>only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 20                        |
| MUSBHDRC is acting as a Host.         MUSBHDRC is acting as a Host.         Host Req         When set, the MUSBHDRC will initiate the<br>Host Negotiation when Suspend mode is<br>entered. It is cleared when Host Negotiation<br>is completed. See Section 15. ('B' device<br>only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW                        |
| 1       Host Req       When set, the MUSBHDRC will initiate the Host Negotiation when Suspend mode is entered. It is cleared when Host Negotiation is completed. See Section 15. ('B' device only.)       RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                           |
| entered. It is cleared when Host Negotiation<br>is completed. See Section 15. ('B' device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | / R/clr                   |
| entered. It is cleared when Host Negotiation<br>is completed. See Section 15. ('B' device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |
| is completed. See Section 15. ('B' device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |
| only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                           |
| 0 Session When operating as an 'A' device, this bit is set or cleared by the CPU to start or end a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                           |
| set or cleared by the CPU to start or end a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | / RW                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |
| session. When operating as a 'B' device, this                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                           |
| bit is act/closed by the MUSPHDPC when a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                           |
| bit is set/cleared by the MUSBHDRC when a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |
| session starts/ends. It is also set by the CPU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |
| When the MUSBHDRC is in Suspend mode,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |
| the bit may be cleared by the CPU to perform                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                           |
| a software disconnect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                           |



#### 6.5 **Indexed Register**

NOTE: The action of the following registers when the selected endpoint has not been configured is undefined.

## 6.5.1 CSR0

CSR0 is a 16-bit register that provides control and status bits for Endpoint 0.

NOTE: The interpretation of the register depends on whether the MUSBHDRC is acting as a peripheral or as a host. Users should also be aware that the value returned when the register is read reflects the status attained e.g. as a result of writing to the register. (with the Index register set to 0)



| Bits | Name              | Description                                 | CPU | USB |
|------|-------------------|---------------------------------------------|-----|-----|
| 15:9 | Reserved          | Unused. Return 0 when read.                 | R   | R   |
| 8    | FlushFIFO         | The CPU writes a 1 to this bit to flush the | Set | R   |
|      |                   | next packet to be transmitted/read from     |     |     |
|      |                   | the Endpoint 0 FIFO. The FIFO pointer is    |     |     |
|      |                   | reset and the TxPktRdy/RxPktRdy bit         |     |     |
|      |                   | (below) is cleared.                         |     |     |
|      |                   | NOTE: FlushFIFO has no effect unless        |     |     |
|      |                   | TxPktRdy/RxPktRdy is set.                   |     |     |
| 7    | Serviced SetupEnd | The CPU writes a 1 to this bit to clear the | Set | R   |
|      |                   | SetupEnd bit. It is cleared automatically.  |     |     |
| 6    | Serviced RxPKtRdy | The CPU writes a 1 to this bit to clear the | Set | R   |
|      |                   | RxPktRdy bit. It is cleared automatically.  |     |     |

#### JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

## 108



| 5 | SendStall | The CPU writes a 1 to this bit to terminate   | Set   | R   |
|---|-----------|-----------------------------------------------|-------|-----|
|   |           | the current transaction. The STALL            |       |     |
|   |           | handshake will be transmitted and then        |       |     |
|   |           | this bit will be cleared automatically.       |       |     |
| 4 | SetupEnd  | This bit will be set when a control           | R     | Set |
|   |           | transaction ends before the DataEnd bit       |       |     |
|   |           | has been set. An interrupt will be            |       |     |
|   |           | generated and the FIFO flushed at this        |       |     |
|   |           | time. The bit is cleared by the CPU writing   |       |     |
|   |           | a 1 to the ServicedSetupEnd bit.              |       |     |
| 3 | DataEnd   | The CPU sets this bit:                        | Set   | R   |
|   |           | 1 When setting TxPktRdy for the last          |       |     |
|   |           | data packet.                                  |       |     |
|   |           | 2 When clearing RxPktRdy after                |       |     |
|   |           | unloading the last data packet.               | 15    |     |
|   |           | 3 When setting TxPktRdy for a zero 🔨          | OLL   |     |
|   |           | length data packet.                           |       |     |
|   |           | It is cleared automatically. $\sqrt{1000}$    |       |     |
| 2 | SentStall | This bit is set when a STAL handshake is      | R/clr | Set |
|   |           | transmitted. The CPU should clear this bit.   |       |     |
| 1 | TxPKtRdy  | The CPU sets this bit after loading a data    | R/set | R   |
|   |           | packet into the FIFO. It is cleared           |       |     |
|   | - C       | automatically when a data packet has          |       |     |
|   | a 2       | been transmitted. An interrupt is also        |       |     |
|   |           | generated at this point (if enabled).         |       |     |
| 0 | RxPKtRdy  | This bit is set when a data packet has        | R     | Set |
|   | 611       | been received. An interrupt is generated      |       |     |
| * | 18-       | when this bit is set. The CPU clears this bit |       |     |
|   |           | by setting the ServicedRxPktRdy bit.          |       |     |

## Host Mode:





| Bits | Name        | Description                                                 | CPU   | USB |
|------|-------------|-------------------------------------------------------------|-------|-----|
| 15:9 | Reserved    | Unused. Return 0 when read.                                 | R     | R   |
| 8    | FlushFIFO   | The CPU writes a 1 to this bit to flush the                 | Set   | R   |
|      |             | next packet to be transmitted/read from                     |       |     |
|      |             | the Endpoint 0 FIFO. The FIFO pointer is                    |       |     |
|      |             | reset and the TxPktRdy/RxPktRdy bit                         |       |     |
|      |             | (below) is cleared.                                         |       |     |
|      |             | NOTE: FlushFIFO has no effect unless                        |       |     |
|      |             | TxPktRdy/RxPktRdy is set.                                   |       |     |
| 7    | NAK Timeout | This bit will be set when Endpoint 0 is                     | R/clr | Set |
|      |             | halted following the receipt of NAK                         |       |     |
|      |             | responses for longer than the time set by                   |       |     |
|      |             | the NAKLimit0 register. The CPU should                      |       |     |
|      |             | clear this bit to allow the endpoint to                     |       |     |
|      |             | continue.                                                   | 11    |     |
| 6    | StatusPkt   | The CPU sets this bit at the same time as                   | RW    | R   |
|      |             | the TxPktRdy or ReqPkt bit is set, to $\bigcirc^{\bigcirc}$ |       |     |
|      |             | perform a status stage transaction. Setting                 |       |     |
|      |             | this bit ensures that the data toggle is set                |       |     |
|      |             | to 1 so that a DATA1 packet is used for                     |       |     |
|      |             | the Status Stage transaction.                               |       |     |
| 5    | ReqPkt      | The CPU sets this bit to request an IN                      | RW    | RW  |
|      | 26          | transaction. It is cleared when RxPktRdy                    |       |     |
|      | a121        | is set.                                                     |       |     |
| 4    | Error       | This bit will be set when three attempts                    | R     | Set |
|      | ifter       | have been made to perform a transaction                     |       |     |
|      | er-         | with no response from the peripheral. The                   |       |     |
| 1    | 018-        | CPU should clear this bit. An interrupt is                  |       |     |
|      |             | generated when this bit is set.                             |       |     |
| 3    | SetupPkt    | The CPU sets this bit, at the same time as                  | RW    | RW  |
|      |             | the TxPktRdy bit is set, to send a SETUP                    |       |     |
|      |             | token instead of an OUT token for the                       |       |     |
|      |             | transaction.                                                |       |     |
| 2    | RxStall     | This bit is set when a STALL handshake is                   | R/clr | Set |
|      |             | received. The CPU should clear this bit.                    |       |     |
| 1    | TxPktRdy    | The CPU sets this bit after loading a data                  | R/set | Clr |
|      |             | packet into the FIFO. It is cleared                         |       |     |
|      |             | automatically when the data packet has                      |       |     |
|      |             | been transmitted. An interrupt is                           |       |     |
|      |             | generated (if enabled) when the bit is                      |       |     |
|      |             | cleared.                                                    |       |     |

110



| 0 | RxPktRdy | This bit is set when a data packet has     | R/clr | RW |
|---|----------|--------------------------------------------|-------|----|
|   |          | been received. An interrupt is generated   |       |    |
|   |          | (if enabled) when this bit is set. The CPU |       |    |
|   |          | should clear this bit when the packet has  |       |    |
|   |          | been read from the FIFO.                   |       |    |

## 6.5.2 Count0

Count0 is a 7-bit read-only register that indicates the number of received data bytes in the Endpoint 0 FIFO. The value returned changes as the contents of the FIFO change and is only valid while RxPktRdy (CSR0.D0) is set.

| Count0 | 0x13440018             |
|--------|------------------------|
| Bit    | 6 5 4 3 2 1 0          |
|        | Endpoint 0<br>Rx Count |
| RST    | 0 0 0 0 0 0 0          |

| Bits  | Name                | Description                          | CPU | USB |
|-------|---------------------|--------------------------------------|-----|-----|
| 6:0   | Endpoint 0 Rx Count | Number of received data bytes in the | R   | W   |
|       |                     | endpoint 0 FIFO.                     |     |     |
| 6.5.3 | ConfigData          | 26.00                                |     |     |

## 6.5.3 ConfigData

ConfigData is an 8-bit Read-Only register that returns information about the selected core configuration.

# ConfigData

#### Bit



#### RST

| Bits | Name  | Description                                  | CPU | USB |
|------|-------|----------------------------------------------|-----|-----|
| 7    | MPRxE | When set to '1', automatic amalgamation of   | R   | R   |
|      |       | bulk packets is selected.                    |     |     |
| 6    | MPTxE | When set to '1', automatic splitting of bulk | R   | R   |
|      |       | packets is selected.                         |     |     |
|      |       |                                              |     | 111 |



| 5 | BigEndian       | When set to '1' indicates Big Endian ordering | R | R |
|---|-----------------|-----------------------------------------------|---|---|
|   |                 | is selected.                                  |   |   |
| 4 | HBRxE           | When set to '1' indicates High-bandwidth Rx   | R | R |
|   |                 | ISO Endpoint Support selected.                |   |   |
| 3 | HBTxE           | When set to '1' indicates High-bandwidth Tx   | R | R |
|   |                 | ISO Endpoint Support selected.                |   |   |
| 2 | DynFIFOSizing   | When set to '1' indicates Dynamic FIFO        | R | R |
|   |                 | Sizing option selected.                       |   |   |
| 1 | SoftConE        | When set to '1' indicates Soft                | R | R |
|   |                 | Connect/Disconnect option selected.           |   |   |
| 0 | UTMI Data Width | Indicates selected UTMI+ data width. 0 => 8   | R | R |
|   |                 | bits; 1 => 16 bits.                           |   |   |

## 6.5.4 NakLimit0 (Host Mode Only)

NAKLimit0 is a 5-bit register that sets the number of frames/microframes (High-Speed transfers) after which Endpoint 0 should timeout on receiving a stream of NAK responses. (Equivalent settings for other endpoints can be made through their TxInterval and RxInterval registers.

The number of frames/microframes selected is  $2_{(m-1)}$  (where *m* is the value set in the register, valid values 2 – 16). If the host receives NAK responses from the target for more frames than the number represented by the Limit set in this register, the endpoint will be halted.

| NOTE: A value of 0 or 1 | disables | the N | VAK          | timeout function. |
|-------------------------|----------|-------|--------------|-------------------|
|                         |          | 10    | $\mathbf{O}$ | •                 |

|     | NakLimit0 |   | <b>0</b> x | 134 | 400   | 1b |
|-----|-----------|---|------------|-----|-------|----|
| Bit |           | 4 | 3          | 2   | 1     | 0  |
|     |           |   | Endpoint 0 | NAK | Limit |    |
| RST |           | 0 | 0          | 0   | 0     | 0  |

| Bits | Bits Name Description |                       | CPU | USB |
|------|-----------------------|-----------------------|-----|-----|
| 4:0  | Endpoint 0 NAK Limit  | Endpoint 0 NAK limit. | RW  | R   |

## 6.5.5 TxMaxP

112

The TxMaxP register defines the maximum amount of data that can be transferred through the selected Tx endpoint in a single operation. There is a TxMaxP register for each Tx endpoint (except Endpoint 0).

Bits 10:0 define (in bytes) the maximum payload transmitted in a single transaction. The value set can

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



be up to 1024 bytes but is subject to the constraints placed by the USB Specification on packet sizes for Bulk, Interrupt and Isochronous transfers in Full speed and High-speed operations.

Where the option of High-bandwidth Isochronous/Interrupt endpoints or of packet splitting on Bulk endpoints has been taken when the core is configured, the register includes either 2 or 5 further bits that define a multiplier *m* which is equal to one more than the value recorded.

In the case of Bulk endpoints with the packet splitting option enabled, the multiplier *m* can be up to 32 and defines the maximum number of 'USB' packets (i.e. packets for transmission over the USB) of the specified payload into which a single data packet placed in the FIFO should be split, prior to transfer. (If the packet splitting option is not enabled, D15–D13 is not implemented and D12–D11 (if included) is ignored.) **NOTE:** The data packet is required to be an exact multiple of the payload specified by bits 10:0, which is itself required to be either 8, 16, 32, 64 or (in the case of High Speed transfers) 512 bytes.

For Isochronous/Interrupt endpoints operating in High-Speed mode and with the High-bandwidth option enabled, *m* may only be either 2 or 3 (corresponding to bit 11 set or bit 12 set, respectively) and it specifies the maximum number of such transactions that can take place in a single microframe. If either bit 11 or bit 12 is non-zero, the MUSBHDRC will automatically split any data packet written to the FIFO into up to 2 or 3 'USB' packets, each containing the specified payload (or less). The maximum payload for each transaction is 1024 bytes, so this allows up to 3072 bytes to be transmitted in each microframe. (For Isochronous/Interrupt transfers in Full-speed mode or if High-bandwidth is not enabled, bits 11 and 12 are ignored.)

The value written to bits 10:0 (multiplied by m in the case of high-bandwidth Isochronous/Interrupt transfers) must match the value given in the *wMaxPacketSize* field of the Standard Endpoint Descriptor for the associated endpoint (see *USB Specification* Revision 2.0, Chapter 9). A mismatch could cause unexpected results. The total amount of data represented by the value written to this register (specified payload × m) must not exceed the FIFO size for the Tx endpoint, and should not exceed half the FIFO size if double-buffering is required.

If this register is changed after packets have been sent from the endpoint, the Tx endpoint FIFO should be completely flushed (using the FlushFIFO bit in TxCSR) after writing the new value to this register.





| Bits     | Name                | Description                             |    | USB |
|----------|---------------------|-----------------------------------------|----|-----|
| 15/12:11 | m-1                 | Multiplier.                             | RW | R   |
| 10:0     | Maximum             | Maximum payload transmitted in a single | RW | R   |
|          | Payload/transaction | transaction.                            |    |     |

## 6.5.6 TxCSR

TxCSR is a 16-bit register that provides control and status bits for transfers through the currently-selected Tx endpoint. There is a TxCSR register for each configured Tx endpoint (not including Endpoint 0).

NOTE: The interpretation of the register depends on whether the MUSBHDRC is acting as a peripheral or as a host. Users should also be aware that the value returned when the register is read reflects the status attained e.g. as a result of writing to the register.

| Peripheral Mode<br>TxCSR |         |             |      |            |             |            |          | ~ 6      | 6          | (         | 57        | )<br>)x1:           | <br>344  | <b>001</b> :  | 2        |
|--------------------------|---------|-------------|------|------------|-------------|------------|----------|----------|------------|-----------|-----------|---------------------|----------|---------------|----------|
| Bit                      | 15      | 14          | 13   | 12         | 11          | 10         | 98       | 7        | 6          | 5         | 4         | 3                   | 2        | 1             | 0        |
|                          | AutoSet | <b>O</b> SI | Mode | DMAReqEnab | FrcData Tog | DMAReqMode | Reserved | IncompTx | CIrDataTog | SentStall | SendStall | FlushFIFO(sefl-clr) | UnderRun | FIFO NotEmpty | TxPktRdy |
| RST                      | 0       | 0           | 0    | 0          | 0           | 0          | 0 0      | 0        | 0          | 0         | 0         | 0                   | 0        | 0             | 0        |

| Bits | Name    | Description                                       | CPU | USB |  |  |
|------|---------|---------------------------------------------------|-----|-----|--|--|
| 15   | AutoSet | Set If the CPU sets this bit, TxPktRdy will be    |     |     |  |  |
| 1    | One     | automatically set when data of the maximum        |     |     |  |  |
|      |         | packet size (value in TxMaxP) is loaded into      |     |     |  |  |
|      |         | the Tx FIFO. If a packet of less than the         |     |     |  |  |
|      |         | maximum packet size is loaded, then               |     |     |  |  |
|      |         | TxPktRdy will have to be set manually.            |     |     |  |  |
|      |         | <b>NOTE:</b> Should not be set for high-bandwidth |     |     |  |  |
|      |         | Isochronous endpoints.                            |     |     |  |  |
| 14   | ISO     | The CPU sets this bit to enable the Tx            | RW  | R   |  |  |
|      |         | endpoint for Isochronous transfers, and           |     |     |  |  |
|      |         | clears it to enable the Tx endpoint for Bulk or   |     |     |  |  |
|      |         | Interrupt transfers.                              |     |     |  |  |
|      |         | NOTE: This bit only has any effect in             |     |     |  |  |
|      |         | Peripheral mode. In Host mode, it always          |     |     |  |  |
|      |         | returns zero.                                     |     |     |  |  |

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| 13  | Mode                 | The CPU sets this bit to enable the endpoint           | RW    | R     |
|-----|----------------------|--------------------------------------------------------|-------|-------|
| 10  | Wode                 | direction as Tx, and clears the bit to enable it       | 1     | IX.   |
|     |                      | as Rx.                                                 |       |       |
|     |                      | <b>NOTE:</b> This bit <i>only</i> has any effect where |       |       |
|     |                      | the same endpoint FIFO is used for both Tx             |       |       |
|     | and Rx transactions. |                                                        |       |       |
| 12  | DMARegEnab           |                                                        |       | R     |
|     |                      | request for the Tx endpoint.                           |       |       |
| 11  | FrcDataTog           | The CPU sets this bit to force the endpoint            | RW    | R     |
|     |                      | data toggle to switch and the data packet to           |       |       |
|     |                      | be cleared from the FIFO, regardless of                |       |       |
|     |                      | whether an ACK was received. This can be               |       |       |
|     |                      | used by Interrupt Tx endpoints that are used           |       |       |
|     |                      | to communicate rate feedback for                       |       |       |
|     |                      | Isochronous endpoints.                                 | 15    |       |
| 10  | DMAReqMode           | The CPU sets this bit to select DMA.                   | RW    | R     |
|     |                      | Request Mode 1 and clears it to select DMA.            |       |       |
|     |                      | Request Mode 0.                                        |       |       |
|     |                      | NOTE: This bit must not be cleared either              |       |       |
|     |                      | before or in the same cycle as the above               |       |       |
|     |                      | DMAReqEnab bit is cleared.                             |       |       |
| 9:8 | Reserved             | Unused, always return 0.                               | R     | R     |
| 7   | InCompTx             | When the endpoint is being used for                    | R/clr | Set   |
|     | at L                 | high-bandwidth Isochronous/Interrupt                   |       |       |
|     | c c l w r            | transfers, this bit is set to indicate where a         |       |       |
|     | fter                 | large packet has been split into 2 or 3                |       |       |
|     | elt                  | packets for transmission but insufficient IN           |       |       |
|     | ONS-eiffel0126       | tokens have been received to send all the              |       |       |
|     | t t                  | parts.                                                 |       |       |
|     |                      | NOTE: In anything other than a                         |       |       |
|     |                      | high-bandwidth transfer, this bit will always          |       |       |
|     |                      | return 0.                                              |       |       |
| 6   | ClrDataTog           | The CPU writes a 1 to this bit to reset the            | Set   | R/clr |
|     |                      | endpoint data toggle to 0.                             |       |       |
| 5   | SentStall            | This bit is set when a STALL handshake is              | R/clr | Set   |
|     |                      | transmitted. The FIFO is flushed and the               |       |       |
|     |                      | TxPktRdy bit is cleared (see below). The               |       |       |
|     |                      | CPU should clear this bit.                             |       |       |



| 4 | SendStall        | The CDL writes a 1 to this hit to issue a         | RW    | D   |
|---|------------------|---------------------------------------------------|-------|-----|
| 4 | SendStan         | The CPU writes a 1 to this bit to issue a         | RVV   | R   |
|   |                  | STALL handshake to an IN token. The CPU           |       |     |
|   |                  | clears this bit to terminate the stall condition. |       |     |
|   |                  | <b>NOTE:</b> This bit has no effect where the     |       |     |
|   |                  | endpoint is being used for Isochronous            |       |     |
|   |                  | transfers.                                        |       |     |
| 3 | FlushFIFO        | The CPU writes a 1 to this bit to flush the       | Set   | R   |
|   |                  | latest packet from the endpoint Tx FIFO.          |       |     |
|   |                  | The FIFO pointer is reset, the TxPktRdy bit       |       |     |
|   |                  | (below) is cleared and an interrupt is            |       |     |
|   |                  | generated. May be set simultaneously with         |       |     |
|   |                  | TxPktRdy to abort the packet that is              |       |     |
|   |                  | currently being loaded into the FIFO.             |       |     |
|   |                  | NOTE: FlushFIFO has no effect unless              |       |     |
|   |                  | TxPktRdy is set. Also note that, if the FIFO      | 17    |     |
|   |                  | is double-buffered, FlushFIFO may need to         | Mr.   |     |
|   |                  | be set twice to completely clear the FIFO.        |       |     |
| 2 | UnderRun         | The USB sets this bit if an IN token is           | R/clr | Set |
|   |                  | received when the TxPktRdy bit not set. The       |       |     |
|   |                  | CPU should clear this bit.                        |       |     |
| 1 | FIFONotEmpty     | The USB sets this bit when there is at least      | R/clr | Set |
|   |                  | 1 packet in the Tx FIFO.                          |       |     |
| 0 | TxPktRdy         | The CPU sets this bit after loading a data        | R/se  | Clr |
|   | $\sim 2^{\circ}$ | packet into the FIFO. It is cleared               | t     |     |
|   | TxPktRdy         | automatically when a data packet has been         |       |     |
|   | · fter           | transmitted. An interrupt is also generated at    |       |     |
|   | elli             | this point (if enabled). TxPktRdy is also         |       |     |
|   | 28-              | automatically cleared (but no interrupt is        |       |     |
| 1 | Our              | generated) prior to loading a second packet       |       |     |
|   |                  | into a double-buffered FIFO.                      |       |     |
|   |                  |                                                   |       |     |

## Host Mode:

| TxCSR |         |          |      |            |            |            |          |   |             |            |         | (        | )x1:                 | 344   | 001          | 2        |
|-------|---------|----------|------|------------|------------|------------|----------|---|-------------|------------|---------|----------|----------------------|-------|--------------|----------|
| Bit   | 15      | 14       | 13   | 12         | 11         | 10         | 9        | 8 | 7           | 6          | 5       | 4        | 3                    | 2     | 1            | 0        |
|       | AutoSet | Reserved | Mode | DMAReqEnab | FrcDataTog | DMAReqMode | Reserved |   | NAK Timeout | ClrDataTog | RxStall | Reserved | FlushFIFO (self-lcr) | Error | FIFONotEmpty | TxPktRdy |
| RST   | 0       | 0        | 0    | 0          | 0          | 0          | 0        | 0 | 0           | 0          | 0       | 0        | 0                    | 0     | 0            | 0        |
|       |         |          |      |            |            |            |          |   |             |            |         |          |                      |       |              |          |

116



| Bits | Name       | Description                                    | CPU   | USB   |
|------|------------|------------------------------------------------|-------|-------|
| 15   | AutoSet    | If the CPU sets this bit, TxPktRdy will be     | RW    | R     |
|      |            | automatically set when a packet of the         |       |       |
|      |            | maximum packet size (TxMaxP) is loaded         |       |       |
|      |            | into the Tx FIFO. If a packet of less than the |       |       |
|      |            | maximum packet size is loaded, then            |       |       |
|      |            | TxPktRdy will have to be set manually.         |       |       |
|      |            | NOTE: Should not be set for high-bandwidth     |       |       |
|      |            | Isochronous endpoints.                         |       |       |
| 14   | Reserved   | Unused, always returns zero.                   | RW    | R     |
| 13   | Mode       | The CPU sets this bit to enable the endpoint   | RW    | R     |
|      |            | direction as Tx, and clears it to enable the   |       |       |
|      |            | endpoint direction as Rx.                      |       |       |
|      |            | NOTE: This bit only has any effect where       |       |       |
|      |            | the same endpoint FIFO is used for both Tx     | 1     |       |
|      |            | and Rx transactions.                           | DIT   |       |
| 12   | DMAReqEnab | The CPU sets this bit to enable the DMA        | RW    | R     |
|      |            | request for the Tx endpoint. $\sqrt{12}$       |       |       |
| 11   | FrcDataTog | The CPU sets this bit to force the endpoint    | RW    | R     |
|      |            | data toggle to switch and the data packet to   |       |       |
|      |            | be cleared from the FIFO, regardless of        |       |       |
|      |            | whether an ACK was received. This can be       |       |       |
|      | 26         | used by Interrupt Tx endpoints that are used   |       |       |
|      | A. 24      | to communicate rate feedback for               |       |       |
|      |            | Isochronous endpoints.                         |       |       |
| 10   | DMAReqMode | The CPU sets this bit to select DMA            | RW    | R     |
|      | e L'       | Request Mode 1 and clears it to select DMA     |       |       |
| 4    | 018-       | Request Mode 0.                                |       |       |
|      |            | NOTE: This bit must not be cleared either      |       |       |
|      |            | before or in the same cycle as the above       |       |       |
|      |            | DMAReqEnab bit is cleared.                     |       |       |
| 9:8  | Reserved   | Unused, always returns 0.                      | R     | R     |
| 7    | NAKTimeout | This bit will be set when the Tx endpoint is   | R/clr | Set   |
|      |            | halted following the receipt of NAK            |       |       |
|      |            | responses for longer than the time set as the  |       |       |
|      |            | NAK Limit by the TxInterval register. The      |       |       |
|      |            | CPU should clear this bit to allow the         |       |       |
|      |            | endpoint to continue.                          |       |       |
|      |            | NOTE: Valid only for Bulk endpoints.           |       |       |
| 6    | ClrDataTog | The CPU writes a 1 to this bit to reset the    | Set   | R/clr |
|      |            | endpoint data toggle to 0.                     |       |       |



| _ | <b>–</b> • • • |                                                | - / - |     |
|---|----------------|------------------------------------------------|-------|-----|
| 5 | RxStall        | This bit is set when a STALL handshake is      | R/clr | Set |
|   |                | received. When this bit is set, any DMA        |       |     |
|   |                | request that is in progress is stopped, the    |       |     |
|   |                | FIFO is completely flushed and the             |       |     |
|   |                | TxPktRdy bit is cleared (see below). The       |       |     |
|   |                | CPU should clear this bit.                     |       |     |
| 4 | Reserved       | Unused, always returns 0.                      | R     | R   |
| 3 | FlushFIFO      | The CPU writes a 1 to this bit to flush the    | Set   | R   |
|   |                | latest packet from the endpoint Tx FIFO.       |       |     |
|   |                | The FIFO pointer is reset, the TxPktRdy bit    |       |     |
|   |                | (below) is cleared and an interrupt is         |       |     |
|   |                | generated. May be set simultaneously with      |       |     |
|   |                | TxPktRdy to abort the packet that is           |       |     |
|   |                | currently being loaded into the FIFO.          |       |     |
|   |                | NOTE: FlushFIFO has no effect unless           | 11    |     |
|   |                | TxPktRdy is set. Also note that, if the FIFO   | Mr.   |     |
|   |                | is double-buffered, FlushFIFO may need to      |       |     |
|   |                | be set twice to completely clear the FIFO.     |       |     |
| 2 | Error          | The USB sets this bit when 3 attempts have     | R/clr | RW  |
|   |                | been made to send a packet and no              |       |     |
|   |                | handshake packet has been received. When       |       |     |
|   |                | the bit is set, an interrupt is generated,     |       |     |
|   | C              | TxPktRdy is cleared and the FIFO is            |       |     |
|   | ~ ?            | completely flushed. The CPU should clear       |       |     |
|   | efel@14        | this bit. Valid only when the endpoint is      |       |     |
|   | . 5 5 6 5      | operating in Bulk or Interrupt mode.           |       |     |
| 1 | FIFONotEmpty   | The USB sets this bit when there is at least   | R/clr | Set |
|   | 28-            | 1 packet in the Tx FIFO.                       |       |     |
| 0 | TxPktRdy       | The CPU sets this bit after loading a data     | R/se  | Clr |
|   |                | packet into the FIFO. It is cleared            | t     |     |
|   |                | automatically when a data packet has been      |       |     |
|   |                | transmitted. An interrupt is also generated at |       |     |
|   |                | this point (if enabled). TxPktRdy is also      |       |     |
|   |                | automatically cleared (but no interrupt is     |       |     |
|   |                | generated) prior to loading a second packet    |       |     |
|   |                | into a double-buffered FIFO.                   |       |     |
|   |                |                                                |       |     |

## 6.5.7 RxMaxP

The RxMaxP register defines the maximum amount of data that can be transferred through the selected Rx endpoint in a single operation. There is a RxMaxP register for each Rx endpoint (except Endpoint 0).

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



Bits 10:0 define (in bytes) the maximum payload transmitted in a single transaction. The value set can be up to 1024 bytes but is subject to the constraints placed by the USB Specification on packet sizes for Bulk, Interrupt and Isochronous transfers in Full speed and High-speed operations.

Where the option of High-bandwidth lsochronous/Interrupt endpoints or of combining Bulk packets has been taken when the core is configured, the register includes either 2 or 5 further bits that define a multiplier m which is equal to one more than the value recorded.

For Bulk endpoints with the packet combining option enabled, the multiplier *m* can be up to 32 and defines the number of USB packets of the specified payload which are to be combined into a single data packet within the FIFO. (If the packet splitting option is not enabled, D15–D13 is not implemented and D12–D11 (if included) is ignored.)

For Isochronous/Interrupt endpoints operating in High-Speed mode and with the High-bandwidth option enabled, *m* may only be either 2 or 3 (corresponding to bit 11 set or bit 12 set, respectively) and it specifies the maximum number of such transactions that can take place in a single microframe. If either bit 11 or bit 12 is non-zero, the MUSBHDRC will automatically combine the separate USB packets received in any microframe into a single packet within the Rx FIFO. The maximum payload for each transaction is 1024 bytes, so this allows up to 3072 bytes to be received in each microframe. (For Isochronous/Interrupt transfers in Full-speed mode or if High-bandwidth is not enabled, bits 11 and 12 are ignored.)

The value written to bits 10:0 (multiplied by *m* in the case of high-bandwidth Isochronous/Interrupt transfers) must match the value given in the *wMaxPacketSize* field of the Standard Endpoint Descriptor for the associated endpoint (see *USB Specification* Revision 2.0, Chapter 9). A mismatch could cause unexpected results.

The total amount of data represented by the value written to this register (specified payload  $\times m$ ) must not exceed the FIFO size for the OUT endpoint, and should not exceed half the FIFO size if double-buffering is required.

|     | RxMaxP |    |    |     |    |    |    |    |     |    |    |      | C     | )x1: | 344  | 001 | 4 |
|-----|--------|----|----|-----|----|----|----|----|-----|----|----|------|-------|------|------|-----|---|
| Bit |        | 15 | 14 | 13  | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5    | 4     | 3    | 2    | 1   | 0 |
|     |        |    | I  | m-1 |    |    |    | Ma | xim | um | Pa | yloa | ad/ti | rans | sact | ion |   |
| RS  | r      | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0    | 0     | 0    | 0    | 0   | 0 |

| Bits  | Name | Description | CPU | USB |
|-------|------|-------------|-----|-----|
| 15/12 | m-1  | Multiplier. | RW  | R   |
| :11   |      |             |     |     |
|       |      |             |     |     |

| 10:0 | Maximum             | Maximum payload transmitted in a single | RW | R |
|------|---------------------|-----------------------------------------|----|---|
|      | Payload/transaction | transaction.                            |    |   |

## 6.5.8 RxCSR

RxCSR is an 16-bit register that provides control and status bits for transfers through the currently-selected Rx endpoint. There is an RxCSR register for each configured Rx endpoint (not including Endpoint 0).

**NOTE:** The interpretation of the register depends on whether the MUSBHDRC is acting as a peripheral or as a host. Users should also be aware that the value returned when the register is read reflects the status attained e.g. as a result of writing to the register.

Peripheral Mode:



| Bits | Name 1010  | Description                                    | CPU | USB |
|------|------------|------------------------------------------------|-----|-----|
| 15   | AutoClear  | If the CPU sets this bit then the RxPktRdy bit | RW  | R   |
|      | 0,11       | will be automatically cleared when a packet    |     |     |
|      | mg_        | of RxMaxP bytes has been unloaded from         |     |     |
| 1    | Olic       | the Rx FIFO. When packets of less than the     |     |     |
|      |            | maximum packet size are unloaded,              |     |     |
|      |            | RxPktRdy will have to be cleared manually.     |     |     |
|      |            | NOTE: Should not be set for highbandwidth      |     |     |
|      |            | Isochronous endpoints.                         |     |     |
| 14   | ISO        | The CPU sets this bit to enable the Rx         | RW  | R   |
|      |            | endpoint for Isochronous transfers, and        |     |     |
|      |            | clears it to enable the Rx endpoint for        |     |     |
|      |            | Bulk/Interrupt transfers.                      |     |     |
| 13   | DMAReqEnab | The CPU sets this bit to enable the DMA        | RW  | R   |
|      |            | request for the Rx endpoint.                   |     |     |





| 12   | DisNyet    | The CPU sets this bit to disable the sending     | RW    | R     |
|------|------------|--------------------------------------------------|-------|-------|
|      |            | of NYET handshakes. When set, all                |       |       |
|      |            | successfully received Rx packets are ACK'd       |       |       |
|      |            | including at the point at which the FIFO         |       |       |
|      |            | becomes full.                                    |       |       |
|      |            | NOTE: This bit only has any effect in            |       |       |
|      |            | High-speed mode, in which mode it should         |       |       |
|      |            | be set for all Interrupt endpoints.              |       |       |
| 11   | DMAReqMode | The CPU sets this bit to select DMA.             | RW    | R     |
|      |            | Request Mode 1 and clears it to select DMA.      |       |       |
|      |            | Request Mode 0.                                  |       |       |
| 10:9 | Reserved   | Unused, always return zero.                      | R     | R     |
| 8    | IncompRx   | This bit is set in a high-bandwidth              | R     | Set   |
|      |            | Isochronous transfer if the packet in the Rx     |       |       |
|      |            | FIFO is incomplete because parts of the          | 1     |       |
|      |            | data were not received. It is cleared when       | DIT   |       |
|      |            | RxPktRdy is cleared.                             |       |       |
|      |            | <b>NOTE:</b> In anything other than a $\sqrt{2}$ |       |       |
|      |            | high-bandwidth Isochronous transfer, this bit    |       |       |
|      |            | will always return 0                             |       |       |
| 7    | ClrDataTog | The CPU writes a 1 to this bit to reset the      | R     | R/clr |
|      |            | endpoint data toggle to 0.                       |       |       |
| 6    | SentStall  | This bit is set when a STALL handshake is        | R/clr | Set   |
|      | a1.57      | transmitted. The CPU should clear this bit.      |       |       |
| 5    | SendStall  | The CPU writes a 1 to this bit to issue a        | RW    | R     |
|      | fter       | STALL handshake. The CPU clears this bit         |       |       |
|      | ong-eiffer | to terminate the stall condition.                |       |       |
| •    | 018-       | NOTE: This bit has no effect where the           |       |       |
|      |            | endpoint is being used for Isochronous           |       |       |
|      |            | transfers.                                       |       |       |
| 4    | FlushFIFO  | The CPU writes a 1 to this bit to flush the      | Set   | R     |
|      |            | next packet to be read from the endpoint Rx      |       |       |
|      |            | FIFO. The FIFO pointer is reset and the          |       |       |
|      |            | RxPktRdy bit (below) is cleared.                 |       |       |
|      |            | NOTE: FlushFIFO has no effect unless             |       |       |
|      |            | RxPktRdy is set. Also note that, if the FIFO     |       |       |
|      |            | is double-buffered, FlushFIFO may need to        |       |       |
|      |            | be set twice to completely clear the FIFO.       |       |       |



| 3 | DataError | This bit is set when RxPktRdy is set if the         | R     | Set |
|---|-----------|-----------------------------------------------------|-------|-----|
|   |           | data packet has a CRC or bit-stuff error. It is     |       |     |
|   |           | cleared when RxPktRdy is cleared.                   |       |     |
|   |           | NOTE: This bit is only valid when the               |       |     |
|   |           | endpoint is operating in ISO mode. In Bulk          |       |     |
|   |           | mode, it always returns zero.                       |       |     |
| 2 | OverRun   | This bit is set if an OUT packet cannot be          | R/clr | Set |
|   |           | loaded into the Rx FIFO. The CPU should             |       |     |
|   |           | clear this bit.                                     |       |     |
|   |           | NOTE: This bit is only valid when the               |       |     |
|   |           | endpoint is operating in ISO mode. In Bulk          |       |     |
|   |           | mode, it always returns zero.                       |       |     |
| 1 | FIFOFull  | This bit is set when no more packets can be         | R     | Set |
|   |           | loaded into the Rx FIFO.                            |       |     |
| 0 | RxPktRdy  | This bit is set when a data packet has been         | R/clr | Set |
|   |           | received. The CPU should clear this bit $\sqrt{-4}$ | JI.   |     |
|   |           | when the packet has been unloaded from              |       |     |
|   |           | the Rx FIFO. An interrupt is generated when         |       |     |
|   |           | the bit is set.                                     |       |     |

#### Host Mode:



| Bits | Name      | Description                                    | CPU | USB |
|------|-----------|------------------------------------------------|-----|-----|
| 15   | AutoClear | If the CPU sets this bit then the RxPktRdy bit | RW  | R   |
|      |           | will be automatically cleared when a packet    |     |     |
|      |           | of RxMaxP bytes has been unloaded from         |     |     |
|      |           | the Rx FIFO. When packets of less than the     |     |     |
|      |           | maximum packet size are unloaded,              |     |     |
|      |           | RxPktRdy will have to be cleared manually.     |     |     |
|      |           | NOTE: Should not be set for highbandwidth      |     |     |
|      |           | Isochronous endpoints.                         |     |     |



| 14   | AutoReq    | If the CPU sets this bit, the ReqPkt bit will be<br>automatically set when the RxPktRdy bit is<br>cleared. | RW    | R     |
|------|------------|------------------------------------------------------------------------------------------------------------|-------|-------|
| 13   | DMAReqEnab | The CPU sets this bit to enable the DMA                                                                    | RW    | R     |
|      |            | request for the Rx endpoint.                                                                               |       |       |
| 12   | DisNyet    | The CPU sets this bit to disable the sending                                                               | RW    | R     |
|      |            | of NYET handshakes. When set, all                                                                          |       |       |
|      |            | successfully received Rx packets are ACK'd                                                                 |       |       |
|      |            | including at the point at which the FIFO                                                                   |       |       |
|      |            | becomes full.                                                                                              |       |       |
|      |            | NOTE: This bit only has any effect in                                                                      |       |       |
|      |            | High-speed mode, in which mode it should                                                                   |       |       |
|      |            | be set for all Interrupt endpoints.                                                                        |       |       |
| 11   | DMAReqMode | The CPU sets this bit to select DMA.                                                                       | RW    | R     |
|      |            | Request Mode 1 and clears it to select DMA.                                                                | 15    |       |
|      |            | Request Mode 0.                                                                                            | DITT  |       |
| 10:9 | Reserved   | Unused, always return 0.                                                                                   | R     | R     |
| 8    | IncompRx   | This bit will be set in a high-bandwidth                                                                   | R     | Set   |
|      |            | Isochronous transfer if the packet received                                                                |       |       |
|      |            | is incomplete. It will be cleared when                                                                     |       |       |
|      |            | RxPktRdy is cleared.                                                                                       |       |       |
|      |            | NOTE: If USB protocols are followed                                                                        |       |       |
|      | - C        | correctly, this bit should never be set. The                                                               |       |       |
|      | 124        | bit becoming set indicates a failure of the                                                                |       |       |
|      |            | associated Peripheral device to behave                                                                     |       |       |
|      | eiffel@120 | correctly. (In anything other than                                                                         |       |       |
|      | elt        | a high-bandwidth Isochronous transfer, this                                                                |       |       |
|      | ng         | bit will always return 0.)                                                                                 |       |       |
| 7    | CIrDataTog | The CPU writes a 1 to this bit to reset the                                                                | Set   | R/clr |
|      |            | endpoint data toggle to 0.                                                                                 |       |       |
| 6    | RxStall    | When a STALL handshake is received, this                                                                   | R/clr | Set   |
|      |            | bit is set and an interrupt is generated. The                                                              |       |       |
|      |            | CPU should clear this bit.                                                                                 |       |       |
| 5    | ReqPkt     | The CPU writes a 1 to this bit to request an                                                               | RW    | RW    |
|      |            | IN transaction. It is cleared when RxPktRdy                                                                |       |       |
|      |            | is set.                                                                                                    |       |       |
|      |            |                                                                                                            |       |       |

| 4 | FlushFIFO            | The CPU writes a 1 to this bit to flush the     | Set   | R   |
|---|----------------------|-------------------------------------------------|-------|-----|
|   |                      | next packet to be read from the endpoint Rx     |       |     |
|   |                      | FIFO. The FIFO pointer is reset and the         |       |     |
|   |                      | RxPktRdy bit (below) is cleared.                |       |     |
|   |                      | NOTE: FlushFIFO has no effect unless            |       |     |
|   |                      | RxPktRdy is set. Also note that, if the FIFO    |       |     |
|   |                      | is double-buffered, FlushFIFO may need to       |       |     |
|   |                      | be set twice to completely clear the FIFO.      |       |     |
| 3 | DataError/NAKTimeout | When operating in ISO mode, this bit is set     | R/clr | Set |
|   |                      | when RxPktRdy is set if the data packet has     |       |     |
|   |                      | a CRC or bit-stuff error and cleared when       |       |     |
|   |                      | RxPktRdy is cleared. In Bulk mode, this bit     |       |     |
|   |                      | will be set when the Rx endpoint is halted      |       |     |
|   |                      | following the receipt of NAK responses for      |       |     |
|   |                      | longer than the time set as the NAK Limit by    | 17    |     |
|   |                      | the RxInterval register. The CPU should         | JII - |     |
|   |                      | clear this bit to allow the endpoint to $e^{O}$ |       |     |
|   |                      | continue.                                       |       |     |
| 2 | Error                | The USB sets this bit when 3 attempts have      | R/clr | Set |
|   |                      | been made to receive a packet and no data       |       |     |
|   |                      | packet has been received. The CPU should        |       |     |
|   |                      | clear this bit. An interrupt is generated when  |       |     |
|   | - 6                  | the bit is set.                                 |       |     |
|   | ar 24                | <b>NOTE:</b> This bit is only valid when the Tx |       |     |
|   |                      | endpoint is operating in Bulk or Interrupt      |       |     |
|   | efel@12              | mode. In ISO mode, it always returns zero.      |       |     |
| 1 | FIFOFull             | This bit is set when no more packets can be     | R     | Set |
|   | ng-                  | loaded into the Rx FIFO.                        |       |     |
| 0 | RxPktRdy             | This bit is set when a data packet has been     | R/clr | Set |
|   |                      | received. The CPU should clear this bit         |       |     |
|   |                      | when the packet has been unloaded from          |       |     |
|   |                      | the Rx FIFO. An interrupt is generated when     |       |     |
|   |                      |                                                 |       |     |

## 6.5.9 RxCount

RxCount is a 13-bit read-only register that holds the number of received data bytes in the packet in the Rx FIFO.

the bit is set.

**NOTE:** The value returned changes as the FIFO is unloaded and is only valid while RxPktRdy (RxCSR.D0) is set.



JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| RxCount | 0x13440018                      |
|---------|---------------------------------|
| Bit     | 12 11 10 9 8 7 6 5 4 3 2 1 0    |
|         | Endpoint Rx Count               |
| RST     | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |

| Bits | Name              | Description                                 | CPU | USB |
|------|-------------------|---------------------------------------------|-----|-----|
| 12:0 | Endpoint Rx Count | Number of received data bytes in the packet | R   | W   |
|      |                   | in the Rx FIFO.                             |     |     |

## 6.5.10 TxType (Host Mode Only)

TxType is a 6-bit register that should be written with the endpoint number to be targeted by the endpoint in the lower 4 bits, and the transaction protocol to use for the currently-selected Tx endpoint in the upper 2 bits. There is a TxType register for each configured Tx endpoint (except Endpoint 0).



RST

| Bits | Name                   | Description                            | CPU | USB |
|------|------------------------|----------------------------------------|-----|-----|
| 5:4  | Protocol               | The CPU should set this to select the  | RW  | R   |
| 1    | OLIP                   | required protocol for the Tx endpoint. |     |     |
|      |                        | 00: Illegal                            |     |     |
|      |                        | 01: Isochronous                        |     |     |
|      |                        | 10: Bulk                               |     |     |
|      |                        | 11: Interrupt                          |     |     |
| 3:0  | Target Endpoint Number | The CPU should set this value to the   | RW  | R   |
|      |                        | endpoint number contained in the Tx    |     |     |
|      |                        | endpoint descriptor returned to the    |     |     |
|      |                        | MUSBHDRC during device enumeration.    |     |     |

## 6.5.11 TxInterval (Host Mode Only)

TxInterval is an 8-bit register that, for Interrupt and Isochronous transfers, defines the polling interval for the currently-selected Tx endpoint. For Bulk endpoints, this register sets the number of frames/microframes after which the endpoint should timeout on receiving a stream of NAK responses.



There is a TxInterval register for each configured Tx endpoint (except Endpoint 0).

In each case the value that is set defines a number of frames/microframes (High Speed transfers), as follows:

| Transfer Type | Speed    | Valid Values (m)                                     | Interpretation                                |  |
|---------------|----------|------------------------------------------------------|-----------------------------------------------|--|
| Interrupt     | LS or FS | 1-255                                                | Polling interval is <i>m</i> frames           |  |
|               | HS       | 1-16 Polling interval is 2( <i>m</i> -1) microframes |                                               |  |
| Isochronous   | FS or HS | 1-16                                                 | Polling interval is 2(m-1) frames/microframes |  |
| Bulk          | FS or HS | 2-16                                                 | NAK Limit is 2(m-1) frames/microframes        |  |
|               |          |                                                      | NOTE: A value of 0 or 1 disables the NAK      |  |
|               |          |                                                      | timeout function.                             |  |

**TxInterval** 

0x1344001b

7 6 5 4 3 2 1 0

Tx Polling Interval/ NAK Limit (m)

0 0 0 0 0 0 0 0

RST

Bit

|      |                               | * EL                                           |     |     |
|------|-------------------------------|------------------------------------------------|-----|-----|
| Bits | Name                          |                                                | CPU | USB |
| 7:0  | Tx Polling Interval/NAK Limit | For interrupt and isochronous transfers,       | RW  | R   |
|      | - 6                           | defines the polling interval for the currently |     |     |
|      | a124                          | selected Tx endpoint. For Bulk endpoints,      |     |     |
|      |                               | this register sets the number of               |     |     |
|      | . 576-                        | frames/microframes after which the endpoint    |     |     |
|      | elr                           | should timeout on receiving a stream of NAK    |     |     |
| A    | ng-                           | responses.                                     |     |     |

## 6.5.12 RxType (Host Mode Only)

RxType is a 6-bit register that should be written with the endpoint number to be targeted by the endpoint in the lower 4 bits, and the transaction protocol to use for the currently-selected Rx endpoint in the upper 2 bits. There is an RxType register for each configured Rx endpoint (except Endpoint 0).





| Bits | Name                   | Description                            | CPU | USB |
|------|------------------------|----------------------------------------|-----|-----|
| 5:4  | Protocol               | The CPU should set this to select the  | RW  | R   |
|      |                        | required protocol for the Rx endpoint. |     |     |
|      |                        | 00: Illegal                            |     |     |
|      |                        | 01: Isochronous                        |     |     |
|      |                        | 10: Bulk                               |     |     |
|      |                        | 11: Interrupt                          |     |     |
| 3:0  | Target Endpoint Number | The CPU should set this value to the   | RW  | R   |
|      |                        | endpoint number contained in the Rx    |     |     |
|      |                        | endpoint descriptor returned to the    |     |     |
|      |                        | MUSBHDRC during device enumeration.    |     |     |

## 6.5.13 RxInterval

RxInterval is an 8-bit register that, for Interrupt and Isochronous transfers, defines the polling interval for the currently-selected Rx endpoint. For Bulk endpoints, this register sets the number of frames/microframes after which the endpoint should timeout on receiving a stream of NAK responses. There is a RxInterval register for each configured Rx endpoint (except Endpoint 0). In each case the value that is set defines a number of frames/microframes (High Speed transfers), as follows:

| Transfer Type | Speed    | Valid Values (m) | Interpretation                                |
|---------------|----------|------------------|-----------------------------------------------|
| Interrupt     | LS or FS | 1-255            | Polling interval is <i>m</i> frames           |
|               | HS       | 1-16             | Polling interval is 2(m-1) microframes        |
| Isochronous   | FS or HS | 1-16             | Polling interval is 2(m-1) frames/microframes |
| Bulk          | FS or HS | 2-16             | NAK Limit is 2(m-1) frames/microframes        |
|               | fto      |                  | NOTE: A value of 0 or 1 disables the NAK      |
| ~             | er       |                  | timeout function.                             |
| -16           | /        |                  |                                               |

|     | RxInterval |                                       |   |   | C | )x1: | 344 | 001 | d |
|-----|------------|---------------------------------------|---|---|---|------|-----|-----|---|
| Bit |            | 7                                     | 6 | 5 | 4 | 3    | 2   | 1   | 0 |
|     |            | Rx Polling Interval/<br>NAK Limit (m) |   |   |   |      |     |     |   |
| RST |            | 0                                     | 0 | 0 | 0 | 0    | 0   | 0   | 0 |

| Bits | Name                          | Description                                    | CPU | USB |
|------|-------------------------------|------------------------------------------------|-----|-----|
| 7:0  | Rx Polling Interval/NAK Limit | For interrupt and isochronous transfers,       | RW  | R   |
|      |                               | defines the polling interval for the currently |     |     |
|      |                               | selected Tx endpoint. For Bulk endpoints,      |     |     |
|      |                               | this register sets the number of               |     |     |
|      |                               | frames/microframes after which the endpoint    |     |     |
|      |                               | should timeout on receiving a stream of NAK    |     |     |
|      |                               | responses.                                     |     |     |



## 6.5.14 FifoSize

FIFOSize is an 8-bit Read-Only register that returns the sizes of the FIFOs associated with the selected additional Tx/Rx endpoints. The lower nibble encodes the size of the selected Tx endpoint FIFO; the upper nibble encodes the size of the selected Rx endpoint FIFO. Values of 3 - 13 correspond to a FIFO size of 2n bytes (8 - 8192 bytes). If an endpoint has not been configured, a value of 0 will be displayed. Where the Tx and Rx endpoints share the same FIFO, the Rx FIFO size will be encoded as 0xF.

NOTE: The register only has this interpretation when the Index register is set to select one of Endpoints 1 – 15 and Dynamic Sizing is not selected. It has a special interpretation when the Index register is set to select Endpoint 0 (see Section 5.3.3), while the result returned is not valid where Dynamic FIFO sizing is used. (Index register set to select Endpoints 1 – 15 only)

| FifoSize | 0x1344001f                   |
|----------|------------------------------|
| Bit      | 7 6 5 4 3 2 1 0              |
|          | Rx FIFO Tx FIFO<br>Size Size |
| RST      | ? ? ? ? ? ? ? ? ? ? ?        |
|          | $\cdot$                      |

| Bits | Name         | Description                                    | CPU | USB |  |  |
|------|--------------|------------------------------------------------|-----|-----|--|--|
| 7:4  | Rx FIFO Size | the sizes of the FIFOs associated with the     | R   | R   |  |  |
|      | ar 24        | <sup>)</sup> selected additional Rx endpoints. |     |     |  |  |
| 3:0  | Tx FIFO Size | the sizes of the FIFOs associated with the     | R   | R   |  |  |
|      | ·fter        | selected additional Tx endpoints.              |     |     |  |  |
|      | ett          |                                                |     |     |  |  |

## 6.5.15 FIFOx

This address range provides 16 addresses for CPU access to the FIFOs for each endpoint. Writing to these addresses loads data into the TxFIFO for the corresponding endpoint. Reading from these addresses unloads data from the RxFIFO for the corresponding endpoint.

The address range is 20h – 5Fh and the FIFOs are located on 32-bit double-word boundaries (Endpoint 0 at 20h, Endpoint 1 at 24h ... Endpoint 15 at 5Ch).



## 6.6 Additional Multipoint Control / Status Registers

The following subsections detail additional control and status registers that are only valid when the multipoint option is enabled in the configuration GUI. If the multipoint option is not enabled these reregisters should not be accessed.

## 6.6.1 TxFuncAddr / RxFuncAddr

### NOTE: REQUIRED IN HOST MODE!

TxFuncAddr and RxFuncAddr are 7-bit read/write registers that record the address of the target function that is to be accessed through the associated endpoint (EP*n*). TxFuncAddr needs to be defined for each TX endpoint that is used; RxFuncAddr needs to be defined for each Rx endpoint that is used.

NOTE: TxFuncAddr must be defined for Endpoint 0. The RxFuncAddr register does not exist on EP0.

| TxFuncAddr/RxFuncAddr | 0x13440080+8*n / 0x13440084+8*n |  |  |
|-----------------------|---------------------------------|--|--|
| Bit                   | 6 5 4 3 2 1 0                   |  |  |
|                       | Addr of Target<br>Function      |  |  |
| RST                   | 0 0 0 0 0 0 0                   |  |  |

| Bits | Name                    | Description                                   | CPU | USB |
|------|-------------------------|-----------------------------------------------|-----|-----|
| 6:0  | Addr of Target Function | read/write registers that record the address  | RW  | R   |
|      | ng                      | of the target function that is to be accessed |     |     |
| 1    | OT                      | through the associated endpoint.              |     |     |

## 6.6.2 TxHubAddr/RxHubAddr

## NOTE: RELEVANT IN HOST MODE ONLY!

TxHubAddr and RxHubAddr are 8-bit read/write registers which, like TxHubPort and RxHubPort, only need to be written where a full- or low-speed device is connected to TX/Rx Endpoint EP*n* via a high-speed USB 2.0 hub which carries out the necessary transaction translation to convert between high-speed transmission and full-/low-speed transmission. In such circumstances:

- the lower 7 bits should record the address of this USB 2.0 hub.
- the top bit should record whether the hub has multiple transaction translators (set to '0' if single transaction translator; set to '1' if multiple transaction translators).



NOTE: If Endpoint 0 is connected to a hub, then TxHubAddr must be defined for EP0. The RxHubAddr register does not exist on EP0.



| Bits                                                                                              | Name              | Description                         | CPU | USB |
|---------------------------------------------------------------------------------------------------|-------------------|-------------------------------------|-----|-----|
| 7                                                                                                 | Multi-Translators | 0: single transaction translator    | RW  | R   |
|                                                                                                   |                   | 1: multiple transaction translators | Ur. |     |
| 6:0                                                                                               | HubAddr           | Hub Address.                        | RW  | R   |
| 6.6.3 TxHubPort / RxHubPort                                                                       |                   |                                     |     |     |
| NOTE: RELEVANT IN HOST MODE ONLY!                                                                 |                   |                                     |     |     |
| TxHubPort and RxHubPort only need to be written where a full- or low-speed device is connected to |                   |                                     |     |     |

## 6.6.3 TxHubPort / RxHubPort

#### NOTE: RELEVANT IN HOST MODE ONLY!

TxHubPort and RxHubPort only need to be written where a full- or low-speed device is connected to TX/Rx Endpoint EPn via a high speed USB 2.0 hub which carries out the necessary transaction translation. In such circumstances, these 7-bit read/write registers need to be used to record the port of that USB 2.0 hub through which the target associated with the endpoint is accessed.

NOTE: If Endpoint 0 is connected to a hub, then TxHubPort must be defined. The RxHubPort register does not exist on EP0.

| TxHubPort/RxHubPort | 0x13440083+8*n / 0x13440087+8*n |
|---------------------|---------------------------------|
| Bit                 | 6 5 4 3 2 1 0                   |
|                     | Hub Port                        |
| RST                 | 0 0 0 0 0 0 0                   |

| Bits | Name     | Description                                 | CPU | USB |
|------|----------|---------------------------------------------|-----|-----|
| 6:0  | Hub Port | record the port of that USB 2.0 hub through | RW  | R   |
|      |          | which the target associated with the        |     |     |
|      |          | endpoint is accessed.                       |     |     |

#### 130

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



## 6.7 Additional Control/Status Registers

## 6.7.1 VControl

## **NOTE: WRITE ONLY!**

VControl is a UTMI+ PHY Vendor register that may optionally be included in the core when the core is configured. Its size is also configurable and may be up to 32 bits. The structure of the register is up to the system designer, though users should note that the UTMI+ specification defines a 4-bit VControl register.



| Bits | Name     | Description                 | CPU | USB |
|------|----------|-----------------------------|-----|-----|
| 3:0  | VControl | UTMI+ PHY Vendor registers. | RW  | -   |

NOTE: READ ONLY! FF010126. COM VStatus is a UTMI+ PHY Vendor register that may optionally be included in the core when the core is configured) its size is also configurable and may be up to 32 bits. The structure of the register is up to the system designer, though users should note that the UTMI+ specification defines an 8-bit VStatus register.

|     | VStatus |   |   |   | C    | )x13 | 344 | 006 | b |
|-----|---------|---|---|---|------|------|-----|-----|---|
| Bit |         | 7 | 6 | 5 | 4    | 3    | 2   | 1   | 0 |
|     |         |   |   | ` | √Sta | atus | 6   |     |   |
| RST |         | ? | ? | ? | ?    | ?    | ?   | ?   | ? |

| Bits | Name    | Description                 | CPU | USB |
|------|---------|-----------------------------|-----|-----|
| 7:0  | VStatus | UTMI+ PHY Vendor registers. | RW  | -   |



## 6.7.3 Hwvers

HWVers register is a 16-bit read-only register that returns information about the version of the RTL from which the core hardware was generated, in particular the RTL version number (vxx.yyy).

| Hwvers |    |    |    |    |    |    |   |   |   |   |   | C  | )x1: | 344 | 006 | С |
|--------|----|----|----|----|----|----|---|---|---|---|---|----|------|-----|-----|---|
| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3    | 2   | 1   | 0 |
|        | RC |    |    | хх |    |    |   |   |   |   | y | /y |      |     |     |   |
| RST    | ?  | ?  | ?  | ?  | ?  | ?  | ? | ? | ? | ? | ? | ?  | ?    | ?   | ?   | ? |

| Bits  | Name           | Description                                  | CPU | USB |
|-------|----------------|----------------------------------------------|-----|-----|
| 15    | RC             | Set to '1' if RTL used from a Release        | R   | R   |
|       |                | Candidate rather than from a full release of | 11  |     |
|       |                | the core.                                    | DIT |     |
| 14:10 | XX             | Major Version Number. (Range 0 – 31) 🕓       | R   | R   |
| 9:0   | ууу            | Minor Version Number. (Range 0 – 999)        | R   | R   |
| 3     | ong_eiffel@12f | Minor Version Number. (Range 0 – 999)        |     |     |

## JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

132



## 6.8 Additional Configuration Registers

## 6.8.1 EPInfo

This 8-bit read-only register allows read-back of the number of TX and Rx endpoints included in the design.

| EPInfo |        | 0x13440078 |
|--------|--------|------------|
|        | 7 6 5  | 4 3 2 1 0  |
|        | RxEdps | TxEdps     |
| RST    | ???    | ??????     |

#### Bits Description CPU USB Name 7:4 **RxEdps** The number of Rx endpoints implemented in R R the design. The number of TX endpoints implemented in 3:0 R R TxEdps the design.

## 6.8.2 RAMInfo

This 8-bit read-only register provides information about the width of the RAM.

| RAMInfo | 101 | 70. |  |  |  |   |    |     |     | C  | )x13 | 344( | 007   | 9 |
|---------|-----|-----|--|--|--|---|----|-----|-----|----|------|------|-------|---|
| Bit     |     |     |  |  |  | _ | 7  | 6   | 5   | 4  | 3    | 2    | 1     | 0 |
|         |     |     |  |  |  |   | DN | ЛАС | Cha | ns | F    | RAN  | 1Bits | S |
| RST     |     |     |  |  |  |   | ?  | ?   | ?   | ?  | ?    | ?    | ?     | ? |

| Bits | Name     | Description                            | CPU | USB |
|------|----------|----------------------------------------|-----|-----|
| 7:4  | DMAChans | The number of DMA channels implemented | R   | R   |
|      |          | in the design.                         |     |     |
| 3:0  | RAMBits  | The width of the RAM address bus.      | R   | R   |



## 6.8.3 LinkInfo

This 8-bit register allows some delays to be specified.

| LinkInfo | (       | )x1344007a |
|----------|---------|------------|
| Bit      | 7 6 5 4 | 3 2 1 0    |
|          | WTCon   | WTID       |
|          | 0 1 0 1 | 1 1 0 0    |

| Bits     | Name                                                              | Description                                  | CPU | USB |  |  |  |  |  |  |  |
|----------|-------------------------------------------------------------------|----------------------------------------------|-----|-----|--|--|--|--|--|--|--|
| 7:4      | WTCon                                                             | Sets the wait to be applied to allow for the | RW  | R   |  |  |  |  |  |  |  |
|          |                                                                   | user's connect/disconnect filter in units of |     |     |  |  |  |  |  |  |  |
|          |                                                                   | 533.3ns. (The default setting corresponds to | 11  |     |  |  |  |  |  |  |  |
| 2.667µs) |                                                                   |                                              |     |     |  |  |  |  |  |  |  |
| 3:0      | WTID                                                              | Sets the delay to be applied from IDPULLUP   | RW  | R   |  |  |  |  |  |  |  |
|          |                                                                   | being asserted to IDDIG being considered     |     |     |  |  |  |  |  |  |  |
|          |                                                                   | valid in units of 4.369ms. (The default      |     |     |  |  |  |  |  |  |  |
|          |                                                                   | setting corresponds to 52.43ms)              |     |     |  |  |  |  |  |  |  |
|          |                                                                   | inter                                        |     |     |  |  |  |  |  |  |  |
| 6.8.4    | 6.8.4 VPLen                                                       |                                              |     |     |  |  |  |  |  |  |  |
| This 8-b | This 8-bit register sets the duration of the VBus pulsing charge. |                                              |     |     |  |  |  |  |  |  |  |

#### 6.8.4 VPLen

134

This 8-bit register sets the duration of the VBus pulsing charge.

|     | VPlen | el <sup>e</sup> r |       |   |   | ( | )x1: | 344 | 007 | 7b |
|-----|-------|-------------------|-------|---|---|---|------|-----|-----|----|
| Bit |       |                   | 7     | 6 | 5 | 4 | 3    | 2   | 1   | 0  |
|     |       |                   | VPLen |   |   |   |      |     |     |    |
| RST |       |                   | 0     | 0 | 1 | 1 | 1    | 1   | 0   | 0  |

| Bits | Name  | Description                                  | CPU | USB |
|------|-------|----------------------------------------------|-----|-----|
| 7:0  | VPLen | Sets the duration of the VBus pulsing charge | RW  | R   |
|      |       | in units of 546.1 µs. (The default setting   |     |     |
|      |       | corresponds to 32.77ms)                      |     |     |



## 6.8.5 HS\_EOF1

This 8-bit register sets the minimum time gap that is to be allowed between the start of the last transaction and the EOF for High-speed transactions.

| HS_EOF1 | 0x1344007c |         |   |   |   | 'c |   |   |
|---------|------------|---------|---|---|---|----|---|---|
| Bit     | 7          | 6       | 5 | 4 | 3 | 2  | 1 | 0 |
|         |            | HS_EOF1 |   |   |   |    |   |   |
| RST     | 1          | 0       | 0 | 0 | 0 | 0  | 0 | 0 |

| Bits  | Name    | Description                                                                     | CPU  | USB |
|-------|---------|---------------------------------------------------------------------------------|------|-----|
| 7:0   | HS_EOF1 | Sets for High-speed transactions the time<br>before EOF to stop beginning new   | RW   | R   |
|       |         | transactions, in units of 133.3ns. (The default setting corresponds to 17.07µs) | only |     |
| 6.8.6 | FS_EOF1 | al used                                                                         | ~    |     |

## 6.8.6 FS\_EOF1

This 8-bit register sets the minimum time gap that is to be allowed between the start of the last transaction and the EOF for Full-speed transactions.

| FS_EOF1 | COM |   | 0x1344007d               |   |   |   |   | 'd |   |
|---------|-----|---|--------------------------|---|---|---|---|----|---|
| Bit     |     | 7 | 6                        | 5 | 4 | 3 | 2 | 1  | 0 |
|         |     |   | 7 6 5 4 3 2 1<br>FS_EOF1 |   |   |   |   |    |   |
| RST     |     | 0 | 1                        | 1 | 1 | 0 | 1 | 1  | 1 |

| Bits | Name    | Description                               | CPU | USB |
|------|---------|-------------------------------------------|-----|-----|
| 7:0  | FS_EOF1 | Sets for Full-speed transactions the time | RW  | R   |
|      |         | before EOF to stop beginning new          |     |     |
|      |         | transactions, in units of 533.3ns. (The   |     |     |
|      |         | default setting corresponds to 63.46µs)   |     |     |



## 6.8.7 LS\_EOF1

This 8-bit register sets the minimum time gap that is to be allowed between the start of the last transaction and the EOF for Low-speed transactions.



| Bits  | Name    | Description                                 | CPU            | USB |
|-------|---------|---------------------------------------------|----------------|-----|
| 7:0   | LS_EOF1 | Sets for Low-speed transactions the time    | RW             | R   |
|       |         | before EOF to stop beginning new            | 11             |     |
|       |         | transactions, in units of 1.067µs. (The     | $u_{r}$        |     |
|       |         | default setting corresponds to 121.6µs) 👌 🔪 | ) <sup>_</sup> |     |
|       |         | 1 USE                                       | . <u></u>      |     |
| 6.8.8 | SoftRst | arna.                                       |                |     |

## 6.8.8 SoftRst

This 8-bit register will assert LOW the output reset signals NRSTO and NRSTOX. This register is self clearing and will be reset by the input NRST.

| SoftRst | . 96. | 0x1344007f |   |     |      | ſ  |   |       |      |
|---------|-------|------------|---|-----|------|----|---|-------|------|
| Bit     |       | 7          | 6 | 5   | 4    | 3  | 2 | 1     | 0    |
|         |       |            | F | Res | erve | ed |   | NRSTX | NRST |
| RST     |       | 0          | 0 | 0   | 0    | 0  | 0 | 0     | 0    |

| Bits | Name     | Description                                   | CPU | USB |
|------|----------|-----------------------------------------------|-----|-----|
| 7:2  | reserved | Unused, always returns zero.                  | -   | -   |
| 1    | NRSTX    | The default value of this bit is 1'b0; When a | RW  | R   |
|      |          | 1 is written to this bit, the output NRSTXO   |     |     |
|      |          | will be asserted (LOW) within a minimum       |     |     |
|      |          | delay of 7 cycles of the CLK input. The       |     |     |
|      |          | output NRSTXO will be asynchronously          |     |     |
|      |          | asserted and synchronously de-asserted        |     |     |
|      |          | with respect to XCLK. This register is        |     |     |
|      |          | self clearing and will be reset by the input  |     |     |
|      |          | NRST.                                         |     |     |



| 0 | NRST | The default value of this bit is 1'b0; When a   | RW | R |
|---|------|-------------------------------------------------|----|---|
|   |      | 1 is written to this bit, the output NRSTO will |    |   |
|   |      | be asserted (LOW) within a minimum delay        |    |   |
|   |      | of 7 cycles of the CLK input. The output        |    |   |
|   |      | NRSTO will be asynchronously asserted           |    |   |
|   |      | and synchronously de-asserted with respect      |    |   |
|   |      | to CLK. This register is self clearing and will |    |   |
|   |      | be reset by the input NRST.                     |    |   |

Long\_eiffel@126.com internal used only



## 6.9 Extended Registers

## 6.9.1 RqPktCnt

## NOTE: HOST MODE ONLY!

For each Rx Endpoint 1 – 15, the MUSBMHDRC provides a 16-bit RqPktCount register. This read/write register is used in Host mode to specify the number of packets that are to be transferred in a block transfer of one or more Bulk packets of length MaxP to Rx Endpoint *n*. The core uses the value recorded in this register to determine the number of requests to issue where the AutoReq option (included in the RxCSR register) has been set.

NOTE: Multiple packets combined into a single bulk packet within the FIFO count as one packet.

| RqPktCnt | 0x13440300+4*n                        |
|----------|---------------------------------------|
| Bit      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|          | RgPktCnt                              |
| RST      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |
|          | into                                  |

| Bits | Name     | Description                                     | CPU | USB |
|------|----------|-------------------------------------------------|-----|-----|
| 15:0 | RqPktCnt | Sets the number of packets of size MaxP         | RW  | RW  |
|      | - 19K    | that are to be transferred in a block transfer. |     |     |
|      | 1@10     | Only used in Host mode when AutoReq is          |     |     |
|      | . ffer   | set. Has no effect in Peripheral mode or        |     |     |
|      | ella     | when AutoReq is not set.                        |     |     |

## 6.9.2 RmtWkIntr

Usb remote wakeup interrupt. It will be generated when there's non idle signaling on the bus during system hibernate.

|     | RmtWkIntr 03                                                                                                    | (13440398   |
|-----|-----------------------------------------------------------------------------------------------------------------|-------------|
| Bit | t de la constant de l | 0           |
|     |                                                                                                                 | Ę           |
|     |                                                                                                                 | <b>NkIr</b> |
|     |                                                                                                                 | RmtWkIntr   |
|     |                                                                                                                 |             |
| RS  | Т                                                                                                               | 0           |



| Bits | Name      | Description                               | CPU | USB |
|------|-----------|-------------------------------------------|-----|-----|
| 0    | RmtWkIntr | Usb remote wakeup interrupt. Self cleared | RW  | S   |
|      |           | after read.                               |     |     |

## 6.9.3 RmtWkIntrE

Usb remote wakeup interrupt enable.

|     | RmtWkIntrE | 0x1344039C |
|-----|------------|------------|
| Bit |            | 0          |
|     |            | RmtWkIntrE |
| RS  | r          | 0          |
|     |            | 1 OV       |

| Bits                                                                                                 | Name         | Description                              | CPU | USB |  |  |
|------------------------------------------------------------------------------------------------------|--------------|------------------------------------------|-----|-----|--|--|
| 0                                                                                                    | RmtWkIntrE   | Usb remote wakeup interrupt enable. High | RW  | R   |  |  |
|                                                                                                      |              | active.                                  |     |     |  |  |
| inter                                                                                                |              |                                          |     |     |  |  |
| 6.9.4                                                                                                | RxDPktBufDis | OT                                       |     |     |  |  |
| Rx DPktBufDis is a 16-bit register that indicates which of the Rx endpoints have disabled the double |              |                                          |     |     |  |  |

## 6.9.4 RxDPktBufDis

Rx DPktBufDis is a 16-bit register that indicates which of the Rx endpoints have disabled the double packet buffer functionality described in section 8.4.2.2 of the MUSBMHDRC Product Specification. NOTE: Bits relating to endpoints that have not been configured may be asserted by writing a '1' their

respective register; however the disable bit will have no observable effect.

| C Cr         |                                                                                                                                                                                                                                                                 |        |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| RxDPktBufDis | 0x13440340                                                                                                                                                                                                                                                      | )      |
| Bit          | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1                                                                                                                                                                                                                             | 0      |
|              | EP15_Rx_Dis<br>EP14_Rx_Dis<br>EP13_Rx_Dis<br>EP12_Rx_Dis<br>EP11_Rx_Dis<br>EP10_Rx_Dis<br>EP10_Rx_Dis<br>EP2_Rx_Dis<br>EP2_Rx_Dis<br>EP4_Rx_Dis<br>EP4_Rx_Dis<br>EP4_Rx_Dis<br>EP4_Rx_Dis<br>EP2_Rx_Dis<br>EP1_Rx_Dis<br>EP1_Rx_Dis<br>EP1_Rx_Dis<br>EP1_Rx_Dis | Dunsed |
| RST          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                             | 0      |

| Bits | Name        | Description                                      | CPU | USB |
|------|-------------|--------------------------------------------------|-----|-----|
| 15   | EP15_Rx_Dis | Rx Double Packet Buffer Disable for Endpoint 15. | RW  | R   |
| 14   | EP14_Rx_Dis | Rx Double Packet Buffer Disable for Endpoint 14. | RW  | R   |
| 13   | EP13_Rx_Dis | Rx Double Packet Buffer Disable for Endpoint 13. | RW  | R   |
| 12   | EP12_Rx_Dis | Rx Double Packet Buffer Disable for Endpoint 12. | RW  | R   |
| 11   | EP11_Rx_Dis | Rx Double Packet Buffer Disable for Endpoint 11. | RW  | R   |



| 1<br>0 | EP1_Rx_Dis<br>Unused | Rx Double Packet Buffer Disable for Endpoint 1.<br>Reserved. | RW<br>R | R<br>R |
|--------|----------------------|--------------------------------------------------------------|---------|--------|
| 2      | EP2_Rx_Dis           | Rx Double Packet Buffer Disable for Endpoint 2.              | RW      | R      |
| 3      | EP3_Rx_Dis           | Rx Double Packet Buffer Disable for Endpoint 3.              | RW      | R      |
| 4      | EP4_Rx_Dis           | Rx Double Packet Buffer Disable for Endpoint 4.              | RW      | R      |
| 5      | EP5_Rx_Dis           | Rx Double Packet Buffer Disable for Endpoint 5.              | RW      | R      |
| 6      | EP6_Rx_Dis           | Rx Double Packet Buffer Disable for Endpoint 6.              | RW      | R      |
| 7      | EP7_Rx_Dis           | Rx Double Packet Buffer Disable for Endpoint 7.              | RW      | R      |
| 8      | EP8_Rx_Dis           | Rx Double Packet Buffer Disable for Endpoint 8.              | RW      | R      |
| 9      | EP9_Rx_Dis           | Rx Double Packet Buffer Disable for Endpoint 9.              | RW      | R      |
| 10     | EP10_Rx_Dis          | Rx Double Packet Buffer Disable for Endpoint 10.             | RW      | R      |

## 6.9.5 TxDPktBufDis

Tx DPktBufDis is a 16-bit register that indicates which of the TX endpoints have disabled the double packet buffer functionality described in section 8.4.1.2 of the MUSBMHDRC Product Specification.

**NOTE:** Bits relating to endpoints that have not been configured may be asserted by writing a '1' their respective register; however the disable bit will have no observable effect.

| TxDPktBufDis | inter                                                                                                                                          | 0x13440342                                                     |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| Bit          | 15 14 13 12 11 10 9 8 7 6 5                                                                                                                    | 4 3 2 1 0                                                      |
|              | EP15_Tx_Dis<br>EP14_Tx_Dis<br>EP13_Tx_Dis<br>EP13_Tx_Dis<br>EP12_Tx_Dis<br>EP10_Tx_Dis<br>EP9_Tx_Dis<br>EP9_Tx_Dis<br>EP6_Tx_Dis<br>EP6_Tx_Dis | EP4_Tx_Dis<br>EP3_Tx_Dis<br>EP2_Tx_Dis<br>EP1_Tx_Dis<br>Unused |
| RST          | 0 0 0 0 0 0 0 0 0 0 0                                                                                                                          | 0 0 0 0 0                                                      |

| )<br>) |             |                                                  |     |     |
|--------|-------------|--------------------------------------------------|-----|-----|
| Bits   | Name        | Description                                      | CPU | USB |
| 15     | EP15_Tx_Dis | Tx Double Packet Buffer Disable for Endpoint 15. | RW  | R   |
| 14     | EP14_Tx_Dis | Tx Double Packet Buffer Disable for Endpoint 14. | RW  | R   |
| 13     | EP13_Tx_Dis | Tx Double Packet Buffer Disable for Endpoint 13. | RW  | R   |
| 12     | EP12_Tx_Dis | Tx Double Packet Buffer Disable for Endpoint 12. | RW  | R   |
| 11     | EP11_Tx_Dis | Tx Double Packet Buffer Disable for Endpoint 11. | RW  | R   |
| 10     | EP10_Tx_Dis | Tx Double Packet Buffer Disable for Endpoint 10. | RW  | R   |
| 9      | EP9_Tx_Dis  | Tx Double Packet Buffer Disable for Endpoint 9.  | RW  | R   |
| 8      | EP8_Tx_Dis  | Tx Double Packet Buffer Disable for Endpoint 8.  | RW  | R   |
| 7      | EP7_Tx_Dis  | Tx Double Packet Buffer Disable for Endpoint 7.  | RW  | R   |
| 6      | EP6_Tx_Dis  | Tx Double Packet Buffer Disable for Endpoint 6.  | RW  | R   |
| 5      | EP5_Tx_Dis  | Tx Double Packet Buffer Disable for Endpoint 5.  | RW  | R   |
| 4      | EP4_Tx_Dis  | Tx Double Packet Buffer Disable for Endpoint 4.  | RW  | R   |

#### 140

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| 3 | EP3_Tx_Dis | Tx Double Packet Buffer Disable for Endpoint 3. | RW | R |
|---|------------|-------------------------------------------------|----|---|
| 2 | EP2_Tx_Dis | Tx Double Packet Buffer Disable for Endpoint 2. | RW | R |
| 1 | EP1_Tx_Dis | Tx Double Packet Buffer Disable for Endpoint 1. | RW | R |
| 0 | Unused     | Reserved.                                       | R  | R |

## 6.9.6 C T UCH

This register sets the chirp timeout. This number when multiplied by 4 represents the number of XCLK cycles before the timeout occurs. That is, if XCLK is 30MHz, this number represents the number of 133ns time intervals before the timeout occurs. If XCLK is 60MHz, this number represents the number of 67ns time intervals before the timeout occurs. Although this bit is written by the host in the CLK domain, the counter that utilizes this value is in the XCLK domain. No time domain crossing is provided as the value in this register is a static. The default value is the value of the compiler directive of the same name located in the configuration file musbmhdrc\_cfg.v.



16 bits (XCLK is 30MHz) and 4074h if the PHY data width is 8 bits (XCLK is 60Mhz)

corresponding to a delay of 1.1ms.

## 6.9.7 C\_T\_HHSRTN

This register sets the delay from the end of High Speed resume signaling (acting as a Host) to enable the UTM normal operating mode. This number when multiplied by 4 represents the number of XCLK cycles before the timeout occurs. That is, if XCLK is 30MHz, this number represents the number of 33.3ns time intervals before the timeout occurs. If XCLK is 60MHz, this number represents the number of 16.7ns time intervals before the timeout occurs. Although this bit is written by the host in the CLK domain, the counter that utilizes this value is in the XCLK domain. No time domain crossing is provided as the value in this register is a static. The default value is the value of the compiler directive of the same name located in the configuration file musbmhdrc cfg.v.

Bit

RST



**C T HHSRTN** 

#### 0x13440346

|  | 15 14 13 12 11 | 10 9 8 | 10 | 5 4 3 | 210 |
|--|----------------|--------|----|-------|-----|
|--|----------------|--------|----|-------|-----|

## ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?

C\_T\_HHSRTN

| Bits    | Name                               | Description                                                      | CPU     | USB  |  |
|---------|------------------------------------|------------------------------------------------------------------|---------|------|--|
| 15:0    | C_T_HHSRTN                         | The delay from the end of High Speed                             | RW      | -    |  |
|         |                                    | resume signaling to enabling UTM normal                          |         |      |  |
|         |                                    | operating mode. The default value is                             |         |      |  |
|         |                                    | determined by compiler directive in                              |         |      |  |
|         |                                    | musbhsfc_xcfg.v file. The default value is                       |         |      |  |
|         |                                    | 2F3h if the host PHY data width is 16 bits                       |         |      |  |
|         |                                    | (XCLK is 30MHz) and 5E6h if the PHY data                         | 17      |      |  |
|         |                                    | width is 8 bits (XCLK is 60Mhz)                                  | DIT     |      |  |
|         |                                    | corresponding to a delay of 100us. $_{\sim} \bigcirc^{\bigcirc}$ |         |      |  |
| 1 US    |                                    |                                                                  |         |      |  |
| 6.9.8   | C_T_HSBT                           | ternar                                                           |         |      |  |
| Per USE | 3 2.0, Section 7.1.19.2, a high-sp | beed host or device expecting a response to a t                  | ransmis | sion |  |

## 6.9.8 C\_T\_HSBT

Per USB 2.0, Section 7.1.19.2, a high-speed host or device expecting a response to a transmission must not timeout the transaction if the interpacket delay is less than 736 bit times, and it must timeout the transaction if no signaling is seen within 816 bit times. This register represents the value to be added to the mimumum high speed timeout period of 736 bit times. The timeout period can be increased in increments of 64 high speed bit times (133 ns). There are 16 possible values. By default, the adder is 0 thus setting the high speed timeout to its minimum value. Use of this register will allow the high speed timeout to be set to values that are greater the maximum specified in USB 2.0 making the MUSBMHDRC non-compliant.



#### 142



|     | Name     |             | Description         |                 | CPU     | USB |
|-----|----------|-------------|---------------------|-----------------|---------|-----|
| 3:0 | C_T_HSBT | The value   | added to the minin  | num High        | RW      | R   |
|     |          | Speed Tim   | eout period (736 b  | it times) in    |         |     |
|     |          | increments  | s of 64 High Speed  | bit times. This |         |     |
|     |          | allows the  | turn around timeou  | it period to be |         |     |
|     |          | set to 16 p | ossible values as f | ollows:         |         |     |
|     |          | Registe     | HS                  | HS              |         |     |
|     |          | r           | Turnaround          | Turnaroun       |         |     |
|     |          | Value       | Timeout (HS         | d Timeout       |         |     |
|     |          |             | Bit times)          | (us)            |         |     |
|     |          | 0           | 736                 | 1.534           |         |     |
|     |          | 1           | 800                 | 1.667           |         |     |
|     |          | 2           | 864                 | 1.801           |         |     |
|     |          | 3           | 928                 | 1.934           |         |     |
|     |          | 4           | 992                 | 2.067           | 1       |     |
|     |          | 5           | 1056                | 2.201           | $O_{r}$ |     |
|     |          | 6           | 1120                | 2.334           |         |     |
|     |          | 7           | 1184 🔨              | 2.467           |         |     |
|     |          | 8           | 1248                | 2.601           |         |     |
|     |          | 9           | 1312                | 2.734           |         |     |
|     |          | 10          | 1376                | 2.868           |         |     |
|     |          | 11 0111     | 1440                | 3.001           |         |     |
|     | C        | .12         | 1504                | 3.134           |         |     |
|     | eiffel@1 | 13          | 1568                | 3.268           |         |     |
|     | cf el a  | 14          | 1632                | 3.401           |         |     |
|     | iti      | 15          | 1696                | 3.534           |         |     |



## 6.10 DMA Registers

## 6.10.1 DMA\_INTR

This register provides an interrupt for each DMA channel. This interrupt register is cleared when read. When any bit of this register is set, the output DMA\_NINT is asserted low. Events that cause interrupts to be set is described in section 17 (The optional DMA Controller description). Bits in this register will only be set if the DMA Interrupt Enable bit for the corresponding channel is enabled (register DMA\_CNTL.D3).



|         | Decemption                                                                | 0.0                                                                                                                                                                                                                       | 005                                                                                                                                                                                                                                   |
|---------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CH8_INT | Channel 8 DMA Interrupt                                                   | RW                                                                                                                                                                                                                        | Set                                                                                                                                                                                                                                   |
| CH7_INT | Channel 7 DMA Interrupt.                                                  | RW                                                                                                                                                                                                                        | Set                                                                                                                                                                                                                                   |
| CH6_INT | Channel 6 DMA Interrupt.                                                  | RW                                                                                                                                                                                                                        | Set                                                                                                                                                                                                                                   |
| CH5_INT | Channel 5 DMA Interrupt.                                                  | RW                                                                                                                                                                                                                        | Set                                                                                                                                                                                                                                   |
| CH4_INT | Channel 4 DMA Interrupt.                                                  | RW                                                                                                                                                                                                                        | Set                                                                                                                                                                                                                                   |
| CH3_INT | Channel 3 DMA Interrupt.                                                  | R                                                                                                                                                                                                                         | Set                                                                                                                                                                                                                                   |
| CH2_INT | Channel 2 DMA Interrupt.                                                  | R                                                                                                                                                                                                                         | Set                                                                                                                                                                                                                                   |
| CH1_INT | Channel 1 DMA Interrupt.                                                  | R                                                                                                                                                                                                                         | Set                                                                                                                                                                                                                                   |
|         | CH7_INT<br>CH6_INT<br>CH5_INT<br>CH4_INT<br>CH3_INT<br>CH2_INT<br>CH2_INT | CH8_INTChannel 8 DMA Interrupt.CH7_INTChannel 7 DMA Interrupt.CH6_INTChannel 6 DMA Interrupt.CH5_INTChannel 5 DMA Interrupt.CH4_INTChannel 4 DMA Interrupt.CH3_INTChannel 3 DMA Interrupt.CH2_INTChannel 2 DMA Interrupt. | CH8_INTChannel 8 DMA Interrupt.RWCH7_INTChannel 7 DMA Interrupt.RWCH6_INTChannel 6 DMA Interrupt.RWCH5_INTChannel 5 DMA Interrupt.RWCH4_INTChannel 4 DMA Interrupt.RWCH3_INTChannel 3 DMA Interrupt.RCH2_INTChannel 2 DMA Interrupt.R |

# 6.10.2 DMA\_CNTL

This register is only available if the MUSBMHDRC is configured to use at least one internal DMA channel. This register provides the DMA transfer control for each channel. The enabling, transfer direction, transfer mode, the DMA burst modes are all controlled by this register.



#### 144

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| Bits | Name                                    | Description                                   | CPU | USB |
|------|-----------------------------------------|-----------------------------------------------|-----|-----|
| 10:9 | DMA_BRSTM                               | Burst Mode.                                   | RW  | R   |
|      |                                         | 00 : (Burst Mode 0 : Bursts of unspecified    |     |     |
|      |                                         | length)                                       |     |     |
|      |                                         | 01: (Burst Mode 1 : INCR4 or unspecified      |     |     |
|      |                                         | length)                                       |     |     |
|      |                                         | 10: (Burst Mode 2 : INCR8, INCR4 or           |     |     |
|      |                                         | unspecified length)                           |     |     |
|      |                                         | 11: (Burst Mode 3 : INCR16, INCR8, INCR4      |     |     |
|      |                                         | or unspecified length)                        |     |     |
| 8    | DMA_ERR                                 | Bus Error Bit. Indicates that a bus error has | RW  | RW  |
|      |                                         | been observed on the input.                   |     |     |
|      |                                         | AHB_HRESPM[1:0]. This bit is cleared by       |     |     |
|      |                                         | software.                                     |     |     |
| 7:4  | DMAEP                                   | The endpoint number this channel is           | RW  | R   |
|      |                                         | assigned to.                                  | Dri |     |
| 3    | DMAIE                                   | DMA Interrupt Enable.                         | RW  | R   |
| 2    | DMAMODE                                 | This bit selects the DMA Transfer Mode.       | RW  | R   |
|      |                                         | 0: DMA Mode0 Transfer                         |     |     |
|      |                                         | 1: DMA Mode1 Transfer                         |     |     |
| 1    | DMA_DIR                                 | This bit selects the DMA Transfer Direction.  | RW  | R   |
|      |                                         | 0: DMA Write (RX Endpoint)                    |     |     |
|      | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | 1: DMa Read (TX Endpoint)                     |     |     |
| 0    | DMA_ENAB                                | This bit enables the DMA transfer and will    | RW  | R   |
|      |                                         | cause the transfer to begin.                  |     |     |

## 6.10.3 DMA\_ADDR

This register identifies the current memory address of the corresponding DMA channel. The Initial memory address written to this register must have a value such that its modulo 4 value is equal to 0. That is, DMA\_ADDR[1:0] must be equal to 2'b00. The lower two bits of this register are read only and cannot be set by software. As the DMA transfer progresses, the memory address will increment as bytes are transferred.





| Bits | Name     | Description                                | CPU | USB |
|------|----------|--------------------------------------------|-----|-----|
| 31:0 | DMA_ADDR | The DMA memory address.                    | RW  | RW  |
|      |          | Note that the initial memory address       |     |     |
|      |          | written to this register must have a value |     |     |
|      |          | such that it's modulo 4 value is equal to  |     |     |
|      |          | 0. That is, DMA_ADDR[1:0] must be equal    |     |     |
|      |          | to 2'b00. The lower two bits of this       |     |     |
|      |          | register are read only and cannot be set   |     |     |
|      |          | by software.                               |     |     |

## 6.10.4 DMA\_COUNT

This register identifies the current DMA count of the transfer. Software will set the initial count of the transfer which identifies the entire transfer length. As the count progresses this count is decremented as bytes are transferred.





## 6.11 Transaction flows as a peripheral

## 6.11.1 Control transactions

## 6.11.1.1 Setup phase





## 6.11.1.2 In data phase



## 148



## 6.11.1.3 Following the status phase





## 6.11.1.4 Out data phase



150



## 6.11.1.5 Following the status phase





## 6.11.2 Bulk/Low-bandwidth interrupt transactions

## 6.11.2.1 In transaction



## 152



## 6.11.2.2 Out transaction



10ng\_eifte

154



## 6.11.3 Full-speed/Low-bandwidth isochronous transactions

## 6.11.3.1 In transaction





## 6.11.3.2 Out transaction



156



## 6.11.4 High-bandwidth transactions (Isochronous and interrupt)

## 6.11.4.1 In transaction





## 6.11.4.2 Out transaction



JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



## 6.12 Transaction flows as a host

## 6.12.1 Control transactions

#### 6.12.1.1 Setup phase





## 6.12.1.2 In data phase





## 6.12.1.3 Following the status phase





## 6.12.1.4 Out data phase





## 6.12.1.5 Following the status phase





## 6.12.2 Bulk/Low-bandwidth interrupt transactions

## 6.12.2.1 In transaction



x-

164



## 6.12.2.2 Out transaction





## 6.12.3 Full-speed/Low-bandwidth isochronous transactions

## 6.12.3.1 In transaction





## 6.12.3.2 Out transaction



V



166



# 6.12.4 High-bandwidth transactions (isochronous and interrupt)

#### 6.12.4.1 In transaction



168



# 6.12.4.2 Out transaction





# 6.13 DMA operations

#### 6.13.1 Single packet tx



170



# 6.13.2 Single packet rx



JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

3



## 6.13.3 Multiple packet tx



172



# 6.13.4 Multiple packet rx

If Size of Data Block Known:





#### If Size of Data Block Not Known:





# 7 MMC/SD CE-ATA Controller

# 7.1 Overview

The MultiMediaCard (MMC) is a universal low cost data storage and communication media that is designed to cover a wide area of applications such as electronic toys, organizers, PDAs, smart phones, and so on.

The Secure Digital (SD) card is an evolution of MMC, It is specifically designed to meet the security, capacity, performance, and environmental requirements inherent in newly emerging audio and video consumer electronic devices. The physical form factor, pin assignment, and data transfer protocol are forward compatible with the MultiMediaCard with some additions. An SD card can be categorized as SD memory or SD I/O card, commonly known as SDIO. A memory card invokes a copyright protection mechanism that complies with the security of the SDMI standard and is faster and capable of higher memory capacity. The SDIO card provides high-speed data I/O with low-power consumption for mobile electronic devices.

For CE-ATA detail protocol , please referred to \_WWW.CE-ATA.ORG.

Features of the MSC Controller include the following:

- Fully compatible with the MMC System Specification version 4.2
- Fully compatible with the SD Memory Card Specification 2.0 and SD I/O Specification 1.0 with 1 command channel and 4 data channels
- Consumer Electronics Advanced Transport Architecture (CE-ATA version 1.1)
- 20-80 Mbps maximum data rate
- Support MMC data width 1bit ,4bit and 8bit
- Built-in programmable frequency divider for MMC/SD bus
- Maskable hardware interrupt for SDIO interrupt, internal status and FIFO status
- 32-entry x 32-bit built-in data FIFO
- Multi-SD function support including multiple I/O and combined I/O and memory
- IRQ supported enable card to interrupt MMC/SD controller
- Single or multi block access to the card including erase operation
- Stream access to the MMC card

174

- Supports SDIO read wait, interrupt detection during 1-bit or 4-bit access
- Supports CE-ATA digital protocol commands
- Support Command Completion Signal and interrupt to CPU
- Command Completion Signal disable feature
- The maximum block length is 4096bytes



# 7.2 Block Diagram

## MSC Controller Block Diagram



Figure 7-1 MMC/SD CE-ATA Controller Block Diagram

176



# 7.3 MMC/SD Controller Signal I/O Description

MSC and the card communication over the CMD and DATA line is base on command and data bit streams which are initiated by a start bit and terminated by a stop bit.

**Command:** a command is a token, which starts an operation. A command is sent from MSC either to a single card (addressed command) or to all connected cards (broadcast command). A command is transferred serially on the CMD line. Each command token is preceded by a start bit ('0') and succeeded by an end bit ('1'). The total length is 48 bits and protected by CRC bits.

| Bit       | 47    | 46           | [45 : 40] | [39 : 8] | [7 : 1] | 0       |
|-----------|-------|--------------|-----------|----------|---------|---------|
| position  |       |              |           |          |         |         |
| Width     | 1     | 1            | 6         | 32       | 7       | 1       |
| (bits)    |       |              |           |          |         | 13      |
| Value     | 0     | 1            | Х         | Х        | x 🔪     | 011     |
| Descripti | Start | Transmission | Command   | argument | CRC7    | End bit |
| on        | bit   | bit          | index     | 1        | U.S     |         |

| Table 7-1 | Command | Token | Format |
|-----------|---------|-------|--------|
|-----------|---------|-------|--------|

**Response:** a response is a token which is sent from an addressed card, or (synchronously) from all connected cards, to MSC as an answer to a previously received command. A response is transferred serially on the CMD line. Response tokens have varies coding schemes depending on their content.

**Data:** data can be transferred from the card to MSC or vice versa. Data is transferred via the data line. Data transfers to/from the SD Memory Card are done in blocks. Data blocks always succeeded by CRC bits. Single and multiple block operations are defined. Note that the Multiple Block operation mode is better for faster write operation. A multiple block transmission is terminated when a stop command follows on the CMD line. Data transfer can be configured by the MSC to use single or multiple data lines.

| Description | Start bit | Data | CRC16  | End bit |
|-------------|-----------|------|--------|---------|
| Stream Data | 0         | Х    | no CRC | 1       |
| Block Data  | 0         | Х    | Х      | 1       |



# 7.4 Register Description

The MMC-SD-CE\_ATA controller is controlled by a set of registers that the application configures before every operation. The \_Table 7-3 lists all the MSC registers.

MSC0 Base Address: 0x10021000 MSC1 Base Address: 0x10022000 MSC2 Base Address: 0x10023000

| Name       | RW     | Reset Value | Address      | Access Size |
|------------|--------|-------------|--------------|-------------|
| MSC_CTRL   | W      | 0x0000      | Base + 0x000 | 16          |
| MSC_STAT   | R      | 0x00000040  | Base + 0x004 | 32          |
| MSC_CLKRT  | RW     | 0x0000      | Base + 0x008 | 16          |
| MSC_CMDAT  | RW     | 0x0000000   | Base + 0x00C | 32          |
| MSC_RESTO  | RW     | 0x40        | Base + 0x010 | 16          |
| MSC_RDTO   | RW     | 0xFFFF      | Base + 0x014 | 32          |
| MSC_BLKLEN | RW     | 0x0000      | Base + 0x018 | 16          |
| MSC_NOB    | RW     | 0x0000      | Base + 0x01C | 16          |
| MSC_SNOB   | R      | 0x????      | Base + 0x020 | 16          |
| MSC_IMASK  | RW     | 0x00FF      | Base + 0x024 | 32          |
| MSC_IREG   | RW     | 0x0000 0111 | Base + 0x028 | 16          |
| MSC_CMD    | RW     | 0x00        | Base + 0x02C | 8           |
| MSC_ARG    | RW 🔨 🔘 | 0x0000000   | Base + 0x030 | 32          |
| MSC_RES    | RCC    | 0x????      | Base + 0x034 | 16          |
| MSC_RXFIFO | R      | 0x???????   | Base + 0x038 | 32          |
| MSC_TXFIFO | W      | 0x???????   | Base + 0x03C | 32          |
| MSC_LPM    | RW     | 0x0000000   | Base + 0x040 | 32          |

#### Table 7-3 MMC/SD Controller Registers Description

## 7.4.1 MMC/SD Control Register (MSC\_CTRL)





|        | SEND_CCSD     | <ul> <li>0: clear bit</li> <li>1: Send Command Completion Signal Disable (CCSD) to CE_ATA device</li> <li>when set, host sends CCSD to CE_ATA device. Software set the bit only if current command is expecting CCS and interrupts are enabled in CE_ATA devices. Once the CCSD pattern is sent to device, host automatically clears the SEND_CCSD bit.</li> </ul> | × |
|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 14 S   | SEND_AS_CCSD  | CE_ATA device<br>when set, host sends CCSD to CE_ATA device. Software set the<br>bit only if current command is expecting CCS and interrupts are<br>enabled in CE_ATA devices. Once the CCSD pattern is sent to<br>device, host automatically clears the SEND_CCSD bit.                                                                                            |   |
| 14 S   | SEND_AS_CCSD  | when set, host sends CCSD to CE_ATA device. Software set the bit only if current command is expecting CCS and interrupts are enabled in CE_ATA devices. Once the CCSD pattern is sent to device, host automatically clears the SEND_CCSD bit.                                                                                                                      |   |
| 14 S   | SEND_AS_CCSD  | bit only if current command is expecting CCS and interrupts are<br>enabled in CE_ATA devices. Once the CCSD pattern is sent to<br>device, host automatically clears the SEND_CCSD bit.                                                                                                                                                                             |   |
| 14 S   | SEND_AS_CCSD  | enabled in CE_ATA devices. Once the CCSD pattern is sent to device, host automatically clears the SEND_CCSD bit.                                                                                                                                                                                                                                                   |   |
| 14 S   | SEND_AS_CCSD  | device, host automatically clears the SEND_CCSD bit.                                                                                                                                                                                                                                                                                                               |   |
| 14 S   | SEND_AS_CCSD  |                                                                                                                                                                                                                                                                                                                                                                    |   |
| 14 S   | SEND_AS_CCSD  |                                                                                                                                                                                                                                                                                                                                                                    |   |
|        |               | 0: clear bit                                                                                                                                                                                                                                                                                                                                                       | W |
|        |               | 1: send internally generated stop after sending CCSD to CE_ATA                                                                                                                                                                                                                                                                                                     |   |
|        |               | device                                                                                                                                                                                                                                                                                                                                                             |   |
|        |               | When set, host automatically sends internally-generated STOP                                                                                                                                                                                                                                                                                                       |   |
|        |               | command(CMD12) to CE_ATA device. After sending CMD12,                                                                                                                                                                                                                                                                                                              |   |
|        |               | Auto Command Done (ACD) is set and generates interrupt to                                                                                                                                                                                                                                                                                                          |   |
|        |               | CPU. After sending the CCSD, controller automatically clears the                                                                                                                                                                                                                                                                                                   |   |
|        |               | SEND_AS_CCSD bit.                                                                                                                                                                                                                                                                                                                                                  |   |
| 13:8 R | Reserved      | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                                                               | R |
| 7 E    | EXIT_MULTIPLE | If CMD12 or CMD52 (I/O abort) is to be sent to terminate multiple                                                                                                                                                                                                                                                                                                  | W |
|        |               | block read/write in advance, set this bit to 1.                                                                                                                                                                                                                                                                                                                    |   |
|        |               | 0: No effect                                                                                                                                                                                                                                                                                                                                                       |   |
|        |               | 1: Exit from multiple block read/write                                                                                                                                                                                                                                                                                                                             |   |
| 6 E    | EXIT_TRANSFER | Only used for SDIO suspend/resume and MMC stream read.                                                                                                                                                                                                                                                                                                             | W |
|        |               | For SDIO, after suspend is accepted, set this bit with 1.                                                                                                                                                                                                                                                                                                          |   |
|        |               | For MMC, after the data of the expected number are received, set                                                                                                                                                                                                                                                                                                   |   |
|        |               | this bit with 1.                                                                                                                                                                                                                                                                                                                                                   |   |
|        | ·fte          | 0: No effect                                                                                                                                                                                                                                                                                                                                                       |   |
|        | elr           | 1: Exit from multiple block read/write after suspend is accepted, or                                                                                                                                                                                                                                                                                               |   |
|        | ng eifte      | exit from stream read                                                                                                                                                                                                                                                                                                                                              |   |
| 5 S    | TART_READWAIT | Only used for SDIO ReadWait. Start the ReadWait cycle.                                                                                                                                                                                                                                                                                                             | W |
|        |               | 0: No effect                                                                                                                                                                                                                                                                                                                                                       |   |
|        |               | 1: Start ReadWait                                                                                                                                                                                                                                                                                                                                                  |   |
| 4 S    | STOP_READWAIT | Only used for SDIO ReadWait. Stop the ReadWait cycle.                                                                                                                                                                                                                                                                                                              | W |
|        |               | 0: No effect                                                                                                                                                                                                                                                                                                                                                       |   |
|        |               | 1: Start ReadWait                                                                                                                                                                                                                                                                                                                                                  |   |
| 3 R    | RESET         | Resets the MMC/SD controller.                                                                                                                                                                                                                                                                                                                                      | W |
|        |               | 0: No effect                                                                                                                                                                                                                                                                                                                                                       |   |
|        |               | 1: Reset the MMC/SD controller                                                                                                                                                                                                                                                                                                                                     |   |
| 2 S    | START_OP      | This bit is used to start the new operation. When starting the                                                                                                                                                                                                                                                                                                     | W |
|        | _             | clock, this bit can be 1. When stopping the clock, this bit can only                                                                                                                                                                                                                                                                                               |   |
|        |               | be 0.                                                                                                                                                                                                                                                                                                                                                              |   |
|        |               | 0: Do nothing                                                                                                                                                                                                                                                                                                                                                      |   |
|        |               | 1: Start the new operation                                                                                                                                                                                                                                                                                                                                         |   |

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| 1:0 | CLOCK_CONTROL | These bits are used to start or stop clock. | W |
|-----|---------------|---------------------------------------------|---|
|     |               | 00: Do nothing                              |   |
|     |               | 01: Stop MMC/SD clock                       |   |
|     |               | 10: Start MMC/SD clock                      |   |
|     |               | 11: Reserved                                |   |

# 7.4.2 MSC Status Register (MSC\_STAT)



| r     |                 |                                                           | r  |
|-------|-----------------|-----------------------------------------------------------|----|
| Bits  | Name            | Description                                               | RW |
| 31    | AUTO_CMD_DONE   | Indicate that the stop command (CMD12) that is internally | R  |
|       |                 | generated by controller has finished.                     |    |
| 30:16 | Reserved 🔨 🔨    | Writing has no effect, read as zero.                      | R  |
| 15    | IS_RESETTING    | MSC is resetting after power up or MSC_STRPCL[RESET]      | R  |
|       | olt.            | is written with 1.                                        |    |
|       | O .             | 0: Reset has been finished                                |    |
| 1     | 0119-           | 1: Reset has not been finished                            |    |
| 14    | SDIO_INT_ACTIVE | Indicates whether an interrupt is detected at the SD I/O  | R  |
|       |                 | card. A separate acknowledge command to the card is       |    |
|       |                 | required to clear this interrupt.                         |    |
|       |                 | 0: No interrupt detected                                  |    |
|       |                 | 1: The interrupt from SDIO is detected                    |    |
| 13    | PRG_DONE        | Indicates whether card has finished programming.          | R  |
|       |                 | 0: Card has not finished programming and is busy          |    |
|       |                 | 1: Card has finished programming and is not busy          |    |
| 12    | DATA_TRAN_DONE  | Indicates whether data transmission to card has           | R  |
|       |                 | completed.                                                |    |
|       |                 | 0: Data transmission to card has not completed            |    |
|       |                 | 1: Data transmission to card has completed                |    |
| 11    | END_CMD_RES     | End command-response sequence or command                  | R  |
|       |                 | sequence.                                                 |    |







## 7.4.3 MSC Clock Rate Register (MSC\_CLKRT)

The MSC\_CLKRT register specifies the frequency division of the MMC/SD bus clock. The software is responsible for setting this register.



| Bits | Name     | Description                          | RW |
|------|----------|--------------------------------------|----|
| 15:3 | Reserved | Writing has no effect, read as zero. | R  |
| 2:0  | CLK_RATE | Clock rate.                          | WR |
|      |          | 000: CLK_DIV                         |    |
|      |          | 001: 1/2 of CLK_DIV                  |    |
|      |          | 010: 1/4 of CLK_DIV                  |    |
|      |          | 011: 1/8 of CLK_DIV                  |    |
|      |          | 100: 1/16 of CLK_DIV                 |    |
|      |          | 101: 1/32 of CLK_DIV                 |    |
|      |          | 110: 1/64 of CLK_DIV O               |    |
|      |          | 111: 1/128 of CLK_DIV                |    |
|      |          | 10,10                                |    |

## 7.4.4 MMC/SD Command and Data Control Register (MSC\_CMDAT)



| Bits | Name         | Description                                           | RW |
|------|--------------|-------------------------------------------------------|----|
| 31   | CCS_EXPECTED | 0: interrupts are not enabled in CE-ATA device, or    | RW |
|      |              | commands does not expect CCS from device              |    |
|      |              | 1: interrupts are enabled in CE_ATA device, or RW_BLK |    |



|       |              | command expects command completion signal from             |    |
|-------|--------------|------------------------------------------------------------|----|
|       |              | device                                                     |    |
|       |              | If the command expects Command Completion Signal           |    |
|       |              | (CCS) from the device, the software should set the control |    |
|       |              |                                                            |    |
| 00    |              | bit. It is auto cleared 0 by hardware.                     |    |
| 30    | READ_CEATA   | 0: host is not performing read access (RW_BLK or           | RW |
|       |              | RW_REG) towards CE_ATA device                              |    |
|       |              | 1: host id performing read access (RW_BLK or RW_REG)       |    |
|       |              | towards CE_ATA device                                      |    |
|       |              | Software should set the bit to indicate that CE_ATA device |    |
|       |              | is being accessed for read transfer. The bit is used to    |    |
|       |              | disable read data timeout indication while performing      |    |
|       |              | CE_ATA read transfers. It is auto cleared 0 by hardware.   |    |
| 29:18 | Reserved     | Writing has no effect, read as zero.                       | R  |
| 17    | SDIO_PRDT    | Determine whether SDIO interrupt is 2 cycle or extend      | RW |
|       |              | more cycle when data block last is transferred             |    |
|       |              | 0: more cycle (like single block) $\sim e^{O}$             |    |
|       |              | 1: exact 2 cycle $\sqrt{\sqrt{2}}$                         |    |
| 16    | SEND_AS_STOP | 0: no stop command sent at end of data transfer            | RW |
|       |              | 1: send stop command at end of data transfer               |    |
|       |              | when stop command has finished, it is auto cleared 0 by    |    |
|       |              | hardware.                                                  |    |
| 15:14 | RTRG         | These bits set the receive FIFO half-empty threshold       | RW |
|       |              | value, when the number of transmit FIFO >= threshold       |    |
|       | 10           | value , RXFIFO_RD_REQ will be set to 1.                    |    |
|       | .fter        | 00 : more than or equal to 8                               |    |
|       | elt          | 01: more than or equal to 16                               |    |
|       | ong_eiffel@  | 10: more than or equal to 24                               |    |
| 1     | Olic         | 11: reserved                                               |    |
| 13:12 | TTRG         | These bits set the transmit FIFO half-empty threshold      | RW |
| -     | -            | value, when the number of transmit FIFO < threshold        |    |
|       |              | value , TXFIFO_WR_REQ will be set to 1.                    |    |
|       |              | 00 : less than 8                                           |    |
|       |              | 01: less than 16                                           |    |
|       |              | 10: less than 24                                           |    |
|       |              | 11: reserved                                               |    |
| 11    | STOP_ABORT   | Specifies the current command is used to abort data        | WR |
|       |              | transfer.                                                  |    |
|       |              | 0: Nothing                                                 |    |
|       |              | 1: The current command is used to abort transfer           |    |
|       |              |                                                            |    |
| 10.0  |              | it is auto cleared 0 by hardware.                          |    |
| 10:9  | BUS_WIDTH    | Specifies the width of the data bus.                       | WR |
|       |              | 00: 1-bit                                                  |    |

182

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|     |                 | 01: Reserved                                                  |    |
|-----|-----------------|---------------------------------------------------------------|----|
|     |                 |                                                               |    |
|     |                 | 10: 4-bit                                                     |    |
|     |                 | 11: 8bit                                                      |    |
| 8   | DMA_EN          | DMA mode enables. When DMA mode is used, this bit is          | WR |
|     |                 | also a mask on RXFIFO_RD_REQ and                              |    |
|     |                 | TXFIFO_WR_REQ interrupts.                                     |    |
|     |                 | 0: Program I/O                                                |    |
|     |                 | 1: DMA mode                                                   |    |
| 7   | INIT            | 80 initialization clocks.                                     | W  |
|     |                 | 0: Do not precede command sequence with 80 clocks             |    |
|     |                 | 1: Precede command sequence with 80 clocks                    |    |
| 6   | BUSY            | Specifies whether a busy signal is expected after the         | WR |
|     |                 | current command. This bit is for no data                      |    |
|     |                 | command/response transactions only.                           |    |
|     |                 | 0: Not expect a busy signal                                   |    |
|     |                 | 1: Expects a busy signal. If the response is R1b, then set it |    |
| 5   | STREAM_BLOCK    | Stream mode.                                                  | WR |
|     |                 | 0: Data transfer of the current command sequence is not in    |    |
|     |                 | stream mode                                                   |    |
|     |                 | 1: Data transfer of the current command sequence is in        |    |
|     |                 | stream mode                                                   |    |
| 4   | WRITE_READ      | Specifies that the data transfer of the current command is    | WR |
|     |                 | a read or write operation.                                    |    |
|     |                 | 0: Specifies that the data transfer of the current command    |    |
|     |                 | is a read operation                                           |    |
|     | eiffele         | 1: Specifies that the data transfer of the current command    |    |
|     | err             | is a write operation                                          |    |
| 3   | DATA_EN         | Specifies whether the current command includes a data         | WR |
| 1   | 01              | transfer. It is also used to reset RX_FIFO and TX_FIFO.       |    |
|     |                 | 0: No data transfer with current command                      |    |
|     |                 | 1: Has data transfer with current command. It is also used    |    |
|     |                 | to reset RX_FIFO and TX_FIFO                                  |    |
| 2:0 | RESPONSE_FORMAT | These bit specify the response format for the current         | WR |
|     | _               | command.                                                      |    |
|     |                 | 000: No response                                              |    |
|     |                 | 001: Format R1 and R1b                                        |    |
|     |                 | 010: Format R2                                                |    |
|     |                 | 011: Format R3                                                |    |
|     |                 | 100: Format R4                                                |    |
|     |                 | 101: Format R5                                                |    |
|     |                 | 110: Format R6                                                |    |
|     |                 | 111: Format R7                                                |    |
|     |                 |                                                               |    |



## 7.4.5 MMC/SD Response Time Out Register (MSC\_RESTO)

| MSC_RESTO |    |    |    |     |      |    |   |   |   |   |   | E   | Bas | e + | 0x( | 010 |
|-----------|----|----|----|-----|------|----|---|---|---|---|---|-----|-----|-----|-----|-----|
| Bit       | 15 | 14 | 13 | 12  | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2   | 1   | 0   |
|           |    |    | R  | ese | erve | d  |   |   |   |   | F | RES | _тс | C   |     |     |
| RST       | 0  | 0  | 0  | 0   | 0    | 0  | 0 | 0 | 0 | 1 | 0 | 0   | 0   | 0   | 0   | 0   |

| Bits  | Name     | Description                                                        | RW      |
|-------|----------|--------------------------------------------------------------------|---------|
| 15:8  | Reserved | Writing has no effect, read as zero.                               | R       |
| 7:0   | RES_TO   | Specifies the number of MSC_CLK clock counts between the command   | WR      |
|       |          | and when the MMC/SD controller turns on the time-out error for the |         |
|       |          | received response. The default value is 64.                        | ſ       |
| 7.4.6 | MMC/SD   | Read Time Out Register (MSC_RDTO)                                  | 2       |
| M     | SC_RDTO  | r Dal Base                                                         | + 0x014 |

#### 7.4.6 MMC/SD Read Time Out Register (MSC\_RDTO)

#### MSC\_RDTO

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

|       |   |   |   |   |   |   |   |   |   |   |   | 6   |   | C( | R | ÈAI | У<br>D_Т | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|---|---|---|---|---|---|---|---|---|---|---|-----|---|----|---|-----|----------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|       |   |   |   |   |   |   |   |   |   |   |   | V I |   |    |   |     |          |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| RST ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1   | 1 | 1  | 1 | 1   | 1        | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

| Bits | Name 📩  | Description                                                         | RW |
|------|---------|---------------------------------------------------------------------|----|
| 31:0 | READ_TO | Specifies the number of clocks between the command and when the     | WR |
| 1    | me      | MMC/SD host controller turns on the time-out error for the received |    |
|      |         | data. The unit is MSC_CLK.                                          |    |

## 7.4.7 MMC/SD Block Length Register (MSC\_BLKLEN)

| MSC_BLKLEN |    |    |    |    |    |    |   |     |    |   |   | E | Bas | e + | <b>0</b> x( | 018 |
|------------|----|----|----|----|----|----|---|-----|----|---|---|---|-----|-----|-------------|-----|
| Bit        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7  | 6 | 5 | 4 | 3   | 2   | 1           | 0   |
|            |    |    |    |    |    |    | В | LK_ | LE | N |   |   |     |     |             |     |
| RST        | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0   | 0  | 0 | 0 | 0 | 0   | 0   | 0           | 0   |

| Bits | Name    | Description                                                            | RW |
|------|---------|------------------------------------------------------------------------|----|
| 15:0 | BLK_LEN | Specifies the number of bytes in a block, and is normally set to 0x200 | WR |

184

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|  | for MMC/SD data transactions. The value Specified in the cards |  |
|--|----------------------------------------------------------------|--|
|  | CSD.                                                           |  |

# 7.4.8 MSC/SD Number of Block Register (MSC\_NOB)

| MSC_NOB |    |    |    |    |    |    |   |   |    |   |   | E | Base | e + | 0x0 | )1C |
|---------|----|----|----|----|----|----|---|---|----|---|---|---|------|-----|-----|-----|
| Bit     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3    | 2   | 1   | 0   |
|         |    |    |    |    |    |    |   | N | ЭB |   |   |   |      |     |     |     |
| RST     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0  | 0 | 0 | 0 | 0    | 0   | 0   | 0   |

| Bits | Name | Description                                                                  | RW |
|------|------|------------------------------------------------------------------------------|----|
| 15:0 | NOB  | Specifies the number of blocks in a data transfer. One block is a $\bigcirc$ | WR |
|      |      | possibility.                                                                 |    |

# 7.4.9 MMC/SD Number of Successfully-transferred Blocks Register (MSC\_SNOB)

In block mode, the MSC\_SNOB register records the number of successfully transferred blocks. If the last block has CRC error, this register also summaries it. It is used to query blocks for multiple block transfer.

|     | MSC_SNOB | co1@140 |    |    |    |    |    |    |    |     |    |    |   | I | Bas | e + | 0x( | )20 |
|-----|----------|---------|----|----|----|----|----|----|----|-----|----|----|---|---|-----|-----|-----|-----|
| Bit |          |         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5 | 4 | 3   | 2   | 1   | 0   |
|     |          |         |    |    |    |    |    |    | MS | SC_ | SN | OB |   |   |     |     |     |     |
| RST |          |         | ?  | ?  | ?  | ?  | ?  | ?  | ?  | ?   | ?  | ?  | ? | ? | ?   | ?   | ?   | ?   |

| Bits | Name     | Description                                                          | RW |
|------|----------|----------------------------------------------------------------------|----|
| 15:0 | MSC_SNOB | Specify the number of successfully transferred blocks for a multiple | R  |
|      |          | block transfer.                                                      |    |



Base + 0x024

# 7.4.10 MMC/SD Interrupt Mask Register (MSC\_IMASK)

# MSC\_IMASK

|     |    |    |    |    | -  |    |    |     |      |    |    |    |    |    |    |    |               |                |               |             |              |               |              |               |      |               |               |   |          |             |          |                |
|-----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|---------------|----------------|---------------|-------------|--------------|---------------|--------------|---------------|------|---------------|---------------|---|----------|-------------|----------|----------------|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14             | 13            | 12          | 11           | 10            | 9            | 8             | 7    | 6             | 5             | 4 | 3        | 2           | 1        | 0              |
|     |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    | AUTO_CMD_DONE | DATA_FIFO_FULL | DATA_FIFO_EMP | CRC_RES_ERR | CRC_READ_ERR | CRC_WRITE_ERR | TIME_OUT_RES | TIME_OUT_READ | SDIO | TXFIFO_WR_REQ | RXFIFO_RD_REQ |   | Keselved | END_CMD_RES | PRG_DONE | DATA_TRAN_DONE |
| RST | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1             | 1              | 1             | 1           | 1            | 1             | 1            | 1             | 1    | 1             | 1             | 1 | 1        | 1           | 1        | 1              |

| Bits  | Name           | Description                                     | RW |
|-------|----------------|-------------------------------------------------|----|
| 31:16 | Reserved       | Writing has no effect, read as zero.            | R  |
| 15    | AUTO_CMD_DONE  | Mask the interrupt Auto Cmd Done (ACD).         | RW |
|       |                | 0: Not masked                                   |    |
|       |                | 0: Not masked<br>1: Masked<br>0: Net masked     |    |
| 14    | DATA_FIFO_FULL | 0: Not masked                                   | RW |
|       |                | 1: Masked                                       |    |
| 13    | DATA_FIFO_EMP  | 0: Not masked                                   | RW |
|       |                | 1: Masked                                       |    |
| 12    | CRC_RES_ERR    | 0: Not masked                                   | RW |
|       |                | 1: Masked                                       |    |
| 11    | CRC_READ_ERR   | 0: Not masked                                   | RW |
|       | cfer           | 1: Masked                                       |    |
| 10    | CRC_WRITE_ERR  | 0: Not masked                                   | RW |
|       |                | 1: Masked                                       |    |
| 9 🔨   | TIME_OUT_RES   | 0: Not masked                                   | RW |
| ر     |                | 1: Masked                                       |    |
| 8     | TIME_OUT_READ  | 0: Not masked                                   | RW |
|       |                | 1: Masked                                       |    |
| 7     | SDIO           | Mask the interrupt from the SD I/O card.        | WR |
|       |                | 0: Not masked                                   |    |
|       |                | 1: Masked                                       |    |
| 6     | TXFIFO_WR_REQ  | Mask the Transmit FIFO write request interrupt. | WR |
|       |                | 0: Not masked                                   |    |
|       |                | 1: Masked                                       |    |
| 5     | RXFIFO_RD_REQ  | Mask the Receive FIFO read request interrupt.   | WR |
|       |                | 0: Not masked                                   |    |
|       |                | 1: Masked                                       |    |
| 4:3   | Reserved       | Writing has no effect, read as zero.            | R  |
| 2     | END_CMD_RES    | Mask the End command response interrupt.        | WR |

186

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

|   |                | 0: Not masked                          |    |
|---|----------------|----------------------------------------|----|
|   |                | 1: Masked                              |    |
| 1 | PRG_DONE       | Mask the Programming done interrupt.   | WR |
|   |                | 0: Not masked                          |    |
|   |                | 1: Masked                              |    |
| 0 | DATA_TRAN_DONE | Mask the Data transfer done interrupt. | WR |
|   |                | 0: Not masked                          |    |
|   |                | 1: Masked                              |    |

# 7.4.11 MMC/SD Interrupt Register (MSC\_IREG)

The MSC\_IREG register shows the currently requested interrupt. The FIFO request interrupts, TXFIFO\_WR\_REQ, and RXFIFO\_RD\_REQ are masked off with the DMA\_EN bit in the MSC\_CMDAT register. The software is responsible for monitoring these bit in program I/O mode.



#### RST

| <b>D</b> '' | et es                                                                                                           |                                         |    |
|-------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------|----|
| Bits        | Name                                                                                                            | Description                             | RW |
| 15          | AUTO_CMD_DONE                                                                                                   | indicate Auto Cmd Done (ACD) interrupt. | RW |
| 1           | ons                                                                                                             | 0: the interrupt is not detected        |    |
|             | t Contraction of the second | 1: the interrupt is detected            |    |
| 14          | DATA_FIFO_FULL                                                                                                  | Indicate data FIFO is full interrupt.   | R  |
|             |                                                                                                                 | 0: the interrupt is not detected        |    |
|             |                                                                                                                 | 1: the interrupt is detected            |    |
| 13          | DATA_FIFO_EMP                                                                                                   | Indicate data FIFO is empty interrupt.  | R  |
|             |                                                                                                                 | 0: the interrupt is not detected        |    |
|             |                                                                                                                 | 1: the interrupt is detected            |    |
| 12          | CRC_RES_ERR                                                                                                     | Indicate response CRC error interrupt.  | RW |
|             |                                                                                                                 | 0: the interrupt is not detected        |    |
|             |                                                                                                                 | 1: the interrupt is detected            |    |
| 11          | CRC_READ_ERR                                                                                                    | Indicate CRC read error interrupt.      | RW |
|             |                                                                                                                 | 0: the interrupt is not detected        |    |
|             |                                                                                                                 | 1: the interrupt is detected            |    |
| 10          | CRC_WRITE_ERR                                                                                                   | Indicate CRC write error interrupt.     | RW |

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|          |                | 0: the interrupt is not detected                               |    |
|----------|----------------|----------------------------------------------------------------|----|
|          |                | 1: the interrupt is detected                                   |    |
| 9        | TIME_OUT_RES   | Indicate response time out interrupt.                          | RW |
|          |                | 0: the interrupt is not detected                               |    |
|          |                | 1: the interrupt is detected                                   |    |
| 8        | TIME_OUT_READ  | Indicate read time out interrupt.                              | RW |
| -        |                | 0: the interrupt is not detected                               |    |
|          |                | 1: the interrupt is detected                                   |    |
| 7        | SDIO           | Indicates whether the interrupt from SDIO is detected.         | R  |
|          |                | 0: The interrupt from SDIO is not detected                     |    |
|          |                | 1: The interrupt from SDIO is detected                         |    |
| 6        | TXFIFO_WR_REQ  | Transmit FIFO write request. Set if data FIFO becomes half     | R  |
| -        |                | empty. (the number of words is $< 8$ )                         |    |
|          |                | 0: No Request for data Write to MSC_TXFIFO                     |    |
|          |                | 1: Request for data write to MSC TXFIFO                        |    |
| 5        | RXFIFO_RD_REQ  | Receive FIFO read request. Set if data FIFO becomes half       | R  |
|          |                | full (the number of words is >= 8) or the entries in data FIFO |    |
|          |                | are the last read data. $\sqrt{150}$                           |    |
|          |                | 0: No Request for data read from MSC_RXFIFO                    |    |
|          |                | 1: Request for data read from MSC_RXFIFO                       |    |
| 4:3      | Reserved       | Writing has no effect, read as zero.                           | R  |
| 2        | END_CMD_RES    | Indicates whether the command/response sequence has            | WR |
|          |                | been finished.                                                 |    |
|          |                | 0: The command/response sequence has not been finished         |    |
|          |                | 1: The command/response sequence has been finished             |    |
|          | ·fter          | Write 1 to clear.                                              |    |
| 1        | PRG_DONE       | Indicates whether card has finished programming.               | WR |
|          | ng-            | 0: Card has not finished programming and is busy               |    |
| <u>)</u> |                | 1: Card has finished programming and is no longer busy         |    |
|          |                | Write 1 to clear.                                              |    |
| 0        | DATA_TRAN_DONE | Indicates whether data transfer is done. Note that for stream  | WR |
|          |                | read/write, only when CMD12 (STOP_TRANS) has been              |    |
|          |                | sent, is this bit set.                                         |    |
|          |                | 0: Data transfer is not complete                               |    |
|          |                | 1: Data transfer has completed or an error has occurred        |    |
|          |                | Write 1 to clear.                                              |    |

188



#### 7.4.12 MMC/SD Command Index Register (MSC\_CMD)



| Bits | Name      | Description                                 | RW |
|------|-----------|---------------------------------------------|----|
| 7:6  | Reserved  | Writing has no effect, read as zero.        | R  |
| 5:0  | CMD_INDEX | Specifies the command index to be executed. | WR |

#### 7.4.13 MMC/SD Command Argument Register (MSC\_ARG)

|          |    |         |     |    |    |    |    |    |    |    |    |    |    |        |    |    |     |             |      |            |    |     |   |   |   | 1 | ( | $\mathcal{I}$ | Y . |   |   |   |
|----------|----|---------|-----|----|----|----|----|----|----|----|----|----|----|--------|----|----|-----|-------------|------|------------|----|-----|---|---|---|---|---|---------------|-----|---|---|---|
|          | MS | MSC_ARG |     |    |    |    |    |    |    |    |    |    |    | . 0    | 0  | -  | 3as | ase + 0x030 |      |            |    |     |   |   |   |   |   |               |     |   |   |   |
| Bit      | 31 | 30      | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18     | 17 | 16 | 15  | 14          | 13   | 12         | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4             | 3   | 2 | 1 | 0 |
|          |    |         |     |    |    |    |    |    |    |    |    |    |    |        |    | AF | RG  | - X         | e    | <u>,</u> C | D. | J J | - |   |   |   |   |               |     |   |   |   |
| RST      | 0  | 0       | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  | 0  | 0   | 0           | 0    | 0          | 0  | 0   | 0 | 0 | 0 | 0 | 0 | 0             | 0   | 0 | 0 | 0 |
|          |    |         |     |    |    |    |    |    |    |    |    |    |    |        | 7  | 7  |     |             |      |            |    |     |   |   |   |   |   |               |     |   |   |   |
| <b>D</b> | 4- |         | NI. |    | _  |    |    |    |    |    |    | 0  |    | $\cup$ |    |    |     |             | 41.0 |            |    |     |   |   |   |   |   |               |     |   |   |   |

| Bits | Name | Description                                     | RW |
|------|------|-------------------------------------------------|----|
| 31:0 | ARG  | Specifies the argument for the current command. | WR |
|      |      | ffele                                           |    |

# 7.4.14 MMC/SD Response FIFO Register (MSC\_RES)

The read-only MMC/SD Response FIFO register (RES\_FIFO) holds the response sent back to the MMC/SD controller after every command. The size of this FIFO is 8 x 16-bit. The RES FIFO does not contain the 7-bit CRC for the response. The Status for CRC checking and response time-out status is in the status register, MSC\_STAT.

The first halt-word read from the response FIFO is the most significant halt-word of the received response.

| MSC_RES | Base + 0x034                          |
|---------|---------------------------------------|
| Bit     | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|         | DATA                                  |
| RST     | ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |



| Bits | Name | Description                                                       | RW |
|------|------|-------------------------------------------------------------------|----|
| 15:0 | DATA | Contains the response to every command that is sent by the MMC/SD | R  |
|      |      | controller. The size of this FIFO register is 8 x 16-bit.         |    |

#### 7.4.15 MMC/SD Receive Data FIFO Register (MSC\_RXFIFO)

The MSC\_RXFIFO is used to read the data from a card. It is read-only to the software, and is read on 32-bit boundary. The size of this FIFO is 16 x 32-bit.



| Bits | Name | Description 1 Oll                                                       | RW |
|------|------|-------------------------------------------------------------------------|----|
| 31:0 | DATA | One word of read data. The size of this FIFO is 16 x 32-bit $2^{\circ}$ | R  |
|      |      | 1 US                                                                    |    |

# 7.4.16 MMC/SD Transmit Data FIFO Register (MSC\_TXFIFO)

The MSC\_TXFIFO is used to write the data to a card. It is write-only to the software, and is written on 32-bit boundary. The size of this FIFO is 16 x 32-bit.

|     | MS | SC_ | тх | FIF | 0  |    |    |    |        |    | 2  | Ś  | )• | Ŭ  |    |    |     |    |    |    |    |    |   |   |   |   |   | E | Bas | e + | 0x( | 03C |
|-----|----|-----|----|-----|----|----|----|----|--------|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|-----|-----|-----|-----|
| Bit | 31 | 30  | 29 | 28  | 27 | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|     |    |     |    | 6   | (  | 27 | £  | L. | ۔<br>د |    |    |    |    |    |    | DA | ΔTA |    |    |    |    |    |   |   |   |   |   |   |     |     |     |     |
| RST | ?  | ?   | ?  | ?   | ?  | ?  | ?  | ?  | ?      | ?  | ?  | ?  | ?  | ?  | ?  | ?  | ?   | ?  | ?  | ?  | ?  | ?  | ? | ? | ? | ? | ? | ? | ?   | ?   | ?   | ?   |

| Bits | Name | Description                                                   | RW |
|------|------|---------------------------------------------------------------|----|
| 31:0 | DATA | One word of write data. The size of this FIFO is 16 x 32-bit. | W  |

#### 7.4.17 MMC/SD Low Power Mode Register (MSC\_LPM)

The MSC\_LPM is used to control whether MSC controller enters Low-Power Mode.



JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| Bits | Name     | Description                                                                   | RW |
|------|----------|-------------------------------------------------------------------------------|----|
| 31:1 | HSPEED   | 0: controller send CMD and data at clock falling                              | RW |
|      |          | 1: controller send CMD and data at clock rising                               |    |
| 30:1 | Reserved | Writing has no effect, read as zero.                                          | R  |
| 0    | LPM      | 0 : Non –Low Power Mode                                                       | RW |
|      |          | 1: Low-Power Mode. Stop clock when card in idle (should be normally set       |    |
|      |          | to only MMC and SD cards. For SDIO cards, if interrupts must be               |    |
|      |          | detected, clock should not be stopped)                                        |    |
|      |          | When software sets the bit, MSC clock can auto be stopped.                    |    |
|      |          | <b>NOTE:</b> when set the bit, the start_clock and stop clock can be not use. |    |

Long-eiffel@126.com internal used only



## 7.5 MMC/SD Functional Description

All communication between system and cards is controlled by the MSC. The MSC sends commands of two type: broadcast and addressed (point-to-point) commands.

Broadcast commands are intended for all cards, command like "Go\_Idle\_State", "Send\_Op\_Cond", "All\_send\_CID" and "Set\_relative\_Addr" are using way of broadcasting. During Broadcast mode, all cards are in open-drain mode, to avoid bus contention.

After Broadcast commands "Set\_relative\_Addr" issue, cards are enter standby mode, and Addressed command will be used from now on, in this mode, CMD/DAT will return to push-pull mode, to have maximum driving for maximum operation frequency.

The MMC and the SD are similar product. Besides the 4x bandwidth and the built-in encryption, they are being programmed similarly.

The MMC/SD controller (MSC) is the interface between the software and the MMC/SD bus. It is responsible for the timing and protocol between the software and the MMC/SD bus. It consists of control and status registers, a 16-bit response FIFO that is 8 entries deep, and one 32-bit receive/transmit data FIFOs that are 16 entries deep. The registers and FIFOs are accessible by the software.

MSC also enable minimal data latency by buffering data and generating and checking CRCs.

@126.

#### 7.5.1 MSC Reset

The MMC/SD controller (MSC) can be reset by a hardware reset or software reset. All registers and FIFO controls are set to their default values after any reset.

# 7.5.2 MSC Card Reset

The command Go\_Idle\_State, CMD0 is the software reset command for MMC and SD Memory Card, and sets each card into Idle State regardless of the current card state; while in SDIO card, CMD52 is used to write IO reset in CCCR. The cards are initialized with a default relative card address (RCA=0x0000) and with a default driver stage register setting (lowest speed, highest driving current capability).

## 7.5.3 Voltage Validation

All cards shall be able to establish communication with the host using any operation voltage in the maximal allowed voltage range specified in this standard. However, the support minimum and maximum values for Vdd are defined in Operation Conditions register (OCR) and many not cover the whole range. Cards that store the CID and CSD data in the payload memory would be able to communicate these information only under data transfer Vdd conditions. That means if host and card

<sup>192</sup> 

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



have non compatible Vdd ranges, the card will not be able to complete the identification cycle, nor to send CSD data.

Therefore, a special command Send Op cont (CMD1 for MMC), SD Send Op Cont (CMD41 for SD Memory) and IO Send Op\_Cont (CMD5 for SDIO) are designed to provide a mechanism to identify and reject cards which do not match the Vdd range desired by the host. This is accomplished by the host sending the required Vdd voltage window as the operand of this command. Cards which can not perform data transfer in the specified range must discard themselves from further bus operations and go into Inactive State. By omitting the voltage range in the command, the host can query each card and determine the common voltage range before sending out-of-range cards into the Inactive State. This guery should be used if the host is able to select a common voltage range or if a notification to the application of non usable cards in the stack is desired.

## 7.5.4 Card Registry

Card registry on MCC and SD card are different.

ed only For SD card, Identification process start at clock rate Fod, while CMD line output drives are push-pull drivers instead of open-drain. After the bus is activated the host will request the cards to send their valid operation conditions. The response to ACMD41 is the operation condition register of the card. The same command shall be send to all of the new cards in the system. Incompatible cards are sent into Inactive State. The host then issue the command All Send CID (CMD2) to each card and get its unique card identification (CID) number. Card that is unidentified, that is, which is in Ready State, send its CID number as the response. After the CID was sent by the card it goes into Identification State. Thereafter, the host issues Send Relative Addr (CMD3) asks the card to publish a new relative card address (RCA), which is shorter that CID and which will be used to address the card in the future data transfer mode. Once the RCA is received the card state changes to the Stand-by State. At this point, if the host wants that the card will have another RCA number, it may ask the card to publish a new number by sending another Send Relative Addr command to the card. The last published RCA is the actual RCA of the card. The host repeats the identification process, that is, the cycles with CMD2 and CMD3 for each card in the system.

In MMC, the host starts the card identification process in open-drain mode with the identification clock rate Fod. The open drain driver stages on the CMD line allow parallel card operation during card identification. After the bus is active the host will request the cards to send their valid operation conditions (CMD1). The response to CMD1 is the 'wired or' operation on the condition restrictions of all cards in the system. Incompatible cards are sent into Inactive State. The host then issues the broadcast command All\_Send\_CID (CMD2), asking all cards for their unique card identification (CID) number. All unidentified cards, that is, those which are in Ready State, simultaneously start sending their CID numbers serially, while bit-wise monitoring their outgoing bitstream. Those cards, whose outgoing CID bits do not match the corresponding bits on the command line in any one of the bit periods stop sending their CID immediately and must wait for the next identification cycle. Since CID is unique for each card, only one card can be successfully send its full CID to the host. This card then



goes into Identification State. Thereafter, the host issues Set\_Relative\_Addr (CMD3) to assign to this card a relative card address (RCA). Once the RCA is received the card state changes to the Stand-by State, and the card does not react to further identification cycles, and its output switches from open-drain to push-pull. The host repeat the process, which is CM2 and CMD3, until the host receive time-out condition to recognize completion of the identification process.

#### 7.5.5 Card Access

#### 7.5.5.1 Block Access, Block Write and Block Read

During block write (CMD24-27) one or more blocks of data are transferred from the host to the card with a CRC appended to the end of each block by the host. A card supporting block write shall always be able to accept a block of data defined by WRITE\_BL\_LEN. If the CRC fails, the card shall indicate the failure on the DAT line; the transferred data will be discarded and not written, and all further transmitted blocks (in multiple block write mode) will be ignored.

Programming of the CID and CSD registers does not require a previous block length setting. The transferred data is also CRC protected. If a part of the CSD or CID register is stored in ROM, then this unchangeable part must match the corresponding part of the receive buffer. If this match fails, then the card will report an error and not change any register contents. Some cards may require long and unpredictable times to write a block of data. After receiving a block of data and completing the CRC check, the card will begin writing and hold the DAT line low if its write buffer is full and unable to accept new data from a new WRITE\_BLOCK command. The host may poll the status of the card with a SEND\_STATUS command (CMD13) at any time, and the card will respond with its status. The status bit READY\_FOR\_DATA indicates whether the card can accept new data or whether the write process is still in progress). The host may deselect the card by issuing CMD7 (to select a different card) which will displace the card into the Disconnect State and release the DAT line without interrupting the write operation. When reselecting the card, it will reactivate busy indication by pulling DAT to low if programming is still in progress and the write buffer is unavailable.

Block read is similar to stream read, except the basic unit of data transfer is a block whose maximizes is defined in the CSD (READ\_BL\_LEN). If READ\_BL\_PARTIAL is set, smaller blocks whose starting and ending address are entirely contained within one physical block (as defined by READ\_BL\_LEN) may also be transmitted. Unlike stream read, a CRC is appended to the end of each block ensuring data transfer integrity. CMD17 (READ\_SINGLE\_BLOCK) initiates a block read and after completing the transfer, the card returns to the Transfer state. CMD18 (READ\_MULTIPLE\_BLOCK) starts a transfer of several consecutive blocks. Blocks will be continuously transferred until a stop command is issued. If the host uses partial blocks whose accumulated length is not block aligned and block misalignment is not allowed, the card shall detect a block misalignment at the beginning of the first mis-aligned block, set the ADDRESS\_ERROR error bit in the status register, abort transmission and wait in the Data State for a stop command.

194

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

#### 7.5.5.2 Stream Access, Stream Write and Stream Read (MMC Only)

君止

Stream write (CMD20) starts the data transfer from the host to the card beginning from the starting address until the host issues a stop command. Since the amount of data to be transferred is not determined in advance, CRC can not be used. If the end of the memory range is reached while sending data and no stop command has been sent by the host, all further transferred data is discarded.

There is a stream oriented data transfer controlled by READ\_DAT\_UNTIL\_STOP (CMD11). This command instructs the card to send its payload, starting at a specified address, until the host sends a STOP\_TRANSMISSION command (CMD12). The stop command has execution delay due to the serial command transmission. The data transfer stops after the end bit of the stop command. If the end of the memory range is reached while sending data and no stop command has been sent yet by the host, the contents of the further transferred payload is undefined.

#### 7.5.5.3 Erase, Group Erase and Sector Erase (MMC Only)

It is desirable to erase many sectors simultaneously in order to enhance the data throughput. Identification of these sectors is accomplished with the TAG\_\* commands. Either an arbitrary set of sectors within a single erase group, or an arbitrary selection of erase groups may be erase at one time, but not both together. That is, the unit of measure for determining an erase is either a sector or an erase group. If a set of sectors must be erased, all selected sectors must lie within the same erase group. To facilitate selection, a first command with the starting address is followed by a second command with the final address, and all sectors (or groups) within this range will be selected for erase.

## 7.5.5.4 Wide Bus Selection/Deselection

Wide Bus (4 bit bus width) operation mode may be selected / deselected using ACMD6. The default bus width after power up or GO\_IDLE (CMD0) is 1 bit bus width. ACMD6 command is valid in 'trans state' only. That means the bus width may be changed only after a card was selected (CMD7).

#### 7.5.6 Protection Management

Three write protect methods are supported in the host for Cards, Card internal write protect (Card's responsibility), Mechanical write protect switch (Host responsibility only) and Password protection card lock operation.

#### 7.5.6.1 Card Internal Write Protection

Card data may be protected against either erase or write. The entire card may be permanently write protected by the manufacturer or content provider by setting the permanent or temporary write protect bits in the CSD. For cards which support write protection of groups of sectors by setting the WP\_GRP\_SIZE sectors as specified in the CSD), and the write protection may be changed by the application. The SET\_WRITE\_PROT command sets the write protection of the addressed



write-protect group, and the CLR WRITE PROT command clears the write protection of the addressed write-protect group.

The SEND WRITE PROT command is similar to a single block read command. The card shall send a data block containing 32 write protection bits (representing 32 write protect groups starting at the specified address) followed by 16 CRC bits. The address field in the write protect commands is a group address in byte units. The card will ignore all LSB's below the group size.

#### 7.5.6.2 Mechanical write protect switch

A mechanical sliding tablet on the side of the card will be used by the user to indicate that a given card is write protected or not. If the sliding tablet is positioned in such a way that the window is open that means the card is write protected. If the window is close the card is not write protected.

A proper, matched, switch on the socket side will indicated to the host that the card is write protected or not. It is the responsibility of the host to protect the card. The position of the write protect switch is rnal used un-known to the internal circuitry of the card.

#### 7.5.6.3 Password Protect

The password protection feature enables the host to lock a card while providing a password, which later will be used for unlocking the card. The password and its size is kept in an 128-bit PWD and 8-bit PWD\_LEN registers, respectively. These registers are non-volatile so that a power cycle will not erase them.

Locked cards respond to (and execute) all commands in the basic command class (class 0) and "lock card" command class. Thus the host is allowed to reset, initialize, select, query for status, etc., but not to access data on the card. If the password was previously set (the value of PWD\_LEN is not 0) will be locked automatically after power on. Similar to the existing CSD and CID register write commands the lock/unlock command is available in "trans state" only. This means that it does not include an address argument and the card must be selected before using it. The card lock/unlock command has the structure and bus transaction type of a regular single block write command. The transferred data block includes all the required information of the command (password setting mode, PWD itself, card lock/unlock etc.). The following table describes the structure of the command data block.

| Byte # | Bit 7         | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2       | Bit 1   | Bit 0   |
|--------|---------------|-------|-------|-------|-------|-------------|---------|---------|
| 0      | Rsv           | Rsv   | Rsv   | Rsv   | ERASE | LOCK_UNLOCK | CLR_PWD | SET_PWD |
| 1      | PWDS_LEN      |       |       |       |       |             |         |         |
| 2      | Password Data |       |       |       |       |             |         |         |
|        |               |       |       |       |       |             |         |         |

#### **Table 7-4 Command Data Block Structure**

#### 196

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| PWDS_LEN |  |
|----------|--|
| + 1      |  |

- ERASE 1 Defines Forced Erase Operation (all other bits shall be 0) and only the command byte is sent.
- LOCK/UNLOCK 1=Locks the card. 0=Unlock the card (note that it is valid to set this bit together with SET\_PWD but it is not allowed to set it together with CLR\_PWD).
- CLR PWD 1=Clears PWD.
- SET\_PWD 1=Set new password to PWD.
- **PWD\_LEN** Defines the following password length (in bytes).
- **PWD** The password (new or currently used depending on the command).

The data block size shall be defined by the host before it send the card lock/unlock command. This will allow different password sizes.

used only The following paragraphs define the various lock/unlock command sequences:

Lock command sequences:

- Setting the Password. 1
  - Select a card (CMD7), if not previously selected already. а
  - Define the block length (CMD16), given by the 8bit card lock/unlock mode, the 8 bits b password size (in bytes), and the number of bytes of the new password. In case that a password replacement is done, then the block size shall consider that both passwords, the old and the new one, are sent with the command.
  - c Send Card Lock/Unlock command with the appropriate data block size on the data line including 16-bit CRC. The data block shall indicate the mode (SET PWD), the length (PWD LEN) and the password itself. In case that a password replacement is done, then the length value (PWD\_LEN) shall include both passwords, the old and the new one, and the PWD field shall include the old password (currently used) followed by the new password.
  - In case that the sent old password is not correct (not equal in size and content) then LOCK UNLOCK FAILED error bit will be set in the status register and the old password does not change. In case that PWD matches the sent old password then the given new password and its size will be saved in the PWD and PWD\_LEN fields, respectively.

#### NOTE:

the password length register (PWD LEN) indicates if a password is currently set. When it equals 0 there is no password set. If the value of PWD\_LEN is not equal to zero the card will lock itself after power up. It is possible to lock the card immediately in the current power session by setting the LOCK/UNLOCK bit (while setting the password) or sending additional command for card lock.

- 2 Reset the password.
  - Select a card (CMD7), if not previously selected already.

- b Define the block length (CMD16), given by the 8-bit card lock/unlock mode, the 8-bit password size (in bytes), and the number of bytes of the currently used password.
- c Send the card lock/unlock command with the appropriate data block size on the data line including 16-bit CRC. The data block shall indicate the mode CLR\_PWD, the length (PWD\_LEN) and the password (PWD) itself (LOCK/UNLOCK bit is don't care). If the PWD and PWD\_LEN is set to 0. If the password is not correct then the LOCK\_UNLOCK\_FAILED error bit will be set in the status register.
- 3 Locking a card.
  - a Select a card (CMD7), if not previously selected already.
  - b Define the block length (CMD16), given by the 8-bit card lock/unlock mode, the 8-bit password size (in bytes), and the number of bytes of currently used password.
  - c Send the card lock/unlock command with the appropriate data block size on the data line including 16-bit CRC. The data block shall indicate the mode LOCK, the length (PWD\_LEN) and the password (PWD) itself.

If the PWD content equals to the sent password then the card will be locked and the card-locked status bit will be set in the status register. If the password is not correct then LOCK\_UNLOCK\_FAILED error bit will be set in the status register.

#### NOTE:

it is possible to set the password and to lock the card in the same sequence. In such case the host shall perform all the required steps for setting the password (as described above) including the bit LOCK set while the new password command is sent. If the password was previously set (PWD\_LEN is not 0), then the card will be locked automatically after power on reset. An attempt to lock a locked card or to lock a card that does not have a password will fail and the LOCK\_UNLOCK\_FAILED error bit will be set in the status register.

#### Unlock command sequences:

- 1 Unlocking the card.
  - a Select a card (CMD7), if not previously selected already.
  - b Define the block length (CMD16), given by the 8-bit card lock/unlock mode, the 8-bit password size (in bytes), and the number of bytes of the currently used password.
  - c Send the card lock/unlock command with the appropriate data block size on the data line including 16-bit CRC. The data block shall indicate the mode UNLOCK, the length (PWD\_LEN) and the password (PWD) itself.

If the PWD content equals to the sent password then the card will be unlocked and the card-locked status bit will be cleared in the status register. If the password is not correct then the LOCK\_UNLOCK\_FAILED error bit will be set in the status register.

#### NOTE:

198

the unlocking is done only for the current power session. As long as the PWD is not

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



cleared the card will be locked automatically on the next power up. The only way to unlock the card is by clearing the password. An attempt to unlock an unlocked card will fail and LOCK UNLOCK FAILED error bit will be set in the status register.

2 Forcing Erase.

> In case that the user forgot the password (the PWD content) it is possible to erase all the card data content along with the PWD content. This operation is called Forced Erase.

- Select a card (CMD7), if not previously selected already. а
- Define the block length (CMD16) to 1 byte (8bit card lock/unlock command). Send the b card lock/unlock command with the appropriate data block of one byte on the data line including 16-bit CRC. The data block shall indicate the mode ERASE (the ERASE bit shall be the only bit set).

If the ERASE bit is not the only bit in the data field then the LCOK UNLOCK FAILED error bit will be set in the status register and the erase request is rejected. If the command was accepted then ALL THE CARD CONTENT WILL BE ERASED including the PWD and PWD\_LEN register content and the locked card will get unlocked.

An attempt to force erase on an unlocked card will fail and LOCK\_UNLOCK\_FAILED error bit com inter will be set in the status register.

## 7.5.7 Card Status

The response format R1 contains a 32-bit field named card status. This field is intended to transmit the card's status information (which may be stored in a local status register) to the host. If not specified otherwise, the status entries are always related to the previous issued command.

Table below defines the different entries of the status. The type and clear condition fields in the table are abbreviate as follows:

Type:

- E: Error bit.
- S: Status bit..
- R: Detected and set for the actual command response.
- X: Detected and set during command execution. The host must poll the card by issuing the status command in order to read these bits.

Clear Condition:

- A: According to the card current state.
- B: Always related to the previous command. Reception of a valid command will clear it (with a delay of one command).
- C: Clear by read.



| Table     | 7-5 | Card  | Status         | Description |
|-----------|-----|-------|----------------|-------------|
| 1 4 6 1 0 |     | ••••• | <b>U</b> lala0 |             |

| Bits | Bits Identifier    |      | Description                         | Clear     |
|------|--------------------|------|-------------------------------------|-----------|
|      |                    |      |                                     | Condition |
| 31   | OUT_OF_RAGE        | ER   | The command's argument was out      | С         |
|      |                    |      | of the allowed range for this card. |           |
|      |                    |      | 0: No Error                         |           |
|      |                    |      | 1: Error                            |           |
| 30   | ADDRESS_ERROR      | ERX  | A misaligned address which did not  | С         |
|      |                    |      | match the block length was used in  |           |
|      |                    |      | the command.                        |           |
|      |                    |      | 0: No Error                         |           |
|      |                    |      | 1: Error                            |           |
| 29   | BLOCK_LEN_ERROR    | ER   | The transferred block length is not | С         |
|      |                    |      | allowed for this, or the number of  | 11        |
|      |                    |      | transferred bytes does not match    | our,      |
|      |                    |      | the block length.<br>0: No Error    | 0×        |
|      |                    |      | 0: No Error                         |           |
|      |                    |      | 1: Error                            |           |
| 28   | ERASE_SEQ_ERROR    | ER   | An error in the sequence of erase   | С         |
|      |                    |      | commands occurred.                  |           |
|      |                    |      | 0: No Error                         |           |
|      |                    |      | ∱ Error                             |           |
| 27   |                    | ) EX | An invalid selection of sectors or  | С         |
|      | $\sqrt{0}$         |      | groups for erase occurred.          |           |
|      | cfere              |      | 0: No Error                         |           |
|      |                    |      | 1: Error                            |           |
| 26   | WP_VIOLATION       | ERX  | Attempt to program a write          | С         |
| 1    | OLIO               |      | protected block.                    |           |
| )    |                    |      | 0: No Protected                     |           |
|      |                    |      | 1: Protected                        |           |
| 25   | CARD_IS_LOCKED     | SX   | When set, signals that the card is  | A         |
|      |                    |      | locked by the host.                 |           |
|      |                    |      | 0: Card unlocked                    |           |
|      |                    |      | 1: Card locked                      |           |
| 24   | LOCK_UNLOCK_FAILED | ERX  | Set when a sequence or password     | С         |
|      |                    |      | error has been detected in          |           |
|      |                    |      | lock/unlock card command or if      |           |
|      |                    |      | there was an attempt to access a    |           |
|      |                    |      | locked card.                        |           |
|      |                    |      | 0: No Error                         |           |
|      |                    |      | 1: Error                            |           |

200



| 23 | COM_CRC_ERROR     | ER           | The CRC check of the previous                        | В   |
|----|-------------------|--------------|------------------------------------------------------|-----|
| 20 |                   |              | command failed.                                      | Б   |
|    |                   |              | 0: No Error                                          |     |
|    |                   |              | 1: Error                                             |     |
| 22 |                   | ER           |                                                      | В   |
| 22 | ILLEGAL_COMMAND   | EK           | Command not legal for the card                       | D   |
|    |                   |              | state.                                               |     |
|    |                   |              | 0: No Error                                          |     |
|    |                   | <b>- - X</b> | 1: Error                                             | -   |
| 21 | CARD_ECC_FAILED   | ΕX           | Card internal ECC was applied but                    | С   |
|    |                   |              | failed to correct the data.                          |     |
|    |                   |              | 0: normal                                            |     |
|    |                   |              | 1: failure                                           |     |
| 20 | CC_ERROR          | ERX          | Internal card controller error.                      | С   |
|    |                   |              | 0: No Error                                          |     |
|    |                   |              | 1: Error                                             | 14  |
| 19 | ERROR             | ERX          | A general or an unknown error                        | OLC |
|    |                   |              | occurred during the operation $\sim$ $\circ$ $\circ$ |     |
|    |                   |              | 0: No Error ү 🔨                                      |     |
|    |                   |              | 1: Error                                             |     |
| 18 | UNDERRUN          | ΕX           | The card could not sustain data                      | С   |
|    |                   |              | transfer in stream read mode.                        |     |
|    |                   |              | 0:No Error                                           |     |
|    |                   | C C          | 1: Error                                             |     |
| 17 | OVERRUN 🔬         | <b>EX</b>    | The card could not sustain data                      | С   |
|    | iffel",           |              | programming in stream write mode.                    |     |
|    | .fter             |              | 0: No Error                                          |     |
|    | elt               |              | 1: Error                                             |     |
| 16 | CID/CSD_OVERWRITE | ERX          | Can be either one of the following                   | С   |
| 1  |                   |              | errors.                                              | -   |
|    |                   |              | 0: No Error                                          |     |
|    |                   |              | 1: Error                                             |     |
| 15 | WP_ERASE_SKIP     | SX           | Only partial address space was                       | С   |
|    |                   |              | erased due to existing write                         | ý   |
|    |                   |              | protected blocks.                                    |     |
|    |                   |              | 0: No Protected                                      |     |
|    |                   |              | 1 : Protected                                        |     |
| 14 |                   | SX           |                                                      | A   |
| 14 | CARD_ECC_DISABLED | 3.           | The command has been executed                        | A   |
|    |                   |              | without using the internal ECC.                      |     |
|    |                   |              | 0: enabled                                           |     |
|    |                   |              | 1: disabled                                          |     |



## 7.5.8 SD Status

The SD status contains status bits that are related to the SD card proprietary features and may be used for future application specific usage. The size of the SD status is one data block of 512bit. The content of this register is transmitted to the Host over the DAT bus along with 16-bit CRC. The SD status is sent to the host over the DAT bus if ACMD13 is sent (CMD55 followed with CMD13). ACMD13 can be sent to a card only in 'tran\_state' (card is selected). SD status structure is described in below.



<sup>202</sup> 

The same abbreviation for type and clear condition were used as for the Card Status above.

| Bits       | Identifier                                                                                            | Туре | Description                     | Clear     |  |  |  |
|------------|-------------------------------------------------------------------------------------------------------|------|---------------------------------|-----------|--|--|--|
|            |                                                                                                       |      |                                 | Condition |  |  |  |
| 511:510    | DAT_BUS_WIDTH                                                                                         | SR   | Shows the currently defined     | А         |  |  |  |
|            |                                                                                                       |      | data bus width that was defined |           |  |  |  |
|            |                                                                                                       |      | by SET_BUS_WIDTH                |           |  |  |  |
|            |                                                                                                       |      | command.                        |           |  |  |  |
|            |                                                                                                       |      | 00: 1 (default)                 |           |  |  |  |
|            |                                                                                                       |      | 01: Reserved                    |           |  |  |  |
|            |                                                                                                       |      | 10: 4 bit width                 |           |  |  |  |
|            |                                                                                                       |      | 11: Reserved                    |           |  |  |  |
| 509        | SECURED_MODE                                                                                          | SR   | Card is in Secured Mode of      | <u> </u>  |  |  |  |
|            |                                                                                                       |      | operation.                      | UT.       |  |  |  |
|            |                                                                                                       |      | 0: Not in the Mode              | ·         |  |  |  |
|            |                                                                                                       |      | 10: In the mode $\sqrt{50}$     |           |  |  |  |
| 508:496    |                                                                                                       | Re   | eserved.                        |           |  |  |  |
| 495:480    | SD_CARD_TYPE                                                                                          | SR   | All 0, is SD Memory cards.      | А         |  |  |  |
| 479:448    | SIZE_OF_PROTECTED_AREA                                                                                | SR   | Size of protected area.         | А         |  |  |  |
| 447:312    |                                                                                                       | Re   | eserved.                        |           |  |  |  |
| 311:0      | 311:0 Reserved for manufacturer.                                                                      |      |                                 |           |  |  |  |
|            | 1@120.                                                                                                |      |                                 |           |  |  |  |
| 7.5.9 SC   | 7.5.9 SDIO $cfe^{\int c}$                                                                             |      |                                 |           |  |  |  |
| I/O access | /O access differs from memory in that the registers can be written and read individually and directly |      |                                 |           |  |  |  |

#### Table 7-6 SD Status Structure

#### 7.5.9 SDIO

I/O access differs from memory in that the registers can be written and read individually and directly without a FAT file structure or the concept of blocks (although block access is supported). These registers allow access to the IO data, control of the IO function, and report on status or transfer I/O data to and from the host.

Each SDIO card may have from 1 to 7 functions plus one memory function built into it. A function is a self contained I/O device. I/O functions may be identical or completely different from each other. All I/O functions are organized as a collection of registers, and there is a maximum of 131,072 registers possible for each I/O function.

#### 7.5.9.1 SDIO Interrupts

In order to allow the SDIO card to interrupt the host, and interrupt function is added to a pin on the SD interface. Pin number 8 which is used as DAT[1] when operating in the 4 bit SD mode is used to signal the card's interrupt to the host. The use of interrupt is optional for each card or function within a card. The SDIO interrupt is "level sensitive", that is, the interrupt line must be held active (low) until it is either recognized and acted upon by the host or de-asserted due to the end of the Interrupt Period.



Once the host has serviced the interrupt, it is cleared via an IO write to the appropriate bit in the CCCR. The interrupt output of all SDIO cards is active low. This host controller provides pull-up resistors on all data lines DAT[3:0].

As Pin 8 of the card is shared between the IRQ and DAT[1] use in the 4 bit SD mode, and interrupt shall only be sent by the card and recognized by the host during a specific time. The time that a low on Pin 8 will be recognized as an interrupt is defined as the Interrupt Period.

The host here will only sample the level of Pin 8 (DAT[1]/IRQ) into the interrupt detector during the Interrupt Period. At all other times, the host will ignore the level on Pin 8. Note that the Interrupt Period is applicable for both memory and IO operations. The definition of the Interrupt Period is different for operations with single block and multiple block data transfer.

#### 7.5.9.2 SDIO Suspend/Resume

Within a multi-function SDIO or a Combo (Mix IO and Memory) card, there are multiple devices (I/O and memory) that must share access to the SD bus. In order to allow the sharing of access to the host among multiple devices, SDIO and combo cards can implement the optional concept of suspend/resume. In a card supports suspend/resume, the host may temporarily halt a data transfer operation to one function or memory (suspend) in order to free the bus for a higher priority transfer to a different function of memory. Once this higher-priority transfer is complete, the original transfer is re-started where it left off (resume). The host controller here is supported by all IO functions except zero, and the memory of a combo card, and can suspend multiple transactions and resume them in any order desired. IO function zero does not support suspend/resume.

The procedure used to perform the Suspend/Resume operation on the SD bus is:

- The host determines which function currently used the DAT[] line(s).
- The host requests the lower priority or slower transaction to suspend.
- -\ The host checks for the transaction suspension to complete.
- The host begins the higher priority transaction.
- The host waits for the completion of the higher priority transaction.
- The host restores the suspended transaction.

#### 7.5.9.3 SDIO Read Wait

The optional Read Wait (RW) operation is defined only for the SD 1-bit and 4-bit modes. The read wait operation allows a host to signal a card that it is doing a read multiple (CMD53) operation to temporarily stall the data transfer while allowing the host to send commands to any function within the SDIO device. To determine if a card supports the Read Wait protocol, the host must test capability bits in CCCR. The timing for Read Wait is base on the Interrupt Period.



#### 7.5.10 Clock Control

The software should guarantee that the card identification process starts in open-drain mode with the clock rate fod (0 ~ 400khz). In addition, the software should also make the card into interrupt mode with fod (only for MMC). The commands that require fod are CMD0, CMD1, CMD2, CMD3, CMD5, CMD40 and ACMD41. In data transfer mode, the MSC controller can operate card with clock rate fpp (0 ~ 25Mhz).

#### 7.5.11 Application Specified Command Handling

The MultiMediaCard/SD system is designed to provide a standard interface for a variety applications types. In this environment it is anticipate that there will be a need for specific customers/applications features. To enable a common way of implementing these features, two types of generic commands are defined in the standard: Application Specific Command, ACMD, and General Command, GEN\_CMD.

GEN\_CMD, this command, when received by the card, will cause the card to interpret the following command as an application specific command, ACMD. The ACMD has the same structure as of regular MultiMediaCard standard commands and it may have the same CMD number. The card will recognize it as ACMD by the fact that it appears after APP\_CMD.

The only effect of the APP\_CMD is that if the command index of the, immediately, following command has an ACMD overloading, the none standard version will used. If, as an example, a card has a definition for ACMD13 but not for ACMD7 then, if received immediately after APP\_CMD command, Command 13 will be interpreted as the non standard ACMD13 but, command 7 as the standard CMD7.

In order to use one of the manufacturer specific ACMD's the host will:

- 1 Send APP\_CMD. The response will have the APP\_CMD bit (new status bit) set signaling to the host that ACMD is now expected.
- 2 Send the required ACMD. The response will have the APP\_CMD bit set, indicating that the accepted command was interpreted as ACMD. If a non-ACMD is sent then it will be respected by the card as normal MultiMediaCard command and the APP\_CMD bit in the Card Status stays clear.

If a non valid command is sent (neither ACMD nor CMD) then it will be handled as a standard MultiMediaCard illegal command error.

The bus transaction of the GEN\_CMD is the same as the single block read or write commands (CMD24 or CMD17). The difference is that the argument denotes the direction of the data transfer (rather than the address) and the data block is not a memory payload data but has a vendor specific format and meaning.

The card shall be selected ('tran\_state') before sending CMD56. The data block size is the

206



BLOCK\_LEN that was defined with CMD16. The response to CMD56 will be R1b (card status + busy indication).

Long\_eiffel@126.com internal used only



#### 7.6 MMC/SD Controller Operation

#### 7.6.1 Data FIFOs

The controller FIFOs for the response tokens, received data, and transmitted data are MSC\_RES, MSC\_RXFIFO, and MSC\_TXFIFO, respectively. These FIFOs are accessible by the software and are described in the following paragraphs.

#### 7.6.1.1 Response FIFO (MSC\_RES)

The response FIFO, MSC\_RES, contains the response received from an MMC/SD card after a command is sent from the controller. MSC\_RES is a read-only, 16-bit, and 8-entry deep FIFO.

The FIFO will hold all possible response lengths. Responses that are only one byte long are located on the LSB of the 16-bit entry in the FIFO. The first half-word read from the response FIFO is the most significant half-word of the received response. For example, if the response format is R1, then the response read from RES\_FIFO is bit [47:32], bit[31:16], bit[15:0] and in the third half-word only the low 8-bit is effective response [15:8] and the high 8-bit is ignored. If the response format is R2, then the response read from MSC\_RES is bit [135:8] and needs reading 8 times.

The FIFO does not contain the response CRC. The status of the CRC check is in the status register, MSC\_STAT.

#### 7.6.1.2 Receive/Transmit Data FIFO (MSC\_RXFIFO/MSC\_TXFIFO)

The receive data FIFO and transmit data FIFO share one 16-entry x 32-bit FIFO, because at one time data are only received or are only transmitted. If it is used to receive data, it is called MSC\_RXFIFO and read-only. If it is used to transmit data, it is called MSC\_TXFIFO and write-only.

Data FIFO and its controls are cleared to a starting state after a system reset or at the beginning of the operations which include data transfer. (MSC\_CMDAT[DATA\_EN] == 1)

If at any time MSC\_RXFIFO becomes full and the data transmission is not complete, the controller turns the MSC\_CLK off to prevent any overflows. When the clock is off, data transmission from the card stops until the clock is turned back on. After MSC\_RXFIFO is not full, the controller turns the clock on to continue data transmission. The full status of the FIFO is registered in the MSC\_STAT [DATA\_FIFO\_FULL] bit.

If at any time MSC\_TXFIFO becomes empty and the data transmission is not complete, the controller turns the MSC\_CLK off to prevent any underrun. When the clock is off, data transmission to the card stops until the clock is turned back on. When MSC\_TXFIFO is no longer empty, the controller automatically restarts the clock. The empty status of the FIFO is registered in the MSC\_STAT [DATA\_FIFO\_EMPTY] bit.



The FIFO is readable on word (32-bit) boundaries. The max read/written number is 16 words. The controller can correctly process big-endian and little-endian data.

Because at the beginning of the operation which include data transfer (MSC\_CMDAT [DATA\_EN] == 1), Data FIFO and its controls are cleared, software should guarantee data in FIFO have been read/written before beginning a new command.

#### 7.6.2 DMA and Program I/O

Software may communicate to the MMC controller via the DMA or program I/O.

To access MSC\_RXFIFO/MSC\_TXFIFO with the DMA, the software must program the DMA to read or write the FIFO with source port width 32-bit, destination port width 32-bit, transfer data size 32-byte, transfer mode single. For example, to write 64 bytes of data to the MSC\_TXFIFO, the software must program the DMA as follows:

| DMA_DCTRn = 2       | // Write 2 32-bytes (64 bytes)                 |
|---------------------|------------------------------------------------|
| DMA_DCCRn[SWDH] = 0 | // source port width is 32-bit                 |
| DMA_DCCRn[DWDH] = 0 | // destination port width is 32-bit $\sqrt{5}$ |
| $DMA_DCCRn[DS] = 4$ | // transfer data size is 32-byte               |
| DMA_DCCRn[TM] = 4   | // transfer mode is single                     |
| DMA_DCCRn[RDIL] = 0 | // request detection interval length is 0      |

The number of 32-bytes should be calculated from the number of transferred bytes as follows: The number of unrels = (Th) with an of bytes = 24) (22

The number of words = (The number of bytes + 31) / 32

If the number of transferred bytes is not the multiple of 4, the controller can correctly process endian.

The DMA trigger level is 8 words, that is to say, the DMA read trigger is when data words in MSC\_RXFIFO is >= 8 and the DMA write trigger is when data words in MSC\_TXFIFO is < 8. Software can also configure DMA registers based on requirements, but the above 32-byte transfer data size is most efficient.

With program I/O, the software waits for the MSC\_IREG [RXFIFO\_RD\_REQ] or MSC\_IREG [TXFIFO\_WR\_REQ] interrupts before reading or writing the respective FIFO.

#### NOTES:

- 1 The MSC\_CMDAT [DMA\_EN] bit must be set to a 1 to enable communication with the DMA and it must be set to a 0 to enable program I/O.
- 2 DMA can be enabled only after MSC\_CMDAT is written, because MSC\_CMDAT [DATA\_EN] is used to reset TX/RXFIFO.

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



#### 7.6.3 Start and Stop clock

The software stops the clock as follows:

- 1 Write MSC STRPCL with 0x01 to stop the MMC/SD bus clock.
- 2 Wait until MSC\_STAT[CLK\_EN] becomes zero.

To start the clock the software writes MSC STRPCL with 0x02.

#### 7.6.4 Software Reset

Reset includes the MSC reset and the card reset.

The MSC reset is through MSC\_STRPCL [RESET] bit.

The card reset is to make the card into idle state. CMD0 (GO IDLE STATE) sets the MMC and SD memory cards into idle state. CMD52 (IO RW DIRECT, with argument 0x88000C08) reset the SD I/O card. The MMC/SD card are initialized with a default relative card address (RCA = 0x0001 for MMC rnal used and RCA = 0x0000 for SD) and with a default driver stage register setting (lowest speed, highest driving current capability).

The following registers must be set before the clock is started:

- Step 1. Stop the clock.
- Step 2. Set MSC\_STRPCL register to 0x08 to reset MSC.
- Step 3. Wait while MSC\_STAT [IS\_RESETTING] is 1.
- Step 4. Set MSC CMD with CMD0.
- Step 5. Update the MSC CMDAT register as follows:
  - а Write 0x0000 to MSC CMDAT [RESPONSE FORMAT].
  - Clear the MSC\_CMDAT [DATA\_EN] bit. b
  - Clear the MSC\_CMDAT [BUSY] bit. С
  - Clear the MSC\_CMDAT [INIT] bit.
- Step 6. Start the clock.

а

- Step 7. Start the operation. (write MSC STRPCL with 0x04)
- Step 8. Wait for the END CMD RES interrupt.
- Step 9. Set MSC\_CMD with CMD52.
- Step 10.Set MSC\_ARG with 0x88000C08.
- Step 11. Update the MSC CMDAT register as follows:
  - Write 0x005 to MSC CMDAT [RESPONSE FORMAT].
  - Clear the MSC CMDAT [DATA EN] bit. b
  - С Clear the MSC\_CMDAT [BUSY] bit.
  - d Clear the MSC\_CMDAT [INIT] bit.
- Step 12. Start the operation.
- Step 13. Wait for the END CMD RES interrupt.



#### 7.6.5 Voltage Validation and Card Registry

At most 10 MMC and 1 SD (either SDMEM or SDIO) can be inserted MMC/SD bus at the same time, and their voltage validation and card registry steps are different, so the software should be programmed as follows:

- Step 1. Check whether SDIO card is inserted.
- Step 2. Check whether SDMEM card is inserted.
- Step 3. Check whether MMC cards are inserted.

#### 7.6.5.1 Check SDIO

The commands are sent as follows:

- Step 1. (Optional) Send CMD52 (IO\_RW\_DIRECT) with argument 0x88000C08 to reset SDIO card.
- Step 2. Send CMD5 (IO\_SEND\_OP\_CMD) to validate voltage.
- Step 3. If the response is correct and the number of IO functions > 0, then continue, else go to check SDMEM.
- Step 4. If C-bit in the response is ready (the initialization has finished), go to 6.
- Step 5. Send CMD5 (IO\_SEND\_OP\_CMD) to validate voltage, then go to 4.
- Step 6. If memory-present-bit in the response is true, then it is a combo card (SDIO + Memory), else it is only a SDIO card.
- Step 7. If it is a combo card, go to check SDMEM to initialize the memory part.
- Step 8. Send CMD3 (SET\_RELATIVE\_ADDR) to let the card publish a RCA. The RCA is returned from the response.
- Step 9. If do not accept the new RCA, go to 8, else record the new RCA.
- Step 10.Go to check MMC, because we can assure that there is no SDMEM card.

#### 7.6.5.2 Check SDMEM

If there is no SDIO card or there is a combo card, continue to check SDMEM.

The commands are sent as follows:

- Step 1. (Optional) Send CMD0 (GO\_IDLE\_STATE) to reset MMC and SDMEM card. This command has no response.
- Step 2. Send CMD55. Here the default RCA 0x0000 is used for CMD55.
- Step 3. If the response is correct (CMD55 has response), then continue, else go to check MMC.
- Step 4. Send ACMD41 (SD\_SEND\_OP\_CMD) to validate voltage (the general OCR value is 0x00FF8000).
- Step 5. If the initialization has finished, go to 7. (The response is the OCR register and it includes a status information bit (bit [31]). This status bit is set if the card power up procedure has been finished. As long as the card is busy, the corresponding bit[31] is set to LOW.)
- Step 6. Send CMD55 and ACMD41 to validate voltage, and then go to 5.
- Step 7. Send CMD2 (ALL\_SEND\_CID) to get the card CID.
- Step 8. Send CMD3 (SET\_RELATIVE\_ADDR) to let card publish a RCA. The RCA is returned



from the response.

Step 9. If do not accept the new RCA, go to 8, else record the new RCA. Step 10.Go to check MMC.

#### 7.6.5.3 Check MMC

Because there may be several MMC card, so some steps  $(5 \sim 8)$  should be repeated several times.

The commands are sent as follows:

- Step 1. Send CMD1 (SEND\_OP\_CMD) to validate voltage (the general OCR value is 0x00FF88000).
- Step 2. If the response is correct, then continue, else goto 9.
- Step 3. If the initialization has finished, go to 5. (The response is the OCR register and it includes a status information bit (bit [31]). This status bit is set if the card power up procedure has been finished. As long as the card is busy, the corresponding bit[31] is set to LOW.)
- Step 4. Send CMD1 (SEND OP CMD) to validate voltage, and then go to 3.
- Step 5. Send CMD2 (ALL\_SEND\_CID) to get the card CID.
- Step 6. If the response timeout occurs, goto 9.
- Step 7. Send CMD3 (SET\_RELATIVE\_ADDR) to assign the card a RCA.
- . com inter Step 8. If there are other MMC cards, then go to 5.
- Step 9. Finish.

#### 7.6.6 Single Data Block Write $\cap \bigcirc \bigcirc$

In a single block write command, the following registers must be set before the operation is started:

- Step 1. Set MSC NOB register to 0x0001.
- Step 2. Set MSC BLKLEN to the number of bytes per block.

Step 3. Update the MSC\_CMDAT register as follows:

- Write 0x001 to MSC\_CMDAT [RESPONSE\_FORMAT]. a
  - Write 0x2 to MSC CMDAT [BUS WIDTH] if the card is SD, else clear it. b
  - С Set the MSC\_CMDAT [DATA\_EN] bit.
  - d Set the MSC CMDAT [WRITE READ] bit.
  - Clear the MSC\_CMDAT [STREAM\_BLOCK] bit. е
  - Clear the MSC CMDAT [BUSY] bit. f
  - Clear the MSC\_CMDAT [INIT] bit. g
- Step 4. Start the operation.
- Step 5. Write MSC IMASK with some value to unmask the expected interrupts.

Then the software must perform the following steps:

- Step 1. Wait for the MSC\_IREG [END\_CMD\_RES] interrupt.
- Step 2. Wait for the MSC IREG [DATA TRAN DONE] interrupt.
  - At the same time write data to the MSC\_TXFIFO and continue until all of the data have been written to the FIFO.



- Step 3. Wait for MSC\_IREG [PROG\_DONE] interrupt. This interrupt indicates that the card has finished programming. Certainly software may start another command sequence on a different card.
- Step 4. Read the MSC\_STAT register to verify the status of the transaction (i.e. CRC error status).

To address a different card, the software sends a select command to that card by sending a basic no data command and response transaction. To address the same card, the software must wait for MSC\_IREG [PROG\_DONE] interrupt. This ensures that the card is not in the busy state.

In addition, CMD26 (PROGRAM\_CID), CMD27 (PROGRAM\_CSD), CMD42 (LOCK/UNLOCK), CMD56 (GEN\_CMD: write) and CMD53 (single\_block\_write) operations are similar to single block write.

#### 7.6.7 Single Block Read

In a single block read command, the following registers must be set before the operation is started:

- Step 1. Set MSC\_NOB register to 0x0001.
- Step 2. Set MSC\_BLKLEN register to the number of bytes per block.
- Step 3. Update the following bits in the MSC\_CMDAT register:
  - a Write 0x001 to MSC\_CMDAT [RESPONSE\_FORMAT].
  - b Write 0x2 to MSC\_CMDAT [BUS\_WIDTH] if the card is SD, else clear it.
  - c Set the MSC\_CMDAT [DATA\_EN] bit.
  - d Clear the MSC\_CMDAT [WRITE\_READ] bit.
  - e Clear the MSC\_CMDAT [STREAM\_BLOCK] bit.
  - f Clear the MSC\_CMDAT [BUSY] bit.
  - g Clear the MSC\_CMDAT [INIT] bit.
- Step 4. Start the operation.

Step 5. Write MSC\_IMASK with some value to unmask the expected interrupts.

Then the software must perform the following steps:

- Step 1. Wait for the MSC\_IREG [END\_CMD\_RES] interrupt.
- Step 2. Wait for the MSC\_IREG [DATA\_TRAN\_DONE] interrupt.

At the same time read data from the MSC\_RXFIFO as data becomes available in the FIFO, and continue reading until all data is read from the FIFO.

Step 3. Read the MSC\_STAT register to verify the status of the transaction (i.e. CRC error status).

In addition, CMD30 (SEND\_WRITE\_PROT), ACMD13 (SD\_STATUS), CMD56 (GEN\_CMD-read), ACMD51 (SEND\_SCR) and CMD53 (single\_block\_read) are similar to single block read.

#### 7.6.8 Multiple Block Write

The multiple block write mode is similar to the single block write mode, except that multiple blocks of

212

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



data are transferred. Each block is the same length. All the registers are set as they are for the single block write, except that the MSC\_NOB register is set to the number of blocks to be written.

The multiple block write mode also requires a stop transmission command, CMD12, after the data is transferred to the card. After the MSC\_IREG [DATA\_TRAN\_DONE] interrupt occurs, the software must program the controller register to send a stop data transmission command.

If multiple block write with pre-defined block count (refer to MMC spec v-3.3) is used, CMD12 should not be sent.

For SDIO card, CMD53 (multiple\_block\_write) is also similar, but when IO abort (CMD52) is sent, MSC\_CMDAT [IO\_ABORT] should be 1.

| Operation           | Stop condition               | Software processing                  |
|---------------------|------------------------------|--------------------------------------|
| Open-ended or SDIO  | After write MSC_NOB          | 1 Wait for DATA_TARN_DONE interrupt. |
| infinite            | blocks                       | 2 Send CMD12 or CMD52. (IO abort)    |
|                     |                              | 3 Wait for END_CMD_RES and           |
|                     |                              | PRG_DONE interrupt.                  |
| Open-ended or SDIO  | Stop writing in advance (not | Set MSC_STRPCL [EXIT_MULTIPLE].      |
| infinite            | write MSC_NOB blocks)        | 2 Wait for DATA_TRAN_DONE interrupt. |
|                     | c COm                        | 3 Send CMD12 or CMD52. (IO abort)    |
|                     | 1960                         | 4 Wait for END_CMD_RES and           |
|                     | 1016                         | PRG_DONE interrupt.                  |
| Predefined block or | After writing MSC_NOB        | 1 Wait for DATA_TRAN_DONE interrupt. |
| SDIO finite         | blocks                       |                                      |
| Predefined block or | Stop writing in advance (not | 1 Set MSC_STRPCL [EXIT_MULTIPLE].    |
| SDIO finite         | write MSC_NOB blocks)        | 2 Wait for DATA_TRAN_DONE interrupt. |
| ¥                   |                              | 3 Send CMD12 or CMD52. (IO abort)    |
|                     |                              | 4 Wait for END_CMD_RES and           |
|                     |                              | PRG_DONE interrupt.                  |

#### Table 7-7 How to stop multiple block write

#### 7.6.9 Multiple Block Read

The multiple blocks read mode is similar to the single block read mode, except that multiple blocks of data are transferred. Each block is the same length. All the registers are set as they are for the single block read, except that the MSC\_NOB register is set to the number of blocks to be read.

The multiple blocks read mode requires a stop transmission command, CMD12, after the data from the card is received. After the MSC\_IREG [DATA\_TRAN\_DONE] interrupt has occurred, the software must program the controller registers to send a stop data transmission command.



If multiple block read with pre-defined block count (refer to MMC spec v-3.3) is used, CMD12 should not be sent.

For SDIO card, CMD53 (multiple block read) is also similar, but when IO abort (CMD52) is sent, MSC\_CMDAT [IO\_ABORT] should be 1.

| Operation           | Stop condition               | Software processing                  |
|---------------------|------------------------------|--------------------------------------|
| Open-ended or SDIO  | After reading MSC_NOB        | 1 Wait for DATA_TRAN_DONE interrupt. |
| infinite            | blocks                       | 2 Send CMD12 or CMD52. (IO abort)    |
|                     |                              | 3 Wait for END_CMD_RES interrupt.    |
| Open-ended or SDIO  | Stop reading in advance (not | 1 Set MSC_STRPCL [EXIT_MULTIPLE].    |
| infinite            | write MSC_NOB blocks)        | 2 Wait for DATA_TRAN_DONE interrupt. |
|                     |                              | 3 Send CMD12 or CMD52. (IQ abort)    |
|                     |                              | 4 Wait for END_CMD_RES interrupt.    |
| Predefined block or | After reading MSC_NOB        | 1 Wait for DATA_TRAN_DONE interrupt. |
| SDIO finite         | blocks                       | 1 45                                 |
| Predefined block or | Stop reading in advance (not | 1 Set MSC_STRPCL [EXIT_MULTIPLE].    |
| SDIO finite         | write MSC_NOB blocks)        | 2 Wait for DATA_TRAN_DONE interrupt. |
|                     | $\sim$                       | Send CMD12 or CMD52. (IO abort)      |
|                     | all                          | 4 Wait for END_CMD_RES interrupt.    |

#### Table 7-8 How to stop multiple block read

7.6.10 Stream Write (MMC) 226. In a stream write command, the following registers must be set before the operation is started:

- Update MSC CMDAT register as follows: 1
  - a Write 0x001 to the MSC CMDAT [RESPONSE FORMAT].
  - Clear the MSC\_CMDAT [BUS\_WIDTH] because only MMC support stream write. b
  - Set the MSC\_CMDAT [DATA\_EN] bit. С
  - d Set the MSC CMDAT [WRITE READ] bit.
  - e Set the MSC\_CMDAT [STREAM\_BLOCK] bit.
  - Clear the MSC\_CMDAT [BUSY] bit. f
  - Clear the MSC\_CMDAT [INIT] bit. g
- 2 Start the operation.
- Write MSC IMASK with some value to unmask the expected interrupts. 3

Then the software must perform the following steps:

- Wait for the MSC\_IREG [END\_CMD\_RES] interrupt. 1
- 2 Write data to the MSC\_TXFIFO and continue until all of the data is written to the Data FIFO.
- Stop clock. Wait until MSC STAT[CLK EN] becomes 0. The clock must be stopped. 3
- Set the command registers for a stop transaction command (CMD12) and other registers. 4

214



- 5 Start the clock and start the operation.
- 6 Wait for the MSC\_IREG [END\_CMD\_ERS] interrupt.
- 7 Wait for the MSC\_IREG [DATA\_TRAN\_DONE] interrupt.
- 8 Wait for the MSC IREG [PRG DONE] interrupt. This interrupt indicates that the card has finished programming. Certainly software may start another command sequence on a different card.
- 9 Read the MSC\_STAT register to verify the status of the transaction.

To address a different card, the software must send a select command to that card by sending a basic no data command and response transaction. To address the same card, the software must wait for MSC\_IREG [PRG\_DONE] interrupt. This ensures that the card is not in the busy state.

If partial blocks are allowed (if CSD parameter WRITE BL PARTIAL is set) the data stream can start and stop at any address within the card address space, otherwise it shall start and stop only at block boundaries. If WRITE BL PARTIAL is not set, 16 more stuff bytes need to be written after the useful used on written data, otherwise only write the useful written data.

#### 7.6.11 Stream Read (MMC)

In a stream read command, the following registers must be set before the operation is turned on:

- Update the MSC CMDAT register as follows: 1
  - a Write 0x01 to the MSC CMDAT [RESPONSE FORMAT].
  - Clear the MSC\_CMDAT [BUS\_WIDTH] because only MMC support stream read. b
  - c Clear the MSC\_CMDAT [WRITE\_READ] bit.
  - d Set the MSC CMDAT STREAM BLOCK bit.
  - Clear the MSC\_CMDAT [BUSY] bit. е
  - f Clear the MSC CMDAT [INIT] bit.
- 2 Start the operation.
- 3 Write MSC IMASK with some value to unmask the expected interrupts.

Then the software must perform the following steps:

- 1 Wait for the MSC IREG [END CMD RES] interrupt.
- 2 Read data from the MSC\_RXFIFO and continue until all of the expected data has been read from the FIFO.
- 3 Write MSC\_STRPCL [EXIT\_TRANSER] with 1. If MSC\_STAT[DATA\_FIFO\_FULL] is 1, then read MSC RXFIFO to make it not full. Because if data FIFO is full, MSC CLK is stopped. Here, the data FIFO contains useless data.
- 4 Set the command registers for a stop transaction command (CMD12) and send it. There is no need to stop the clock.
- 5 Wait for the MSC\_IREG [END\_CMD\_RES].
- 6 Wait for the MSC IREG [DATA TRAN DONE] interrupt.
- Read the MSC\_STAT register to verify the status of the transaction. 7



#### 7.6.12 Erase, Select/Deselect and Stop

For CMD7 (SELECT/DESELECT\_CARD), CMD12 (STOP\_TRANSMISSION) and CMD38 (ERASE), the following registers must be set before the operation is started:

- Update the MSC CMDAT register as follows: 1
  - Write 0x01 to the MSC CMDAT [RESPONSE FORMAT]. а
  - b Clear the MSC\_CMDAT [DATA\_EN] bit.
  - c Clear the MSC\_CMDAT [WRITE\_READ] bit.
  - d Clear the MSC CMDAT [STREAM BLOCK] bit.
  - e Set the MSC\_CMDAT [BUSY] bit.
  - Clear the MSC CMDAT [INIT] bit. f
- Start the operation. 2
- 3 Write MSC IMASK with some value to unmask the expected interrupts.

Then the software must perform the following steps:

- 1 Wait for the MSC IREG [END CMD RES] interrupt.
- 2 Wait for the MSC IREG [PRG DONE] interrupt. If CMD12 is sent to terminate data read operation, then there is no need to wait for MSC IREG [PRG DONE] interrupt. This interrupt indicates that the card has finished programming. Certainly software may start interna another command sequence on a different card.

#### 7.6.13 SDIO Suspend/Resume

The actual suspend/resume steps are as follows:

- During data transfer, send CMD52 to require suspend. BR and RAW flag should be 1. 1
- If BS flag in the response is 0, then suspend has been accepted and goto 4. 2
- Send CMD52 to query card status. R flag should be 1. Go to 2. 3
- 4 Write MSC STRPCL [EXIT TRANSFER] with 1.
- 5 Wait for the MSC\_IREG [DATA\_TRAN\_DONE] interrupt.
- 6 Read MSC NOB, MSC SNOB and etc, save them into variables.
- 7 Set registers for high priority transfer and start it.
- 8 Wait until high priority transfer is finished.
- 9 Restore registers from variables, but MSC NOB should be (MSC NOB – MSC SNOB).
- 10 Send CMD52 to require resume. FSx should be resumed function number.

#### 7.6.14 SDIO ReadWait

The actual ReadWait steps are as follows:

- During multiple block read, read MSC SNOB. If MSC SNOB is nearby or equal to 1 MSC NOB, no need to use ReadWait.
- 2 Write MSC\_STRPCL [START\_READWAIT] with 1.
- 3 Wait until MSC STAT [IS READWAIT] becomes 1.
- 4 Send CMD52 to query card status.
- 5 Write MSC\_STRPCL [STOP\_READWAIT] with 1.



#### 7.6.15 Operation and Interrupt

The software can use polling-status method to operate the MMC/SD card, but this is not the proposed method, because its performance is very low. The proposed method is to use interrupt. Generally there are fixed necessary steps to finish each command. The steps are as follows:

- 1 (Optional) Stop clock. Poll CLK\_EN.
- 2 Fill the registers (MSC\_CMD, MSC\_CMDAT, MSC\_ARG, MSC\_CLKRT, and etc).
- 3 (Optional) Start clock.
- 4 Start the operation. Wait for the MSC\_IREG [END\_CMD\_RES] interrupt.
- 5 Wait for the MSC\_IREG [DATA\_TRAN\_DONE] interrupt.
- 6 Send STOP\_TRANS (CMD12) or I/O abort (CMD52). Wait for the MSC\_IREG [END\_CMD\_ERS] interrupt.
- 7 Wait for the MSC\_IREG [DATA\_TRAN\_DONE] interrupt.
- 8 Wait for the MSC\_IREG [PRG\_DONE] interrupt.

|       |                      | - |   | 1 | 1 | 1                                           | 1  | 1 | 1 | 05         |
|-------|----------------------|---|---|---|---|---------------------------------------------|----|---|---|------------|
| Index | Abbreviation         | 1 | 2 | 3 | 4 | 5                                           | 6  | 7 | 8 | Comments   |
| CMD0  | GO_IDLE_STATE        | Y | Y | Y | Y |                                             | 1  | V | Ρ |            |
| CMD1  | SEND_OP_COND         | Y | Υ | Υ | Y |                                             | J7 |   |   |            |
| CMD2  | ALL_SEND_CID         | Υ | Υ | Y | Y | $C_{I_{I_{I_{I_{I_{I_{I_{I_{I_{I_{I_{I_{I_$ |    |   |   |            |
| CMD3  | SET_RELATIVE_ADDR    | Υ | Y | Y | Y |                                             |    |   |   |            |
| CMD4  | SET_DSR              | Y | Y | Y | Υ |                                             |    |   |   |            |
| CMD7  | SELECT/DSELECT_CARD  | Y | Υ | Υ | Υ |                                             |    |   | Y |            |
| CMD9  | SEND_CID             | Υ | Υ | Υ | Υ |                                             |    |   |   |            |
| CMD10 | SEND_CSD             | Υ | Υ | Υ | Y |                                             |    |   |   |            |
| CMD11 | READ_DAT_UNTIL_STOP  | Υ | Υ | Υ | Y |                                             | Y  | Υ |   |            |
| CMD12 | STOP_TRANSMISSION    | Υ | Υ | Υ | Υ |                                             |    |   | Υ |            |
| CMD13 | SEND_STATUS          | Υ | Υ | Υ | Y |                                             |    |   |   |            |
| CMD15 | GO_INACTIVE_STATE    | Υ | Υ | Υ | Y |                                             |    |   |   |            |
| CMD16 | SET_BLOCKLEN         | Υ | Υ | Υ | Y |                                             |    |   |   |            |
| CMD17 | READ_SINGLE_BLOCK    | Υ | Υ | Υ | Υ | Υ                                           |    |   |   |            |
| CMD18 | READ_MULTIPLE_BLOCK  | Υ | Y | Υ | Y | Y                                           | Υ  |   |   | Open-ended |
| CMD18 | READ_MULTIPLE_BLOCK  | Υ | Υ | Υ | Υ | Υ                                           |    |   |   | Predefine  |
|       |                      |   |   |   |   |                                             |    |   |   | blocks     |
| CMD20 | WRITE_DAT_UNTIL_STOP | Υ | Υ | Υ | Υ |                                             | Υ  | Υ | Υ |            |
| CMD23 | SET_BLOCK_COUNT      | Υ | Y | Υ | Y |                                             |    |   |   |            |
| CMD24 | WRITE_SINGLE_BLOCK   | Υ | Y | Υ | Y | Y                                           |    |   | Y |            |
| CMD25 | WRITE_MULTIPLE_BLOCK | Y | Y | Y | Y | Y                                           | Υ  |   | Y | Open-ended |
| CMD25 | WRITE_MULTIPLE_BLOCK | Υ | Y | Υ | Y | Y                                           |    |   | Y | Predefine  |
|       |                      |   |   |   |   |                                             |    |   |   | blocks     |
| CMD26 | PROGRAM_CID          | Υ | Y | Υ | Y | Y                                           |    |   | Y |            |
| CMD27 | PROGRAM_CSD          | Υ | Y | Υ | Y | Y                                           |    |   | Y |            |

#### Table 7-9 The mapping between Commands and Steps

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| CMD28  | SET_WRITE_PROT       | Y   | Y | Y | Y |           |          |      | Y   |       |
|--------|----------------------|-----|---|---|---|-----------|----------|------|-----|-------|
| CMD29  | CLR_WRITE_PROT       | Y   | Υ | Y | Y |           |          |      | Y   |       |
| CMD30  | SEND_WRITE_PROT      | Y   | Υ | Y | Y | Υ         |          |      |     |       |
| CMD32  | ERASE_WR_BLOCK_START | Y   | Υ | Y | Υ |           |          |      |     |       |
| CMD33  | ERASE_WR_BLOCK_END   | Y   | Υ | Y | Υ |           |          |      |     |       |
| CMD35  | ERASE_GROUP_START    | Y   | Υ | Y | Υ |           |          |      |     |       |
| CMD36  | ERASE_GROUP_END      | Y   | Υ | Y | Υ |           |          |      |     |       |
| CMD38  | ERASE                | Y   | Υ | Y | Υ |           |          |      | Y   |       |
| CMD39  | FAST_IO              | Y   | Υ | Y | Υ |           |          |      |     |       |
| CMD40  | GO_IRQ_STATE         | Y   | Υ | Y | Υ |           |          |      |     |       |
| CMD42  | LOCK/UNLOCK          | Y   | Υ | Y | Υ | Υ         |          |      | Y   |       |
| CMD55  | APP_CMD              | Υ   | Υ | Υ | Υ |           |          |      |     |       |
| CMD56  | GEN_CMD              | Υ   | Υ | Υ | Υ | Υ         |          |      |     | Read  |
| CMD56  | GEN_CMD              | Y   | Υ | Y | Y | Υ         |          |      | Y   | Write |
|        |                      |     |   |   |   |           |          |      |     | aurs  |
| ACMD6  | SET_BUS_WIDTH        | Y   | Υ | Y | Υ |           |          |      | .7  | 05    |
| ACMD13 | SD_STATUS            | Y   | Υ | Y | Υ | Υ         |          | 110  | 600 |       |
| ACMD22 | SEND_NUM_WR_BLOCKS   | Y   | Υ | Y | Υ |           | <b>1</b> | Or I |     |       |
| ACMD23 | SET_WR_BLOCK_COUNT   | Y   | Υ | Y | Y | $\cdot V$ | 0        |      |     |       |
| ACMD41 | SD_SEND_OP_COND      | Y   | Y | Y | Ŷ |           |          |      |     |       |
| ACMD42 | SET_CLR_CARD_DETECT  | Y   | Y | Y | Y |           |          |      |     |       |
| ACMD51 | SEND_SCR             | CYO | Ý | Y | Y | Y         |          |      |     |       |
|        | 196.                 |     |   |   |   |           |          |      |     |       |

**NOTE:** For stream read/write, STOP\_CMD is sent after finishing data transfer. For write, STOP\_CMD is with the last six bytes. For read, STOP\_CMD is sent after receiving data and card sends some data which MSC ignores.

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

218



# 8 UART Interface

#### 8.1 Overview

This chapter describes the universal asynchronous receiver/transmitter (UART) serial ports. There are four UARTs: All UARTs use the same programming model. Each of the serial ports can operate in interrupt based mode or DMA-based mode.

The Universal asynchronous receiver/transmitter (UART) is compatible with the 16550-industry standard and can be used as slow infrared asynchronous interface that conforms to the Infrared Data Association (IrDA) serial infrared specification 1.1.

#### 8.1.1 Features

- Full-duplex operation
- 5-, 6-, 7- or 8-bit characters with optional no parity or even or odd parity and with 1, 1<sup>1</sup>/<sub>2</sub>, or 2 stop bits
- 32x8 bit transmit FIFO and 32x11bit receive FIFO
- Independently controlled transmit, receive (data ready or timeout), line status interrupts
- Internal diagnostic capability Loopback control and break, parity, overrun and framing-error is provided
- Separate DMA requests for transmit and receive data services in FIFO mode
- Supports modem flow control by software or hardware
- Slow infrared asynchronous interface that conforms to IrDA specification

## 8.1.2 Pin Description

#### Table 8-1 UART Pins Description

| Name | Туре   | Description                                 |  |
|------|--------|---------------------------------------------|--|
| RxD  | Input  | Receive data input                          |  |
| TxD  | Output | Transmit data output                        |  |
| CTS_ | Input  | Clear to Send — Modem Transmission enabled  |  |
| RTS_ | Output | Request to Send — UART Transmission request |  |

NOTE: UART3, UART2, UART1, UART0 support RxD, TxD, RTS\_, CTS\_.



#### 8.2 Register Descriptions

All UART register 32-bit access address is physical address. When ULCR.DLAB is 0, URBR, UTHR and UIER can be accessed; When ULCR.DLAB is 1, UDLLR and UDLHR can be accessed.

| Name   | Description                              | RW | Reset<br>Value | Address    | Access<br>Size |
|--------|------------------------------------------|----|----------------|------------|----------------|
| URBR0  | UART Receive Buffer Register 0           | R  | 0x??           | 0x10030000 | 8              |
| UTHR0  | UART Transmit Hold Register 0            | W  | 0x??           | 0x10030000 | 8              |
| UDLLR0 | UART Divisor Latch Low Register 0        | RW | 0x00           | 0x10030000 | 8              |
| UDLHR0 | UART Divisor Latch High Register 0       | RW | 0x00           | 0x10030004 | 8              |
| UIER0  | UART Interrupt Enable Register 0         | RW | 0x00           | 0x10030004 | 8              |
| UIIR0  | UART Interrupt Identification Register 0 | R  | 0x01           | 0x10030008 | 8              |
| UFCR0  | UART FIFO Control Register 0             | W  | 0x00           | 0x10030008 | 8              |
| ULCR0  | UART Line Control Register 0             | RW | 0x00           | 0x1003000C | 8              |
| UMCR0  | UART Modem Control Register 0            | RW | 0x00           | 0x10030010 | 8              |
| ULSR0  | UART Line Status Register 0              | R  | 0x00           | 0x10030014 | 8              |
| UMSR0  | UART Modem Status Register 0             | R  | 0x00           | 0x10030018 | 8              |
| USPR0  | UART Scratchpad Register 0               | RW | 0x00           | 0x1003001C | 8              |
| ISR0   | Infrared Selection Register 0            | RW | 0x00           | 0x10030020 | 8              |
| UMR0   | UART M Register 0                        | RW | 0x00           | 0x10030024 | 8              |
| UACR0  | UART Add Cycle Register 0                | RW | 0x00           | 0x10030028 | 16             |
| URBR1  | UART Receive Buffer Register 1           | R  | 0x??           | 0x10031000 | 8              |
| UTHR1  | UART Transmit Hold Register 1            | W  | 0x??           | 0x10031000 | 8              |
| UDLLR1 | UART Divisor Latch Low Register 1        | RW | 0x00           | 0x10031000 | 8              |
| UDLHR1 | UART Divisor Latch High Register 1       | RW | 0x00           | 0x10031004 | 8              |
| UIER1  | UART Interrupt Enable Register 1         | RW | 0x00           | 0x10031004 | 8              |
| UIIR1  | UART Interrupt Identification Register 1 | R  | 0x01           | 0x10031008 | 8              |
| UFCR1  | UART FIFO Control Register 1             | W  | 0x00           | 0x10031008 | 8              |
| ULCR1  | UART Line Control Register 1             | RW | 0x00           | 0x1003100C | 8              |
| UMCR1  | UART Modem Control Register 1            | RW | 0x00           | 0x10031010 | 8              |
| ULSR1  | UART Line Status Register 1              | R  | 0x00           | 0x10031014 | 8              |
| UMSR1  | UART Modem Status Register 1             | R  | 0x00           | 0x10031018 | 8              |
| USPR1  | UART Scratchpad Register 1               | RW | 0x00           | 0x1003101C | 8              |
| ISR1   | Infrared Selection Register 1            | RW | 0x00           | 0x10031020 | 8              |
| UMR1   | UART M Register 1                        | RW | 0x00           | 0x10031024 | 8              |
| UACR1  | UART Add Cycle Register 1                | RW | 0x00           | 0x10031028 | 16             |
| URBR2  | UART Receive Buffer Register 2           | R  | 0x??           | 0x10032000 | 8              |
| UTHR2  | UART Transmit Hold Register 2            | W  | 0x??           | 0x10032000 | 8              |
| UDLLR2 | UART Divisor Latch Low Register 2        | RW | 0x00           | 0x10032000 | 8              |
| UDLHR2 | UART Divisor Latch High Register 2       | RW | 0x00           | 0x10032004 | 8              |

#### Table 8-2 UART Registers Description

220

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

| UIER2  | UART Interrupt Enable Register 2         | RW | 0x00 | 0x10032004 | 8  |
|--------|------------------------------------------|----|------|------------|----|
| UIIR2  | UART Interrupt Identification Register 2 | R  | 0x01 | 0x10032008 | 8  |
| UFCR2  | UART FIFO Control Register 2             | W  | 0x00 | 0x10032008 | 8  |
| ULCR2  | UART Line Control Register 2             | RW | 0x00 | 0x1003200C | 8  |
| UMCR2  | UART Modem Control Register 2            | RW | 0x00 | 0x10032010 | 8  |
| ULSR2  | UART Line Status Register 2              | R  | 0x00 | 0x10032014 | 8  |
| UMSR2  | UART Modem Status Register 2             | R  | 0x00 | 0x10032018 | 8  |
| USPR2  | UART Scratchpad Register 2               | RW | 0x00 | 0x1003201C | 8  |
| ISR2   | Infrared Selection Register 2            | RW | 0x00 | 0x10032020 | 8  |
| UMR2   | UART M Register 2                        | RW | 0x00 | 0x10032024 | 8  |
| UACR2  | UART Add Cycle Register 2                | RW | 0x00 | 0x10032028 | 16 |
| URBR3  | UART Receive Buffer Register 3           | R  | 0x?? | 0x10033000 | 8  |
| UTHR3  | UART Transmit Hold Register 3            | W  | 0x?? | 0x10033000 | 8  |
| UDLLR3 | UART Divisor Latch Low Register 3        | RW | 0x00 | 0x10033000 | 8  |
| UDLHR3 | UART Divisor Latch High Register 3       | RW | 0x00 | 0x10033004 | 8  |
| UIER3  | UART Interrupt Enable Register 3         | RW | 0x00 | 0x10033004 | 8  |
| UIIR3  | UART Interrupt Identification Register 3 | R  | 0x01 | 0x10033008 | 8  |
| UFCR3  | UART FIFO Control Register 3             | W  | 0x00 | 0x10033008 | 8  |
| ULCR3  | UART Line Control Register 3             | RW | 0x00 | 0x1003300C | 8  |
| UMCR3  | UART Modem Control Register 3            | RW | 0x00 | 0x10033010 | 8  |
| ULSR3  | UART Line Status Register 3              | R  | 0x00 | 0x10033014 | 8  |
| UMSR3  | UART Modem Status Register 3             | R  | 0x00 | 0x10033018 | 8  |
| USPR3  | UART Scratchpad Register 3               | RW | 0x00 | 0x1003301C | 8  |
| ISR3   | Infrared Selection Register 3            | RW | 0x00 | 0x10033020 | 8  |
| UMR3   | UART M Register 3                        | RW | 0x00 | 0x10033024 | 8  |
| UACR3  | UART Add Cycle Register 3                | RW | 0x00 | 0x10033028 | 16 |
|        |                                          |    |      | •          |    |

### 8.2.1 UART Receive Buffer Register (URBR)

The read-only URBR is corresponded to one level 11bit buffer in non-FIFO mode and a 32x11bit FIFO that holds the character(s) received by the UART. Bits in URBR are right justified when being configured to use fewer than eight bits, and the rest of most significant data bits are zeroed and the most significant three bits of each buffer are the status for the character in the buffer. If ULSR.DRY is 0, don't read URBR, otherwise wrong operation may occur.





| Bits | ts Name Description |                               | RW |
|------|---------------------|-------------------------------|----|
| 7:0  | URBR                | 8-bit UART receive read data. | R  |

#### 8.2.2 UART Transmit Hold Register (UTHR)

The write-only UTHR is corresponded to one leve 8 bit buffer in non-FIFO mode and a 32x8bit FIFO in FIFO mode that holds the data byte(s) to be transmitted next.

| UTH  | IRO, UTHR1, UT | 0x1003                               | 30000, ( |     |   | )0, 0<br>3000 |    |    |   |
|------|----------------|--------------------------------------|----------|-----|---|---------------|----|----|---|
| Bit  |                |                                      | [        | 7 6 | 5 | 4 ;           | 32 | 1  | 0 |
|      |                |                                      |          |     |   | UTH           | R  |    |   |
| RST  |                |                                      |          | ??  | ? | )<br>, ,      | ?? | ?  | ? |
| Bits | Name           | Description                          | , C      | .00 | ٢ |               |    | R۱ | N |
| 7:0  | UTHR           | 8-bit UART transmit write hold data. | n.       |     |   |               |    | W  |   |

#### 8.2.3 UART Divisor Latch Low/High Register (UDLLR / UDLHR)

UART Divisor Latch registers, UDLLR/UDLHR together compose the divisor for the programmable baud rate generator that can take the UART device clock and divide it by 1 to  $(2^{16} - 1)$ .

The UART device source clock is EXCLK or EXCLK/2 that is determined by CPCCR.ECS. UDLHR/UDLLR stores the high/low 8-bit of the divisor respectively. Load these divisor latches during initialization to ensure that the baud rate generator operates properly. If both Divisor Latch registers are 0, the 16X clock stops.

If you don't set UMR and UACR, UART will work at normal mode with the specified frequency. The relationship between baud rate and the value of Divisor is shown by the formula when UMR and UACR are not set:

**Baud Rate =** (UART device clock) / (16 \* **Divisor**)

| UDLLR0, UDLLR1, UDLLR2, UDLLR3 | 0x10030000, 0x10031000, 0x10032000,<br>0x10033000 (DLAB = 1) |
|--------------------------------|--------------------------------------------------------------|
| Bit                            | 7 6 5 4 3 2 1 0                                              |
|                                | Divisor Latch Low 8-bit                                      |
| RST                            | 0 0 0 0 0 0 0 0                                              |

#### 222

| JZ4770 Mobile | Application | Processor | Peripheral | s Prog | ramn | ning | Manual |  |
|---------------|-------------|-----------|------------|--------|------|------|--------|--|
| <u> </u>      |             |           |            |        |      | ~    |        |  |

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|     | UDLHR0, UDLHR1, UDLHR2, UDLHR3         0x10030004, 0x10031004, 0x1003           Bit         7         6         5         4         3         2 |  |   |       |      |     |     |     |     |    |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------|--|---|-------|------|-----|-----|-----|-----|----|
| Bit |                                                                                                                                                 |  |   |       |      |     | •   |     |     |    |
|     |                                                                                                                                                 |  | C | )ivis | or L | atc | h H | igh | 8-b | it |
| RS  |                                                                                                                                                 |  | 0 | 0     | 0    | 0   | 0   | 0   | 0   | 0  |

#### 8.2.4 UART Interrupt Enable Register (UIER)

The UART Interrupt Enable Register (UIER) contains the interrupt enable bits for the five types of interrupts (receive data ready, timeout, line status, and transmit data request, and modem status) that set a value in UIIR.

#### UIER0, UIER1, UIER2, UIER3

#### 0x10030004, 0x100301004, 0x10032004,

| OILINO, OILIN |    | 0 | )x1(     | )03 | 300   | 4 ([ | <b>J</b> ĹA | <b>B</b> = | = 0)  |
|---------------|----|---|----------|-----|-------|------|-------------|------------|-------|
| Bit           |    | 7 | 6        | 5   | 4     | 3    | 2           | 1          | 0     |
|               |    |   | Reserved |     | RTOIE | MSIE | RLSIE       | TDRIE      | RDRIE |
| RST           |    | 0 | 0        | 0   | 0     | 0    | 0           | 0          | 0     |
| ·             | in |   |          |     |       |      |             |            |       |

| Bits | Name     | Description                                                          | RW |
|------|----------|----------------------------------------------------------------------|----|
| 7:5  | Reserved | Writing has no effect, read as zero.                                 | R  |
| 4    | RTOIE    | Receive Timeout Interrupt Enable.                                    | RW |
|      |          | 0: Disable the receive timeout interrupt                             |    |
|      |          | 1. Enable the receive timeout interrupt                              |    |
|      | . 0      | Timeout means the URDR (FIFO mode) is not empty but no character has |    |
|      | 18-      | received for a period of time T: T (bits) = 4 X Word length + 12.    |    |
| 3    | MSIE     | Modem Status Interrupt Enable.                                       | RW |
|      |          | 0: Disable the modem status interrupt                                |    |
|      |          | 1: Enable the modem status interrupt                                 |    |
| 2    | RLSIE    | Receive Line Status Interrupt Enable.                                | RW |
|      |          | 0: Disable receive line status interrupt                             |    |
|      |          | 1: Enable receive line status interrupt                              |    |
| 1    | TDRIE    | Transmit Data Request Interrupt Enable.                              | RW |
|      |          | 0: Disable the transmit data request interrupt                       |    |
|      |          | 1: Enable the transmit data request interrupt                        |    |
| 0    | RDRIE    | Receive Data Ready Interrupt Enable.                                 | RW |
|      |          | 0: Disable the receive data ready interrupt                          |    |
|      |          | 1: Enable the receive data ready interrupt                           |    |

224



#### 8.2.5 UART Interrupt Identification Register (UIIR)

The read-only UART Interrupt Identification Register (UIIR) records the prioritized pending interrupt source information. Its initial value after power-on reset is 0x01.

| UIIR0, UIIR1, UIIR2, UIIR3 | 0x10030008, 0x10031008, 0x10 | )32008   | , 0x10033 | 800    |
|----------------------------|------------------------------|----------|-----------|--------|
| Bit                        | 7 6                          | 54       | 3 2 1     | 0      |
|                            | FFMSEL                       | Reserved | CINI      | INPEND |
| RST                        | 0 0                          | 0 0      | 0 0 0     | 1      |

| Bits | Name     | Description                                                                                       | RW |
|------|----------|---------------------------------------------------------------------------------------------------|----|
| 7:6  | FFMSEL   | FIFO Mode Select.                                                                                 | R  |
|      |          | 0b00: Non-FIFO mode                                                                               |    |
|      |          | 0b01: Reserved                                                                                    |    |
|      |          | 0b10: Reserved                                                                                    |    |
|      |          | 0b00: NoIFFIFI O mode<br>0b01: Reserved<br>0b11: FIFO mode<br>Writing has no effect, read as zero |    |
| 5:4  | Reserved | Writing has no effect, read as zero.                                                              | R  |
| 3:1  | INID     | Interrupt Identifier.                                                                             | R  |
|      |          | These bits identify the current highest priority pending interrupt.                               |    |
|      |          | INID Description                                                                                  |    |
|      |          | 0b000 Modem Status                                                                                |    |
|      |          | 0b001 Transmit Data Request                                                                       |    |
|      |          | 0b010 Receive Data Ready                                                                          |    |
|      |          | 0b011 Receive Line Status                                                                         |    |
|      |          | 0b100 Reserved                                                                                    |    |
|      | o V      | 0b101 Reserved                                                                                    |    |
| 1    | ous      | 0b110 Receive Time Out                                                                            |    |
|      |          | 0b111 Reserved                                                                                    |    |
|      |          |                                                                                                   |    |
|      |          | See _Table 8-3 for details.                                                                       |    |
| 0    | INPEND   | Interrupt Pending.                                                                                | R  |
|      |          | 0: interrupt is pending                                                                           |    |
|      |          | 1: No interrupt pending                                                                           |    |

#### Table 8-3 UART Interrupt Identification Register Description

| UIIR.INID |          |      | Interrupt Set/Clear Cause |                 |
|-----------|----------|------|---------------------------|-----------------|
|           | Priority | Туре | Source                    | Clear Condition |
| 0b0001    |          | None | No pending interrupt      | _               |

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| 0b0110   | 1st Highest | Receive Line  | Overrun, Parity, Frame       | Reading ULSR or empty all     |
|----------|-------------|---------------|------------------------------|-------------------------------|
|          |             | Status        | Error, Break Interrupt,      | the error characters in DMA   |
|          |             |               | and FIFO Error (DMA          | mode                          |
|          |             |               | mode only)                   |                               |
| 0b0100   | 2nd         | Receive Data  | FIFO mode: Trigger           | FIFO mode: Reading URBR       |
|          | Highest     | Ready         | threshold was reached        | till below trigger threshold. |
|          |             |               | Non-FIFO mode: URBR          | Non-FIFO mode: Empty          |
|          |             |               | full                         | URBR                          |
| 0b1100   | 2nd         | Receive       | FIFO mode only: URBR         | Reset receive buffer by       |
|          | Highest     | Timeout       | not empty but no data        | setting UFCR.RFRT to 1 or     |
|          |             |               | read in for a period of time | Reading URBR                  |
| 0b0010   | 3rd Highest | Transmit      | FIFO mode: Empty             | FIFO mode: Data number in     |
|          |             | Data Request  | location in UTHR equal to    | UTHR more than half           |
|          |             |               | half or more than half       |                               |
|          |             |               | Non-FIFO mode: UTHR          | Non-FIFO mode: Writing        |
|          |             |               | empty                        | UTHR OTT                      |
| 0b0000   | 4th Highest | Modem         | Modem CTS_ pin status        | Reading UMSR                  |
|          |             | Status        | change                       | ND.                           |
|          |             |               | na                           |                               |
|          |             |               | * eru                        |                               |
| 8.2.6 UA | RT FIFO Cor | trol Register |                              |                               |

#### 8.2.6 UART FIFO Control Register (UFCR)

The write-only register UFCR contains the control bits for receive and transmit FIFO.

```
UFCR0, UFCR1, UFCR2, UFCR3
```

#### 0x10030008, 0x10031008, 0x10032008, 0x10033008

Bit



#### RST

| Bits | Name     | Description                                                                | RW |
|------|----------|----------------------------------------------------------------------------|----|
| 7:6  | RDTR     | Receive Buffer Data Number Trigger.                                        | W  |
|      |          | These bits are used to select the trigger level for the receive data ready |    |
|      |          | interrupt in FIFO mode.                                                    |    |
|      |          | 0b00: 1                                                                    |    |
|      |          | 0b01: 8                                                                    |    |
|      |          | 0b10: 16                                                                   |    |
|      |          | 0b11: 24                                                                   |    |
| 5    | Reserved | Writing has no effect, read as zero.                                       | R  |
| 4    | UME      | UART Module Enable.                                                        | W  |
|      |          | 0: Disable UART                                                            |    |
|      |          | 1: Enable UART                                                             |    |

| 3 | DME  | DMA Mode Enable.                        | W |
|---|------|-----------------------------------------|---|
|   |      | 0: Disable DMA mode                     |   |
|   |      | 1: Enable DMA mode                      |   |
| 2 | TFRT | Transmit Holding Register Reset.        | W |
|   |      | 0: Not reset                            |   |
|   |      | 1: Reset transmit FIFO                  |   |
| 1 | RFRT | Receive Buffer Reset.                   | W |
|   |      | 0: Not reset                            |   |
|   |      | 1: Reset receive FIFO                   |   |
| 0 | FME  | FIFO Mode Enable.                       | W |
|   |      | Set this bit before the trigger levels. |   |
|   |      | 0: non-FIFO mode                        |   |
|   |      | 1: FIFO mode                            |   |

### 8.2.7 UART Line Control Register (ULCR)

The ULCR defines the format for UART data transmission.

#### ULCR0, ULCR1, ULCR2, ULCR3





RST

Bit

| Bits | Name ୧ | Description                                                                | RW |
|------|--------|----------------------------------------------------------------------------|----|
| 7    | DLAB   | Divisor Latch Access Bit.                                                  | W  |
|      |        | 0: Enable to access URBR, UTHR or UIER                                     |    |
|      |        | 1: Enable to access UDLLR or UDLHR                                         |    |
| 6    | SBK    | Set Break.                                                                 | W  |
|      |        | Causes a break condition (at least one 0x00 data) to be transmitted to the |    |
|      |        | receiving UART. Acts only on the TXD pin and has no effect on the          |    |
|      |        | transmit logic.                                                            |    |
|      |        | 0: No effect on TXD output                                                 |    |
|      |        | 1: Forces TXD output to 0                                                  |    |
| 5    | STPAR  | Sticky Parity.                                                             | W  |
|      |        | Setting this bit forces parity location to be opposite of PARM bit when    |    |
|      |        | PARE is 1 (it is ignored when PARE is 0).                                  |    |
|      |        | 0: Disable Sticky parity                                                   |    |
|      |        | 1: Enable Sticky parity (opposite o f PARM bit)                            |    |
| 4    | PARM   | Parity Odd/Even Mode Select.                                               | W  |

226

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.





|       |          | If PARE = 0, PARM is ignored.                                                 |   |
|-------|----------|-------------------------------------------------------------------------------|---|
|       |          | 0: Odd parity                                                                 |   |
|       |          | 1: Even parity                                                                |   |
| 3     | PARE     | Parity Enable.                                                                | W |
|       |          | Enables a parity bit to be generated on transmission or checked on            |   |
|       |          | reception.                                                                    |   |
|       |          | 0: No parity                                                                  |   |
|       |          | 1: Parity                                                                     |   |
| 2     | SBLS     | Stop Bit Length Select.                                                       | W |
|       |          | Specifies the number of stop bits transmitted and received in each            |   |
|       |          | character. When receiving, the receiver checks only the first stop bit.       |   |
|       |          | 0: 1 stop bit                                                                 |   |
|       |          | 1: 2 stop bits, except for 5-bit character then 1-1/2 bits                    |   |
| 1:0   | WLS      | Word Length Select.                                                           | W |
|       |          | 0b00: 5-bit character                                                         |   |
|       |          | 0b00: 5-bit character       0b10: 7-bit character       0b11: 8-bit character |   |
|       |          | 0b10: 7-bit character                                                         |   |
|       |          | 0b11: 8-bit character                                                         |   |
| 8.2.8 | UART Lin | e Status Register (ULSR)                                                      |   |

#### 8.2.8 UART Line Status Register (ULSR)

The read-only ULSR indicates status information during the data transfer. Receive error information in ULSR[4:1] remains set until software reads ULSR and it must be read before the error character is read.

#### ULSR0, ULSR1, ULSR2, ULSR3

Bit

RST

#### 0x10030014, 0x10031014, 0x10032014, 0x10033014

| 7           | 6    | 5    | 4  | 3    | 2     | 1    | 0   |
|-------------|------|------|----|------|-------|------|-----|
| <b>JOJI</b> | TEMP | TDRQ | IB | FMER | PARER | OVER | ЪRY |
| 0           | 1    | 1    | 0  | 0    | 0     | 0    | 0   |

| Bits | Name  | Description                                                                                                                                                                                                                                                                                 | RW |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 7    | FIFOE | FIFO Error Status. (FIFO mode only)                                                                                                                                                                                                                                                         | R  |
|      |       | FIFOE is set when there is at least one kind of receive error (parity,                                                                                                                                                                                                                      |    |
|      |       | frame, overrun, break) for any of the characters in receive buffer. FIFOE                                                                                                                                                                                                                   |    |
|      |       | is reset when all error characters are read out of the buffer.                                                                                                                                                                                                                              |    |
|      |       | During DMA transfer, the error interrupt generates when FIFOE is 1, and<br>no receive DMA request generates even when data in receive buffer<br>reaches the trigger threshold until all the error characters are read out. In<br>non-DMA mode, FIFOE set does not generate error interrupt. |    |



|     |       | 0: No error data in receive buffer or non-FIFO mode                             |   |
|-----|-------|---------------------------------------------------------------------------------|---|
|     |       | 1: One or more error character in receive buffer                                |   |
| 6   |       |                                                                                 | Р |
| 6   | TEMP  | Transmit Holding Register Empty.                                                | R |
|     |       | Set when both UTHR and shift register are empty. It is cleared when             |   |
|     |       | either the UTHR or the shift register contains a data character.                |   |
|     |       | 0: There is data in the transmit shifter and UTHR                               |   |
|     |       | 1: All the data in the transmit shifter and UTHR has been shifted out           |   |
| 5   | TDRQ  | Transmit Data Request.                                                          | R |
|     |       | Set when UTHR has half or more empty location (FIFO mode) or empty              |   |
|     |       | (non-FIFO mode).                                                                |   |
|     |       | When both UIER.TDRIE and TDRQ are 1, transmit data request interrupt            |   |
|     |       | generates or during DMA transfer, DMA request to the DMA controller             |   |
|     |       | generates when UIER.TDRIE is 0 and TDRQ is 1.                                   |   |
|     |       | 11                                                                              |   |
|     |       | 0: There is one (non-FIFO mode) or more than half data (FIFO mode) in           |   |
|     |       | UTHR                                                                            |   |
|     |       | 1: None data (non-FIFO mode) or half or less than half data (FIFO mode)         |   |
|     |       | in UTHR                                                                         |   |
| 4   | BI    | Break Interrupt.                                                                | R |
|     |       | BI is set when the received data input is held low for longer than a            |   |
|     |       | full-word transmission time (the total time of start bit + data bits + parity   |   |
|     |       | bit + stop bits). BL is cleared when the processor reads the ULSR. In           |   |
|     |       | FIFO mode, only one character equal to 0x00 is loaded into the FIFO             |   |
|     |       | regardless of the length of the break condition. BI shows the break             |   |
|     |       | condition for the character at the front of the FIFO, not the most recently     |   |
|     | P     | received character.                                                             |   |
|     | 20-   | 0: No break signal has been received                                            |   |
| 1   | Olic  | 1: Break signal received                                                        |   |
| 3   | FMER  | Framing Error.                                                                  | R |
|     |       | Set when the bit following the last data bit or parity bit is detected to be 0. |   |
|     |       | If the ULCR had been set for two or one and half stop bits, the other stop      |   |
|     |       | bits are not checked except the first one. In FIFO mode, FMER shows a           |   |
|     |       | framing error for the character at the front of the receive buffer, not for the |   |
|     |       | most recently received character.                                               |   |
|     |       | Cleared when the processor reads the ULSR.                                      |   |
|     |       | 0: No framing error                                                             |   |
|     |       | 1: Invalid stop bit has been detected                                           |   |
| 2   | PARER | Parity Error.                                                                   | R |
| _   |       | Indicates that the received data character does not have the correct even       |   |
|     |       | or odd parity, as selected by the even parity select bit. PARER is set          |   |
|     |       | upon detection if a parity error and is cleared when the processor reads        |   |
|     |       | the ULSR. In FIFO mode, PARER shows a parity error for the character            |   |
| 220 |       |                                                                                 |   |

228



|       |         | at the front of the EIEO, not the most recently received observator        |   |
|-------|---------|----------------------------------------------------------------------------|---|
|       |         | at the front of the FIFO, not the most recently received character.        |   |
|       |         | 0: No parity error                                                         |   |
|       |         | 1: Parity error has occurred                                               |   |
| 1     | OVER    | Overrun Error.                                                             | R |
|       |         | Set when both receive buffer and shifter are full and new data is received |   |
|       |         | which will be lost.                                                        |   |
|       |         | Cleared when the processor reads the ULSR.                                 |   |
|       |         | 0: No data has been lost                                                   |   |
|       |         | 1: Receive data has been lost                                              |   |
| 0     | DRY     | Data Ready.                                                                | R |
|       |         | Set when a complete incoming character has been received into the          |   |
|       |         | Receive Buffer registers. DRY is cleared when the receive buffer is read   |   |
|       |         | (non-FIFO mode) or when the buffer is empty or when the buffer is reset    |   |
|       |         | by setting UFCR.RFRT to 1.                                                 |   |
|       |         | 0: No data has been received                                               |   |
|       |         | 1: Data is available in URBR                                               |   |
|       | -       | - <u> </u>                                                                 |   |
|       |         | 1 45                                                                       |   |
| 3.2.9 | UART Mo | dem Control Register (UMCR)                                                |   |

#### 8.2.9 UART Modem Control Register (UMCR)

The UMCR uses the modem control pins RTS\_ and CTS\_ to control the interface with a modem or data set. UMCR also controls the loopback mode. Loopback mode must be enabled before the UART 7.6. com is enabled.

| UMCR0, UMCR1, UMCR2, UMCR3 | 2 |
|----------------------------|---|
|----------------------------|---|

#### 0x10030010, 0x10031010, 0x10032010, 0x10033010



#### RST

Bit

| Bits | Name     | Description                                                                 | RW |  |  |
|------|----------|-----------------------------------------------------------------------------|----|--|--|
| 7    | MDCE     | Modem Control Enable.                                                       | W  |  |  |
|      |          | : Modem function is disabled                                                |    |  |  |
|      |          | 1: Modem function is enabled                                                |    |  |  |
| 6    | FCM      | Flow Control Mode.                                                          |    |  |  |
|      |          | 0: Flow control by software                                                 |    |  |  |
|      |          | 1: Flow control by hardware                                                 |    |  |  |
| 5    | Reserved | Writing has no effect, read as zero.                                        | R  |  |  |
| 4    | LOOP     | Loop Back.                                                                  | W  |  |  |
|      |          | This bit is used for diagnostic testing of the UART. When LOOP is 1, TXD    |    |  |  |
|      |          | output pin is set to a logic 1 state, RXD is disconnected from the pin, and |    |  |  |
|      |          | the output of the transmitter shifter register is looped back into the      |    |  |  |

|     |          | receiver shift register input internally, similar to CTS_ and RTS_ pins and<br>the RTS bit of the UMCR is connected to CTS bit of UMSR respectively.<br>Loopback mode must be selected before the UART is enabled. |   |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|     |          | 0: Normal operation mode                                                                                                                                                                                           |   |
|     |          | 1: Loopback-mode UART operation                                                                                                                                                                                    |   |
| 3:2 | Reserved | Writing has no effect, read as zero.                                                                                                                                                                               | R |
| 1   | RTS      | Request To Send.                                                                                                                                                                                                   | W |
|     |          | This bit can control the RTS_ output state.                                                                                                                                                                        |   |
|     |          | 0: RTS_ force to high                                                                                                                                                                                              |   |
|     |          | 1: RTS_ force to low                                                                                                                                                                                               |   |
| 0   | Reserved | Writing has no effect, read as zero.                                                                                                                                                                               | R |

#### 8.2.10 UART Modem Status Register (UMSR)

The read-only UMSR provides the current state of the control lines from the modem to the processor. They are cleared when the processor reads UMSR.

#### UMSR0, UMSR1, UMSR2, UMSR3

#### 0x10030018, 0x10031018, 0x10032018, 0x10033018



#### RST

Bit

| Bits | Name     | Description                                                              | RW |
|------|----------|--------------------------------------------------------------------------|----|
| 7:5  | Reserved | Writing has no effect, read as zero.                                     | R  |
| 4    | CTS      | Status of Clear To Send.                                                 | R  |
|      |          | When MDCE bit is 1, this bit is the complement of CTS_input. If Loop bit |    |
|      |          | of UMCR is 1, this bit is equivalent to RTS bit of UMCR.                 |    |
|      |          | 0: CTS_ pin is 1                                                         |    |
|      |          | 1: CTS_ pin is 0                                                         |    |
| 3:1  | Reserved | Writing has no effect, read as zero.                                     | R  |
| 0    | CCTS     | Change status of CTS                                                     | R  |
|      |          | When MDCE bit is 1, this bit indicates the state change on CTS_ pin.     |    |
|      |          | 0: No state change on CTS_ pin since last read of UMSR                   |    |
|      |          | 1: A change occurs on the state of CTS_ pin                              |    |

#### 230





#### 8.2.11 UART Scratchpad Register

This Scratchpad register is used as a scratch register for the programmer and has no effect on the UART.

#### 0x1003001C, 0x1003101C, 0x1003201C, USPR0, USPR1, USPR2, USPR3 0x1003301C 7 6 5 4 3 2 1 0 Bit Scratch Data RST ? ? ? ? ? ? ? ?

#### 8.2.12 Infrared Selection Register (ISR)

The ISR is used to configure the slow-infrared (SIR) interface that is provided in each UART to support two-way wireless communication using infrared transmission that conforms to the IrDA serial infrared specification 1.1. The maximum frequency is up to 115.2kbps.

| ISR0, ISR1, ISR2, ISR3 | 0x10030020, 0x10031020, 0x10032020, 0x10033020        |
|------------------------|-------------------------------------------------------|
| Bit                    | 7 6 5 4 3 2 1 0                                       |
|                        | Reserved<br>RDPL<br>TDPL<br>XMODE<br>RCVEIR<br>XMITIR |
| RST                    | 0 0 0 0 0 0 0 0                                       |

#### RST

| Bits | Name     | Description                                                                | RW |
|------|----------|----------------------------------------------------------------------------|----|
| 7:5  | Reserved | Writing has no effect, read as zero.                                       | R  |
| 4 🔨  | RDPL     | Receive Data Polarity.                                                     | W  |
|      |          | 0: Slow-infrared (SIR) interface decoder takes positive pulses as zeros    |    |
|      |          | 1: SIR decoder takes negative pulses as zeros                              |    |
| 3    | TDPL     | Transmit Data Polarity.                                                    | W  |
|      |          | 0: SIR encoder generates a positive pulse for a data bit of zero           |    |
|      |          | 1: SIR encoder generates a negative pulse for a data bit of zero           |    |
| 2    | XMODE    | Transmit Pulse Width Mode.                                                 | W  |
|      |          | Set when the transmit encoder needs to generate 1.6us pulses (that are     |    |
|      |          | 3/16 of a bit-time at 115.2 kbps).                                         |    |
|      |          | Cleared when the transmit encoder needs to generate 3/16 of a bit-time     |    |
|      |          | wide according to current baud rate.                                       |    |
|      |          | 0: Transmit pulse width is 3/16 of a bit-time wide                         |    |
|      |          | 1: Transmit pulse width is 1.6 us                                          |    |
| 1    | RCVEIR   | Receiver SIR Enable.                                                       | W  |
|      |          | This bit is used to select the signal from the RXD pin is processed by the |    |

| 君正      |
|---------|
| Ingenic |

| - |        |                                                                                 |   |
|---|--------|---------------------------------------------------------------------------------|---|
|   |        | IrDA decoder before it is fed to the UART (RCVEIR = 1) or bypass IrDA           |   |
|   |        | decoder and is fed directly to the UART (RCVEIR = 0).                           |   |
|   |        | 0: Receiver is in UART mode                                                     |   |
|   |        | 1: Receiver is in SIR mode                                                      |   |
| 0 | XMITIR | Transmitter SIR Enable.                                                         | W |
|   |        | This bit is used to select TXD output pin is processed by the IrDA              |   |
|   |        | encoder before it is fed to the device pin (XMITIR = 1) or bypass IrDA          |   |
|   |        | encoder and is fed directly to the device pin (XMITIR = 0).                     |   |
|   |        | <b>NOTE:</b> disable infrared LED before XMITIR is set, otherwise a false start |   |
|   |        | bit may occur.                                                                  |   |
|   |        | 0: Transmitter is in UART mode                                                  |   |
|   |        | 1: Transmitter is in SIR mode                                                   |   |

#### 8.2.13 UART M Register (UMR)

ed only

UMR0, UMR1, UMR2, UMR3 Bit



| _ | 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|----------|---|---|---|---|---|---|
|   |   | Reserved |   |   |   | М |   |   |
|   | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 0 |

RST

M is the value of UMR register, 0

It will take UART at least M cycles to transmit or receive one bit. It will take UART at most M+1 cycles to transmit or receive one bit.

## 8.2.14 UART Add Cycle Register (UACR)



If nth bit of the register is 1, it will take UART M+1 cycles to transmit or receive the bit of date. If the register is 12'h0, UART will receive or transmit a bit by M cycle(s). If the register is 12'hfff, UART will receive or transmit a bit by M+1 cycle(s). For the detail to see <u>For any frequency clock to use the Uart.</u>

232

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



#### 8.3 Operation

The following sections describe the UART operations that include flow of configuration, data transmission, data reception, and Infrared mode.

#### 8.3.1 UART Configuration

Before UART starts to transfer data or changing transfer format, configuration must be done to define the transfer format. The sample flow is as the following:

In FIFO mode, set FME bit of UFCR to 1, reset receive and transmit FIFO, then initialize the UART as described below:

- 1 Clear UFCR.UME to 0.
- 2 Set value in UDLL/UDHR to generate the baud rate clock.
- 3 Set data format in ULCR.
- 4 If it is in FIFO MODE, set FME bit and other FIFO control in UFCR, reset receive and transmit FIFO, otherwise skip item 4.
- 5 Set each interrupt enable bit in UIER in interrupt-based transfer or set UFCR.DME in DMA-based transfer (DMA transfer is FIFO mode only), then set UFCR.UME. terna

#### 8.3.2 Data Transmission

After configuration, UART is ready for data transfer. For data transmission, refer to the following procedure:

- Read ULSR.TDRQ (interrupt disable) or wait for transmit data request interrupt (interrupt 1 enable), if TDRQ = 1 or transmit data request interrupt generates, that means there is enough empty location in UTHR for new data.
- 2 If ULSR.TDRQ is 1 or get the transmit data request interrupt, write transmit data to UTHR to start transmission.
- 3 Do item 1 and item 2 if there are more data waiting for transmit.
- 4 After all necessary data are written to UTHR, wait ULSR.TEMP = 1, that means all data completely transmitted.
- 5 If it is necessary to send break, set ULCR.SBK and at least wait for 1-bit interval time to send a valid break, then clear ULCR.SBK.
- 6 Clear UME bit to finish UART transmission.

#### 8.3.3 Data Reception

After configuration, UART is ready for data transfer. For data reception, refer to the following sample procedure:

- 1 Read ULSR.DRY (interrupt disable) or wait for receive data request interrupt (interrupt enable), if ULSR.DRY =1 or receive data request interrupt generates, that means URBR has one data (non-FIFO mode) or data in URBR reaches the trigger value. (FIFO mode)
- If ULSR.DRY = 1 or receive data request interrupt generates, then read ULSR.FIFOE or see if 2



there is error interrupt, if FIFOE = 1, it means received data has receive error, then go to error handler, other wise go to item 3.

- 3 Read one received data in URBR (non-FIFO mode) or data equal to trigger value in URBR. (FIFO mode)
- 4 Check whether all data received: check whether ULSR.DRY = 0, in FIFO mode and interrupt is enabled, timeout interrupt may generate, when timeout interrupt generates, read URBR till ULSR.DRY = 0.
- 5 Clear UFCR.UME to end data reception when all data are received and ULSR.DRY = 0.

#### 8.3.4 Receive Error Handling

A sample error handling flow is as the following:

- 1 If ULSR.FIFOE = 1, it means there is receive error in received data, then check what error it iternal used only is.
- If ULSR.OVER = 1, go to OVER error handling. 2
- 3 If ULSR.BI = 1, go to Break handling.
- 4 If ULSR.FMER = 1, go to Frame error handling.
- 5 If PARER = 1, go to PARER error handling.

#### 8.3.5 Modem Transfer

When UMCR.MDCE = 1, modem control is enabled. Transfer flow can be stopped and restarted by software through RTS\_ and CTS\_ pin. When UART transmitter detects low level on CTS\_ pin, it stops transmission and TxD pin goes to mark state after finishing transmitting the current character until it detects CTS pin goes back to high level. RTS pin is output to receiving UART and its state can be controlled by setting UMCR RTS bit, that is, setting UMCR.RTS to 1, RTS pin is low level output that means UART is ready to receive data, on the contrary, it means UART currently can't receive more data.

#### 8.3.6 DMA Transfer

UART can operate in DMA-based (UFCR.DME = 1, FIFO mode only), that is, dma request initiated by UART takes the place of interrupt request and transmission/reception is carried out using DMA instead of CPU. Be sure that software guarantee to disable transmit and receive interrupt except timeout and error interrupts.

During DMA transfer, if an interrupt occurs, software must first read the ULSR to see if an error interrupt exists, then check the UIIR for the source of the interrupt and if DMA channel is already halt because of the error indicator from UART, then disable DMA channel and read out all the error data from receive FIFO. Software re-set and re-enable DMA and data transfer by DMA will re-start.

#### JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

234



#### 8.3.7 Slow IrDA Asynchronous Interface

Each UART supports slow infra-red (SIR) transmission and reception by setting ISR.XMITIR and ISR.RCVEIR to 1 (make sure the two bits are not set to 1 at the same time because SIR can't operate full-duplex). According to the IrDA 1.1, data rate is limited at a maximum value of 115.2Kbps.

In SIR transmit mode, the transmit pulse comes out at a rate of 3/16 (when the transmit data bit is zero); in SIR receive mode, the receiver must detect the 3/16 pulsed period to recognize a zero value (an active high or low pulse is demodulation to 0, and no pulse is demodulation to 1).

Compared to normal UART, there are some limitations to SIR, that is, each character is fixed to 8-bit data width, no parity and 1 stop bit and modem function is ignored. The IrDA 1.1 specifies a minimum 10ms latency after an optical node ceases transmitting before its receiver recovers its receiving function and software must guarantee this delay.

In the IrDA 1.1 specification, communication must start up at the rate of 9600bps, but then allows the link to negotiate higher (or lower) data rates if supported by both ends. However, the communication rate will not automatically change. Change, if necessary, is performed by software.

#### 8.3.8 For any frequency clock to use the UART

**NOTE:** if you don't set M register and UACR the UART work at normal mode with the specified frequencies. To use other frequency you should to set M register and UACR to right value.

#### 1 The Improving

Following changes are made:

- a One bit is composed by M CLK<sub>BR</sub> cycles, which can be 4~1024.
- b Some extra CLK<sub>BR</sub> cycles can be inserted in some bits in one frame, so that like M has fraction.

```
For instance:
```

```
CLK_{BR} = CLK_{DEV} / N \qquad N = 1, 2, \dotsCLK_{BR} = CLK_{DEV} = 4MHzBand rate = 460800
In accurateM_a = 8.681We take
```

M = 8, with 8 extra cycles in every frame



A 12-bit register is used to indicate where to insert the extra cycles. The first line is the time expected The second line is the time actual The third line is the time error



For transmission, in theory, the biggest error is half of CLKBR cycle, which is 0.125us here. 1@126.com ir

#### 2 To set UMR register

CLK<sub>BR</sub> = CLK<sub>DEV</sub> / N

M<sub>a</sub>= CLK<sub>BR</sub>/band rate M is modem of Ma

Write M to Mregister.

Considering the power and the robust quality, for M form 6 to 32 is you better select by set the UDLR.

The max error

$$\frac{0.5 / CLK_{BR}}{M_a / CLK_{BR}} = 0.5 / M_a < 0.5 / M$$

| М               | 4     | 8     | 16     | 32    | 64    |
|-----------------|-------|-------|--------|-------|-------|
| $error/W_{bit}$ | 12.5% | 6.25% | 3.125% | 1.56% | 0.78% |

#### 3 To set UACR value

For each bit of it means:

0: means not to add additional cycle to the bit that UART is prepare to transmit or receive, in another word, you will to use M cycles to transmit or receive the bit

236

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



1: means to add additional cycle to the bit that UART is prepare to transmit or receive, in another word, you will to use M+1 cycles to transmit or receive the bit

To set UACR value you must ensure that the max error of each bit should be less than  $0.5P_{BR}$ . For example:  $M_a$ -M =0.15; M+1- $M_a$ =0.85;

Write 8 to UMR,

Write 0x408 to UACR

| cycle/bit | : | Μ, | Μ, | Μ, | M+1, | Μ, | Μ, | Μ, | Μ, | Μ, | Μ, | M+1, | Μ |
|-----------|---|----|----|----|------|----|----|----|----|----|----|------|---|
| UACR      | : | 0  | 0  | 0  | 1    | 0  | 0  | 0  | 0  | 0  | 0  | 1    | 0 |

Long-eiffel@126.com internal used only



## 9 Smart Card Controller

#### 9.1 **Overview**

Smart Card Controller (SCC) interface is a primary device and communications interface for kinds of IC cards. The SCC interface supports communication with smart cards as specified in standard ISO7816-3. There are two SCC interfaces integrated in this SOC. And they perform the same functions. The SCC interface supports T=0 and T=1 protocol defined in ISO7816-3.

Software controls the session between the SCC interface and the card by SCC registers. Choosing protocol type and parameters, receiving and sending a byte to/from the card, activating/deactivating the card, and similar operations are accomplished with read/write operations to SCC registers. Transforming byte convention (inverse to direct and vice-versa, according to the session convention) is performed within SCC. Hence, software does not have to perform format inversion before character receipt. The SCC interface provides functionality to support the above standards, but it is the internal used responsibility of software to ensure the standards are met.

Features:

- Supports normal card and UIM card •
- 8-bit, 16-level receive-/transmit- FIFO
- Supports asynchronous character (T=0) communication modes •
- Supports asynchronous block (T=1) communication modes
- Supports setting of clock-rate conversion factor F (372, 512, 558, etc.), and bit-rate adjustment • factor D (1, 2, 4, 8, 16, 32, 12, 20, etc.)
- Supports extra guard time waiting •
- Auto-error detection in T=0 receive mode •
- Auto-character repeat in T=0 transmit mode
- Transforms inverted format to regular format and vice versa •
- Support stop clock function in some power consuming sensitive applications



### 9.2 Pin Description

### **Table 9-1 Smart Card Controller Pins Description**

| Name    | I/O          | Description                            |
|---------|--------------|----------------------------------------|
| SCC_CLK | Output       | Serial clock connects SCC and the card |
| SCC_DAT | Input/Output | Data communication pin                 |

Long\_eiffel@126.com internal used only



### **Register Description** 9.3

| Name    | RW | Reset Value | Address    | Access Size |
|---------|----|-------------|------------|-------------|
| SCCDR   | RW | 0x??        | 0x10041000 | 8           |
| SCCFDR  | R  | 0x00        | 0x10041004 | 8           |
| SCCCR   | RW | 0x0000000   | 0x10041008 | 32          |
| SCCSR   | RW | 0x8000      | 0x1004100C | 16          |
| SCCTFR  | RW | 0x0173      | 0x10041010 | 16          |
| SCCEGTR | RW | 0x00        | 0x10041014 | 8           |
| SCCECR  | RW | 0x0000000   | 0x10041018 | 32          |
| SCCRTOR | RW | 0x00        | 0x1004101C | 8           |

### Table 9-2 Smart Card Controller Registers Description

### 9.3.1 Transmit/Receive FIFO Data Register (SCCDR)



| Bits | Name | csel                  | Description | RW |
|------|------|-----------------------|-------------|----|
| 7:0  | DR   | Data port of HW FIFO. |             | RW |

### 9.3.2 FIFO Data Count Register (SCCFDR)

|     | SCCFDR |   |          |   |   | <b>0</b> x | 100 | 941 | 004 |
|-----|--------|---|----------|---|---|------------|-----|-----|-----|
| Bit |        | 7 | 6        | 5 | 4 | 3          | 2   | 1   | 0   |
|     |        |   | Reserved |   |   |            | R   |     |     |
| RSI |        | 0 | 0        | 0 | 0 | 0          | 0   | 0   | 0   |

| Bits | Name     | Description                          | RW |
|------|----------|--------------------------------------|----|
| 7:5  | Reserved | Writing has no effect, read as zero. | R  |
| 4:0  | R        | Characters resisted in FIFO.         | R  |

<sup>240</sup> 

JZ4770 Mobile Application Processor Peripherals Programming Manual



### 9.3.3 Control Register (SCCCR)

|     | SC   | CC  | R   |    |          |    |    |      |       |    |    |          |    |    |    |    |    |      |      |      |        |       |      |      |       |      |   |          | 0x    | 100 | )41( | 800    |
|-----|------|-----|-----|----|----------|----|----|------|-------|----|----|----------|----|----|----|----|----|------|------|------|--------|-------|------|------|-------|------|---|----------|-------|-----|------|--------|
| Bit | 31   | 30  | 29  | 28 | 27       | 26 | 25 | 24   | 23    | 22 | 21 | 20       | 19 | 18 | 17 | 16 | 15 | 14   | 13   | 12   | 11     | 10    | 9    | 8    | 7     | 6    | 5 | 4        | 3     | 2   | 1    | 0      |
|     | SCCE | TRS | T2R |    | Reserved |    |    | יכוא | FLUSH |    |    | Reserved |    |    |    | פא | ЦЪ | CONV | TXIE | RXIE | TENDIE | RTOIE | ECIE | EPIE | RETIE | EOIE |   | Reseived | TSEND | Ň   | < L  | CLKSTP |
| RST | 0    | 0   | 0   | 0  | 0        | 0  | 0  | 0    | 0     | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0    | 0      | 0     | 0    | 0    | 0     | 0    | 0 | 0        | 0     | 0   | 0    | 0      |

| Bits  | Name     |       |                                                                       | Description                                             | RW |  |  |  |  |
|-------|----------|-------|-----------------------------------------------------------------------|---------------------------------------------------------|----|--|--|--|--|
| 31    | SCCE     | Enab  | oles or disables                                                      | SCC. When disable it, the SCC_CLK will be stopped.      | RW |  |  |  |  |
| 30    | TRS      | Tran  | smit or Receiv                                                        | e Select. 0: Reception mode; 1: Transmission mode.      | RW |  |  |  |  |
| 29    | T2R      | Auto  | to-T2R support. T2R means Transmit turn to Reception. 0: controlled R |                                                         |    |  |  |  |  |
|       |          | by S  | SW; 1: controlled by HW.                                              |                                                         |    |  |  |  |  |
| 28:26 | Reserved | Writi | /riting has no effect, read as zero.                                  |                                                         |    |  |  |  |  |
| 25:24 | FDIV     | Freq  | uency Divider                                                         | Select.                                                 | RW |  |  |  |  |
|       |          |       |                                                                       | SCC_CLK frequency                                       |    |  |  |  |  |
|       |          |       | 00                                                                    | Same as device clk                                      |    |  |  |  |  |
|       |          |       | 01                                                                    | Half of device clk                                      |    |  |  |  |  |
|       |          |       | 10                                                                    | 1/4 of device clk                                       |    |  |  |  |  |
|       |          |       | 11                                                                    | Reserved                                                |    |  |  |  |  |
| 23    | FLUSH    | Flush | n FIFO. 0: Doe                                                        | s not empty the Rx/Tx FIFO; 1: Empty the Rx/Tx FIFO.    | RW |  |  |  |  |
| 22:18 | Reserved | Writi | ng has no effe                                                        | ct, read as zero.                                       | R  |  |  |  |  |
| 17:16 | TRIG     | Rece  | eive/Transmit F                                                       | FIFO trigger.                                           | RW |  |  |  |  |
|       |          | . 58  | e v                                                                   | Trigger Value                                           |    |  |  |  |  |
|       | 0        | 77    | 00                                                                    | 1                                                       |    |  |  |  |  |
|       | ong_e    |       | 01                                                                    | 4                                                       |    |  |  |  |  |
| 1     | 01,0     |       | 10                                                                    | 8                                                       |    |  |  |  |  |
| -     |          |       | 11                                                                    | 14                                                      |    |  |  |  |  |
| 15    | TP       | Com   | municate proto                                                        | ocol. 0: (T=0); 1: (T=1).                               | RW |  |  |  |  |
| 14    | CONV     | Card  | data transfer                                                         | convention. 0: LSB first; 1: MSB first and inverted.    | RW |  |  |  |  |
| 13    | TXIE     | Tx F  | IFO counter m                                                         | eets the trigger value interrupt enable bit.            | RW |  |  |  |  |
| 12    | RXIE     | Rx F  | IFO counter m                                                         | eets the trigger value interrupt enable bit.            | RW |  |  |  |  |
| 11    | TENDIE   | Tran  | smission finish                                                       | ed interrupt enable bit. (Both FIFO and transmitter are | RW |  |  |  |  |
|       |          | empt  | ty)                                                                   |                                                         |    |  |  |  |  |
| 10    | RTOIE    | Rece  | eption timeout                                                        | interrupt enable bit.                                   | RW |  |  |  |  |
| 9     | ECIE     | ETU   | counter overfl                                                        | ow interrupt enable bit.                                | RW |  |  |  |  |
| 8     | EPIE     | Parit | y error interrup                                                      | ot enable bit.                                          | RW |  |  |  |  |
| 7     | RETIE    | Re-tr | ansmitting 3 ti                                                       | mes interrupt enable bit.                               | RW |  |  |  |  |
| 6     | EOIE     | Rece  | ceive overrun error interrupt enable bit.                             |                                                         |    |  |  |  |  |
| 5:4   | Reserved | Writi | ng has no effe                                                        | ct, read as zero.                                       | R  |  |  |  |  |



| TSEND  |              | C C                                                     | RW                                                                                                                                                                                                     |
|--------|--------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PX     | Parameter X. | SCC stop clock mode selection.                          | RW                                                                                                                                                                                                     |
|        |              | SCC clock stop                                          |                                                                                                                                                                                                        |
|        | 00           | Does not support SCC clock stop                         |                                                                                                                                                                                                        |
|        | 01           | SCC_CLK stops at state low                              |                                                                                                                                                                                                        |
|        | 10           | SCC_CLK stops at state high                             |                                                                                                                                                                                                        |
|        | 11           | Reserved                                                |                                                                                                                                                                                                        |
| CLKSTP |              |                                                         | RW                                                                                                                                                                                                     |
|        | PX           | received; 1: TPXParameter X.00011011CLKSTPSCC clock std | PX     Parameter X. SCC stop clock mode selection.       00     Does not support SCC clock stop       01     SCC_CLK stops at state low       10     SCC_CLK stops at state high       11     Reserved |

### 9.3.4 Status Register (SCCSR)



| Bits  | Name     | COMDescription                                                     | RW |
|-------|----------|--------------------------------------------------------------------|----|
| 15    | TRANS    | Transfer status. Specifies whether the transfer is stopped or not. | R  |
| 14:13 | Reserved | Writing has no effect, read as zero.                               | R  |
| 12    | ORER     | Receive overrun error.                                             | RW |
| 11    | RTO 📀    | Reception timeout.                                                 | R  |
| 10    | PER      | Parity error.                                                      | RW |
| 9     | TFTG     | Hit Tx FIFO trigger.                                               | R  |
| 8     | RFTG     | Hit Rx FIFO trigger.                                               | R  |
| 7     | TEND     | Transmission end. Both Tx FIFO and transmitter are empty.          | RW |
| 6:5   | Reserved | Writing has no effect, read as zero.                               | R  |
| 4     | RETR_3   | Re-transmit exceed 3 times.                                        | RW |
| 3:1   | Reserved | Writing has no effect, read as zero.                               | R  |
| 0     | ECNTO    | ETU counter overflow.                                              | RW |

### 242

### 9.3.5 Transmission Factor Register (SCCTFR)

| SCCTFR |    |    |          |    |    |    |   |   |   |   |    |   | <b>0</b> x | 100 | 41 | 010 |
|--------|----|----|----------|----|----|----|---|---|---|---|----|---|------------|-----|----|-----|
| Bit    | 15 | 14 | 13       | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4 | 3          | 2   | 1  | 0   |
|        |    |    | Reserved |    |    |    |   |   |   |   | FD |   |            |     |    |     |
| RST    | 0  | 0  | 0        | 0  | 0  | 0  | 0 | 1 | 0 | 1 | 1  | 1 | 0          | 0   | 1  | 1   |

| Bits  | Name     | Description                                    | RW |
|-------|----------|------------------------------------------------|----|
| 15:11 | Reserved | Writing has no effect, read as zero.           | R  |
| 10:0  | FD       | Value of F/D. The initial value is 0x173(371). | RW |

### 9.3.6 Extra Guard Timer Register (SCCEGTR)

## SCCEGTR 0x10041014 Bit 7 6 5 4 3 2 1 0 RST 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</

| Name | Description                                                                                                      | RW                                                                            |
|------|------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| EGTR | The register is corresponding with N value of ISO7816-3. Which indicates the extra-guard time of a transmission? | RW                                                                            |
|      | EGTR                                                                                                             | EGTR The register is corresponding with N value of ISO7816-3. Which indicates |

### 9.3.7 ETU Counter Value Register (SCCECR)

|     | sc       | CE | CR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x | 100 | 41( | 018 |
|-----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|------------|-----|-----|-----|
| Bit | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2   | 1   | 0   |
|     | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | E  | С  |    |    |    |   |   |   |   |   |   |            |     |     |     |
| RST | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0          | 0   | 0   | 0   |

| Bits  | Name     | Description                                                                 | RW |
|-------|----------|-----------------------------------------------------------------------------|----|
| 31:20 | Reserved | Writing has no effect, read as zero.                                        | R  |
| 19:0  | EC       | ETU counter. Write operation will clear the internal counter automatically. | RW |



### 9.3.8 Reception Timeout Register (SCCRTOR)

| SCCRTOS |   |   |   |   | <b>0</b> x | 100 | 410 | 01C |
|---------|---|---|---|---|------------|-----|-----|-----|
| Bit     | 7 | 6 | 5 | 4 | 3          | 2   | 1   | 0   |
|         |   |   |   | R | го         |     |     |     |
| RST     | 0 | 0 | 0 | 0 | 0          | 0   | 0   | 0   |

| Bits | Name | Description                             | RW |
|------|------|-----------------------------------------|----|
| 7:0  | RTO  | Retry times when parity error detected. | RW |

Long\_eiffel@126.com internal used only



### **TS Slave Interface (TSSI)** 10

### 10.1 Overview

The TS Slave Interface (TSSI) in JZ4770 is used to connect DTV Demodulator. It supports MPEG-2 Transport Stream (TS) as its input.

Features:

- Support both parallel mode and serial mode for TS data transfer •
- TSDI0 or TSDI7 can be used to transfer data in serial mode .
- The order of data in one byte supports LSB at first or MSB at first •
- The order of data in one word supports LSB at first or MSB at first .
- .
- •
- .
- Up to 33 PID filters can be used when PID filtering function is enabled USEd Support adding data 0 before or after transport stream Support master DMA transmission s enable •
- .

246



### **10.2 Pin Description**

### Table 10-1 TSSI Pin Description

| Name    | I/O | Description             |
|---------|-----|-------------------------|
| TSDI0~7 | I   | TS data bus             |
| TSFAIL  | I   | TS packet uncorrectable |
| TSCLK   | I   | TS clock                |
| TSFRM   | I   | TS data valid           |
| TSSTR   | 1   | TS packet start         |

Long-eiffel@126.com internal used only



### **10.3 Register Description**

In this section, we will describe the registers in TSSI. Following table lists all the register definitions. All registers' 32bit addresses are physical addresses. And detailed function of each register will be described below.

| Name    | Description                    | RW | Reset Value | Address    | Access Size |
|---------|--------------------------------|----|-------------|------------|-------------|
| TSENA   | TSSI Enable Register           | RW | 0x08        | 0x134E0000 | 8           |
| TSCFG   | TSSI Configure Register        | RW | 0x04FF      | 0x134E0004 | 16          |
| TSCTRL  | TSSI Control Register          | RW | 0x03        | 0x134E0008 | 8           |
| TSSTAT  | TSSI State Register            | RW | 0x00        | 0x134E000C | 8           |
| TSFIFO  | TSSI FIFO Register             | R  | 0x????????  | 0x134E0010 | 32          |
| TSPEN   | TSSI PID Enable Register       | RW | 0x00000000  | 0x134E0014 | 32          |
| TSNUM   | TSSI Data Number Register      | RW | 0x00        | 0x134E0018 | 801         |
| TSDTR   | TSSI Data Trigger Register     | RW | 0x7F        | 0x134E001C | 8           |
| TSPID0  | TSSI PID Filter Register 0     | RW | 0x0000000   | 0x134E0020 | 32          |
| TSPID1  | TSSI PID Filter Register 1     | RW | 0x0000000   | 0x134E0024 | 32          |
| TSPID2  | TSSI PID Filter Register 2     | RW | 0x00000000  | 0x134E0028 | 32          |
| TSPID3  | TSSI PID Filter Register 3     | RW | 0x00000000  | 0x134E002C | 32          |
| TSPID4  | TSSI PID Filter Register 4     | RW | 0x00000000  | 0x134E0030 | 32          |
| TSPID5  | TSSI PID Filter Register 5     | RW | 0x00000000  | 0x134E0034 | 32          |
| TSPID6  | TSSI PID Filter Register 6     | RW | 0x00000000  | 0x134E0038 | 32          |
| TSPID7  | TSSI PID Filter Register 7     | RW | 0x00000000  | 0x134E003C | 32          |
| TSPID8  | TSSI PID Filter Register 8     | RW | 0x00000000  | 0x134E0040 | 32          |
| TSPID9  | TSSI PID Filter Register 9     | RW | 0x00000000  | 0x134E0044 | 32          |
| TSPID10 | TSSI PID Filter Register 10    | RW | 0x00000000  | 0x134E0048 | 32          |
| TSPID11 | TSSI PID Filter Register 11    | RW | 0x0000000   | 0x134E004C | 32          |
| TSPID12 | TSSI PID Filter Register 12    | RW | 0x00000000  | 0x134E0050 | 32          |
| TSPID13 | TSSI PID Filter Register 13    | RW | 0x00000000  | 0x134E0054 | 32          |
| TSPID14 | TSSI PID Filter Register 14    | RW | 0x0000000   | 0x134E0058 | 32          |
| TSPID15 | TSSI PID Filter Register 15    | RW | 0x00000000  | 0x134E005C | 32          |
| TSDDA   | TSSI DMA Descriptor Address    | RW | 0x00000000  | 0x134E0060 | 32          |
| TSDTA   | TSSI DMA Target Address        | R  | 0x0000000   | 0x134E0064 | 32          |
| TSDID   | TSSI DMA Identifier            | R  | 0x0000000   | 0x134E0068 | 32          |
| TSDCMD  | TSSI DMA Command               | R  | 0x0000000   | 0x134E006C | 32          |
| TSDST   | TSSI DMA Status                | RW | 0x0000000   | 0x134E0070 | 32          |
| TSTC    | TSSI Transfer Control Register | RW | 0x00000000  | 0x134E0074 | 32          |

Table 10-2 TSSI Register Description



### 10.3.1 TSSI Enable Register (TSENA)

The register TSENA is used to trigger TSSI to work.



| Bits | Name     | Description                                                           | RW |
|------|----------|-----------------------------------------------------------------------|----|
| 7    | SFT_RST  | TSSI FIFO software-reset. Set it to 1 and later it will be cleared by | RW |
|      |          | hardware auto.                                                        | 1  |
|      |          | 0: Stop reset                                                         | 3  |
|      |          | 1: Start reset                                                        |    |
| 6:5  | Reserved | Writing has no effect, read as zero.                                  | R  |
| 4    | FAIL     | 0:FAIL signal is decided by TSSI Demodulator $\sqrt{-\sqrt{V}}$       |    |
|      |          | 1:FAIL signal is equal to 1                                           |    |
| 3    | PEN_0    | Choose PID filter enable for PID=0                                    | RW |
|      |          | 0: not enable                                                         |    |
|      |          | 1: enable                                                             |    |
| 2    | PID_EN   | Enable / disenable the PID filtering function.                        | RW |
|      |          | 0: PID filtering function is not enabled                              |    |
|      |          | 1: PID filtering function is enabled                                  |    |
| 1    | DMA_EN 🟒 | Enable / disenable the DMA mode.                                      | RW |
|      | e e      | 0: DMA mode is not enabled (CPU only)                                 |    |
|      | ns-      | 1: DMA mode is enabled                                                |    |
| 0    | ENA      | Enable / disenable the TSSI module.                                   | RW |
|      |          | 0: TSSI is not enabled                                                |    |
|      |          | 1: TSSI is enabled                                                    |    |

248



### 10.3.2 TSSI Configure Register (TSCFG)

The register TSCFG is used to configure the TSSI.

| TSCFG |          |          |          |        |        |   |          |       | <b>0</b> x′ | 134     | E000                | 4 |
|-------|----------|----------|----------|--------|--------|---|----------|-------|-------------|---------|---------------------|---|
| Bit   | 16 15 14 | 13 12    | 11 10    | 9      | 8 7    | 6 | 5        | 4     | 3           | 2       | 1 0                 |   |
|       | F_TRIGV  | Reserved | TRANS_MD | EDN_WD | EDN_BT |   | TSCLK_CH | PARAL | TSCLK_P     | TSFRM_H | TSSTR_H<br>TSFAIL H |   |
| RST   | 0 0 0    | 0 0      | 1 0      | 0      | 1 1    | 1 | 1        | 1     | 1           | 1       | 1 0                 |   |

| DCT |
|-----|
| ROL |
|     |

| Bits  | Name                 |                               | Description                               | RW |
|-------|----------------------|-------------------------------|-------------------------------------------|----|
| 16:14 | F_TRIGV              | Specify the trigger           | value of FIFO.                            | RW |
|       |                      | F_TRIGV                       | Description                               |    |
|       |                      | 0                             | Trigger Value is 4                        |    |
|       |                      | 1                             | Trigger Value is 8                        |    |
|       |                      | 2                             | Trigger Value is 16                       |    |
|       |                      | 3                             | Trigger Value is 32                       |    |
|       |                      | 4                             | Trigger Value is 48                       |    |
|       |                      | 5                             | Trigger Value is 64                       |    |
|       |                      | 6                             | Trigger Value is 80                       |    |
|       |                      | 7                             | Trigger Value is 96                       |    |
|       |                      | Trigger value shoul           | d be greater than Expected Transfer Size. |    |
| 13:12 | Reserved             | Writing has no effe           | ct, read as zero.                         | R  |
| 11:10 | TRANS_MD             | Choose the mode of            | of adding data 0.                         | RW |
|       | 01                   | TRANS_MD                      | Description                               |    |
|       | ong_e1               | 0                             | Add data 0 before transport stream        |    |
| 1     | Olic                 | 1                             | Add data 0 after transport stream         |    |
|       |                      | 2                             | Do not add data 0                         |    |
|       |                      | 3                             | Reserved                                  |    |
| 9     | EDN_WD <sup>*1</sup> | The order of data ir          | ו word.                                   | RW |
| 8     | EDN_BT <sup>*1</sup> | The order of data ir          | n byte.                                   | RW |
| 7     | TSDI_H               | Choose the polarity           | v of TSDI0∼7.                             | RW |
|       |                      | 0: TSDI0~7 is activ           | e low                                     |    |
|       |                      | 1: TSDI0~7 is activ           | e high                                    |    |
| 6     | USE_0                | USE_0 is only used            | d in SERIAL mode (TSCFG.PARAL=0).         | RW |
|       |                      | 0: Use TSDI7 to tra           | insfer data                               |    |
|       |                      | 1: Use TSDI0 to tra           | insfer data                               |    |
| 5     | TSCLK_CH             | Choose how to use             | TSCLK.                                    | RW |
|       |                      | 0: When $f_{pclk} > 3f_{TSC}$ | CLK                                       |    |
|       |                      | 1: When $f_{pclk} > 2f_{TSC}$ |                                           |    |
| 4     | PARAL                | Choose the working            | g mode of TSSI.                           | RW |

JZ4770 Mobile Application Processor Peripherals Programming Manual



|                   | 1         |         |               |             |            |           |          |           |        |    |
|-------------------|-----------|---------|---------------|-------------|------------|-----------|----------|-----------|--------|----|
|                   |           | 0:      | Serial Mod    | de          |            |           |          |           |        |    |
|                   |           | 1:      | Parallel M    | ode         |            |           |          |           |        |    |
| 3                 | TSCLK_F   | P Tr    | nis bit is us | ed to dete  | rmine whic | h edge of | TSCLK is | used wher | n TSSI | RW |
|                   |           | is      | sampling of   | data.       |            |           |          |           |        |    |
|                   |           | 0:      | Use the n     | egative ed  | lge of TSC | LK        |          |           |        |    |
|                   |           | 1:      | Use the p     | ositive edg | ge of TSCL | .K        |          |           |        |    |
| 2                 | TSFRM_    | H Ch    | hoose the     | polarity of | TSFRM.     |           |          |           |        | RW |
|                   |           | 0:      | TSFRM is      | active lov  | v          |           |          |           |        |    |
|                   |           | 1:      | TSFRM is      | active hig  | Jh         |           |          |           |        |    |
| 1                 | TSSTR_H   | H Cł    | hoose the     | polarity of | TSSTR.     |           |          |           |        | RW |
|                   |           | 0:      | TSSTR is      | active low  | /          |           |          |           |        |    |
|                   |           | 1:      | TSSTR is      | active hig  | h          |           |          |           |        |    |
| 0                 | TSFAIL_I  | H Cł    | hoose the     | polarity of | TSFAIL.    |           |          |           |        | RW |
|                   |           | 0:      | TSFAIL is     | active low  | V          |           |          |           | 4      |    |
|                   |           | 1:      | TSFAIL is     | active hig  | h          |           |          |           | 14     |    |
|                   |           |         |               |             |            |           |          | sed (     |        |    |
| NOTE:             |           |         |               |             |            |           | 4        | ceu       |        |    |
| <sup>*1</sup> : E | END_BT ar | nd END_ | _WD in reg    | ister TSC   | FG.        |           | 1 U      |           |        |    |
|                   |           |         |               |             |            |           | 31       |           |        |    |
|                   | F         | Byte0   | Byte1         | Byte2       | Byte3      | Byte4     | Byte5    | Byte6     | Byte7  | 7  |

### NOTE:

|               |              |        |        |        | $\sim \sqrt{1}$ |        |        |        |  |
|---------------|--------------|--------|--------|--------|-----------------|--------|--------|--------|--|
|               | Byte0        | Byte1  | Byte2  | Byte3  | Byte4           | Byte5  | Byte6  | Byte7  |  |
|               | Bit0-7       | Bit0-7 | Bit0-7 | Bit0-7 | Bit0-7          | Bit0-7 | Bit0-7 | Bit0-7 |  |
|               |              |        | c C    | 01     |                 |        |        |        |  |
|               |              |        | D=0    | Byte0  | Byte1           | Byte2  | Byte3  |        |  |
| long          |              | ere    |        | Byte4  | Byte5           | Byte6  | Byte7  |        |  |
|               | err          |        |        |        |                 |        |        |        |  |
| 1008          |              | END W  | D=1    | Byte3  | Byte2           | Byte1  | Byte0  |        |  |
| <i>Y</i> e    |              | _      |        | Byte7  | Byte6           | Byte5  | Byte4  |        |  |
|               |              |        |        |        |                 |        |        |        |  |
| END_BT=0      | ND_BT=0 Bit0 |        | Bit2   | Bit3   | Bit4            | Bit5   | Bit6   | Bit7   |  |
|               |              |        |        |        |                 |        |        |        |  |
| END_BT=1 Bit7 |              | Bit6   | Bit5   | Bit4   | Bit3            | Bit2   | Bit1   | Bit0   |  |



### 10.3.3 TSSI Control Register (TSCTRL)

The register TSCTRL is used to control TSSI to work.



| Name     | Description                          | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved | Writing has no effect, read as zero. | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| F_DTRM   | FIFO data trigger interrupt mask.    | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|          | 0: enabled                           | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|          | 1: masked                            | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| F_OVRNM  | FIFO overrun interrupt mask.         | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|          | 0: enabled                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|          | 1: masked                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| F_TRIGM  | FIFO trigger interrupt mask.         | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|          | 0: enabled                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|          | 1: masked                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|          | Reserved<br>F_DTRM<br>F_OVRNM        | Reserved       Writing has no effect, read as zero.         F_DTRM       FIFO data trigger interrupt mask.         0: enabled       0: enabled         1: masked       0: enabled         0: enabled       0: enabled         1: masked       USEQ         F_OVRNM       FIFO overrun interrupt mask.         0: enabled       0: enabled         1: masked       USEQ         F_TRIGM       FIFO trigger interrupt mask.         0: enabled       USEQ         0: enabled       USEQ |

### 10.3.4 TSSI State Register (TSSTAT)

The register TSSTAT is used to keep the state of TSSI.



RST

| Bits | Name     | Description                          | RW |
|------|----------|--------------------------------------|----|
| 7:3  | Reserved | Writing has no effect, read as zero. | R  |
| 2    | F_DTR    | FIFO data trigger interrupt flag.    | RW |
|      |          | 1: active                            |    |
|      |          | 0: not active                        |    |
| 1    | F_OVRN   | FIFO overrun interrupt flag.         | RW |
|      |          | 1: active                            |    |
|      |          | 0: not active                        |    |
|      |          |                                      | •  |



| 0 | F_TRIG | FIFO trigger interrupt flag. | RW |
|---|--------|------------------------------|----|
|   |        | 1: active                    |    |
|   |        | 0: not active                |    |

### 10.3.5 TSSI FIFO Register (TSFIFO)

The register TSFIFO is corresponded to TSSI FIFO.



### 10.3.6 TSSI PID Enable Register (TSPEN)

The register TSPEN is used to control the PID filtering.

| — Т 9 | SPF | -N |
|-------|-----|----|
|       |     |    |

### 0x134E0014

| Bit | 31     | 30     | 29     | 28     | 27     | 26     | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    | 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-----|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|     | EN_151 | EN_141 | EN_131 | EN_121 | EN_111 | EN_101 | EN_91 | EN_81 | EN_71 | EN_61 | EN_51 | EN 41 | EN_31 | EN_21 | EN_11 | EN_01 | EN_150 | EN_140 | EN_130 | EN_120 | EN_110 | EN_100 | EN_90 | EN_80 | EN_70 | EN_60 | EN_50 | EN_40 | EN_30 | EN_20 | EN_10 | EN_00 |
| RST | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|     |        |        |        | 3      | Q      | Sy     |       |       |       |       |       |       |       |       |       |       |        |        |        |        |        |        |       |       |       |       |       |       |       |       |       |       |

| Bits  | Name     | Description                        | RW |
|-------|----------|------------------------------------|----|
| 31:16 | EN_x1    | PID filter enable for TSPIDx.PID1. | RW |
|       | (x=15~0) | 0: not enable                      |    |
|       |          | 1: enable                          |    |
| 15:0  | EN_x0    | PID filter enable for TSPIDx.PID0. | RW |
|       | (x=15~0) | 0: not enable                      |    |
|       |          | 1: enable                          |    |



### 10.3.7 TSSI Data Number Register (TSNUM)

The register TSNUM is used to show the current number of the data in FIFO.



| Bits                                      | Name     | Description                                    | RW  |  |  |  |  |  |  |  |  |
|-------------------------------------------|----------|------------------------------------------------|-----|--|--|--|--|--|--|--|--|
| 7                                         | Reserved | Writing has no effect, read as zero.           | R   |  |  |  |  |  |  |  |  |
| 6:0                                       | DNUM     | The current number of data in FIFO.            | RW  |  |  |  |  |  |  |  |  |
|                                           |          | The range of the data number is from 0 to 127. | XT. |  |  |  |  |  |  |  |  |
|                                           |          | t on                                           | 7)  |  |  |  |  |  |  |  |  |
| 10.3.8 TSSI Data Trigger Register (TSDTR) |          |                                                |     |  |  |  |  |  |  |  |  |
|                                           |          |                                                |     |  |  |  |  |  |  |  |  |

### 10.3.8 TSSI Data Trigger Register (TSDTR)

The register TSDTR is used to trigger the FIFO level interrupt when the current data number in the FIFO is more than the value in TSDTR.



| Bits | Name     | Description                                    | RW |
|------|----------|------------------------------------------------|----|
| 7    | Reserved | Writing has no effect, read as zero.           | R  |
| 6:0  | DTRG     | The trigger number of FIFO.                    | RW |
|      |          | The range of the data number is from 0 to 127. |    |

### 10.3.9 TSSI PID Filter Registers (TSPID0~15)

The registers TSPID0~15 are used to store PID values that need to be filtered from MPEG-2 TS.



JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| Bits  | Name     | Description                                  | RW |
|-------|----------|----------------------------------------------|----|
| 31:29 | Reserved | Writing has no effect, read as zero.         | R  |
| 28:16 | PID1     | Set the PID value that needs to be filtered. | RW |
| 15:13 | Reserved | Writing has no effect, read as zero.         | R  |
| 12:0  | PID0     | Set the PID value that needs to be filtered. | RW |

### 10.3.10 TSSI DMA Descriptor Address (TSDDA)



| Bits   | Name | Description                                                             | RW |
|--------|------|-------------------------------------------------------------------------|----|
| [31:0] | DA   | Descriptor Address.                                                     | RW |
|        |      | It must be aligned to 4-word.                                           |    |
|        |      | It can be written by software and coped from the descriptor. Software   |    |
|        |      | should write the descriptor address before enable the DMA, and only the |    |
|        |      | first DA needed if LINK enabled.                                        |    |

### 10.3.11 TSSI DMA Target Address (TSDTA)

254

|     | TD | ГА |    | ~  | 6  | 1  | T  | Y  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x | 134 | EO | 064 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----|-----|----|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2   | 1  | 0   |
|     |    | Y  | ,  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    |     |    |     |
|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Т  | A  |    |    |    |    |    |   |   |   |   |   |   |    |     |    |     |
|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    |     |    |     |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0   | 0  | 0   |

| Bits | Name | Description                           | R |
|------|------|---------------------------------------|---|
| 31:0 | ТА   | Target Address.                       | R |
|      |      | It should be aligned to 32-word.      |   |
|      |      | It will be coped from the descriptor. |   |

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



### 10.3.12 TSSI DMA Identifier (TSDID)

### TDID 0x134E0068 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved DID

| Bit  | s Name         | Description                                                        | R      |
|------|----------------|--------------------------------------------------------------------|--------|
| 31:  | 16 Reserved    | Writing has no effect, read as zero.                               | R      |
| 15:  | 0 DID          | Descriptor Identifier.                                             | R      |
|      |                | It will be coped from the descriptor.                              |        |
|      |                | It will be copied to TDST.DID.                                     |        |
| 10.3 | .13 TSSI DM/   | A Command (TSDCMD)                                                 |        |
|      | TDCMD          | 0x134                                                              | 4E006C |
| Bit  | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0    |

### 10.3.13 TSSI DMA Command (TSDCMD)

### TDCMD

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19       | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6        | 5 | 4    | 3   | 2   | 1    | 0    |
|-----|----|----|----|----|----|----|----|----|----|----|----|-----|----------|----|----|----|----|----|----|----|----|----|---|---|---|----------|---|------|-----|-----|------|------|
|     |    |    |    |    |    |    |    |    |    |    | ſ  | TLI | EN<br>)• | C( | ON | 7  | 7  |    |    |    |    |    |   |   |   | Reserved |   | TEFE | TC7 | 761 | TEIE | LINK |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0        | 0 | 0    | 0   | 0   | 0    | 0    |

| Bits | Name     | Description                                                | R   |
|------|----------|------------------------------------------------------------|-----|
| 31:8 | TLEN     | Transfer Length.                                           | R   |
| 1    | O        | Unit is word.                                              |     |
|      |          | When DMA transfer end, the TLEN will be counted down to 0. |     |
|      |          | This field will be coped from the descriptor.              |     |
| 7:5  | Reserved | Writing has no effect, read as zero.                       | R   |
| 4    | TEFE     | Transfer End Flag Enable.                                  | R   |
|      |          | 0: disable TSDST.TEND                                      |     |
|      |          | 1: enable TSDST.TEND                                       |     |
|      |          | This field will be coped from the descriptor.              |     |
| 3:2  | TSZ      | Expected Transfer Size.                                    | R   |
|      |          | 0: 4 word                                                  |     |
|      |          | 1: 8 word                                                  |     |
|      |          | 2: 16 word                                                 |     |
|      |          | 3: 32 word                                                 |     |
|      |          | This field will be coped from the descriptor.              |     |
| 1    | TEIE     | Transfer End Interrupt Enable.                             | R   |
|      |          |                                                            | 255 |

JZ4770 Mobile Application Processor Peripherals Programming Manual



|   |      | 0, disable interrupt                          |   |
|---|------|-----------------------------------------------|---|
|   |      | 1, enable interrupt                           |   |
|   |      | This field will be coped from the descriptor. |   |
| 0 | LINK | Descriptor Link Enable.                       | R |
|   |      | 0, disable                                    |   |
|   |      | 1, enable                                     |   |
|   |      | This field will be coped from the descriptor. |   |

### 10.3.14 TSST DMA Status (TSDST)

|     | TD | ST |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   | 0x | 134 | E0 | 070 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|----|-----|----|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7   | 6 | 5 | 4 | 3  | 2   | 1  | 0   |
|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |    |     |    |     |
|     |    |    |    |    |    |    |    | D  | D  |    |    |    |    |    |    |    |    |    |    |    |    |    | Re | ser | /ed |   |   |   |    |     |    | ND  |
|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |    |     |    | Ħ   |
|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |    |     |    |     |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0 | 0 | 0 | 0  | 0   | 0  | 0   |

| Bits  | Name     | Description                                                    | RW |
|-------|----------|----------------------------------------------------------------|----|
| 31:16 | DID      | Copied from Descriptor Identifier when DMA interrupt occurred. | RW |
|       |          | Write 0 will clear this field.                                 |    |
| 15:1  | Reserved | Write has no effect, read as zero.                             | R  |
| 0     | TEND     | Transfer End Flag                                              | RW |
|       |          | 0: Transfer is not finished                                    |    |
|       |          | 1. Transfer is finished                                        |    |
|       | 0        | Write 0 will clear this field.                                 |    |

### 10.3.15 TSSI Transfer Control Register (TSTC)

|     | TS | тс |    |    |    |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x | 134 | E0  | 074 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|------------|-----|-----|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2   | 1   | 0   |
|     |    |    |    |    |    |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |   |   |   |   | 0 | P | Reserved   | OPE | EMM | APM |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0          | 0   | 0   | 0   |

| Bits | Name     | Description                          | RW |
|------|----------|--------------------------------------|----|
| 31:2 | Reserved | Writing has no effect, read as zero. | R  |

<sup>256</sup> 

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| 5:4 | OP       | Optional Pric  | rity Configuration. Only us   | ed when OPE is set to 1.       |    |
|-----|----------|----------------|-------------------------------|--------------------------------|----|
|     |          | OP             | TSSI AHB Priority             | Number of Data in FIFO         |    |
|     |          | 2'b00          | 0                             | n <= 16                        |    |
|     |          |                | 1                             | 16 < n <= 32                   |    |
|     |          |                | 2                             | 32 < n <= 64                   |    |
|     |          |                | 3                             | 64 < n                         |    |
|     |          | 2'b01          | 0                             | n <= 16                        |    |
|     |          |                | 1                             | 16 < n <= 48                   |    |
|     |          |                | 2                             | 48 < n <= 80                   |    |
|     |          |                | 3                             | 80 < n                         |    |
|     |          | 2'b10          | 0                             | n <= 32                        |    |
|     |          |                | 1                             | 32 < n <= 64                   |    |
|     |          |                | 2                             | 64 < n <= 96                   |    |
|     |          |                | 3                             | 96 < n                         |    |
|     |          | 2'b11          | 0                             | n <= 48                        |    |
|     |          |                | 1                             | 48 < n <= 80                   |    |
|     |          |                | 2                             | 80 < n <= 112                  |    |
|     |          |                | 3                             | 112 < n                        |    |
|     |          | It is suggeste | ed to use 2'b10.              |                                |    |
| 3   | Reserved | Writing has r  | o effect, read as zero.       |                                | R  |
| 2   | OPE      | Optional Price | rity Mode Enable Control.     | Only used when APM is 1.       | RW |
|     |          | 0: TSSI calci  | lates the priority according  | g to the fifo status           |    |
|     |          | 1: TSSI calcu  | ulates the priority according | g to OP which is configured    |    |
|     |          | by softwa      | re                            |                                |    |
| 1   | EME      | Emergency M    | Node Enable Control.          |                                | RW |
|     | ng-      | 0: Emergenc    | y Mode Disable                |                                |    |
| 1   | Oric     | 1: Emergenc    | y Mode Enable                 |                                |    |
| 0   | АРМ      | Auto Priority  | Mode Enable Control.          |                                | RW |
|     |          | 0: Auto priori | ty mode disables. TSSI us     | es the priority set by arbiter |    |
|     |          | 1: Auto priori | ty mode enables. TSSI car     | n use the priority according   |    |
|     |          | the FIFO s     | tatus                         |                                |    |



### 10.4 TSSI Timing

TSSTR

TSFAIL

rig 10ng-eiffe



Figure 10-2 Timing waveform in serial mode

258



### 10.5 TSSI Guide

### **10.5.1 TSSI Operation without PID Filtering Function**

- 1 Set TSCTRL to 0x03 to mask all interrupts.
- 2 Set TSCFG to choose the working mode of TSSI and the trigger value of FIFO.
- 3 Set TSENA.PID\_EN to 0 to turn off the PID filtering function.
- 4 set the DMA descriptor first if using the master DMA.
- 5 Set TSENA.DMA EN to 1 or 0 to decide whether to use the DMA mode or not.
- 6 Write 0x00 to TSSTAT clear all interrupt flag.
- 7 Set TSCTRL to 0x00 to enable all interrupts.
- 8 Set TSENA.ENA to 1 to turn on TSSI module.

### **10.5.2 TSSI Operation with PID Filtering Function**

- Set TSCTRL to 0x03 to mask all interrupts. 1
- ed only 2 Set TSCFG to choose the working mode of TSSI and the trigger value of FIFO.
- 3 Set TSENA.PID\_EN to 1 to turn on the PID filtering function
- 4 set the DMA descriptor first if using the master DMA.
- Set TSENA.DMA EN to 1 or 0 to decide whether to use the DMA mode or not. 5
- Write 0x00 to TSSTAT clear all interrupt flag. 6
- 7 Set TSCTRL to 0x00 to enable all interrupts.
- 8 Set TSENA.ENA to 1 to turn on TSSI module.
- Change TSPID registers and then set TSPID to enable the PID filter. 9
- 10 When PID in TS package is equal to the valve in TSPID register, the TS package will be getting.



### Ethernet MAC Controller 11

### 11.1 Overview

The processor contains one Ethernet media access controller (MAC), each capable of supporting 10/100Mbps Ethernet. The MAC provides the interface between the host application and the PHY layer through the media independent interface (MII) or the Reduced-MII (RMII). The PHY layer device is external to the processor.

The MAC supports the protocol requirements to meet the Ethernet/IEEE 802.3 specification. The MAC operates in both half and full duplex modes. In half-duplex mode, the controller supports the IEEE802.3 Carrier Sense Multiple Access with Collision Detection (CSMA/CD) protocol. In full-duplex mode, it supports the IEEE802.3 MAC Control Layer, including the pause operation for flow control.

A dedicated DMA engine is implemented to support the MAC so that the general purpose DMA is not ternal used required.

The MAC features are:

- IEEE 802.3, 802.3u specification compliance •
- 10/100 Mbps data transfer rates .
- IEEE 802.3 compliant MII interface to talk to an external PHY
- The Reduced-MII interface to an external PHY •
- Full and half duplex .
- CSMA/CD in half duplex •
- Flow control support for full duplex
- Collision detection and auto retransmit on collisions in half duplex •
- Automatic 32-bit CRC generation and checking .
- Optional to insert PAD/CRC32 on transmit packets •
- Optional automatic Pad stripping on the receive packets •
- External and internal loopback support on the MII
- Filtering modes supported on the Ethernet side
  - One 48 bit Perfect address
  - 64 hash-filtered multicast addresses \_
  - Pass all multicast addresses
  - Promiscuous Mode
  - Pass all incoming packets with a status report
  - \_ Toss bad packets
- Dedicated DMA engine using burst mode .
- DMA linked list Descriptor Chaining support
- Descriptor architecture allows large blocks of data transfer with minimum CPU intervention

JZ4770 Mobile Application Processor Peripherals Programming Manual

<sup>260</sup> 

### 11.2 VLAN support Ethernet Signals

The following table shows the signals associated with the Ethernet MAC MII interfaces.

| Signal       | I/O    | Description                                                          |
|--------------|--------|----------------------------------------------------------------------|
| RX_CLK       | Input  | Continuous clock that provides the timing reference for the          |
|              |        | datatransfer from the PHY to the MAC. RX_CLK is sourced by the       |
|              |        | PHY.RX_CLK must have a frequency equal to 25% of the data rate       |
|              |        | of the received signal data stream (typically 25 MHz at 100-Mbps and |
|              |        | 2.5MHz at 10-Mbps).                                                  |
| RX_DV        | Input  | RX_DV is driven by the external Ethernet PHY and indicates that a    |
|              |        | receive frame is in process and that the data on RXD[3:0] is valid.  |
| RX_ER        | Input  | RX_ER is driven by the Ethernet PHY. RX_ER shall be asserted for     |
|              |        | one or more RX_CLK periods to indicate to the MAC that an error      |
|              |        | was detected some where in the frame presently being transferred     |
|              |        | from the PHY to the MAC.                                             |
| RXD [3:0]    | Input  | RXD[3:0] is a 4-bit wide data bus driven by the PHY to the MAC       |
|              |        | synchronous with RX_CLK. For each RX_CLK period in which             |
|              |        | RX_DV is asserted, RXD[3:0] transfers four bits of recovered data    |
|              |        | from the PHY to the MAC. While RX_DV is negated, RXD[3:0] has no     |
|              |        | effect on the MAC                                                    |
| TX_CLK(REF_C | Input  | Continuous clock input for synchronization of transmit data. 25 MHz  |
| LK)          |        | when operating at 100-Mbps and 2.5 MHz when operating at             |
|              | 288    | 10-Mbps.                                                             |
|              | 1110   | When in RMII mode, REF_CLK 50MZ whenever at 100-Mbps or at           |
| 6            | 5      | 10-Mbps.                                                             |
| TX_EN        | Output | Indicates that the data on TXD[3:0] is valid.                        |
| TXD [3:0]    | Output | 4-bit wide data bus synchronous to TX_CLK. For each TX_CLK           |
|              |        | period in which TX_EN is asserted, TXD[3:0] presents valid data to   |
|              |        | the PHY. While TX_EN is negated the data presented on TXD[3:0] is    |
|              |        | not valid.                                                           |
| CRS          | Input  | The PHY asserts CRS when either transmit or receive medium is non    |
|              |        | idle. The PHY negates CRS when both the transmit and receive         |
|              |        | medium are idle. CRS is an asynchronous input.                       |
| COL          | Input  | The PHY asserts COL upon detection of a collision on the medium      |
|              |        | and continues to assert COL while the collision condition persists.  |
|              |        | COL is an asynchronous input. The COL signal is ignored by the       |
|              |        | MAC when operating in full duplex mode.                              |
| MDC          | Output | MDC is sourced by the MAC to the PHY as the timing reference for     |
|              |        | transfer of information on the MDIO signal. MDC is an aperiodic      |
|              |        | signal that has no maximum high or low times. The MDC frequency is   |

### Table 11-1 Ethernet MII Signals



|      |     | fixed at system bus clock divided by 160.                         |
|------|-----|-------------------------------------------------------------------|
| MDIO | I/O | MDIO is the bidirectional data signal between the MAC and the PHY |
|      |     | that is clocked by MDC.                                           |

### Table 11-2 Pin Map of MII and RMII Mode

| Normal MII Mode | Reduced MII Mode |
|-----------------|------------------|
| TXD[1:0]        | TXD[1:0]         |
| TXD[3:2]        | NC               |
| TXEN            | TXEN             |
| TXCLK           | REF_CLK          |
| RXD[1:0]        | RXD[1:0]         |
| RXD[3:2]        | NC               |
| RXDV            | CRS DV           |
| RXCLK           | NC               |
| COL             | NC               |
| CRS             | NC               |
| MDC             | MDC 🔨 🔍          |
| MDIO            | MDIO MDIO        |
| MDIO<br>MDIO    | om inte          |
| cfeler          |                  |

262



### 11.3 Block Diagram





### 11.4 DMA Module

### 11.4.1 Overview

The DMA module provides a DMA bridge between a host system that uses an AMBA AHB<sup>™</sup> bus and the Ethernet MAC.

The DMA module interfaces to the host system through 32-bit AHB Master and Slave ports. On the MAC side of the module, it has a high-performance synchronous interface for DMA data transfer to/from the FIFO and a semi-synchronous interface for configuring the MAC and the FIFO through their HST interfaces.

For ease of handling by software, transfers are handled using linked lists of transfer descriptors which together define one buffer in host memory for Tx operations and another for Rx operations. These buffers will typically be configured as ring buffers but this is up to the user to implement.

Registers within the DMA provide Control and Status information concerning these transfers. These registers are accessed through the AHB Slave port, alongside accesses to the HST interfaces on the MAC and the FIFO. ternal

### 11.4.2 Features

- AMBA AHB 2.0 compliant Master port for payload data transfer
- AMBA AHB 2.0 compliant Slave port for DMA bridge, FIFO and MAC configuration •
- RAM-free synchronous single-clock domain design •
- 32-bit architecture
- Linked-List Transfer Descriptors for minimal software overhead .

### 11.4.3 Register Map

| Name         | RW | Reset Value | Address    | Access Size |
|--------------|----|-------------|------------|-------------|
| DMATxCtrl    | RW | 0x0000000   | 0x134B0180 | 32          |
| DMATxDesc    | RW | 0x?0000000  | 0x134B0184 | 32          |
| DMATxStatus  | RW | 0x???????   | 0x134B0188 | 32          |
| DMARxCtrl    | RW | 0x0000000   | 0x134B018C | 32          |
| DMARxDesc    | RW | 0x?0000000  | 0x134B0190 | 32          |
| DMARxStatus  | RW | 0x???????   | 0x134B0194 | 32          |
| DMAIntrMask  | RW | 0x?0000000  | 0x134B0198 | 32          |
| DMAInterrupt | RW | 0x?0000000  | 0x134B019C | 32          |

### 264



eserved

### 11.4.4 Register Description

### 11.4.4.1 DMATxCtrl

|     | DM | АТ | cCti | rl |    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x | 134 | <b>B0</b> ′ | 180  |
|-----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|---|---|---|---|---|---|------------|-----|-------------|------|
| Bit | 31 | 30 | 29   | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2   | 1           | 0    |
|     |    |    |      |    |    |    |    |    |    |    |    |    |    |    | Re | ser | ved |    |    |    |    |    |   |   |   |   |   |   |            |     |             | TXEN |
| RST | 0  | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0          | 0   | 0           | 0    |

| Bits     | Name     | Description                                                                | RW              |
|----------|----------|----------------------------------------------------------------------------|-----------------|
| 31:1     | Reserved | Writing has no effect, read as zero.                                       | R               |
| 0        | TXEN     | Setting this bit enables DMA transmit packet transfers. The bit is cleared | RW              |
|          |          | by the built-in DMA controller whenever it encounters a Tx Underrun or     |                 |
|          |          | Bus Error state. Default is '0'.                                           |                 |
| 11.4.4.2 | 2 DMATxD | esc rhal useu                                                              |                 |
| DM       | ATxDesc  | int <sup>er</sup> 0x13                                                     | 4 <b>B0</b> 184 |

### 11.4.4.2 DMATxDesc

### **DMATxDesc**

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

DMATxDesc

## 

| Bits | Name      | Description                                                            | RW |
|------|-----------|------------------------------------------------------------------------|----|
| 31:1 | DMATxDesc | When TxEnable is set by the host, the built-in DMA                     | R  |
|      |           | controller reads this register to discover the location in host memory |    |
|      |           | of the first transmit packet descriptor.                               |    |
| 0    | Reserved  | Writing has no effect, read as zero.                                   | R  |

### 11.4.4.3 DMATxStatus

|     | DM                  | AT | xSta | atus | 5  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |   |   |   |   |   | 0x | 134     | <b>B0</b> <sup>,</sup> | 188 |
|-----|---------------------|----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|---|---|---|---|---|----|---------|------------------------|-----|
| Bit | 31                  | 30 | 29   | 28   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9    | 8 | 7 | 6 | 5 | 4 | 3  | 2       | 1                      | 0   |
|     | Reserved TxPktCount |    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R  | ese | erve | d |   |   |   |   |    | TxUdrun | TxPktSent              |     |
| RST | 0                   | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0 | 0 | 0 | 0 | 0 | 0  | 0       | 0                      | 0   |
|     |                     |    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |   |   |   |   |   |    |         | 2                      | 65  |

JZ4770 Mobile Application Processor Peripherals Programming Manual



| Bits  | Name       | Description                                                            | RW |
|-------|------------|------------------------------------------------------------------------|----|
| 31:24 | Reserved   | Writing has no effect, read as zero.                                   | R  |
| 23:16 | TxPktCount | 8-bit transmit packet counter that is incremented whenever the         | RW |
|       |            | built-in DMA controller successfully transfers a packet, and           |    |
|       |            | decremented whenever the host writes a '1' to bit 0 of this register.  |    |
| 15:2  | Reserved   | Writing has no effect, read as zero.                                   | R  |
| 1     | TxUdrun    | Set whenever the DMA controller reads a set ('1') Empty Flag in the    | RW |
|       |            | descriptor it is processing.                                           |    |
| 0     | TxPktSent  | When set, indicates that one or more packets have been successfully    | RW |
|       |            | transferred. Writing a '1' to this bit reduces the TxPktCount value by |    |
|       |            | one. The bit is cleared whenever TxPktCount is zero.                   |    |

### 11.4.4.4 DMARxCtrl

|     | DM | AR | xCt | rl |    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |   |   |   | 2 | ( | 25 | <b>0</b> x1 | ر<br>ا34 | B01 | 8C   |
|-----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|---|---|---|---|---|----|-------------|----------|-----|------|
| Bit | 31 | 30 | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3           | 2        | 1   | 0    |
|     |    |    |     |    |    |    |    |    |    |    |    |    |    |    | Re | ser | ved |    |    |    |    |    |   |   |   |   |   |    |             |          |     | RXEN |
| RST | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0  | 0           | 0        | 0   | 0    |
|     |    |    |     |    |    |    |    |    |    |    |    |    |    |    | 71 | 1   |     |    |    |    |    |    |   |   |   |   |   |    |             |          |     |      |

| Bits | Name     | Description                                                             | RW |
|------|----------|-------------------------------------------------------------------------|----|
| 31:1 | Reserved | Writing has no effect, read as zero.                                    | R  |
| 0    | RXEN     | Setting this bit enables DMA receive packet transfers. When set, the    | RW |
|      |          | built-in DMA controller will start to receive a new packet whenever the |    |
|      | 6        | FIFO indicates that a new packet is available (FRSOF asserted). The bit |    |
| 1    | ons      | is cleared by the built-in DMA controller whenever it encounters an Rx  |    |
| )    |          | Overflow or Bus Error state.                                            |    |

### 11.4.4.5 DMARxDescriptor

|     | DM | AR | xDe | esci | ript | or |    |    |    |    |    |    |    |     |     |     |     |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x | 134 | <b>B0</b> 1 | 90 |
|-----|----|----|-----|------|------|----|----|----|----|----|----|----|----|-----|-----|-----|-----|----|----|----|----|----|---|---|---|---|---|---|------------|-----|-------------|----|
| Bit | 31 | 30 | 29  | 28   | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17  | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2   | 1           | 0  |
|     |    |    |     |      |      |    |    |    |    |    |    |    | 0  | DES | SCP | _A[ | DDF | २  |    |    |    |    |   |   |   |   |   |   |            |     | C           | )  |
| RST | 0  | 0  | 0   | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0          | 0   | 0           | 0  |

| Bits | Name   | Description                                                              | RW |
|------|--------|--------------------------------------------------------------------------|----|
| 31:2 | DESCP_ | When RxEnable is set by the host, the built-in DMA controller reads this | RW |
| 266  | •      |                                                                          |    |

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|     | ADDR | register to discover the location in host memory of the first receive packet |    |
|-----|------|------------------------------------------------------------------------------|----|
|     |      | Descriptor.                                                                  |    |
| 1:0 | 0    | Ignored by the DMA controller, since it is a requirement of the system that  | RW |
|     |      | all descriptors are 32-bit aligned in host memory.                           |    |

### 11.4.4.6 DMARxStatus

|     | DM | AR | xSt | atu  | s    |    |    |    |    |    |     |     |    |    |    |    |    |    |    |    |    |     |      |   |   |   |   |   | <b>0</b> x | 134   | <b>B0</b> ′ | 194   |
|-----|----|----|-----|------|------|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|-----|------|---|---|---|---|---|------------|-------|-------------|-------|
| Bit | 31 | 30 | 29  | 28   | 27   | 26 | 25 | 24 | 23 | 22 | 21  | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9    | 8 | 7 | 6 | 5 | 4 | 3          | 2     | 1           | 0     |
|     |    |    | R   | lese | erve | d  |    |    |    |    | RxI | ۶ΚТ | c  | NT |    |    |    |    |    |    | R  | ese | erve | d |   |   |   |   | BUS_ERR    | Rx_OF | 0           | RxPKT |
| RST | 0  | 0  | 0   | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0 | 0 | 0 | 0 | 0 | 0          | 0     | 0           | 0     |
|     |    |    |     |      |      |    |    |    |    |    |     |     |    |    |    |    |    |    |    |    |    |     |      |   |   |   | ( | 5 | 17         | , J   |             |       |

| Bits  | Name      | Description                                                              | RW |
|-------|-----------|--------------------------------------------------------------------------|----|
| 31:24 | Reserved  | Writing has no effect, read as zero.                                     | R  |
| 23:16 | RxPKT_CNT | 8-bit receive packet counter that is incremented whenever the built-in   | RW |
|       |           | DMA controller successfully transfers a packet, and is decremented       | С  |
|       |           | whenever the host writes a '1' to bit zero of this register.             |    |
| 15:4  | Reserved  | Writing has no effect, read as zero.                                     | R  |
| 3     | BUS_ERR   | When set, indicates that a host slave split, retry or error response was | RW |
|       |           | received by the DMA controller.                                          | С  |
| 2     | Rx_OF     | Set whenever the DMA controller reads a zero Empty Flag in the           | RW |
|       |           | descriptor it is processing.                                             | С  |
| 1     | 0         | 0.                                                                       | R  |
| 0     | RxPKT     | When set, indicates that one or more packets have been successfully      | RW |
| 1     | 01.0      | transferred. Writing a '1' to this bit reduces the RxPktCount value by   |    |
| -     |           | one. The bit is cleared whenever RxPktCount is zero.                     |    |

### 11.4.4.7 DMAIntrMask

|     | DM   | IAIr   | ntr <b>I</b> V | lasl   | ¢  |    |    |    |    |    |    |    |    |    |      |     |    |    |    |    |    |    |   |   |            |       |   |       | <b>0</b> x | 134 | <b>B0</b> 1 | 198   |
|-----|------|--------|----------------|--------|----|----|----|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|---|---|------------|-------|---|-------|------------|-----|-------------|-------|
| Bit | 31   | 30     | 29             | 28     | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7          | 6     | 5 | 4     | 3          | 2   | 1           | 0     |
|     | STEN | CLRCNT | AUTOZ          | TSGIIB |    |    |    |    |    |    |    |    |    | Re | serv | /ed |    |    |    |    |    |    |   |   | RX_BUS_ERR | Rx_OF | 0 | RxPKT | TX_BUS_ERR | 0   | Tx_UR       | TXPKT |
| RST | 0    | 0      | 0              | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0          | 0     | 0 | 0     | 0          | 0   | 0           | 0     |



| Bits  | Name      | Description                                                           | RW |
|-------|-----------|-----------------------------------------------------------------------|----|
| 31    | STEN      | Enable counting STAT.                                                 | RW |
| 30    | CLRCNT    | Zero all counters and carries immediately.                            | RW |
| 27    | AUTOZ     | Auto zero addressed.                                                  | RW |
| 28:27 | BURST     | 00: BURST4                                                            | RW |
|       |           | 01: BURST4                                                            |    |
|       |           | 10: BURST8                                                            |    |
|       |           | 11: BURST16                                                           |    |
| 26:8  | Reserved  | Writing has no effect, read as zero.                                  | R  |
| 7     | RX_BUS_ER | Setting this bit to '1' enables the BusError bit in the DMARxStatus   | RW |
|       | R         | register as an interrupt source.                                      |    |
| 6     | Rx_OF     | Setting this bit to '1' enables the RxOverflow bit in the DMARxStatus | RW |
|       |           | register as an interrupt source.                                      |    |
| 5     | 0         | 0.                                                                    | R  |
| 4     | RxPKT     | Setting this bit to '1' enables the RxPktReceived bit in the          | RW |
|       |           | DMARxStatus register as an interrupt source.                          |    |
| 3     | TX_BUS_ER | Setting this bit to '1' enables the BusError bit in the DMATxStatus   | RW |
|       | R         | register as an interrupt source. $\sqrt{\sqrt{2}}$                    |    |
| 2     | 0         | 0. Dat                                                                | R  |
| 1     | Tx_UR     | Setting this bit to '1' enables the TxUnderrun bit in the DMATxStatus | RW |
|       |           | register as an interrupt source.                                      |    |
| 0     | TxPKT     | Setting this bit to '1' enables the TxPktSent bit in the DMATxStatus  | RW |
|       |           | register as an interrupt source.                                      |    |

|      |                      |                     |     |          |    |        | 1   | ey | ISIC | a a | s ai | 1 m | ιςI  | ιup | 1 30 | Juit | JE. |    |    |    |    |    |   |   |            |       |   |       |                         |   |             |       |
|------|----------------------|---------------------|-----|----------|----|--------|-----|----|------|-----|------|-----|------|-----|------|------|-----|----|----|----|----|----|---|---|------------|-------|---|-------|-------------------------|---|-------------|-------|
| 11.4 | 1.4.4.8 DMAInterrupt |                     |     |          |    |        |     |    |      |     |      |     |      |     |      |      |     |    |    |    |    |    |   |   |            |       |   |       |                         |   |             |       |
|      | DM                   | I <mark>A</mark> In | tri | o<br>.pt | 6  | e<br>S | , Y |    | 23   | 22  | 21   | 20  | 10   | 18  | 17   | 16   | 15  | 11 | 13 | 12 | 11 | 10 | 0 | 8 | 7          | 6     | 5 | Λ     | <b>0</b> x <sup>2</sup> | - | <b>B0</b> 1 | 19c   |
| BIT  | 51                   | 30                  | 29  | 20       | 21 | 20     | 25  | 24 | 23   | 22  | 21   | 20  | 19   | 10  | 17   | 10   | 15  | 14 | 15 | 12 |    | 10 | 9 | • | 1          | 0     | 5 | 4     | <u></u> о               | 2 |             | U     |
|      |                      |                     |     |          |    |        |     |    |      |     | R    | ese | erve | d   |      |      |     |    |    |    |    |    |   |   | RX_BUS_ERR | RX_OF | 0 | RxPKT | TX_BUS_ERR              | 0 | Tx_UR       | TXPKT |
| RST  | 0                    | 0                   | 0   | 0        | 0  | 0      | 0   | 0  | 0    | 0   | 0    | 0   | 0    | 0   | 0    | 0    | 0   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0          | 0     | 0 | 0     | 0                       | 0 | 0           | 0     |

| Bits | Name      | Description                                                           | RW |
|------|-----------|-----------------------------------------------------------------------|----|
| 31:8 | Reserved  | Writing has no effect, read as zero.                                  | R  |
| 7    | RX_BUS_ER | Set to '1' to record a Receive Bus Error interrupt when the BusError  | R  |
|      | R         | bit in the DMARxStatus register and bit 7 of the DMAIntrMask register |    |
|      |           | are both set.                                                         |    |
| 6    | Rx_OF     | Set to '1' to record an Rx Overflow interrupt when the RxOverflow bit | R  |

### 268

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|   |           | in the DMARxStatus register and bit 6 of the DMAIntrMask register               |   |
|---|-----------|---------------------------------------------------------------------------------|---|
|   |           | are both set.                                                                   |   |
| 5 | 0         | 0.                                                                              | R |
| 4 | RxPKT     | Set to '1' to record a RxPkt Received interrupt when the                        | R |
|   |           | RxPktReceived bit in the DMARxStatus register and bit 4 of the                  |   |
|   |           | DMAIntrMask register are both set.                                              |   |
| 3 | TX_BUS_ER | Set to '1' to record a Transmit Bus Error interrupt when the BusError           | R |
|   | R         | bit in the DMATxStatus register and bit 3 of the DMAIntrMask register           |   |
|   |           | are both set.                                                                   |   |
| 2 | 0         | 0.                                                                              | R |
| 1 | Tx_UR     | Set to '1' to record a Tx Underrun interrupt when the TxUnderrun bit            | R |
|   |           | in the DMATxStatus register and bit 1 of the DMAIntrMask register               |   |
|   |           | are both set.                                                                   |   |
| 0 | TxPKT     | Set to '1' to record a Tx Pkt Sent interrupt when the TxPktSent bit in          | R |
|   |           | the DMATxStatus register and bit 0 of the DMAIntrMask register are              |   |
|   |           | both set.                                                                       |   |
|   |           | internal use                                                                    |   |
|   | e ei      | the DMATxStatus register and bit 0 of the DMAIntrMask register are<br>both set. |   |
|   | Tous      |                                                                                 |   |



### 11.5 FIFO Module

### 11.5.1 Overview

The FIFO module consists of the following seven major RTL modules:

- 10/100 Mb/s FIFO Fabric Transmit Interface Module \_
- 10/100 Mb/s FIFO System Transmit Interface Module \_
- 10/100 Mb/s FIFO Fabric Receive Interface Module
- 10/100 Mb/s FIFO System Receive Interface Module
- 10/100 Mb/s FIFO System Watermark Module \_
- 10/100 Mb/s FIFO Host Interface Module \_
- 10/100 Mb/s FIFO Clock and Reset Module

### 11.5.2 Features

- •
- .
- •
- •
- •
- •
- •
- Programmable high transmit storage-level indicator •
- Graceful receive memory full frame drop •
- Graceful enable and disable •
- Programmable frame mode or word cut-through threshold •
- Transmit storage underrun indication •
- Transmit storage frame rewind capabilities •
- Full memory utilization •
- Optional per transmit frame MAC configuration data •
- Synchronous dual-port memory utilization •
- Low gate count •
- Easy synthesis .

| Name   | RW | Reset Value | Address    | Access Size |
|--------|----|-------------|------------|-------------|
| CFG_R0 | RW | 0x000001F   | 0x134B003C | 32          |
| CFG_R1 | rw | 0x0FFFFFF   | 0x134b004C | 32          |
| CFG_R2 | RW | 0x1FFF1FFF  | 0x134B0050 | 32          |
| CFG_R3 | RW | 0x0FFF0FFF  | 0x134B0054 | 32          |
| CFG_R4 | RW | 0x0000000   | 0x134B0058 | 32          |

### 11.5.3 Register Map

270

JZ4770 Mobile Application Processor Peripherals Programming Manual



| CFG_R5     | RW | 0x0000FFFF | 0x134B005C | 32 |
|------------|----|------------|------------|----|
| RAM_ACC_R0 | RW | 0x0000000  | 0x134B0060 | 32 |
| RAM_ACC_R1 | RW | 0x0000000  | 0x134B0064 | 32 |
| RAM_ACC_R2 | RW | 0x0000000  | 0x134B0068 | 32 |
| RAM_ACC_R3 | R  | 0x0000000  | 0x134B006C | 32 |
| RAM_ACC_R4 | RW | 0x0000000  | 0x134B0070 | 32 |
| RAM_ACC_R5 | RW | 0x0000000  | 0x134B0074 | 32 |
| RAM_ACC_R6 | RW | 0x0000000  | 0x134B0078 | 32 |
| RAM_ACC_R7 | R  | 0x0000000  | 0x134B007C | 32 |

### **11.5.4 Register Description**

### 11.5.4.1 CFG\_R0

|     | CF | G_R |    |    |    |      |     |    |    |    |    |           |           |           |             |           |    |          |    |          |          |          |          |          |   | 1        | ( | 55       | 0x1      | 34<br> 34 | B00      | 3C       |
|-----|----|-----|----|----|----|------|-----|----|----|----|----|-----------|-----------|-----------|-------------|-----------|----|----------|----|----------|----------|----------|----------|----------|---|----------|---|----------|----------|-----------|----------|----------|
| Bit | 31 | 30  | 29 | 28 | 27 | 26   | 25  | 24 | 23 | 22 | 21 | 20        | 19        | 18        | 17          | 16        | 15 | 14       | 13 | 12       | 11       | 10       | 9        | 8        | 7 | 6        | 5 | 4        | 3        | 2         | 1        | 0        |
|     |    |     |    |    | Re | ser\ | /ed |    |    |    |    | FTFENRPLY | STFENRPLY | FRFENRPLY | 🔬 SRFENRPLY | WTMENRPLY |    | Reserved |    | FTFENREQ | STFENREQ | FRFENREQ | SRFENREQ | WTMENREQ |   | Reserved |   | HSTRSTFT | HSTRSTST | HSTRSTFR  | HSTRSTSR | HSTRSTWT |
| RS  | 0  | 0   | 0  | 0  | 0  | 0    | 0   | 0  | 0  | 0  | 0  | 0         | 0         | 0         | 0           | 0         | 0  | 0        | 0  | 0        | 0        | 0        | 0        | 0        | 0 | 0        | 0 | 1        | 1        | 1         | 1        | 1        |

| Bits  | Name      | Description                                                            | RW  |
|-------|-----------|------------------------------------------------------------------------|-----|
| 31:21 | Reserved  | Writing has no effect, read as zero.                                   | R   |
| 20    | FTFENRPLY | When asserted, the mmiitfif_fab module is enabled. When negated,       | R   |
|       | -ng-      | the mmiitfif_fab module is disabled. The bit should be polled until it |     |
| 1     | Ore       | reaches the expected value.                                            |     |
| 19    | STFENRPLY | When asserted, the mmiitfif_sys module is enabled. When negated,       | R   |
|       |           | the mmiitfif_sys module is disabled. The bit should be polled until it |     |
|       |           | reaches the expected value.                                            |     |
| 18    | FRFENRPLY | When asserted, the mmiirfif_fab module is enabled. When negated,       | R   |
|       |           | the mmiirfif_fab module is disabled. The bit should be polled until it |     |
|       |           | reaches the expected value.                                            |     |
| 17    | SRFENRPL  | When asserted, the mmiirfif_sys module is enabled. When negated,       | R   |
|       | Y         | the mmiirfif_sys module is disabled. The bit should be polled until it |     |
|       |           | reaches the expected value.                                            |     |
| 16    | WTMENRPL  | When asserted, the mmiitfif_wtm module is enabled. When negated,       | R   |
|       | Y         | the mmiitfif_wtm module is disabled. The bit should be polled until it |     |
|       |           | reaches the expected value.                                            |     |
| 15:13 | Reserved  | Writing has no effect, read as zero.                                   | R   |
| 12    | FTFENREQ  | When asserted, requests enabling of the mmiitfif_fab module. When      | RW  |
|       |           | ·                                                                      | 271 |

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|               |                  | negated, requests disabling of the mmiitfif_fab module.              |        |
|---------------|------------------|----------------------------------------------------------------------|--------|
| 11            | STFENREQ         | When asserted, requests enabling of the mmiitfif_sys module. When    | RW     |
|               |                  | negated, requests disabling of the mmiitfif_sys module.              |        |
| 10            | FRFENREQ         | When asserted, requests enabling of the mmiirfif_fab module. When    | RW     |
|               |                  | negated, requests disabling of the mmiirfif_fab module.              |        |
| 9             | SRFENREQ         | When asserted, requests enabling of the mmiirfif_sys module. When    | RW     |
|               |                  | negated, requests disabling of the mmiirfif_sys module.              |        |
| 8             | WTMENREQ         | When asserted, requests enabling of the mmiitfif_wtm module. When    | RW     |
|               |                  | negated, requests disabling of the mmiitfif_wtm module.              |        |
| 7:5           | Reserved         | Writing has no effect, read as zero.                                 | R      |
| 4             | HSTRSTFT         | When asserted, this bit will place the mmiitfif_fab module in reset. | RW     |
| 3             | HSTRSTST         | When asserted, this bit will place the mmiitfif_sys module in reset. | RW     |
| 2             | HSTRSTFR         | When asserted, this bit will place the mmiirfif_fab module in reset. | RW     |
| 1             | HSTRSTSR         | When asserted, this bit will place the mmiirfif_sys module in reset. | RW     |
| 0             | HSTRSTWT         | When asserted, this bit will place the mmiitfif_wtm module in reset. | RW     |
| 11.5.4.       | 2 CFG_R1         | ternal used on                                                       |        |
| CFO           | G_R1             | <u>ر ک</u> 0x134                                                     | 4B004C |
| <b>Bit</b> 31 | 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2      | 1 0    |
|               |                  |                                                                      |        |

### 11.5.4.2 CFG\_R1

### CFG\_R1

### 0x134B004C

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

| Reserved | CEGERTH COM | CFGXOFFRTX |
|----------|-------------|------------|
|          | efelora     |            |

### 

| Bits  | Name     | Description                                                                     | RW |
|-------|----------|---------------------------------------------------------------------------------|----|
| 31:28 | Reserved | Writing has no effect, read as zero.                                            | R  |
| 27:16 | CFGFRTH  | This hex value represents the minimum number of 4-byte locations                | RW |
|       |          | that will be simultaneously stored in the receive RAM, relative to the          |    |
|       |          | beginning of the frame being input, before <b>frrdy</b> may be asserted.        |    |
|       |          | Note that frrdy will be latent a certain amount of time due to fabric           |    |
|       |          | transmit clock to system transmit clock time domain crossing, and               |    |
|       |          | conditional on <b>fracpt</b> assertion. When set to maximum value, <b>frrdy</b> |    |
|       |          | may be asserted only after the completion of the input frame. The               |    |
|       |          | value of this register must be greater than 18d when hstdrplt64 is              |    |
|       |          | asserted; the additional two bits allow for overhead. The register              |    |
|       |          | length shown is for a receive RAM with 12 address bits (16K Bytes).             |    |
|       |          | The register length will vary with the addressable RAM size used.               |    |
| 15:0  | CFGXOFFR | This hex value represents the number of pause quanta (64 bit times)             | RW |

### 272

JZ4770 Mobile Application Processor Peripherals Programming Manual



| ſ | ТХ | that occur after an XOFF pause frame has been acknowledged            |  |
|---|----|-----------------------------------------------------------------------|--|
|   |    | (psack), while the M-MIIFIF receive storage level has remained        |  |
|   |    | higher than the low watermark, until the M-MIIFIF will reassert tpcf. |  |

### 11.5.4.3 CFG\_R2

# BIT 3 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 O I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I <th colspan=

| Bits  | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                           | RW |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 31:29 | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                                                                                                                                  | R  |
| 28:16 | CFGHWM   | This hex value represents the maximum number of 4-byte words that will be simultaneously stored in the receive RAM before <b>tpcf</b> and <b>psval</b> will facilitate an XOFF pause control frame. The register length shown is for a receive RAM with 12 address bits (16K Bytes). The register length will vary with the addressable RAM size used.                                                                                | RW |
| 15:13 | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                                                                                                                                  | R  |
| 12:0  | CFGLWM   | This hex value represents the minimum number of 4-byte words that<br>will be simultaneously stored in the receive RAM before <b>tpcf</b> and<br><b>psval</b> will facilitate an XON pause control frame in response to a<br>previously transmitted XOFF pause control frame. The register length<br>shown is for a receive RAM with 12 address bits (16K Bytes). The<br>register length will vary with the addressable RAM size used. | RW |

### 11.5.4.4 CFG\_R3

|     | CFO | G_R | 13  |    |    |    |    |    |    |    |     |     |    |    |    |    |    |     |     |    |    |    |   |   |   |    |     |   | <b>0</b> x | 134 | B0( | )54 |
|-----|-----|-----|-----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|-----|-----|----|----|----|---|---|---|----|-----|---|------------|-----|-----|-----|
| Bit | 31  | 30  | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20  | 19 | 18 | 17 | 16 | 15 | 14  | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5   | 4 | 3          | 2   | 1   | 0   |
|     | R   | ese | rve | d  |    |    |    |    | CF | GH | WIV | IFT |    |    |    |    | R  | ese | rve | d  |    |    |   |   | С | FG | FTT | Ή |            |     |     |     |
| RST | 0   | 0   | 0   | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1   | 1  | 1  | 1  | 1  | 0  | 0   | 0   | 0  | 1  | 1  | 1 | 1 | 1 | 1  | 1   | 1 | 1          | 1   | 1   | 1   |



| Bits                                      | Name       | Description                                                                     | RW             |  |  |  |  |  |  |  |  |  |  |
|-------------------------------------------|------------|---------------------------------------------------------------------------------|----------------|--|--|--|--|--|--|--|--|--|--|
| 31:28                                     | Reserved   | Writing has no effect, read as zero.                                            | R              |  |  |  |  |  |  |  |  |  |  |
| 27:16                                     | CFGHWMFT   | This hex value represents the maximum number of 4-byte locations                | RW             |  |  |  |  |  |  |  |  |  |  |
|                                           |            | that will be simultaneously stored in the transmit RAM before fthwm             |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | vill be asserted. Note that <b>fthwm</b> has two <b>ftclk</b> clock periods of  |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | latency before assertion or negation. This should be considered when            |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | calculating any headroom required for maximum size packets. The                 |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | register length shown is for a transmit RAM with 11 address bits (8K            |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | Bytes). The register length will vary with the addressable RAM size             |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | used.                                                                           |                |  |  |  |  |  |  |  |  |  |  |
| 15:12                                     | Reserved   | Writing has no effect, read as zero.                                            | R              |  |  |  |  |  |  |  |  |  |  |
| 11:0                                      | CFGFTTH    | This hex value represents the minimum number of 4-byte locations                | RW             |  |  |  |  |  |  |  |  |  |  |
|                                           |            | that will be simultaneously stored in the transmit RAM, relative to the         |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | beginning of the frame being input, before <b>tpsf</b> will be asserted. Note   |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | that <b>tpsf</b> will be latent a certain amount of time due to fabric transmit |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | clock to system transmit clock time domain crossing. When set to                |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | maximum value, <b>tpsf</b> will be asserted only after the completion of the    |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | input frame. The register length shown is for a transmit RAM with 11            |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | address bits (8K Bytes). The register length will vary with the                 |                |  |  |  |  |  |  |  |  |  |  |
|                                           |            | addressable RAM size used.                                                      |                |  |  |  |  |  |  |  |  |  |  |
| 11.5.4.5 CFG_R4<br>CFG_R4 0126 001 0x134E |            |                                                                                 |                |  |  |  |  |  |  |  |  |  |  |
|                                           | · • · •_·· | 196°                                                                            |                |  |  |  |  |  |  |  |  |  |  |
| CEC                                       | R4         |                                                                                 | 4 <b>B00</b> 5 |  |  |  |  |  |  |  |  |  |  |
|                                           | -          | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2                 | 1 0            |  |  |  |  |  |  |  |  |  |  |

### 11.5.4.5 CFG\_R4

### CFG\_R4

| 04         | 24 |    | ~ ~ ~ |  |
|------------|----|----|-------|--|
| <b>0x1</b> | 34 | BU | 058   |  |

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|---|---|---|---|---|---|
|     |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |   |   |   |   |   |   |
|     |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |   |   |   |   |   |   |
|     |    |    |    |    |    |    | _  |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |   |   |   |   |   |   |
|     |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |    | 1  | IS | rfĽ | IR | -RI | 1 |   |   |   |   |   |
|     |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |   |   |   |   |   |   |
|     |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |   |   |   |   |   |   |
| ПОТ |    | 0  | _  | 0  | 0  | 0  | 0  | _   | ~    | 0  | ~  | 0  | 0  | 0  | 0  | 0  |    | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0   | 0 | 0 | 0 | 0 | 0 | 0 |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0   | 0 | 0 | 0 | 0 | 0 | 0 |

| Bits  | Name      | Description                                                             | RW |
|-------|-----------|-------------------------------------------------------------------------|----|
| 31:16 | Reserved  | Writing has no effect, read as zero.                                    | R  |
| 15:0  | HSTFLTRFR | These configuration bits are used to signal the drop frame conditions   | RW |
|       | М         | internal to the M-MIIFIF. The bits correspond to the Receive Statistics |    |
|       |           | Vector on a one-to-one basis. For example bit 0 corresponds to          |    |
|       |           | RSV[16], and bit 1 corresponds to RSV[17]. When these bits              |    |
|       |           | compare and the don't care is not asserted, the frame will be           |    |
|       |           | dropped. This is true for all hstfltrm bits with the exception of       |    |
|       |           | hstfltrfrm[15], which is used to compare with the unicast address       |    |
|       |           | match input port of the M-MIIFIF.                                       |    |

274



| The se  | tting of these bits, along with their don't care values in the   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hstfltr | rmdc configuration registers, create the filter that will assert |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| the src | Irpfrm output if the receive frame does not pass the             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| accept  | able conditions and should be dropped by the system. For         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| examp   | le, if you want to drop a frame that contains a FCS Error, bit 4 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| would   | be set, and all receive frames that have RSV[20] asserted        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| would   | be dropped.                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         | hstfltrf<br>the srd<br>accepta<br>examp<br>would b               | The setting of these bits, along with their don't care values in the<br><b>hstfltrfrmdc</b> configuration registers, create the filter that will assert<br>the <b>srdrpfrm</b> output if the receive frame does not pass the<br>acceptable conditions and should be dropped by the system. For<br>example, if you want to drop a frame that contains a FCS Error, bit 4<br>would be set, and all receive frames that have RSV[20] asserted<br>would be dropped. |

### 11.5.4.6 CFG\_R5



| Bits  | Name      | CO <sup>TH</sup> Description                                              | RW |
|-------|-----------|---------------------------------------------------------------------------|----|
| 31:23 | Reserved  | Writing has no effect, read as zero.                                      | R  |
| 22    | CFGHDPLX  | Assertion of this bit configures the M-MIIFIF to enable half-duplex       | RW |
|       |           | backpressure as a flow control mechanism. Deassertion of this bit         |    |
|       | 01        | configures the M-MIIFIF to enable pause frames as a flow control          |    |
|       | 202       | mechanism.                                                                |    |
| 21 🔨  | SRFULL    | Assertion of this read-only bit indicates that the maximum capacity of    | RW |
| -     |           | the receive FIFO storage has been met or exceeded. If the cfgfrth         |    |
|       |           | bits are not all set, exceeding the FIFO storage capacity may result in   |    |
|       |           | data frame truncation as opposed to full frame deletion. Frame            |    |
|       |           | truncation is not recommended as an operation of the M-MIIFIF. The        |    |
|       |           | bit should be polled until it reaches the expected value.                 |    |
| 20    | HSTSRFULL | This bit should be written asserted when it is desired to clear the       | RW |
|       | CLR       | srfull indicator bit. After hstfullclr assertion, srfull should be read   |    |
|       |           | until it becomes deasserted. hstfullclr should then be written            |    |
|       |           | deasserted for the indicator to become operational again.                 |    |
| 19    | CLKENMOD  | This bit should be asserted when TXCENI is being toggled. This is         | RW |
|       | E         | done when the PE-MACMII is integrated with the PE-RMII.                   |    |
| 18    | HSTDRPLT6 | Setting this bit will cause the frame to be dropped if a receive frame is | RW |
|       | 4         | less than 64 bytes in length. This bit should not be asserted if cfgfrth  |    |
|       |           | is less than 12h.                                                         |    |



| 17:16 | Reserved  | Writing has no effect, read as zero.                                    | R  |
|-------|-----------|-------------------------------------------------------------------------|----|
| 15:0  | HSTFLTRFR | These configuration bits indicate which Receive Statistics Vectors are  | RW |
|       | MDC       | don't cares for M-MIIFIF frame drop circuitry. The bits correspond to   |    |
|       |           | the Receive Statistics Vector on a one per one basis. For example, bit  |    |
|       |           | 0 corresponds to RSV[16], and bit 1 corresponds to RSV[17]. Setting     |    |
|       |           | of a hstfltrfrmdc bit will indicate a don't care for that RSV bit.      |    |
|       |           | Clearing the bit will look for a matching level on the corresponding    |    |
|       |           | hstfltrfrm bit. If a match is made, then the frame is dropped. All bits |    |
|       |           | should be set when cfgfrth bits are not all set.                        |    |

### 11.5.4.7 RAM\_ACC\_R0



| Bits  | Name     | Description                                                           | RW |
|-------|----------|-----------------------------------------------------------------------|----|
| 31    | HSTTRAMW | Host transmit RAM write request. Requests the handshake of            | RW |
|       | REQ      | hsttramwdat and hsttramwadx values to the transmit FIFO RAM.          |    |
|       | er       | Should only be asserted while hsttramwack is negated and while the    |    |
| 1     | 018-     | transmit data path is disabled from receiving data and in a steady    |    |
|       |          | state. It should only be negated after receiving an asserted          |    |
|       |          | hsttramwack.                                                          |    |
| 30    | HSTTRAMW | Host transmit RAM write acknowledge. Signifies the acceptance of      | R  |
|       | ACK      | hsttramwdat and hsttramwadx values to the transmit FIFO RAM or        |    |
|       |          | mmiitfif_fab module. Will only be asserted or negated following       |    |
|       |          | assertion or negation of hsttramwreq.                                 |    |
| 29:24 | Reserved | Writing has no effect, read as zero.                                  | R  |
| 23:16 | HSTTRAMW | Host transmit RAM write data. This is the upper byte of transmit FIFO | RW |
|       | DAT      | RAM data that will be written at the address of hsttramwadx[10:0] if  |    |
|       |          | hsttramwadx[12] is negated and hsttramwreq is asserted. This part     |    |
|       |          | of the transmit FIFO RAM contains control information for the frame   |    |
|       |          | as follows:                                                           |    |
|       |          | hsttramwdat[39] = ftcfrm                                              |    |
|       |          | hsttramwdat[38:37] = ftpppadmode[1:0]                                 |    |

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



|       |          | hsttramwdat[36] = ftppen                                                                                                                                                                                                                                                                                          |    |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|       |          | hsttramwdat[35] = ftppgenfcs                                                                                                                                                                                                                                                                                      |    |
|       |          | hsttramwdat[34] = fteof                                                                                                                                                                                                                                                                                           |    |
|       |          | hsttramwdat[33:32] = ftdatnvld[1:0]                                                                                                                                                                                                                                                                               |    |
| 15:13 | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                              | R  |
| 12:0  | HSTTRAMW | Host transmit RAM write address. This field has different functionality                                                                                                                                                                                                                                           | RW |
|       | ADX      | based on the value of hsttramwadx[12] and whether the M-MIIFIF                                                                                                                                                                                                                                                    |    |
|       |          | FIFO RAM access register 0 is being written to or read from.                                                                                                                                                                                                                                                      |    |
|       |          | When read from, <b>hsttramwadx[11:0]</b> field contains the actual write pointer value of the mmiitfif_fab module.                                                                                                                                                                                                |    |
|       |          | When written to, the <b>hsttramwadx</b> register will be loaded. If<br><b>hsttramwadx[12]</b> is low, <b>hsttramwadx[10:0]</b> will be the transmit<br>RAM address to which <b>hsttramwdat</b> is written. If <b>hsttramwadx[12]</b> is<br>high, <b>hsttramwadx[11:0]</b> contains the pointer value that will be |    |
|       |          | written to the mmiitfif_fab module.                                                                                                                                                                                                                                                                               |    |
|       |          | The register definition for hsttramwadx[10:0] is for a transmit RAM                                                                                                                                                                                                                                               |    |
|       |          | with 11 address bits (8K Bytes). The register length will vary with the                                                                                                                                                                                                                                           |    |
|       |          | addressable RAM size used. The definition of hsttramwadx[12:11]                                                                                                                                                                                                                                                   |    |
|       |          | will shift to remain left-justified in the register.                                                                                                                                                                                                                                                              |    |
|       |          |                                                                                                                                                                                                                                                                                                                   |    |

11.5.4.8 RAM\_ACC\_R1 RAM\_ACC\_R1 0x134B0064 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

#### **HSTTRAMWDAT**

| Bits | Name     | Description                                                         | RW |
|------|----------|---------------------------------------------------------------------|----|
| 31:0 | HSTTRAMW | Host transmit RAM write data. This is the lower 4 bytes of transmit | RW |
|      | DAT      | FIFO RAM data that will be written at the address of                |    |
|      |          | hsttramwadx[10:0] if hsttramwadx[12] is negated and                 |    |
|      |          | hsttramwreq is asserted.                                            |    |



## 11.5.4.9 RAM\_ACC\_R2

|     | RA          | M           | ACO | C_R  | 2   |     |    |    |    |    |    |     |    |     |    |    |    |      |     |    |    |    |   |    |     |     |      |     | <b>0</b> x | 134 | <b>B0</b> | 068 |
|-----|-------------|-------------|-----|------|-----|-----|----|----|----|----|----|-----|----|-----|----|----|----|------|-----|----|----|----|---|----|-----|-----|------|-----|------------|-----|-----------|-----|
| Bit | 31          | 30          | 29  | 28 2 | 27  | 26  | 25 | 24 | 23 | 22 | 21 | 20  | 19 | 18  | 17 | 16 | 15 | 14   | 13  | 12 | 11 | 10 | 9 | 8  | 7   | 6   | 5    | 4   | 3          | 2   | 1         | 0   |
|     | HSTTRAMRREQ | HSTTRAMRACK |     | Re   | ese | rve | d  |    |    | н  | ST | TRA | MF | RDA | АТ |    | Re | serv | /ed |    |    |    |   | HS | TTF | RAN | /IRA | ۰DX |            |     |           |     |
| RST | 0           | 0           | 0   | 0    | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0   | 0  | 0  | 0  | 0    | 0   | 0  | 0  | 0  | 0 | 0  | 0   | 0   | 0    | 0   | 0          | 0   | 0         | 0   |

| Bits  | Name     | Description                                                          | RW |
|-------|----------|----------------------------------------------------------------------|----|
| 31    | HSTTRAMR | Host transmit RAM read request. Requests the handshake of            | RW |
|       | REQ      | hsttramradx values to the transmit FIFO RAM and hsttramrdat          |    |
|       |          | values from the transmit FIFO RAM. Should only be asserted while     |    |
|       |          | hsttramrack is negated and while the transmit data path is disabled  |    |
|       |          | from receiving data and in a steady state. It should only be negated |    |
|       |          | after receiving an asserted hsttramrack                              |    |
| 30    | HSTTRAMR | Host transmit RAM read acknowledge. Signifies the acceptance of      | R  |
|       | ACK      | hsttramradx values to the transmit FIFO RAM and reception of         |    |
|       |          | hsttramrdat from the transmit FIFO RAM location addressed. Will      |    |
|       |          | only be asserted or negated following assertion or negation of       |    |
|       |          | hsttramrreg.                                                         |    |
| 29:24 | Reserved | Writing has no effect, read as zero.                                 | R  |
| 23:16 | HSTTRAMR | Host transmit RAM read data. This is the upper byte of transmit FIFO | R  |
|       | DAT      | RAM data that was read at the address of hsttramradx[10:0] if        |    |
| 1     | ons      | hsttramradx[12] is negated and hsttramrreq is asserted. This part    |    |
| )     |          | of the transmit FIFO RAM contains control information for the frame  |    |
|       |          | as follows:                                                          |    |
|       |          | hsttramrdat[39] = ftcfrm                                             |    |
|       |          | hsttramrdat[38:37] = ftpppadmode[1:0]                                |    |
|       |          | hsttramrdat[36] = ftppen                                             |    |
|       |          | hsttramrdat[35] = ftppgenfcs                                         |    |
|       |          | hsttramrdat[34] = fteof                                              |    |
|       |          | hsttramrdat[33:32] = ftdatnvld[1:0]                                  |    |
| 15:13 | Reserved | Writing has no effect, read as zero.                                 | R  |
| 12:0  | HSTTRAMR | Host transmit RAM read address. If hsttramradx[12] is written low,   | RW |
|       | ADX      | hsttramradx[10:0] is the transmit FIFO RAM address that              |    |
|       |          | hsttramrdat is read from. If hsttramradx[12] is written high,        |    |
|       |          | hsttramradx[11:0] contains the pointer value read from the           |    |
|       |          | mmiitfif_sys module.                                                 |    |

#### 278



Г

Τ

|  | The register definition for hsttramradx[10:0] is for a transmit RAM     |  |
|--|-------------------------------------------------------------------------|--|
|  | with 11 address bits (8K Bytes). The register length will vary with the |  |
|  | addressable RAM size used. The definition of hsttramradx[12:11]         |  |
|  | will shift to remain left-justified in the register.                    |  |

#### 11.5.4.10 RAM\_ACC\_R3

|     | <b>RAM_ACC_R3 0x134B006</b> 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1         HSTTRAMRDAT |    |    |    |    |    |    |    |    |    |    |    |    |    |    | )6C |    |     |    |    |    |    |   |   |   |   |   |    |          |   |   |   |
|-----|-------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|----|----|----|---|---|---|---|---|----|----------|---|---|---|
| Bit | 31                                                                                                                                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3        | 2 | 1 | 0 |
|     |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |   |   |   |   |   |    |          |   |   |   |
|     |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |   |   |   |   |   |    |          |   |   |   |
|     |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    | Н  | ST | rr/ | MF | RDA | Т  |    |    |    |   |   |   |   |   |    |          |   |   |   |
|     |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |   |   |   |   |   | ~  | <b>1</b> | Z |   |   |
|     |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |   |   |   | 1 | ( | 2) | 1        |   |   |   |
| RST | 0                                                                                                                                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0   | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0  | 0        | 0 | 0 | 0 |
|     |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |   | 1 | 5 |   |   |    |          |   |   |   |

| Bits | Name     | Description                                                        | RW |
|------|----------|--------------------------------------------------------------------|----|
| 31:0 | HSTTRAMR | Host transmit RAM read data. This is the lower 4 bytes of transmit | R  |
|      | DAT      | FIFO RAM data that is read at the address of hsttramradx[10:0] if  |    |
|      |          | hsttramradx[12] is negated and hsttramrreq is asserted.            |    |

|     |             |             |    |    |     |     | ł   | nst     | tran | nra | dx  | [12    | <b>?]</b> is | ne  | gat | ted | an | d h  | stt | ran | nrre | eq | is a | isse | erte | ed. | -    | -   |    |     |     |     |
|-----|-------------|-------------|----|----|-----|-----|-----|---------|------|-----|-----|--------|--------------|-----|-----|-----|----|------|-----|-----|------|----|------|------|------|-----|------|-----|----|-----|-----|-----|
| 11. |             | .11<br>M_/  |    |    |     |     | 5_F | ₹4<br>€ | 51   | 0   | Z   | e<br>e | )•           | C   | J.  |     |    |      |     |     |      |    |      |      |      |     |      |     | 0x | 134 | BOO | )70 |
| Bit | 31          | 30          | 29 | 28 | 27  | 26  | 25  | 24      | 23   | 22  | 21  | 20     | 19           | 18  | 17  | 16  | 15 | 14   | 13  | 12  | 11   | 10 | 9    | 8    | 7    | 6   | 5    | 4   | 3  | 2   | 1   | 0   |
|     | HSTRRAMWREQ | HSTRRAMWACK |    | R  | ese | rve | d   |         |      | HS  | STR | RA     | .MV          | VDA | ιT  |     | Re | serv | red |     |      |    | ł    | HST  | ſRF  | RAM | 1774 | ۸DX | (  |     |     |     |
| RST | 0           | 0           | 0  | 0  | 0   | 0   | 0   | 0       | 0    | 0   | 0   | 0      | 0            | 0   | 0   | 0   | 0  | 0    | 0   | 0   | 0    | 0  | 0    | 0    | 0    | 0   | 0    | 0   | 0  | 0   | 0   | 0   |

| Bits | Name     | Description                                                          | RW |
|------|----------|----------------------------------------------------------------------|----|
| 31   | HSTRRAMW | Host receive RAM write request. Requests the handshake of            | RW |
|      | REQ      | hstrramwdat and hstrramwadx values to the receive FIFO RAM.          |    |
|      |          | Should only be asserted while hstrramwack is negated and while the   |    |
|      |          | receive data path is disabled from receiving data and is in a steady |    |
|      |          | state. It should only be negated after receiving an asserted         |    |
|      |          | hstrramwack.                                                         |    |



| 00    |          |                                                                          | _  |
|-------|----------|--------------------------------------------------------------------------|----|
| 30    | HSTRRAMW | Host receive RAM write acknowledge. Signifies the acceptance of          | R  |
|       | ACK      | hstrramwdat and hstrramwadx values to the receive FIFO RAM or            |    |
|       |          | mmiirfif_sys module. Will only be asserted or negated following          |    |
|       |          | assertion or negation of <b>hstrramwreq</b> .                            |    |
| 29:24 | Reserved | Writing has no effect, read as zero.                                     | R  |
| 23:16 | HSTRRAMW | Host receive RAM write data. This is the upper byte of receive FIFO      | RW |
|       | DAT      | RAM data that will be written at the address of hstrramwadx[11:0] if     |    |
|       |          | hstrramwadx[13] is negated and hstrramwreq is asserted. This part        |    |
|       |          | of the receive FIFO RAM contains control information for the frame as    |    |
|       |          | follows:                                                                 |    |
|       |          | hstrramwdat[35] = frsof                                                  |    |
|       |          | hstrramwdat[34] = freof                                                  |    |
|       |          | hstrramwdat[33:32] = frdatnvld[1:0]                                      |    |
| 15:13 | Reserved | Writing has no effect, read as zero.                                     | R  |
| 12:0  | HSTRRAMW | Host receive RAM write address. This field has different functionality   | RW |
|       | ADX      | based on the value of hstrramwadx[13] and whether the M-MIFIF            |    |
|       |          | FIFO RAM access register 4 is being written to or read from.             |    |
|       |          | When read from, hstrramwadx[12:0] field contains the actual write        |    |
|       |          | pointer value of the mmiirfif_sys module.                                |    |
|       |          | When written to, the hstrramwadx register will be loaded. If             |    |
|       |          | hstrramwadx[13] is low, hstrramwadx[11:0] will be the receive            |    |
|       |          | FIFO RAM address to which hstrramwdat is written. If                     |    |
|       |          | hstrramwadx[13] is high, hstrramwadx[12:0] contains the pointer          |    |
|       |          | value that will be written to the mmiirfif_sys module.                   |    |
|       |          | The register definition for hstrramwadx[12:0] is for a receive RAM       |    |
|       |          | with 12 address bits (16K bytes). The register length will vary with the |    |
|       | $\sim$   | addressable RAM size used. The definition of hstrramwadx[13] will        |    |
|       |          |                                                                          |    |

## 11.5.4.12 RAM\_ACC\_R5

|     | RA | M  | ACO | C_R | 5  |    |    |    |    |    |    |    |    |    |     |     |    |     |    |    |    |    |   |   |   |   |   |   | <b>0</b> x <sup>•</sup> | 134 | <b>B0</b> ( | 074 |
|-----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|-----|----|----|----|----|---|---|---|---|---|---|-------------------------|-----|-------------|-----|
| Bit | 31 | 30 | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                       | 2   | 1           | 0   |
|     |    |    |     |     |    |    |    |    |    |    |    |    |    |    |     |     |    |     |    |    |    |    |   |   |   |   |   |   |                         |     |             |     |
|     |    |    |     |     |    |    |    |    |    |    |    |    |    |    |     |     |    |     |    |    |    |    |   |   |   |   |   |   |                         |     |             |     |
|     |    |    |     |     |    |    |    |    |    |    |    |    |    | H  | STF | RRA | MV | VDA | ۸T |    |    |    |   |   |   |   |   |   |                         |     |             |     |
|     |    |    |     |     |    |    |    |    |    |    |    |    |    |    |     |     |    |     |    |    |    |    |   |   |   |   |   |   |                         |     |             |     |
|     |    |    |     |     |    |    |    |    |    |    |    |    |    |    |     |     |    |     |    |    |    |    |   |   |   |   |   |   |                         |     |             |     |
| RST | 0  | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0   | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0                       | 0   | 0           | 0   |

| Bits | Name     | Description                                                       | RW |
|------|----------|-------------------------------------------------------------------|----|
| 15:0 | HSTRRAMW | Host receive RAM write data. This is the lower 4 bytes of receive | RW |

280



| DAT | FIFO RAM data that will be written at the address of |  |
|-----|------------------------------------------------------|--|
|     | hstrramwadx[11:0] if hsttramwadx[13] is negated and  |  |
|     | hstrramwreq is asserted.                             |  |

#### 11.5.4.13 RAM\_ACC\_R6

# OUTO <th col

| Bits  | Name     | Description 1                                                         | RW |
|-------|----------|-----------------------------------------------------------------------|----|
| 31    | HSTRRAMR | Host receive RAM read request. Requests the handshake of              | RW |
|       | REQ      | hstrramradx values to the receive FIFO RAM and hstrramrdat            |    |
|       |          | values from the receive FIFO RAM. Should only be asserted while       |    |
|       |          | hstrramrack is negated and while the receive data path is disabled    |    |
|       |          | from receiving data and in a steady state. It should only be negated  |    |
|       |          | after receiving an asserted hstrramrack.                              |    |
| 30    | HSTRRAMR | Host receive RAM read acknowledge. Signifies the acceptance of        | R  |
|       | ACK      | hstrramradx values to the receive FIFO RAM and reception of           |    |
|       | er       | hstrramrdat from the receive FIFO RAM location addressed. Will        |    |
|       | n8-      | only be asserted or negated following assertion or negation of        |    |
|       |          | hstrramrreq.                                                          |    |
| 29:24 | Reserved | Writing has no effect, read as zero.                                  | R  |
| 23:16 | HSTRRAMR | Host receive RAM read data. This is the upper byte of receive FIFO    | R  |
|       | DAT      | RAM data that was read at the address of hstrramradx[10:0] if         |    |
|       |          | hstrramradx[13] is negated and hstrramrreq is asserted. This part     |    |
|       |          | of the receive FIFO RAM contains control information for the frame as |    |
|       |          | follows:                                                              |    |
|       |          | hstrramrdat[35] = frsof                                               |    |
|       |          | hstrramrdat[34] = freof                                               |    |
|       |          | hstrramrdat[33:32] = frdatnvld[1:0]                                   |    |
| 15:13 | Reserved | Writing has no effect, read as zero.                                  | R  |
| 12:0  | HSTRRAMR | Host receive RAM read address. If hstrramradx[13] is written low,     | RW |
|       | ADX      | hstrramradx[11:0] is the receive FIFO RAM address that                |    |
|       |          | hstrramrdat is read from. If hstrramradx[13] is written high,         |    |



| hstrramradx[12:0] contains the pointer value read from the               |
|--------------------------------------------------------------------------|
| mmiirfif_fab module.                                                     |
| The register definition for hstrramradx[12:0] is for a receive RAM       |
| with 12 address bits (16K bytes). The register length will vary with the |
| addressable RAM size used. The definition of hstrramradx[13] will        |
| shift to remain left-justified in the register.                          |

#### 11.5.4.14 RAM\_ACC\_R7

|     | RA | M  | AC | C_R | 7  |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |    |   |   |    | <b>0</b> x′ | 134 | B00 | <b>7</b> 70 |
|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|----|---|---|----|-------------|-----|-----|-------------|
| Bit | 31 | 30 | 29 | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4  | 3           | 2   | 1   | 0           |
|     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |    |   |   |    |             |     |     |             |
|     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |    |   |   |    |             |     |     |             |
|     |    |    |    |     |    |    |    |    |    |    |    |    |    | Н  | ST | RRA | MR | DA | Т  |    |    |    |   |   |    |   |   |    | $\lambda$   | Y   |     |             |
|     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |    | 1 | ( | 27 | 1           |     |     |             |
|     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   | .0 | 0 | - |    |             |     |     |             |
| RST | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0  | 0 | 0 | 0  | 0           | 0   | 0   | 0           |

| Bits | Name     | Description                                                       | RW |
|------|----------|-------------------------------------------------------------------|----|
| 31:0 | HSTRRAMR | Host receive RAM read data. This is the lower 4 bytes of receive  | R  |
|      | DAT      | FIFO RAM data that is read at the address of hstrramradx[11:0] if |    |
|      |          | hstrramradx[13] is negated and hstrramrreq is asserted.           |    |
| ý    | ong_eif  | reloin                                                            |    |

JZ4770 Mobile Application Processor Peripherals Programming Manual Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



### 11.6 MII Module

#### 11.6.1 Overview

The MII module is a full function 10 / 100 Mbps Media Access Controller modules with Media Independent Interface and optional interface modules.

#### 11.6.2 Register Map

| RW     | Reset Value                              | Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Access Size                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RW     | 0x00008000                               | 0x134B0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B0004                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B0008                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x0000000                                | 0x134B000C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x0000370f                               | 0x134B0010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000600                               | 0x134B0014                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00001000                               | 0x134B0018                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B001C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B0020                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B0024                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B0028                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B002C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B0030                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW 🔨 🔘 | 0x0000000                                | 0x134B0034                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RWC    | 0x00000000                               | 0x134B0040                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B0044                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RW     | 0x00000000                               | 0x134B0048                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|        | RW R | RW       0x00008000         RW       0x0000000         RW       0x0000000 | RW         0x00008000         0x134B0000           RW         0x0000000         0x134B0004           RW         0x0000000         0x134B0008           RW         0x0000000         0x134B000C           RW         0x0000000         0x134B0010           RW         0x00000600         0x134B0010           RW         0x00000600         0x134B0014           RW         0x00000000         0x134B0012           RW         0x0000000         0x134B0012           RW         0x0000000         0x134B0020           RW         0x0000000         0x134B0024           RW         0x0000000         0x134B0028           RW         0x0000000         0x134B0020           RW         0x0000000         0x134B0020           RW         0x0000000         0x134B0020           RW         0x0000000         0x134B0030           RW         0x0000000         0x134B0034           RW         0x0000000         0x134B0040           RW         0x0000000         0x134B0044 |

#### 11.6.3 Register Description

#### 11.6.3.1 MAC1

|     | ма | C1 |    |    |    |    |    |     |      |    |    |    |    |    |    |    |         |         |           |          |          |                 |          |                 |   |          |   |          | <b>0</b> x | 134             | <b>B0</b> ( | 000   |
|-----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|---------|---------|-----------|----------|----------|-----------------|----------|-----------------|---|----------|---|----------|------------|-----------------|-------------|-------|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15      | 14      | 13        | 12       | 11       | 10              | 9        | 8               | 7 | 6        | 5 | 4        | 3          | 2               | 1           | 0     |
|     |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    | SFT_RST | SIM_RST | RMII_MODE | Reserved | RST_RMCS | <b>RST_RFUN</b> | RST_TMCS | <b>RST_TFUN</b> |   | Reserved |   | LOOPBACK | TX_PAUSE   | <b>RX_PAUSE</b> | PASS_ALL    | RX_EN |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1       | 0       | 0         | 0        | 0        | 0               | 0        | 0               | 0 | 0        | 0 | 0        | 0          | 0               | 0           | 0     |



| Name      | Description                                                                                                                                             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SFT_RST   | Setting this bit will put all modules within the PE-MACMII in reset                                                                                     | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           |                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| SIM_RST   |                                                                                                                                                         | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | within the Transmit Function.                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| RMII_MODE | RMII_MODE.                                                                                                                                              | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Reserved  | Writing has no effect, read as zero.                                                                                                                    | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| RST_RMCS  | Setting this bit will put the MAC Control Sublayer / Receive domain                                                                                     | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | logic in reset.                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| RST_RFUN  | Setting this bit will put the Receive Function logic in reset.                                                                                          | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| RST_TMCS  | Setting this bit will put the MAC Control Sublayer / Tx domain logic in                                                                                 | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | reset.                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| RST_TFUN  | Setting this bit will put the Transmit Function logic in reset.                                                                                         | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Reserved  | Writing has no effect, read as zero.                                                                                                                    | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| LOOPBACK  | Setting this bit will cause the MAC Transmit interface to be loop                                                                                       | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | backed to the MAC Receive interface. Clearing this bit results in                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | normal operation.                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TX_PAUSE  | When enabled, PAUSE Flow Control frames are allowed to be                                                                                               | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | transmitted. When disabled, Flow Control frames are blocked.                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| RX_PAUSE  | When enabled, the MAC acts upon received PAUSE Flow Control                                                                                             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | frames. When disabled, received PAUSE Flow Control frames are                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | ignored.                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| PASS_ALL  | When enabled, the MAC will indicate PASS CURRENT RECEIVE                                                                                                | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | FRAME for all frames regardless of type (normal vs. Control). When                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | disabled, the MAC de-asserts PASS CURRENT RECEIVE FRAME                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| : {       | for valid Control frames.                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| RX_EN     | Set this to allow receive frames to be received. Internally the MAC                                                                                     | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| mg_       | synchronizes this control bit to the incoming receive stream and                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | outputs SYNCHRONIZED RECEIVE ENABLE, to be used by host                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | system to qualify receive frames.                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | SFT_RST<br>SIM_RST<br>RMII_MODE<br>Reserved<br>RST_RMCS<br>RST_RFUN<br>RST_TMCS<br>RST_TFUN<br>Reserved<br>LOOPBACK<br>TX_PAUSE<br>RX_PAUSE<br>PASS_ALL | SFT_RST       Setting this bit will put all modules within the PE-MACMII in reset except the Host Interface. The Host Interface is reset via HRST.         SIM_RST       Setting this bit will cause a reset to the random number generator within the Transmit Function.         RMII_MODE       RMII_MODE.         Reserved       Writing has no effect, read as zero.         RST_RMCS       Setting this bit will put the MAC Control Sublayer / Receive domain logic in reset.         RST_RFUN       Setting this bit will put the Receive Function logic in reset.         RST_TFUN       Setting this bit will put the MAC Control Sublayer / Tx domain logic in reset.         RST_TFUN       Setting this bit will put the Transmit Function logic in reset.         RST_TFUN       Setting this bit will cause the MAC Transmit interface to be loop backed to the MAC Receive interface. Clearing this bit results in normal operation.         TX_PAUSE       When enabled, PAUSE Flow Control frames are allowed to be transmitted. When disabled, Flow Control frames are blocked.         RX_PAUSE       When enabled, the MAC acts upon received PAUSE Flow Control frames are ignored.         PASS_ALL       When enabled, the MAC de-asserts PASS CURRENT RECEIVE FRAME for all frames regardless of type (normal vs. Control). When disabled, the MAC de-asserts PASS CURRENT RECEIVE FRAME for all frames.         RX_EN       Set this to allow receive frames to be received. Internally the MAC synchronizes this control bit to the incoming receive stream and outputs SYNCHRONIZED RECEIVE ENABLE, to be used by host< |

#### 11.6.3.2 MAC2

|     | MA | C2 |    |    |    |    |    |    |      |     |    |    |    |    |    |    |    |           |       |                   |          |    |          |          |          |   |        |        | <b>0</b> x | 134      | <b>B0</b> ( | 004      |
|-----|----|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|-----------|-------|-------------------|----------|----|----------|----------|----------|---|--------|--------|------------|----------|-------------|----------|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14        | 13    | 12                | 11       | 10 | 9        | 8        | 7        | 6 | 5      | 4      | 3          | 2        | 1           | 0        |
|     |    |    |    |    |    |    |    | Re | serv | /ed |    |    |    |    |    |    |    | EXC_DEFER | BP_NB | <b>NO_BACKOFF</b> | peruesea |    | LONG_PRE | PURE_PRE | AUTO_PAD |   | PAD_EN | CRC_EN | DLY_CRC    | HUGE_FRM | LEN_CK      | FULL_DPX |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0         | 0     | 0                 | 0        | 0  | 0        | 0        | 0        | 0 | 0      | 0      | 0          | 0        | 0           | 0        |

#### 284



| Bits  | Name     | Description                                                            | RW |
|-------|----------|------------------------------------------------------------------------|----|
| 14    | EXC_DEFE | When enabled the MAC will defer to carrier indefinitely as per the     | RW |
|       | R        | Standard. When disabled, the MAC will abort when the excessive         |    |
|       |          | deferral limit is reached and provide feedback to the host system.     |    |
| 13    | BP_NB    | When enabled, the MAC after incidentally causing a collision during    | RW |
|       |          | backpressure will immediately retransmit without backoff reducing the  |    |
|       |          | chance of further collisions and ensuring transmit packets get sent.   |    |
| 12    | NO_BACKO | When enabled, the MAC will immediately retransmit following a          | RW |
|       | FF       | collision rather than using the Binary Exponential Backoff algorithm   |    |
|       |          | as specified in the Standard.                                          |    |
| 11:10 | Reserved | Writing has no effect, read as zero.                                   | R  |
| 9     | LONG_PRE | When enabled, the MAC only allows receive packets, which contain       | RW |
|       |          | preamble fields less than 12 bytes in length. When disabled, the MAC   |    |
|       |          | allows any length preamble as per the Standard.                        |    |
| 8     | PURE_PRE | When enable, the MAC will verify the content of the preamble to        | RW |
|       |          | ensure it contains 0x55 and is error-free. A packet with errored       |    |
|       |          | preamble is discarded. When disabled, no preamble checking is          |    |
|       |          | performed.                                                             |    |
| 7     | AUTO_PAD | Set this bit to cause the MAC to automatically detect the type of      | RW |
|       |          | frame, either tagged or un-tagged, by comparing the two octets         |    |
|       |          | following the source address with 0x8100 (VLAN Protocol ID) and        |    |
|       |          | pad accordingly.                                                       |    |
| 6     | VLAN_PAD | Set this bit to cause the MAC to pad all short frames to 64 bytes and  | RW |
|       |          | append a valid CRC.                                                    |    |
| 5     | PAD_EN   | Set this bit to have the MAC pad all short frames. Clear this bit if   | RW |
|       | •        | frames presented to the MAC have a valid length. This bit is used in   |    |
|       | er       | conjunction with AUTO PAD ENABLE and VLAN PAD ENABLE.                  |    |
| 4     | CRC_EN   | Set this bit to append a CRC to every frame whether padding was        | RW |
| )     |          | required or not. Must be set if PAD/CRC ENABLE is set. Clear this bit  |    |
|       |          | if frames presented to the MAC contain a CRC.                          |    |
| 3     | DLY_CRC  | This bit determines the number of bytes, if any, of proprietary header | RW |
|       |          | information that exists on the front of IEEE 802.3 frames.             |    |
| 2     | HUGE_FRM | When enabled frames of any length are transmitted and received.        | RW |
| 1     | LEN_CK   | When enabled, both transmit and receive frame lengths are              | RW |
|       |          | compared to the Length/Type field. If the Length/Type field            |    |
|       |          | represents a length then the check is performed. Mismatches are        |    |
|       |          | reported on the Transmit/Receive Statistics Vector.                    |    |
| 0     | FULL_DPX | When enabled, MAC operates in Full-Duplex mode. Disable for Half-      | RW |
|       |          | Duplex operation.                                                      |    |



#### 11.6.3.3 IPGT

#### **IPGT**

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

|     |   |   |   |   |   |   |   |   |   |   |   | Re | serv | ved |   |   |   |   |   |   |   |   |   |   |   |   |   | B2 | B_II | PG |   |   |
|-----|---|---|---|---|---|---|---|---|---|---|---|----|------|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|----|------|----|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0    | 0   | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0    | 0  | 0 | 0 |

| Bits     | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW |
|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 31:7     | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R  |
| 6:0      | B2B_IPG  | This is a programmable field representing the nibble time offset of the minimum possible period between the end of any transmitted packet, to the beginning of the next. In Full-Duplex mode, the register value should be the desired period in nibble times minus 3. In Half-Duplex mode, the register value should be the desired period in nibble times minus 6. In Full-Duplex the recommended setting is 0x15 (21d), which represents the minimum IPG of 0.96 $\mu$ s (in 100 Mb/s) or 9.6 $\mu$ s (in 10 Mb/s). In Half-Duplex the recommended setting is 0x12 (18d), which also represents the minimum IPG of 0.96 $\mu$ s (in 100 Mb/s) or 9.6 $\mu$ s (in 10 Mb/s). | RW |
| 11.6.3.4 | 4 IPGR   | fe1@140                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |

#### 11.6.3.4 IPGR

|     |     |    |    |    | e  | $\sum$ | Y  |    |     |     |    |    |    |    |    |    |    |    |    |     |     |     |    |   |          |   |    |     |             |     |     |           |
|-----|-----|----|----|----|----|--------|----|----|-----|-----|----|----|----|----|----|----|----|----|----|-----|-----|-----|----|---|----------|---|----|-----|-------------|-----|-----|-----------|
|     | IPG | R  | 5  | S  |    |        |    |    |     |     |    |    |    |    |    |    |    |    |    |     |     |     |    |   |          |   |    |     | <b>0</b> x′ | 134 | B00 | <b>0C</b> |
| Bit | 31  | 30 | 29 | 28 | 27 | 26     | 25 | 24 | 23  | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10  | 9  | 8 | 7        | 6 | 5  | 4   | 3           | 2   | 1   | 0         |
|     |     |    |    |    |    |        |    | Re | sen | ved |    |    |    |    |    |    |    |    | NE | 32B | _IP | G_I | P1 |   | Reserved |   | NE | 32B | _IP         | G_I | 2   |           |
| RST | 0   | 0  | 0  | 0  | 0  | 0      | 0  | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0 | 0        | 0 | 0  | 0   | 0           | 0   | 0   | 0         |

| Bits  | Name      | Description                                                          | RW |
|-------|-----------|----------------------------------------------------------------------|----|
| 31:15 | Reserved  | Writing has no effect, read as zero.                                 | R  |
| 14:8  | NB2B_IPG_ | This is a programmable field representing the optional carrierSense  | RW |
|       | P1        | window referenced in IEEE 802.3/4.2.3.2.1 'Carrier Deference'. If    |    |
|       |           | carrier is detected during the timing of IPGR1, the MAC defers to    |    |
|       |           | carrier. If, however, carrier becomes active after IPGR1, the MAC    |    |
|       |           | continues timing IPGR2 and transmits, knowingly causing a collision, |    |

286

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.

|     |           | thus ensuring fair access to medium. Its range of values is 0x0 to             |    |
|-----|-----------|--------------------------------------------------------------------------------|----|
|     |           | IPGR2. The recommended value is 0xC (12d).                                     |    |
| 7   | Reserved  | Writing has no effect, read as zero.                                           | R  |
| 6:0 | NB2B_IPG_ | This is a programmable field representing the Non-Back-to-Back                 | RW |
|     | P2        | Inter-Packet-Gap. The recommended value is 0x12 (18d), which                   |    |
|     |           | represents the minimum IPG of 0.96 $\mu$ s (in 100 Mb/s) or 9.6 $\mu$ s (in 10 |    |
|     |           | Mb/s).                                                                         |    |

#### 11.6.3.5 CLRT

|     | CLI | RT |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |      |   | <b>0</b> x | 134             | <b>B0</b> | 010 |
|-----|-----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|------|---|------------|-----------------|-----------|-----|
| Bit | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22   | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5    | 4 | 3          | 2               | 1         | 0   |
|     |     |    |    |    |    |    |    | R  | ese | erve | ł  |    |    |    |    |    |    |    |    |    | C  | N  |   | U | R | lese | erve | d | F          | <b>√</b><br>₹T_ | MAX       | ×   |
| RST | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | 1 | 1 | 0 | 0    | 0    | 0 | 1          | 1               | 1         | 1   |

| Bits  | Name     | Description                                                                                                                                                                                                                                                                                                                                  | RW |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 31:14 | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                                         | R  |
| 13:8  | cw       | This is a programmable field representing the slot time or collision window during which collisions occur in properly configured networks. Since the collision window starts at the beginning of transmission, the preamble and SFD is included. Its default of 0x37 (55d) corresponds to the count of frame bytes at the end of the window. | RW |
| 7:4   | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                                         | R  |
| 3:0   | RT_MAX   | This is a programmable field specifying the number of retransmission attempts following a collision before aborting the packet due to excessive collisions. The Standard specifies the attemptLimit to be 0xF (15d). Its default is '0xF'.                                                                                                   | RW |

#### 11.6.3.6 MAXF

|     | MA                                                           | XF |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | <b>0</b> x′ | 134 | <b>B0</b> ( | 014 |
|-----|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-------------|-----|-------------|-----|
| Bit | 31                                                           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3           | 2   | 1           | 0   |
|     | Sit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17<br>Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MA | XF |   |   |   |   |   |             |     |             |     |
| RST | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0 | 0 | 0 | 0 | 0 | 0           | 0   | 0           | 0   |



### 11.6.3.7 RAM\_ACC\_R7

| Bits  | Name     | Description                                                         | RW |
|-------|----------|---------------------------------------------------------------------|----|
| 31:16 | Reserved | Writing has no effect, read as zero.                                | R  |
| 15:0  | MAXF     | This field resets to 0x0600, which represents a maximum receive     | RW |
|       |          | frame of 1536 octets. An untagged maximum size Ethernet frame is    |    |
|       |          | 1518 octets. A tagged frame adds four octets for a total of 1522    |    |
|       |          | octets. If a shorter maximum length restriction is desired, program |    |
|       |          | this 16-bit field.                                                  |    |

#### 11.6.3.8 SUPP

|     | SU | PP |    |    |    |    |    |      |      |    |    |    |    |    |    |    |         |          |    |      |          |   |       |          |             |    |      | <b>0</b> x | 134      | <b>B0</b> | 018 |
|-----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|---------|----------|----|------|----------|---|-------|----------|-------------|----|------|------------|----------|-----------|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15      | 14 13    | 12 | 11   | 10       | 9 | 8     | 7        | 6           | 5  | 4    | 3          | 2        | 1         | 0   |
|     |    |    |    |    |    |    | R  | lese | erve | d  |    |    |    |    |    |    | RST_INT | Reserved |    | RMII | Pecenied |   | SPEED | RST_100X | P<br>P<br>P | NC | S II | RST_10T    | Reserved | EN_JAB    | BM  |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0 0      | 1  | 0    | 0        | 0 | 0     | 0        | 0           | 0  | 0    | 0          | 0        | 0         | 0   |
|     |    | _  |    |    |    |    |    |      |      |    |    |    |    | ~  | JU | 1  | Y       |          |    |      |          |   |       |          |             |    |      |            |          |           |     |

| Bits  | Name     | Description                                                               | RW |
|-------|----------|---------------------------------------------------------------------------|----|
| 31:16 | Reserved | Writing has no effect, read as zero.                                      | R  |
| 15    | RST_INT  | Setting this bit resets the attached Interface module. Clearing this bit  | RW |
|       | . ?      | allows for normal operation. This bit can be used in place of bits 11, 7, |    |
|       | e Y      | and 3 when connecting only 1 interface module.                            |    |
| 14:13 | Reserved | Writing has no effect, read as zero.                                      | R  |
| 12    | PHY_MODE | This bit configures the Serial MII logic with the connecting SMII         | RW |
|       |          | device type. Set this bit when connecting to a SMII PHY. Clear this bit   |    |
|       |          | when connecting to a SMII MAC. When MAC is selected, the SMII will        |    |
|       |          | operate at 100 Mb/s, Full Duplex.                                         |    |
| 11    | RST_RMII | This bit resets the Reduced MII logic.                                    | RW |
| 10:9  | Reserved | Writing has no effect, read as zero.                                      | R  |
| 8     | SPEED    | This bit configures the Reduced MII logic for the current operating       | RW |
|       |          | speed. When set, 100 Mb/s mode is selected. When cleared, 10 Mb/s         |    |
|       |          | mode is selected.                                                         |    |
| 7     | RST_100X | This bit resets the PE100X module, which contains the 4B/5B symbol        | RW |
|       |          | encipher/decipher logic. Effects PE100X module only.                      |    |
| 6     | FQ       | When enabled, transmit data is quieted which allows the contents of       | RW |
|       |          | the cipher to be output. When cleared, normal operation is enabled.       |    |
|       |          | Effects PE100X module only.                                               |    |

#### 288



| 5 | NC       | When enabled, the raw transmit 5B symbols are transmitted without   | RW |
|---|----------|---------------------------------------------------------------------|----|
|   |          | ciphering. When disabled, normal ciphering occurs. Effects PE100X   |    |
|   |          | module only.                                                        |    |
| 4 | LF       | When enabled, the 330ms Link Fail timer is disabled allowing for    | RW |
|   |          | shorter simulations. Removes the 330 $\mu$ S link-up time before    |    |
|   |          | reception of streams is allowed. When cleared, normal operation     |    |
|   |          | occurs. Effects PE100X module only.                                 |    |
| 3 | RST_10T  | This bit resets the PE10T module which converts MII nibble streams  | RW |
|   |          | to the serial bit stream of 10T transceivers. Effects PE10T module  |    |
|   |          | only.                                                               |    |
| 2 | Reserved | Writing has no effect, read as zero.                                | R  |
| 1 | EN_JAB   | This bit enables the Jabber Protection logic within the PE10T in    | RW |
|   |          | ENDEC mode. Jabber is the condition where a transmitter is stuck on |    |
|   |          | for longer than 50ms preventing other stations from transmitting.   |    |
|   |          | Effects PE10T module only.                                          |    |
| 0 | BM       | When '1' - MAC is in 10BASE-T ENDEC mode which changes              | RW |
|   |          | decodes (such as Excess Defer) to be based on the bit clock rather  |    |
|   |          | than the nibble clock. $\sqrt{\sqrt{2}}$                            |    |

#### 11.6.3.9 TEST

com internal TEST 0x134B001C Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 E F S Reserved 

| Bits | Name     | Description                                                             | RW |
|------|----------|-------------------------------------------------------------------------|----|
| 31:3 | Reserved | Writing has no effect, read as zero.                                    | R  |
| 2    | ТВ       | Setting this bit will cause the MAC to assert backpressure on the link. | RW |
|      |          | Backpressure causes preamble to be transmitted, raising carrier         |    |
|      |          | sense. A transmit packet from the system will be sent during            |    |
|      |          | backpressure.                                                           |    |
| 1    | TP       | This bit causes the MAC Control sublayer to inhibit transmissions,      | RW |
|      |          | just as if a PAUSE Receive Control frame with a non-zero pause time     |    |
|      |          | parameter was received.                                                 |    |
| 0    | SQ       | This bit reduces the effective PAUSE Quanta from 64 byte-times to 1     | RW |
|      |          | byte-time.                                                              |    |



## 11.6.3.10 MCFG

#### MCFG

|     | МС | FG |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |      |      |    |   |   |   |   | <b>0</b> x | 134 | <b>B0</b> | )20 |
|-----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|---|---|---|---|------------|-----|-----------|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9    | 8  | 7 | 6 | 5 | 4 | 3          | 2   | 1         | 0   |
|     |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    | RM |    |    |    | R  | lese | erve | ed |   |   |   |   | CS         |     | NP        | S   |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0 | 0 | 0 | 0 | 0          | 0   | 0         | 0   |

| Bits  | Name     | [                               | Description | ۱            |                     | RW |
|-------|----------|---------------------------------|-------------|--------------|---------------------|----|
| 31:16 | Reserved | Writing has no effect, read as  | zero.       |              |                     | R  |
| 15    | RM       | This bit resets the MII Manag   | ement mod   | lule.        |                     | RW |
| 14:5  | Reserved | Writing has no effect, read as  | zero.       |              | 13                  | R  |
| 4:2   | CS       | This field is used by the clock | divide logi | c in creatin | g the MII           | RW |
|       |          | Management Clock (MDC) wil      | nich IEEE 8 | 302.3u defi  | nes to be no faster |    |
|       |          | than 2.5 MHz. Some PHYs su      | upport cloc | k rates up t | o 12.5 MHz,         |    |
|       |          | however.                        | * er        | nar          |                     |    |
|       |          | Clock Select                    | 4           | 3            | 2                   |    |
|       |          | Host Clock divided by 4         | 0           | 0            | x                   |    |
|       |          | Host Clock divided by 6         | 0           | 1            | 0                   |    |
|       |          | Host Clock divided by 8         | 0           | 1            | 1                   |    |
|       |          | Host Clock divided by 10        | 1           | 0            | 0                   |    |
|       |          | Host Clock divided by 14        | 1           | 0            | 1                   |    |
|       | C CY     | Host Clock divided by 20        | 1           | 1            | 0                   |    |
| 1     | ong_e1   | Host Clock divided by 28        | 1           | 1            | 1                   |    |
| )     |          |                                 |             |              |                     |    |
| 1     | NP       | Set this bit to cause the MII M | •           |              | •                   | RW |
|       |          | read/write cycles without the   |             |              |                     |    |
|       |          | cause normal cycles to be pe    | rformed. So | ome PHYs     | support             |    |
|       |          | suppressed preamble.            |             |              |                     |    |
| 0     | SI       | Set this bit to cause the MII N | •           |              |                     | RW |
|       |          | cycles across a range of PHY    |             |              | •                   |    |
|       |          | module will perform read cycl   |             |              | •                   |    |
|       |          | in PHY ADDRESS[4:0]. Clear      | This bit to | allow contir | huous reads of the  |    |
|       |          | same PHY.                       |             |              |                     |    |

#### 11.6.3.11 MCMD

#### мсмр

|     | Μ | СМ   | D   |     |      |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x | 134 | <b>B0</b> ( | 024 |
|-----|---|------|-----|-----|------|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|---|---|---|---|---|---|------------|-----|-------------|-----|
| Bit | 3 | 1 30 | ) 2 | 9 2 | 8 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 3 17 | 16   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2   | 1           | 0   |
|     |   |      |     |     |      |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |   |   |   |   |   |   |            |     |             |     |
|     |   |      |     |     |      |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |   |   |   |   |   |   |            |     | Z           | Ω   |
|     |   |      |     |     |      |    |    |    |    |    |    |    |    | F  | Rese | erve | d  |    |    |    |    |    |   |   |   |   |   |   |            |     | SCA         | REA |

#### 

| Bits    | Name     | Description                                                        | RW              |
|---------|----------|--------------------------------------------------------------------|-----------------|
| 31:2    | Reserved | Writing has no effect, read as zero.                               | R               |
| 1       | SCAN     | This bit causes the MII Management module to perform Read cycles   | RW              |
|         |          | continuously. This is useful for monitoring Link Fail for example. |                 |
| 0       | READ     | This bit causes the MII Management module to perform a single      | RW              |
|         |          | Read cycle. The Read data is returned in Register 0xC(MII Mgmt     |                 |
|         |          | Read Data).                                                        |                 |
| 11.6.3. | 12 MADR  | internat                                                           |                 |
| MAI     | DR       | C COILLI Ox13                                                      | 4 <b>B002</b> 8 |

#### 11.6.3.12 MADR

|     | MA | DR |    |    |    |    |    |    |    |      |     | 6  |    | C  | Эr | 11 |    |    |    |    |     |     |     |   |   |          |   |   | 0x | 134 | B0( | )28 |
|-----|----|----|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|----|----|-----|-----|-----|---|---|----------|---|---|----|-----|-----|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10  | 9   | 8 | 7 | 6        | 5 | 4 | 3  | 2   | 1   | 0   |
|     |    |    |    |    |    |    |    |    | Re | serv | ved |    |    |    |    |    |    |    |    |    | PH' | Y_A | .DR |   |   | Reserved |   |   | RE | G_A | ١DR |     |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0 | 0 | 0        | 0 | 0 | 0  | 0   | 0   | 0   |

| Bits  | Name     | Description                                                            | RW |
|-------|----------|------------------------------------------------------------------------|----|
| 31:13 | Reserved | Writing has no effect, read as zero.                                   | R  |
| 12:8  | PHY_ADR  | This field represents the 5-bit PHY Address field of Mgmt cycles. Up   | RW |
|       |          | to 31 PHYs can be addressed (0 is reserved).                           |    |
| 7:5   | Reserved | Writing has no effect, read as zero.                                   | R  |
| 4:0   | REG_ADR  | This field represents the 5-bit Register Address field of Mgmt cycles. | RW |
|       |          | Up to 32 registers can be accessed.                                    |    |



#### 11.6.3.13 MWTD

## **MWTD** 0x134B002C Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved **WDATA**

#### 

| Bit  | ts    | Ν      | ame   | ł  |    |       |      |       |      |     |      |       |     |     | De   | SC   | rip | tior            | า  |      |      |      |      |      |      |     |            |     | R         | W   |
|------|-------|--------|-------|----|----|-------|------|-------|------|-----|------|-------|-----|-----|------|------|-----|-----------------|----|------|------|------|------|------|------|-----|------------|-----|-----------|-----|
| 31:  | 16    | Rese   | erved |    | ١  | Writi | ng   | ha    | s no | ) e | ffeo | ct, r | rea | d a | s z  | erc  | ).  |                 |    |      |      |      |      |      |      |     |            |     | R         |     |
| 15:  | 0     | WDA    | ΔTA   |    | ١  | Whe   | n v  | writ  | ten, | а   | MII  | M     | gm  | t w | rite | су   | cle | is              | pe | rfor | me   | d u  | sing | g th | e 1  | 6-b | oit        |     | W         |     |
|      |       |        |       |    | 0  | data  | an   | nd t  | he p | ore | -co  | onfi  | gur | ed  | P۲   | IY a | anc | d Re            | eg | iste | r ad | ddre | ess  | est  | fron | n   |            |     |           |     |
|      |       |        |       |    | F  | Regi  | ste  | er (( | )x0/ | ۹). |      |       |     |     |      |      |     |                 |    |      |      |      |      |      |      | ~   | <b>1</b>   | Y   |           |     |
| 11.6 | 5.3.1 | 4 MF   | RDD   |    |    |       |      |       |      |     |      |       |     |     |      |      |     | 10 <sup>1</sup> | 0  | 3    |      | U    | 38   | 6    | (    | 77  |            |     |           |     |
| 1    | MRD   | D      |       |    |    |       |      |       |      |     |      |       |     |     |      | x    | 6   | J.              | ¥. |      |      |      |      |      |      |     | <b>0</b> x | 134 | <b>B0</b> | 030 |
| Bit  | 31 3  | 0 29 2 | 28 27 | 26 | 25 | 24 2  | 23 2 | 22 :  | 21 2 | 20  | 19   | 18    | 17  | 16  | 15   | 14   | 13  | 12              | 1  | 1 10 | 9    | 8    | 7    | 6    | 5    | 4   | 3          | 2   | 1         | 0   |

#### 11.6.3.14 MRDD

#### **MRDD**

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

|     |   |   |   |   |   |   | F | Rese | erve | ed |   |   |   |   |   |   |   |   |   |   |   |   |   | RD | ATA | N. |   |   |   |   |   |   |
|-----|---|---|---|---|---|---|---|------|------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|----|-----|----|---|---|---|---|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0   | 0  | 0 | 0 | 0 | 0 | 0 | 0 |

| Bits  | Name     | Description                                                       | RW |
|-------|----------|-------------------------------------------------------------------|----|
| 31:16 | Reserved | Writing has no effect, read as zero.                              | R  |
| 15:0  | RDATA    | Following a MII Mgmt Read Cycle, the 16-bit data can be read from | R  |
|       |          | this location.                                                    |    |

#### 11.6.3.15 MIND

|     | МІМ | ND |    |    |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x | 134  | <b>B0</b> | 034  |
|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|---|---|---|---|---|---|------------|------|-----------|------|
| Bit | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2    | 1         | 0    |
|     |     |    |    |    |    |    |    |    |    |    |    |    | R  | lese | erve | d  |    |    |    |    |    |    |   |   |   |   |   |   | LF         | NVLD | SCAN      | BUSY |
| RST | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0          | 0    | 0         | 0    |

#### 292

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| Bits | Name     | Description                                                       | RW |
|------|----------|-------------------------------------------------------------------|----|
| 31:4 | Reserved | Writing has no effect, read as zero.                              | R  |
| 3    | LF       | When '1' is returned - indicates MII Mgmt link fail has occurred. | R  |
| 2    | NVLD     | When '1' is returned - indicates MII Mgmt Read cycle has not      | R  |
|      |          | completed and the Read Data is not yet valid.                     |    |
| 1    | SCAN     | When '1' is returned - indicates a scan operation (continuous MII | R  |
|      |          | Mgmt Read cycles) is in progress.                                 |    |
| 0    | BUSY     | When '1' is returned - indicates MII Mgmt module is currently     | R  |
|      |          | performing an MII Mgmt Read or Write cycle.                       |    |

#### 11.6.3.16 SA0

|     | SA | 0  |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |     |     |    |   |    |    |    |            |     | <b>0</b> x | 134 | <b>B0</b> | 040 |
|-----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|-----|-----|----|---|----|----|----|------------|-----|------------|-----|-----------|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10 | 9 | 8  | 7  | 6  | 5          | 4   | 3          | 2   | 1         | 0   |
|     |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |     |     |    |   |    |    | λ  |            | О,  | 1          |     |           |     |
|     |    |    |    |    |    |    | _  |     |      |    |    |    |    |    |    |    |    |    |    |     |     |    |   |    | 39 | 20 | <b>)</b> ~ |     |            |     |           |     |
|     |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    | SAE | וטנ | 1  |   | U. |    |    |            | SAE | 2טכ        |     |           |     |
|     |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    | 0  | x'  | Ū,  | 2  |   |    |    |    |            |     |            |     |           |     |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0 | 0  | 0  | 0  | 0          | 0   | 0          | 0   | 0         | 0   |
|     |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    | Y  |    |    |     |     |    |   |    |    |    |            |     |            |     |           |     |

| Bits    | Name     | Description                                               | RW |
|---------|----------|-----------------------------------------------------------|----|
| 31:16   | Reserved | Writing has no effect, read as zero.                      | R  |
| 15:8    | SADD1    | This field holds the first octet of the station address.  | RW |
| 7:0     | SADD2 🔥  | This field holds the second octet of the station address. | RW |
| 11.6.3. | 17 SA1   | ×                                                         |    |
|         |          |                                                           |    |

|     | SA1 |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |     |     |    |   |   |   |   |   |     | <b>0</b> x | 134 | <b>B0</b> | 044 |
|-----|-----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|-----|------------|-----|-----------|-----|
| Bit | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3          | 2   | 1         | 0   |
|     |     |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    | :  | SAE | DD3 |    |   |   |   |   |   | SAI | )D4        | •   |           |     |
| RST | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0 | 0 | 0 | 0 | 0 | 0   | 0          | 0   | 0         | 0   |

| Bits  | Name     | Description                                               | RW  |
|-------|----------|-----------------------------------------------------------|-----|
| 31:16 | Reserved | Writing has no effect, read as zero.                      | R   |
| 15:8  | SADD3    | This field holds the third octet of the station address.  | RW  |
| 7:0   | SADD4    | This field holds the fourth octet of the station address. | RW  |
|       |          |                                                           | 293 |



#### 11.6.3.18 SA2

|     | SA | 2  |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |     |     |    |   |   |   |   |   |     | <b>0</b> x | 134 | <b>B0</b> ( | )48 |
|-----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|-----|------------|-----|-------------|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3          | 2   | 1           | 0   |
|     |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    | SAI | DD5 |    |   |   |   |   |   | SAE | DD6        |     |             |     |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0 | 0 | 0 | 0 | 0 | 0   | 0          | 0   | 0           | 0   |

| Bits  | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 31:16 | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R  |
| 15:8  | SADD5    | This field holds the fifth octet of the station address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW |
| 7:0   | SADD6    | This field holds the sixth octet of the station address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW |
| 3     | ong_eif  | This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address.<br>This field holds the sixth octet of the station address. |    |



## 11.7 RMII Module

#### 11.7.1 Overview

The Reduced-MII was designed to convey the complete 16-bit MII information between a 10/100 Mb/s MAC and an RMII PHY with 7 pins per port.

The RMII module converts the Media Independent Interface to the new and improved Reduced Media Independent Interface for use with new lower pin count PHYs. The RMII adheres to the Reduced-MII Specification version 1.2, dated March 20, 1998.

#### 11.7.2 Feature

- Provides reduced pin-count interface for Ethernet physical layer devices •
- Long eiffel@126.com internal used only Supports Preliminary Draft Version 1.2 of the RMII Specification •
- Supports Full and Half duplex operation ٠
- Supports 10 and 100 Mb/s operation •



#### 11.8 SAL Module

#### 11.8.1 Overview

The SAL module, Station Address Logic module, accepts the destination address field of incoming packets and all the related control signals and performs an address comparison.

Two types of valid destination addresses exist; a single physical address and a multicast address. When a single physical destination address is received, the PE-SAL module performs a direct comparison between the destination address and the address stored in the 48-bit Station Address Register. The 48-bit Station Address Register is loaded by the host when the module is first configured.

When a multicast destination address is received, a hash algorithm is applied to the address after it goes through a 32-bit CRC checker. The upper 6 bits of the 32-bit result from the CRC checker is decoded and used to select a bit in a 64-bit hash table which is pre-configured by the host. If the address compares correctly, the signal ACCEPT is set high to reflect a successful address comparison and the packet will be flagged as accepted. Otherwise, REJECT will be set high to reject the packet. The PE-SAL module can also be programmed to accept all incoming packets (promiscuous mode), all packets with multicast address or all packets with broadcast address.

In addition to the above functionality, the PE-SAL module facilitates insertion of its internal 48-bit Station Address Register into the system transmit data stream through byte multiplexed enabled

| output.<br>11.8.2 Register Ma | pfel@ | 126.000     |            |             |
|-------------------------------|-------|-------------|------------|-------------|
| Name C                        | RW    | Reset Value | Address    | Access Size |
| AFR, 18                       | RW    | 0x0000000   | 0x134B01A0 | 32          |
| HT1                           | RW    | 0x0000000   | 0x134B01A4 | 32          |
| HT2                           | RW    | 0x0000000   | 0x134B01A8 | 32          |

#### 11.8.3 Register Description

#### 11.8.3.1 AFR



296

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| Bits | Name     | Description                          | RW |
|------|----------|--------------------------------------|----|
| 31:4 | Reserved | Writing has no effect, read as zero. | R  |
| 3    | PRO      | Promiscuous Mode.                    | RW |
| 2    | PRM      | Accept Multicast.                    | RW |
| 1    | AMC      | Accept Multicast (qualified).        | RW |
| 0    | ABC      | Accept Broadcast.                    | RW |

#### 11.8.3.2 HT1

|     | HT | 1  |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     |            |    |   |   |     |   |   |    | <b>0</b> x1 | 134 | <b>B01</b> | <b>A4</b> |
|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|------------|----|---|---|-----|---|---|----|-------------|-----|------------|-----------|
| Bit | 31 | 30 | 29 | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14  | 13  | 12  | 11         | 10 | 9 | 8 | 7   | 6 | 5 | 4  | 3           | 2   | 1          | 0         |
|     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    | н  | 1  |     |     |     |            |    |   |   | - 6 | 6 | ( | 21 | 1           | J   |            |           |
| RST | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0          | 0  | 0 | 0 | 0   | 0 | 0 | 0  | 0           | 0   | 0          | 0         |
|     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     | $\sqrt{2}$ | 1  |   |   |     |   |   |    |             |     |            |           |
| Ri  | ts |    |    | Nar | ne |    |    |    |    |    |    |    |    |    |    |    | De | scr | int | ion | 12         |    |   |   |     |   |   |    |             |     | R۱         | N         |

| Bits     | Name  | Description         | RW |
|----------|-------|---------------------|----|
| 31:0     | HT1   | Hash Table [64:32]. | RW |
| 11.8.3.3 | 3 HT2 | col@126.com         |    |

#### 11.8.3.3 HT2

|     |    |         |    |    |    |    |    |     | 1    | (m) | ۲. |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |             |     |     |           |
|-----|----|---------|----|----|----|----|----|-----|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------------|-----|-----|-----------|
|     | нт | 2       |    |    |    | •  | çŞ | Ľ ( | د رخ |     |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x1 | 341 | B01 | <b>A8</b> |
| Bit | 31 | 30      | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2   | 1   | 0         |
|     | 1  | $r_{c}$ | )L | 9  | /  |    |    |     |      |     |    |    |    |    |    | нт | ٢2 |    |    |    |    |    |   |   |   |   |   |   |             |     |     |           |
|     |    |         |    |    |    |    |    |     |      |     |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |             |     |     |           |
| RST | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0           | 0   | 0   | 0         |

| Bits | Name | Description        | RW |
|------|------|--------------------|----|
| 31:4 | HT2  | Hash Table [31:0]. | RW |



#### 11.9 STAT Module

#### 11.9.1 Overview

The STAT module is a low gate count, register based, statistics gathering module. It has 37 separate counters, which simply count or accumulate conditions that occur as packets are transmitted and received. These counters will support RMON MIB group 1, RMON MIB group 2 if table counters, RMON MIB group 3, RMON MIB group 9, RMON MIB 2, and the dot 3 Ethernet MIB.

On the transmit side, the STAT module looks at bits from the Transmit Statistics Vector (TSV[51:0]) whenever Transmit Statistics Vector Pulse (TSVP) is asserted. A particular MACs Transmit Function sub-module generates the Transmit Statistics Vector.

During receive packets, the Receive Statistics Vector (RSV[30:0]) is examined whenever the Receive Statistics Vector Pulse (RSVP) is asserted. A particular MACs Receive Function sub-module generates the Receive Statistics Vector.

One or more non-zero elements in either of these statistics vectors trigger the STAT module to update its statistics counters. These counters are stored in internal data registers. The host can access the internal data registers at any time. The STAT is capable of maintaining worst-case throughput conditions of one RSV and/or one TSV per four STAT internal clocks.

The ECU may be interrupted upon any one counter's rollover condition via a carry interrupt output from the STAT. Each counters rollover condition can be discreetly masked from causing an interrupt by internal masking registers. In addition, each individual counter value may be reset on read access, or all counters may be simultaneously reset by assertion of an external module input pin.

| Name  | RW | Reset Value | Address    | Access Size |
|-------|----|-------------|------------|-------------|
| TR64  | RW |             | 0x134B0080 | 32          |
| TR127 | RW |             | 0x134B0084 | 32          |
| TR255 | RW |             | 0x134B0088 | 32          |
| TR511 | RW |             | 0x134B008C | 32          |
| TR1K  | RW |             | 0x134B0090 | 32          |
| TRMAX | RW |             | 0x134B0094 | 32          |
| TRMGV | RW |             | 0x134B0098 | 32          |
| RBYT  | RW |             | 0x134B009C | 32          |
| RPKT  | RW |             | 0x134B00A0 | 32          |
| RFCS  | RW |             | 0x134B00A4 | 32          |
| RMCA  | RW |             | 0x134B00A8 | 32          |
| RBCA  | RW |             | 0x134B00AC | 32          |

#### 11.9.2 Register Map

298

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| RXCFRW0x134B00B032RXPFRW0x134B00B432RXUORW0x134B00B832RALNRW0x134B00BC32RFLRRW0x134B00C432RCDERW0x134B00C332RCDERW0x134B00C332RCSERW0x134B00C432RVRRW0x134B00C432RVRRW0x134B00D432RJRRRW0x134B00D432RJRRRW0x134B00D632RDRPRW0x134B00D632TDTRW0x134B00E032TDTRW0x134B00E432TDTRW0x134B00E332TDTARW0x134B00E432TDFARW0x134B00E432TDFARW0x134B00E032TDFRRW0x134B00E432TDFRRW0x134B00E432TDFRRW0x134B00E432TDFRRW0x134B00E432TDFRRW0x134B010632TLCLRW0x134B010632TNCLRW0x134B010632TDRPRW0x134B011032TDRPRW0x134B011032TDRPRW0x134B011032TDRPRW0x134B012432TJRFRW0x134B012432TDRPRW0x134B012032TDRPRW <th></th> <th></th> <th></th> <th></th>                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                       |        |            |    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--------|------------|----|
| RXUORW0x134B00B832RALNRW0x134B00C032RFLRRW0x134B00C032RCDERW0x134B00C432RCSERW0x134B00C632RUNDRW0x134B00C032RFRGRW0x134B00D032RFRGRW0x134B00D032RJBRRW0x134B00D032RDRPRW0x134B00D032RDRPRW0x134B00D032TDTRW0x134B00D032TDTRW0x134B00E032TDTRW0x134B00E032TDTRRW0x134B00E432TDFARW0x134B00E632TDFRRW0x134B00E632TDFRRW0x134B00F432TDFRRW0x134B00F432TSCLRW0x134B00F632TLCLRW0x134B010032TLCLRW0x134B010032TDFPRW0x134B010032TDFPRW0x134B010032TDRPRW0x134B010032TDRPRW0x134B010032TDRPRW0x134B010032TDRPRW0x134B010032TDRPRW0x134B011032TDRPRW0x134B011032TDRPRW0x134B011032TDRPRW0x134B012032TDRPRW </td <td></td> <td></td> <td>0x134B00B0</td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                         |                                       |        | 0x134B00B0 |    |
| RALNRW0x134B00BC32RFLRRW0x134B00C032RCDERW0x134B00C432RCSERW0x134B00C632RUNDRW0x134B00C032RFRGRW0x134B00D032RFRGRW0x134B00D432RJBRRW0x134B00D432RJBRRW0x134B00D032RDRPRW0x134B00D032TBYTRW0x134B00E032TDKTRW0x134B00E032TDKARW0x134B00E432TBCARW0x134B00E632TDFRRW0x134B00F432TDFRRW0x134B00F432TDFRRW0x134B00F432TDFRRW0x134B00F432TCLRW0x134B01F432TKCLRW0x134B010632TLCLRW0x134B010632TDFPRW0x134B010632TLCLRW0x134B010632TLCLRW0x134B010632TDFPRW0x134B011032TDFPRW0x134B011032TDFPRW0x134B011032TLCLRW0x134B011032TLCLRW0x134B011032TDFPRW0x134B011032TDFPRW0x134B011032TDFPRW0x134B011232TLCLRW                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RXPF                                  | RW     | 0x134B00B4 | 32 |
| RFLR         RW         0x134B00C0         32           RCDE         RW         0x134B00C4         32           RCSE         RW         0x134B00C8         32           RUND         RW         0x134B00C0         32           RVR         RW         0x134B00D0         32           RFRG         RW         0x134B00D4         32           RJBR         RW         0x134B00D6         32           RJBR         RW         0x134B00D6         32           RDRP         RW         0x134B00E0         32           TBYT         RW         0x134B00E0         32           TPKT         RW         0x134B00E0         32           TMCA         RW         0x134B00E0         32           TBCA         RW         0x134B00E0         32           TDFR         RW         0x134B00F4         32           TDFR         RW         0x134B00F6         32           TDFR         RW         0x134B00F6         32           TSCL         RW         0x134B00F6         32           TXCL         RW         0x134B010         32           TDRP         RW         0x134B0106   | RXUO                                  | RW     | 0x134B00B8 | 32 |
| RCDE         RW         0x134B00C4         32           RCSE         RW         0x134B00C8         32           RUND         RW         0x134B00C0         32           ROVR         RW         0x134B00D0         32           RFRG         RW         0x134B00D4         32           RJBR         RW         0x134B00D6         32           RDRP         RW         0x134B00D0         32           TBYT         RW         0x134B00D0         32           TPKT         RW         0x134B00E0         32           TMCA         RW         0x134B00E4         32           TMCA         RW         0x134B00E4         32           TDFR         RW         0x134B00E6         32           TDFR         RW         0x134B00E6         32           TDFR         RW         0x134B00E6         32           TDFR         RW         0x134B00E6         32           TSCL         RW         0x134B00E6         32           TCL         RW         0x134B00E6         32           TNCL         RW         0x134B010         32           TDFP         RW         0x134B0106   | RALN                                  | RW     | 0x134B00BC | 32 |
| RCSE         RW         0x134B00C8         32           RUND         RW         0x134B00C         32           ROVR         RW         0x134B00D0         32           RFRG         RW         0x134B00D4         32           RJBR         RW         0x134B00D6         32           RDRP         RW         0x134B00D0         32           TBYT         RW         0x134B00E0         32           TPKT         RW         0x134B00E4         32           TPKT         RW         0x134B00E4         32           TMCA         RW         0x134B00E6         32           TBCA         RW         0x134B00F6         32           TDFR         RW         0x134B00F6         32           TDFR         RW         0x134B00F6         32           TDFR         RW         0x134B00F6         32           TSCL         RW         0x134B00F0         32           TLCL         RW         0x134B00F0         32           TXCL         RW         0x134B010         32           TDRP         RW         0x134B010         32           TDRP         RW         0x134B010     | RFLR                                  | RW     | 0x134B00C0 | 32 |
| RUND         RW         0x134B00CC         32           ROVR         RW         0x134B00D0         32           RFRG         RW         0x134B00D4         32           RJBR         RW         0x134B00D6         32           RJBR         RW         0x134B00D6         32           RDRP         RW         0x134B00DC         32           TBYT         RW         0x134B00E0         32           TPKT         RW         0x134B00E4         32           TMCA         RW         0x134B00E6         32           TBCA         RW         0x134B00E6         32           TSCA         RW         0x134B00F0         32           TDFR         RW         0x134B00F0         32           TDFR         RW         0x134B00F6         32           TSCL         RW         0x134B00FC         32           TKCL         RW         0x134B0100         32           TLCL         RW         0x134B0100         32           TKCL         RW         0x134B0100         32           TDRP         RW         0x134B0110         32           TDRP         RW         0x134B0110 | RCDE                                  | RW     | 0x134B00C4 | 32 |
| ROVR         RW         0x134B00D0         32           RFRG         RW         0x134B00D4         32           RJBR         RW         0x134B00D8         32           RDRP         RW         0x134B00DC         32           TBYT         RW         0x134B00C0         32           TBYT         RW         0x134B00E0         32           TPKT         RW         0x134B00E0         32           TMCA         RW         0x134B00E3         32           TMCA         RW         0x134B00E6         32           TSCA         RW         0x134B00F0         32           TDFR         RW         0x134B00F1         32           TSCL         RW         0x134B00F2         32           TSCL         RW         0x134B00F2         32           TKCL         RW         0x134B0100         32           TLCL         RW         0x134B0100         32           TNCL         RW         0x134B0100         32           TDRP         RW         0x134B0110         32           TDRP         RW         0x134B0110         32           TDRP         RW         0x134B0110 | RCSE                                  | RW     | 0x134B00C8 | 32 |
| RFRG         RW         0x134B00D4         32           RJBR         RW         0x134B00D8         32           RDRP         RW         0x134B00DC         32           TBYT         RW         0x134B00E0         32           TPKT         RW         0x134B00E0         32           TMCA         RW         0x134B00E3         32           TBCA         RW         0x134B00E0         32           TSCA         RW         0x134B00E0         32           TDFR         RW         0x134B00F0         32           TDFR         RW         0x134B00F0         32           TDFR         RW         0x134B00F4         32           TEDF         RW         0x134B00F6         32           TSCL         RW         0x134B00F2         32           TMCL         RW         0x134B0100         32           TXCL         RW         0x134B0100         32           TDRP         RW         0x134B0100         32           TDRP         RW         0x134B0100         32           TDRP         RW         0x134B0100         32           TDRP         RW         0x134B0110 | RUND                                  | RW     | 0x134B00CC | 32 |
| RJBR         RW         0x134B00D8         32           RDRP         RW         0x134B00DC         32           TBYT         RW         0x134B00E0         32           TPKT         RW         0x134B00E4         32           TMCA         RW         0x134B00E3         32           TBCA         RW         0x134B00E0         32           TSCA         RW         0x134B00E0         32           TSCA         RW         0x134B00E0         32           TDFR         RW         0x134B00E0         32           TDFR         RW         0x134B00F0         32           TSCL         RW         0x134B00F8         32           TSCL         RW         0x134B00F0         32           TLCL         RW         0x134B0104         32           TXCL         RW         0x134B0108         32           TDRP         RW         0x134B0100         32           TDRP         RW         0x134B0100         32           TDRP         RW         0x134B0100         32           TDRP         RW         0x134B0110         32           TJBR         RW         0x134B0110 | ROVR                                  | RW     | 0x134B00D0 | 32 |
| RDRP         RW         0x134B00DC         32           TBYT         RW         0x134B00E0         32           TPKT         RW         0x134B00E4         32           TMCA         RW         0x134B00E8         32           TBCA         RW         0x134B00E6         32           TXPF         RW         0x134B00F0         32           TDFR         RW         0x134B00F4         32           TEDF         RW         0x134B00F4         32           TSCL         RW         0x134B00F6         32           TKCL         RW         0x134B0100         32           TKCL         RW         0x134B0106         32           TDRP         RW         0x134B0106         32           TDRP         RW         0x134B0110         32           TJBR         RW         0x134B0110         32           TVCF         RW         0x134B0112 | RFRG                                  | RW     | 0x134B00D4 | 32 |
| TBYT         RW         0x134B00E0         32           TPKT         RW         0x134B00E4         32           TMCA         RW         0x134B00E8         32           TBCA         RW         0x134B00EC         32           TBCA         RW         0x134B00EC         32           TSCA         RW         0x134B00F0         32           TDFR         RW         0x134B00F4         32           TEDF         RW         0x134B00F8         32           TSCL         RW         0x134B00F0         32           TMCL         RW         0x134B00F0         32           TKCL         RW         0x134B00F0         32           TLCL         RW         0x134B010         32           TXCL         RW         0x134B010         32           TDRP         RW         0x134B010         32           TDRP         RW         0x134B010         32           TDRP         RW         0x134B0110         32           TDRP         RW         0x134B0110         32           TXCF         RW         0x134B0120         32           TOVR         RW         0x134B0128     | RJBR                                  | RW     | 0x134B00D8 | 32 |
| TPKT         RW         0x134B00E4         32           TMCA         RW         0x134B00E8         32           TBCA         RW         0x134B00EC         32           TXPF         RW         0x134B00F0         32           TDFR         RW         0x134B00F4         32           TEDF         RW         0x134B00F3         32           TSCL         RW         0x134B00F6         32           TMCL         RW         0x134B00F6         32           TMCL         RW         0x134B00F0         32           TLCL         RW         0x134B0100         32           TXCL         RW         0x134B0104         32           TXCL         RW         0x134B0104         32           TNCL         RW         0x134B0106         32           TDRP         RW         0x134B010         32           TDRP         RW         0x134B0110         32           TXCF         RW         0x134B0110         32           TVND         RW         0x134B0120         32           TVND         RW         0x134B0120         32           TFRG         RW         0x134B0120  | RDRP                                  | RW     | 0x134B00DC | 32 |
| TMCA         RW         0x134B00E8         32           TBCA         RW         0x134B00EC         32           TXPF         RW         0x134B00F0         32           TDFR         RW         0x134B00F4         32           TEDF         RW         0x134B00F6         32           TSCL         RW         0x134B00FC         32           TMCL         RW         0x134B0100         32           TLCL         RW         0x134B0104         32           TXCL         RW         0x134B0104         32           TXCL         RW         0x134B0104         32           TXCL         RW         0x134B0104         32           TNCL         RW         0x134B0106         32           TNCL         RW         0x134B0106         32           TDFP         RW         0x134B0100         32           TDRP         RW         0x134B0110         32           TJBR         RW         0x134B0110         32           TVCF         RW         0x134B0120         32           TOVR         RW         0x134B0120         32           TUND         RW         0x134B0128 | ТВҮТ                                  | RW     | 0x134B00E0 | 32 |
| TBCA         RW         0x134B00EC         32           TXPF         RW         0x134B00F0         32           TDFR         RW         0x134B00F4         32           TEDF         RW         0x134B00F6         32           TSCL         RW         0x134B00FC         32           TMCL         RW         0x134B00FC         32           TLCL         RW         0x134B0100         32           TXCL         RW         0x134B0104         32           TXCL         RW         0x134B0100         32           TXCL         RW         0x134B0108         32           TNCL         RW         0x134B0100         32           TNCL         RW         0x134B0100         32           TDRP         RW         0x134B0110         32           TDRP         RW         0x134B0114         32           TJBR         RW         0x134B0116         32           TXCF         RW         0x134B0110         32           TOVR         RW         0x134B0120         32           TUND         RW         0x134B0128         32           TFRG         RW         0x134B0120 | ТРКТ                                  | RW     | 0x134B00E4 | 32 |
| TXPF         RW         0x134B00F0         32           TDFR         RW         0x134B00F4         32           TEDF         RW         0x134B00F8         32           TSCL         RW         0x134B00FC         32           TMCL         RW         0x134B00FC         32           TLCL         RW         0x134B0100         32           TXCL         RW         0x134B0104         32           TXCL         RW         0x134B0106         32           TNCL         RW         0x134B0100         32           TNCL         RW         0x134B0108         32           TNCL         RW         0x134B0100         32           TDFH         RW         0x134B0100         32           TDRP         RW         0x134B0110         32           TJBR         RW         0x134B0114         32           TXCF         RW         0x134B0110         32           TVND         RW         0x134B0120         32           TUND         RW         0x134B0120         32           TFRG         RW         0x134B0120         32           CAR1         R         0x134B0130  | TMCA                                  | RW     | 0x134B00E8 | 32 |
| TDFR       RW       0x134B00F4       32         TEDF       RW       0x134B00F8       32         TSCL       RW       0x134B00FC       32         TMCL       RW       0x134B0100       32         TLCL       RW       0x134B0104       32         TXCL       RW       0x134B0104       32         TXCL       RW       0x134B0106       32         TNCL       RW       0x134B0106       32         TNCL       RW       0x134B0100       32         TPFH       RW       0x134B0100       32         TDRP       RW       0x134B0110       32         TJBR       RW       0x134B0114       32         TYCF       RW       0x134B0116       32         TVOR       RW       0x134B0110       32         TVND       RW       0x134B0120       32         TUND       RW       0x134B0120       32         TFRG       RW       0x134B0128       32         CAR1       R       0x134B0130       32         CAR2       R       0x134B0134       32         CAM1       RW       0x134B0138       32 <td>TBCA</td> <td>RW</td> <td>0x134B00EC</td> <td>32</td>                                    | TBCA                                  | RW     | 0x134B00EC | 32 |
| TEDF         RW         0x134B00F8         32           TSCL         RW         0x134B00FC         32           TMCL         RW         0x134B0100         32           TLCL         RW         0x134B0104         32           TXCL         RW         0x134B0104         32           TXCL         RW         0x134B0108         32           TNCL         RW         0x134B0108         32           TNCL         RW         0x134B0100         32           TPFH         RW         0x134B0110         32           TDRP         RW         0x134B0110         32           TJBR         RW         0x134B0114         32           TJBR         RW         0x134B0116         32           TXCF         RW         0x134B0120         32           TOVR         RW         0x134B0120         32           TUND         RW         0x134B0124         32           TFRG         RW         0x134B012C         32           CAR1         R         0x134B0130         32           CAR2         R         0x134B0134         32                                                | TXPF                                  | RW     | 0x134B00F0 | 32 |
| TSCL       RW       0x134B00FC       32         TMCL       RW       0x134B0100       32         TLCL       RW       0x134B0104       32         TXCL       RW       0x134B0108       32         TNCL       RW       0x134B0100       32         TNCL       RW       0x134B0108       32         TNCL       RW       0x134B0100       32         TPFH       RW       0x134B0110       32         TDRP       RW       0x134B0114       32         TJBR       RW       0x134B0118       32         TYCF       RW       0x134B0110       32         TXCF       RW       0x134B0110       32         TOVR       RW       0x134B0120       32         TUND       RW       0x134B0124       32         TFRG       RW       0x134B0126       32         CAR1       R       0x134B0130       32         CAR2       R       0x134B0134       32         CAM1       RW       0x134B0138       32                                                                                                                                                                                              | TDFR                                  | RW     | 0x134B00F4 | 32 |
| TMCL       RW       0x134B0100       32         TLCL       RW       0x134B0104       32         TXCL       RW       0x134B0108       32         TNCL       RW       0x134B0100       32         TNCL       RW       0x134B0100       32         TPFH       RW       0x134B0110       32         TDRP       RW       0x134B0114       32         TJBR       RW       0x134B0114       32         TFCS       RW       0x134B0110       32         TXCF       RW       0x134B0110       32         TOVR       RW       0x134B0110       32         TUND       RW       0x134B0120       32         TUND       RW       0x134B0124       32         TFRG       RW       0x134B0128       32         CAR1       R       0x134B0130       32         CAR2       R       0x134B0134       32         CAM1       RW       0x134B0138       32                                                                                                                                                                                                                                              | TEDF                                  | RW     | 0x134B00F8 | 32 |
| TLCL       RW       ON       0x134B0104       32         TXCL       RW       0x134B0108       32         TNCL       RW       0x134B010C       32         TPFH       RW       0x134B0110       32         TDRP       RW       0x134B0114       32         TJBR       RW       0x134B0114       32         TFCS       RW       0x134B0116       32         TXCF       RW       0x134B0120       32         TOVR       RW       0x134B0124       32         TUND       RW       0x134B0128       32         TERG       RW       0x134B0120       32         CAR1       R       0x134B0120       32         CAR2       R       0x134B0130       32         CAM1       RW       0x134B0138       32                                                                                                                                                                                                                                                                                                                                                                                     | TSCL                                  | RW     | 0x134B00FC | 32 |
| TXCL       RW       0x134B0108       32         TNCL       RW       0x134B010C       32         TPFH       RW       0x134B0110       32         TDRP       RW       0x134B0114       32         TJBR       RW       0x134B0118       32         TFCS       RW       0x134B0116       32         TXCF       RW       0x134B0120       32         TOVR       RW       0x134B0124       32         TUND       RW       0x134B0128       32         TFRG       RW       0x134B0120       32         CAR1       R       0x134B0120       32         CAR2       R       0x134B0130       32         CAM1       RW       0x134B0138       32                                                                                                                                                                                                                                                                                                                                                                                                                                              | TMCL                                  | RW     | 0x134B0100 | 32 |
| TNCL         RW         0x134B010C         32           TPFH         RW         0x134B0110         32           TDRP         RW         0x134B0114         32           TJBR         RW         0x134B0118         32           TFCS         RW         0x134B011C         32           TXCF         RW         0x134B0120         32           TOVR         RW         0x134B0124         32           TUND         RW         0x134B0128         32           TFRG         RW         0x134B0128         32           CAR1         R         0x134B0130         32           CAR2         R         0x134B0134         32                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TLCL                                  | RW COM | 0x134B0104 | 32 |
| TPFH       RW       0x134B0110       32         TDRP       RW       0x134B0114       32         TJBR       RW       0x134B0118       32         TFCS       RW       0x134B0110       32         TXCF       RW       0x134B0120       32         TOVR       RW       0x134B0124       32         TUND       RW       0x134B0128       32         TFRG       RW       0x134B012C       32         CAR1       R       0x134B0130       32         CAM1       RW       0x134B0138       32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | TXCL                                  | RW 00. | 0x134B0108 | 32 |
| TDRP       RW       0x134B0114       32         TJBR       RW       0x134B0118       32         TFCS       RW       0x134B011C       32         TXCF       RW       0x134B0120       32         TOVR       RW       0x134B0124       32         TUND       RW       0x134B0128       32         TFRG       RW       0x134B012C       32         CAR1       R       0x134B0130       32         CAR2       R       0x134B0138       32         CAM1       RW       0x134B0138       32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | TNCL                                  | RW 10  | 0x134B010C | 32 |
| TJBR       RW       0x134B0118       32         TFCS       RW       0x134B011C       32         TXCF       RW       0x134B0120       32         TOVR       RW       0x134B0124       32         TUND       RW       0x134B0128       32         TFRG       RW       0x134B0120       32         CAR1       R       0x134B0130       32         CAM1       RW       0x134B0138       32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | TPFH                                  | RWC    | 0x134B0110 | 32 |
| TFCS       RW       0x134B011C       32         TXCF       RW       0x134B0120       32         TOVR       RW       0x134B0124       32         TUND       RW       0x134B0128       32         TFRG       RW       0x134B012C       32         CAR1       R       0x134B0130       32         CAR2       R       0x134B0134       32         CAM1       RW       0x134B0138       32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | TDRP                                  | RW     | 0x134B0114 | 32 |
| TXCF         RW         0x134B0120         32           TOVR         RW         0x134B0124         32           TUND         RW         0x134B0128         32           TFRG         RW         0x134B012C         32           CAR1         R         0x134B0130         32           CAR2         R         0x134B0138         32           CAM1         RW         0x134B0138         32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TJBR 0                                | RW     | 0x134B0118 | 32 |
| TOVR         RW         0x134B0124         32           TUND         RW         0x134B0128         32           TFRG         RW         0x134B012C         32           CAR1         R         0x134B0130         32           CAR2         R         0x134B0134         32           CAM1         RW         0x134B0138         32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TFCS                                  | RW     | 0x134B011C | 32 |
| TUND         RW         0x134B0128         32           TFRG         RW         0x134B012C         32           CAR1         R         0x134B0130         32           CAR2         R         0x134B0134         32           CAM1         RW         0x134B0138         32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | · · · · · · · · · · · · · · · · · · · | RW     | 0x134B0120 | 32 |
| TFRG         RW         0x134B012C         32           CAR1         R         0x134B0130         32           CAR2         R         0x134B0134         32           CAM1         RW         0x134B0138         32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TOVR                                  | RW     | 0x134B0124 | 32 |
| CAR1         R         0x134B0130         32           CAR2         R         0x134B0134         32           CAM1         RW         0x134B0138         32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TUND                                  | RW     | 0x134B0128 | 32 |
| CAR2         R         0x134B0134         32           CAM1         RW         0x134B0138         32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | TFRG                                  | RW     | 0x134B012C | 32 |
| CAM1 RW 0x134B0138 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | CAR1                                  | R      | 0x134B0130 | 32 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | CAR2                                  | R      | 0x134B0134 | 32 |
| CAM2 RW 0x134B013C 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | CAM1                                  | RW     | 0x134B0138 | 32 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | CAM2                                  | RW     | 0x134B013C | 32 |



#### 11.9.3 Register Description

#### 11.9.3.1 TR64

|     | TR | 64 |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | <b>0</b> x | 134 | <b>B0</b> ( | 080 |
|-----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|------------|-----|-------------|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7 | 6 | 5 | 4 | 3          | 2   | 1           | 0   |
|     |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |            |     |             |     |
|     |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |            |     |             |     |
|     |    |    |    |    |    | R  | lese | erve | d  |    |    |    |    |    |    |    |    |    |    |    |    |    | TR | 64 |   |   |   |   |            |     |             |     |
|     |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |            |     |             |     |
|     |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |            |     |             |     |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0          | 0   | 0           | 0   |

| Bits  | Name     | Description                                                        | RW |
|-------|----------|--------------------------------------------------------------------|----|
| 31:18 | Reserved | Writing has no effect, read as zero.                               | R  |
| 17:0  | TR64     | Transmit and Receive 64 Byte Frame Counter: Incremented for each   | RW |
|       |          | good or bad frame transmitted and received which is 64 bytes in    |    |
|       |          | length inclusive (excluding framing bits but including FCS bytes). |    |

#### 11.9.3.2 TR127



| Bits  | Name     | Description                                                         | RW |
|-------|----------|---------------------------------------------------------------------|----|
| 31:18 | Reserved | Writing has no effect, read as zero.                                | R  |
| 17:0  | TR127    | Transmit and Receive 65 to 127 Byte Frame Counter: Incremented      | RW |
|       |          | for each good or bad frame transmitted and received which is 65 to  |    |
|       |          | 127 bytes in length inclusive (excluding framing bits but including |    |
|       |          | FCS bytes).                                                         |    |



#### 11.9.3.3 TR255

#### TR255

|     | TR | 255 |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   | <b>0</b> x | 134 | <b>B0</b> ( | 880 |
|-----|----|-----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|------------|-----|-------------|-----|
| Bit | 31 | 30  | 29 | 28 | 27 | 26 | 25  | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7 | 6 | 5 | 4 | 3          | 2   | 1           | 0   |
|     |    |     |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |    |    |    | TR | 255 |   |   |   |   |            |     |             |     |
| RST | 0  | 0   | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0 | 0 | 0 | 0 | 0          | 0   | 0           | 0   |

| Bits                 | Name     | Description                                                         | RW     |
|----------------------|----------|---------------------------------------------------------------------|--------|
| 31:18                | Reserved | Writing has no effect, read as zero.                                | R      |
| 17:0                 | TR255    | Transmit and Receive 128 to 255 Byte Frame Counter: Incremented     | RW     |
|                      |          | for each good or bad frame transmitted and received which is 128 to |        |
|                      |          | 255 bytes in length inclusive (excluding framing bits but including |        |
|                      |          | FCS bytes).                                                         |        |
| 11.9.3. <sup>4</sup> | 4 TR511  | internal us                                                         |        |
| TR5                  | 511      | 0x134                                                               | 4B008C |

#### 11.9.3.4 TR511

|     | TR | 511 |    |    |    |    |     |      |    |    |    |    |    |    | -1 | 7  | Y  |    |    |    |    |    |    |     |   |   |   |   | <b>0</b> x1 | 134 | <b>B00</b> | <b>38</b> 0 |
|-----|----|-----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|-------------|-----|------------|-------------|
| Bit | 31 | 30  | 29 | 28 | 27 | 26 | 25  | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7 | 6 | 5 | 4 | 3           | 2   | 1          | 0           |
|     |    |     |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |    |    |    | TR | 511 |   |   |   |   |             |     |            |             |
| RST | 0  | 0   | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0 | 0 | 0 | 0 | 0           | 0   | 0          | 0           |

| Bits  | Name     | Description                                                         | RW |
|-------|----------|---------------------------------------------------------------------|----|
| 31:18 | Reserved | Writing has no effect, read as zero.                                | R  |
| 17:0  | TR511    | Transmit and Receive 256 to 511 Byte Frame Counter: Incremented     | RW |
|       |          | for each good or bad frame transmitted and received which is 256 to |    |
|       |          | 511 bytes in length inclusive (excluding framing bits but including |    |
|       |          | FCS bytes).                                                         |    |



#### 11.9.3.5 TR1K

# TR1K 0x134B0090 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved TR1K

| Bits  | Name     | Description                                                          | RW |
|-------|----------|----------------------------------------------------------------------|----|
| 31:18 | Reserved | Writing has no effect, read as zero.                                 | R  |
| 17:0  | TR1K     | Transmit and Receive 512 to 1023 Byte Frame Counter: Incremented     | RW |
|       |          | for each good or bad frame transmitted and received which is 512 to  |    |
|       |          | 1023 bytes in length inclusive (excluding framing bits but including |    |
|       |          | FCS bytes).                                                          |    |

#### 11.9.3.6 TRMAX



| Bits  | Name     | Description                                                             | RW |
|-------|----------|-------------------------------------------------------------------------|----|
| 31:18 | Reserved | Writing has no effect, read as zero.                                    | R  |
| 17:0  | TRMAX    | Transmit and Receive 1024 to 1518 Byte Frame Counter:                   | RW |
|       |          | Incremented for each good or bad frame transmitted and received         |    |
|       |          | which is 1024 to 1518 bytes in length inclusive (excluding framing bits |    |
|       |          | but including FCS bytes).                                               |    |



#### 11.9.3.7 TRMGV

#### TRMGV

|     | TRI | MG | V  |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   | <b>0</b> x | 134 | <b>B0</b> ( | 98 |
|-----|-----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|------------|-----|-------------|----|
| Bit | 31  | 30 | 29 | 28 | 27 | 26 | 25  | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7 | 6 | 5 | 4 | 3          | 2   | 1           | 0  |
|     |     |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |    |    | ٦  | ſRN | ١G | / |   |   |   |            |     |             |    |
| RST | 0   | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0 | 0 | 0 | 0 | 0          | 0   | 0           | 0  |

| Bits     | Name     | Description                                                             | RW     |
|----------|----------|-------------------------------------------------------------------------|--------|
| 31:18    | Reserved | Writing has no effect, read as zero.                                    | R      |
| 17:0     | TRMGV    | Transmit and Receive 1519 to 1522 Byte VLAN Frame Counter:              | RW     |
|          |          | Incremented for each good VLAN frame transmitted and received           |        |
|          |          | which is 1519 to 1522 bytes in length inclusive (excluding framing bits |        |
|          |          | but including FCS bytes).                                               |        |
| 11.9.3.8 | 8 RBYT   | eternal us                                                              |        |
| RB       | л        | OTA III Ox13                                                            | 4B009C |

#### 11.9.3.8 RBYT

|    |    |    |          |                    |                          |                               |                                  |                                     |                                        |                                           |                                              |                                                 |                                                    |                                                       |                                                          | Y                                                           |                                                                |                                                                      |                                                                           |                                                                                               |                                                                                             |                                                                                                 |                                                                                                 |                                                                                                   |                                                                                                       |                                                                                                         |                                                                                                           |                                                                                                             |                                                                                                               |                                                                                                                 |                                                                                                                   |
|----|----|----|----------|--------------------|--------------------------|-------------------------------|----------------------------------|-------------------------------------|----------------------------------------|-------------------------------------------|----------------------------------------------|-------------------------------------------------|----------------------------------------------------|-------------------------------------------------------|----------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| RB | YΤ |    |          |                    |                          |                               |                                  |                                     |                                        |                                           |                                              |                                                 | 6                                                  | 5                                                     |                                                          |                                                             |                                                                |                                                                      |                                                                           |                                                                                               |                                                                                             |                                                                                                 |                                                                                                 |                                                                                                   |                                                                                                       |                                                                                                         |                                                                                                           | <b>0</b> x1                                                                                                 | 34                                                                                                            | B00                                                                                                             | )9C                                                                                                               |
| 31 | 30 | 29 | 28       | 27                 | 26                       | 25                            | 24                               | 23                                  | 22                                     | 21                                        | 20                                           | 19                                              | 18                                                 | 17                                                    | 16                                                       | 15                                                          | 14                                                             | 13                                                                   | 12                                                                        | 11                                                                                            | 10                                                                                          | 9                                                                                               | 8                                                                                               | 7                                                                                                 | 6                                                                                                     | 5                                                                                                       | 4                                                                                                         | 3                                                                                                           | 2                                                                                                             | 1                                                                                                               | 0                                                                                                                 |
|    |    |    |          |                    |                          |                               |                                  |                                     |                                        | $\langle l$                               | 2                                            |                                                 |                                                    |                                                       |                                                          |                                                             |                                                                |                                                                      |                                                                           |                                                                                               |                                                                                             |                                                                                                 |                                                                                                 |                                                                                                   |                                                                                                       |                                                                                                         |                                                                                                           |                                                                                                             |                                                                                                               |                                                                                                                 |                                                                                                                   |
|    |    |    |          |                    |                          |                               |                                  |                                     |                                        | <b>y</b>                                  |                                              |                                                 |                                                    |                                                       |                                                          |                                                             |                                                                |                                                                      |                                                                           |                                                                                               |                                                                                             |                                                                                                 |                                                                                                 |                                                                                                   |                                                                                                       |                                                                                                         |                                                                                                           |                                                                                                             |                                                                                                               |                                                                                                                 |                                                                                                                   |
|    |    |    | Res      | serv               | ved                      |                               |                                  |                                     |                                        |                                           |                                              |                                                 |                                                    |                                                       |                                                          |                                                             |                                                                |                                                                      | R                                                                         | BY                                                                                            | Г                                                                                           |                                                                                                 |                                                                                                 |                                                                                                   |                                                                                                       |                                                                                                         |                                                                                                           |                                                                                                             |                                                                                                               |                                                                                                                 |                                                                                                                   |
|    |    |    |          |                    |                          |                               |                                  |                                     |                                        |                                           |                                              |                                                 |                                                    |                                                       |                                                          |                                                             |                                                                |                                                                      |                                                                           |                                                                                               |                                                                                             |                                                                                                 |                                                                                                 |                                                                                                   |                                                                                                       |                                                                                                         |                                                                                                           |                                                                                                             |                                                                                                               |                                                                                                                 |                                                                                                                   |
|    |    |    |          |                    |                          |                               |                                  |                                     |                                        |                                           |                                              |                                                 |                                                    |                                                       |                                                          |                                                             |                                                                |                                                                      |                                                                           |                                                                                               |                                                                                             |                                                                                                 |                                                                                                 |                                                                                                   |                                                                                                       |                                                                                                         |                                                                                                           |                                                                                                             |                                                                                                               |                                                                                                                 |                                                                                                                   |
| 0  | 0  | 0  | 0        | 0                  | 0                        | 0                             | 0                                | 0                                   | 0                                      | 0                                         | 0                                            | 0                                               | 0                                                  | 0                                                     | 0                                                        | 0                                                           | 0                                                              | 0                                                                    | 0                                                                         | 0                                                                                             | 0                                                                                           | 0                                                                                               | 0                                                                                               | 0                                                                                                 | 0                                                                                                     | 0                                                                                                       | 0                                                                                                         | 0                                                                                                           | 0                                                                                                             | 0                                                                                                               | 0                                                                                                                 |
|    | 31 |    | 31 30 29 | 31 30 29 28<br>Res | 31 30 29 28 27<br>Reserv | 31 30 29 28 27 26<br>Reserved | 31 30 29 28 27 26 25<br>Reserved | 31 30 29 28 27 26 25 24<br>Reserved | 31 30 29 28 27 26 25 24 23<br>Reserved | 31 30 29 28 27 26 25 24 23 22<br>Reserved | 31 30 29 28 27 26 25 24 23 22 21<br>Reserved | 31 30 29 28 27 26 25 24 23 22 21 20<br>Reserved | 31 30 29 28 27 26 25 24 23 22 21 20 19<br>Reserved | 31 30 29 28 27 26 25 24 23 22 21 20 19 18<br>Reserved | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17<br>Reserved | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16<br>Reserved | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15<br>Reserved | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14       Reserved | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13         Reserved | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12         Reserved         Reserved | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11         Reserved         RBY | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10         Reserved         RBYT | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9         Reserved       RBYT | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8         Reserved       RBYT | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7         Reserved         RBYT | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6         Reserved         RBYT | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5         Reserved         RBYT | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4         Reserved         RBYT | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3         Reserved         RBYT | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2         Reserved         RBYT | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1         Reserved         RBYT |

| Bits  | Name     | Description                                                         | RW |
|-------|----------|---------------------------------------------------------------------|----|
| 31:23 | Reserved | Writing has no effect, read as zero.                                | R  |
| 22:0  | RBYT     | Receive Byte Counter: The Statistic Counter register is incremented | RW |
|       |          | by the byte count of all frames received, including those in bad    |    |
|       |          | packets, excluding framing bits but including FCS bytes.            |    |



#### 11.9.3.9 RPKT

#### RPKT

|     | RP | кт |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | <b>0</b> x1 | 34 | B00 | <b>A0</b> |
|-----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-------------|----|-----|-----------|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7 | 6 | 5 | 4 | 3           | 2  | 1   | 0         |
|     |    |    |    |    |    | R  | lese | erve | d  |    |    |    |    |    |    |    |    |    |    |    |    |    | RP | кт |   |   |   |   |             |    |     |           |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0           | 0  | 0   | 0         |

| Bits                 | Name           | Description                                                          | RW     |
|----------------------|----------------|----------------------------------------------------------------------|--------|
| 31:18                | Reserved       | Writing has no effect, read as zero.                                 | R      |
| 17:0                 | RPKT           | Receive Packet Counter: Incremented for each frame received          | RW     |
|                      |                | packet (including bad packets, all Unicast, Broadcast, and Multicast |        |
|                      |                | packets).                                                            |        |
| 11.9.3. <sup>-</sup> | 10 RFCS        | Lernal USeu                                                          |        |
| RFC                  | s              | 11 <sup>1</sup> 0x13                                                 | 4B00A4 |
| <b>Bit</b> 31 3      | 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2      | 1 0    |

#### 11.9.3.10 RFCS

#### RFCS

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

|     |   |   |   |   |   |   |   |   | F | Rese | erve | d |   |   |   |   |   |   |   |   |   |   |   |   |   | RF | cs |   |   |   |   |   |
|-----|---|---|---|---|---|---|---|---|---|------|------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|----|---|---|---|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0 | 0 | 0 | 0 | 0 |

| Bits  | Name     | Description                                                      | RW |
|-------|----------|------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                             | R  |
| 11:0  | RFCS     | Receive FCS Error Counter: Incremented for each frame received   | RW |
|       |          | that has a integral 64 to 1518 length and contains a Frame Check |    |
|       |          | Sequence error.                                                  |    |



#### 11.9.3.11 RMCA

#### RMCA

|     | RM | СА |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | <b>0</b> x1 | 34 | B00 | <b>8</b> |
|-----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-------------|----|-----|----------|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7 | 6 | 5 | 4 | 3           | 2  | 1   | 0        |
|     |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |    |    |    | RM | CA |   |   |   |   |             |    |     |          |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0           | 0  | 0   | 0        |

| Bits    | Name     | Description                                                                                                                                                                                                        | RW    |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:18   | Reserved | Writing has no effect, read as zero.                                                                                                                                                                               | R     |
| 17:0    | RMCA     | Receive Multicast Packet Counter: Incremented for each Multicast<br>good frame of lengths smaller than 1518 (non VLAN) or 1522 (VLAN)<br>excluding Broadcast frames. This does not look at range/length<br>errors. | RW    |
| 11.9.3. | 12 RBCA  | internal use                                                                                                                                                                                                       |       |
| RBC     | CA       | 0x134                                                                                                                                                                                                              | B00AC |

#### 11.9.3.12 RBCA

|     | RB | СА |    |    |     |      |    |    |    |    |    |    |    |    | -10 | 7  | Y  |    |    |    |    |    |   |   |   |   |   |   | 0x1 | 34 | 300 | AC |
|-----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----|----|-----|----|
| Bit | 31 | 30 | 29 | 28 | 27  | 26   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1   | 0  |
|     |    |    |    | R  | ese | erve | d  |    |    |    | 7  |    | )• |    |     |    |    |    |    |    | RB | CA |   |   |   |   |   |   |     |    |     |    |
| RST | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0   | 0  | 0   | 0  |

| Bits  | Name     | Description                                                            | RW |
|-------|----------|------------------------------------------------------------------------|----|
| 31:22 | Reserved | Writing has no effect, read as zero.                                   | R  |
| 21:0  | RBCA     | Receive Broadcast Packet Counter: Incremented for each Broadcast       | RW |
|       |          | good frame of lengths smaller than 1518 (non VLAN) or 1522 (VLAN)      |    |
|       |          | excluding Multicast frames. This does not look at range/length errors. |    |



#### 11.9.3.13 RXCF

#### RXCE

|     | RX | CF<br>30 29 28 27 26 25 24 23 22 21 20 19 18 1 |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | <b>0</b> x1 | 34 | B00 | <b>B0</b> |
|-----|----|------------------------------------------------|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-------------|----|-----|-----------|
| Bit | 31 | 30                                             | 29 | 28 | 27 | 26 | 25  | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7 | 6 | 5 | 4 | 3           | 2  | 1   | 0         |
|     |    |                                                |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |    |    |    | RX | CF |   |   |   |   |             |    |     |           |
| RST | 0  | 0                                              | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0           | 0  | 0   | 0         |

| Bi  | ts   | Name        | Description                                                        | RW     |
|-----|------|-------------|--------------------------------------------------------------------|--------|
| 31: | 18   | Reserved    | Writing has no effect, read as zero.                               | R      |
| 17: | :0   | RXCF        | Receive Control Frame Packet Counter: Incremented for each MAC     | RW     |
|     |      |             | Control frame received (PAUSE & Unsupported).                      |        |
|     |      | I4 RXPF     | mal used or                                                        |        |
|     | RXP  | F           | $\times \mathbb{C}^{V}$ 0x134                                      | 4B00B4 |
| Bit | 31 3 | 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0    |

#### 11.9.3.14 RXPF

#### **RXPF**

#### 0x134B00B4

|     |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    | _ <b>X</b> | C  |    |    |    |   |   |   |    |    |   |   |   |   |   |
|-----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|------------|----|----|----|----|---|---|---|----|----|---|---|---|---|---|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14         | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4 | 3 | 2 | 1 | 0 |
|     |    |    |    |    |    |    |    |    | R  | lese | erve | ed |    |    |    |    |    |            |    |    |    |    |   |   |   | RX | PF |   |   |   |   |   |
|     |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |            |    |    |    |    |   |   |   |    |    |   |   |   |   |   |

| Bits  | Name     | Description                                                 | RW |
|-------|----------|-------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                        | R  |
| 11:0  | RXPF     | Receive PAUSE Frame Packet Counter: Incremented each time a | RW |
|       |          | valid PAUSE MAC Control frame is received.                  |    |



#### 11.9.3.15 RXUO

# **RXUO** 0x134B00B8 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved **RXUO**

| Bits                 | Name        | Description                                                        | RW    |
|----------------------|-------------|--------------------------------------------------------------------|-------|
| 31:12                | Reserved    | Writing has no effect, read as zero.                               | R     |
| 11:0                 | RXUO        | Receive Unknown OPcode Counter: Incremented each time a MAC        | RW    |
|                      |             | Control Frame is received which contains an opcode other than a    |       |
|                      |             | PAUSE.                                                             |       |
| 11.9.3. <sup>-</sup> | 16 RALN     | Lernal Useu                                                        |       |
| RAL                  | _N          | ۲ <sup>1</sup> 0x134                                               | B00BC |
| <b>Bit</b> 31 3      | 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0   |

#### 11.9.3.16 RALN

#### RALN

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

|     |   |   |   |   |   |   |   |   | R | lese | erve | d |   |   |   |   |   |   |   |   |   |   |   |   |   | RA | LN |   |   |   |   |   |
|-----|---|---|---|---|---|---|---|---|---|------|------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|----|---|---|---|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0 | 0 | 0 | 0 | 0 |

| Bits  | Name     | Description                                                       | RW |
|-------|----------|-------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                              | R  |
| 11:0  | RALN     | Receive Alignment Error Counter: Incremented for each received    | RW |
|       |          | frame from 64 to 1518 which contains an invalid FCS and is not an |    |
|       |          | integral number of bytes.                                         |    |



#### 11.9.3.17 RFLR

#### RFLR

# 0x134B00C0 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved RFLR

| Bits                 | Name     | Description                                                                                                                                                                                                                                                                                                 | RW    |
|----------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:16                | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                        | R     |
| 15:0                 | TR127    | Receive Frame Length Error Counter: Incremented for each frame<br>received in which the 802.3 length field did not match the number of<br>data bytes actually received (46 - 1500 bytes). The counter is not<br>incremented if the length field is not a valid 802.3 length, such as an<br>EtherType value. | RW    |
| 11.9.3. <sup>-</sup> | 18 RCDE  | com internal                                                                                                                                                                                                                                                                                                | 48000 |

#### 11.9.3.18 RCDE

|     |    |    |    |    |    |    |    |    |    |      |      |    |    | ~( | 21 | 7  |    |    |    |    |    |    |   |   |   |    |    |   |             |    |     |            |
|-----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----|----|---|-------------|----|-----|------------|
|     | RC | DE |    |    |    |    |    |    |    |      |      | C  |    | C' |    |    |    |    |    |    |    |    |   |   |   |    |    |   | <b>0</b> x1 | 34 | B00 | <b>)C4</b> |
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4 | 3           | 2  | 1   | 0          |
|     |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |    |     |            |
|     |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |    |     |            |
|     |    |    |    |    |    |    |    |    | R  | lese | erve | d  |    |    |    |    |    |    |    |    |    |    |   |   |   | RC | DE |   |             |    |     |            |
|     |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |    |     |            |
|     |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |    |     |            |
| RST |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0  | 0  | 0 | 0           | 0  | 0   | 0          |
| ROI | U  | U  | U  | U  | U  | U  | U  | U  | U  | U    | U    | U  | U  | U  | U  | U  | U  | U  | U  | U  | U  | U  | U | U | U | U  | U  | U | U           | U  | U   | U          |

| Bits  | Name     | Description                                                       | RW |
|-------|----------|-------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                              | R  |
| 11:0  | RCDE     | Receive Code Error Counter: Incremented each time a valid carrier | RW |
|       |          | was present and at least one invalid data symbol was detected.    |    |

0x134B00C8

#### 11.9.3.19 RCSE

#### RCSE

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

|     |   |   |   |   |   |   |   |   | F | lese | erve | ed |   |   |   |   |   |   |   |   |   |   |   |   |   | RC | SE |   |   |   |   |   |
|-----|---|---|---|---|---|---|---|---|---|------|------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|----|----|---|---|---|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0 | 0 | 0 | 0 | 0 |

| Bits            | Name     | Description                                                                                                                                                                                                                                                                                                                 | RW    |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:12           | Reserved | Writing has no effect, read as zero.                                                                                                                                                                                                                                                                                        | R     |
| 11:0            | RCSE     | Receive False Carrier Counter: Incremented each time a false carrier<br>is detected during idle, as defined by a 1 on RX_ER and an '0xE' on<br>RXD. The event is reported along with the statistics generated on the<br>next received frame. Only one false carrier condition can be detected<br>and logged between frames. | RW    |
| 11.9.3.2<br>RUN | 20 RUND  | com internal                                                                                                                                                                                                                                                                                                                | B00CC |

#### 11.9.3.20 RUND

|     | RUI      | ND |    |    |    |    |    |    |    |    |    | C  |    | C  | Эr | 1.0 |    |    |    |    |    |    |   |   |   |   |   |   | 0x1 | 34 | 300 | сс |
|-----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|-----|----|-----|----|
| Bit | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1   | 0  |
|     | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    | RU | ND |    |   |   |   |   |   |   |     |    |     |    |
| RST | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0   | 0  | 0   | 0  |

| Bits  | Name     | Description                                                            | RW |
|-------|----------|------------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                                   | R  |
| 11:0  | RUND     | Receive Undersize Packet Counter: Incremented each time a frame        | RW |
|       |          | is received which is less than 64 bytes in length and contains a valid |    |
|       |          | FCS and were otherwise well formed. This does not look at Range        |    |
|       |          | Length errors.                                                         |    |



#### 11.9.3.21 ROVR

|     | RO       | VR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x1 | 34 | <b>B00</b> | D0 |
|-----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------------|----|------------|----|
| Bit | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2  | 1          | 0  |
|     | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO | VR |    |   |   |   |   |   |   |             |    |            |    |
| RST | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0           | 0  | 0          | 0  |

| Bits     | Name     | Description                                                        | RW                    |
|----------|----------|--------------------------------------------------------------------|-----------------------|
| 31:12    | Reserved | Writing has no effect, read as zero.                               | R                     |
| 11:0     | ROVR     | Receive Oversize Packet Counter: Incremented each time a frame is  | RW                    |
|          |          | received which exceeded 1518 (non VLAN) or 1522 (VLAN) and 🔨       |                       |
|          |          | contains a valid FCS and were otherwise well formed. This does not |                       |
|          |          | look at Range Length errors.                                       |                       |
| 11.9.3.2 | 22 RFRG  | . nternal us                                                       |                       |
| RFC      | s        | 0x134                                                              | 4 <mark>B00</mark> D4 |

#### 11.9.3.22 RFRG

|     | RFO      | cs |    |    |    |    |    |    |    |    |    |    |    | 6  | 5  | 1  | Γ, |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x1 | 34 | B00 | D4 |
|-----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------------|----|-----|----|
| Bit | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2  | 1   | 0  |
|     |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |             |    |     |    |
|     | Descend  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |             |    |     |    |
|     | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RF | RG |   |   |   |   |   |   |             |    |     |    |
|     |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |             |    |     |    |
|     |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |             |    |     |    |
| RST | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0           | 0  | 0   | 0  |

| Bits  | Name     | Description                                                        | RW |
|-------|----------|--------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                               | R  |
| 11:0  | RFRG     | Receive Fragments Counter: Incremented for each frame received     | RW |
|       |          | which is less than 64 bytes in length and contains an invalid FCS, |    |
|       |          | includes integral and non-integral lengths.                        |    |



#### 11.9.3.23 RJBR

# **RJBR** 0x134B00D8 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved **RJBR**

| Bits            | Name        | Description                                                        | RW    |
|-----------------|-------------|--------------------------------------------------------------------|-------|
| 31:12           | Reserved    | Writing has no effect, read as zero.                               | R     |
| 11:0            | RJBR        | Receive Jabber Counter: Incremented for frames received which      | RW    |
|                 |             | exceed 1518 (non VLAN) or 1522 (VLAN) bytes and contains an        |       |
|                 |             | invalid FCS, includes alignment errors.                            |       |
| 11.9.3.2        | 24 RDRP     | ternal used                                                        |       |
| RDF             | RP          | ر 0x134 0x134                                                      | BOODC |
| <b>Bit</b> 31 3 | 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0   |

#### 11.9.3.24 RDRP

#### **RDRP**

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

|     |   |   |   |   |   |   |   |   | R | lese | erve | ed |   |   |   |   |   |   |   |   |   |   |   |   |   | RD | IRP |   |   |   |   |   |
|-----|---|---|---|---|---|---|---|---|---|------|------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|----|-----|---|---|---|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0   | 0 | 0 | 0 | 0 | 0 |

| Bits  | Name     | Description                                                       | RW |
|-------|----------|-------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                              | R  |
| 11:0  | RDRP     | Receive Dropped packets Counter: Incremented for frames received  | RW |
|       |          | which are streamed to system but are later dropped due to lack of |    |
|       |          | system resources.                                                 |    |



# 11.9.3.25 TBYT

|     | TB | YΤ |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x′ | 134 | B00 | )E0 |
|-----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------------|-----|-----|-----|
| Bit | 31 | 30 | 29 | 28  | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2   | 1   | 0   |
|     |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |    |    |    | ΤB | ΥT |    |   |   |   |   |   |   |             |     |     |     |
| RST | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0           | 0   | 0   | 0   |

| Bits     | Name     | Description                                                                                                                                                                                                  | RW     |
|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 31:24    | Reserved | Writing has no effect, read as zero.                                                                                                                                                                         | R      |
| 23:0     | ТВҮТ     | Transmit Byte Counter: Incremented by the number of bytes that were put on the wire including fragments of frames that were involved with collisions. This count does not include preamble/SFD or jam bytes. | RW     |
| 11.9.3.2 | 26 TPKT  | internal us                                                                                                                                                                                                  |        |
| ТРК      | т        | 0x13                                                                                                                                                                                                         | 4B00E4 |

### 11.9.3.26 TPKT



| Bits  | Name     | Description                                                            | RW |
|-------|----------|------------------------------------------------------------------------|----|
| 31:18 | Reserved | Writing has no effect, read as zero.                                   | R  |
| 17:0  | ТРКТ     | Transmit Packet Counter: Incremented for each transmitted packet       | RW |
|       |          | (including bad packets, excessive deferred packets, excessive          |    |
|       |          | collision packets, late collision packets, all Unicast, Broadcast, and |    |
|       |          | Multicast packets).                                                    |    |



### 11.9.3.27 TMCA

#### тмса

|     | тм       | СА |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | <b>0</b> x′ | 134 | B00 | )E8 |
|-----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------------|-----|-----|-----|
| Bit | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2   | 1   | 0   |
|     | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | тм | CA |   |   |   |   |   |   |             |     |     |     |
| RST | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0           | 0   | 0   | 0   |

| Bits  | s Name        | Description                                                        | RW    |
|-------|---------------|--------------------------------------------------------------------|-------|
| 31:1  | 8 Reserved    | Writing has no effect, read as zero.                               | R     |
| 17:0  | TMCA          | Transmit Multicast Packet Counter: Incremented for each Multicast  | RW    |
|       |               | valid frame transmitted (excluding Broadcast frames).              |       |
| 11.9. | 3.28 TBCA     | nal used or                                                        |       |
| т     | BCA           | x erlt 0x134                                                       | BOOEC |
| Bit 3 | 1 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0   |

#### 11.9.3.28 TBCA

#### TBCA

#### 0x134B00EC

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

|          |   |   |   |   |   |   |     |      |    |   |   |   |   |   | 20 | 1 |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |  |
|----------|---|---|---|---|---|---|-----|------|----|---|---|---|---|---|----|---|---|---|---|---|---|---|----|----|---|---|---|---|---|---|---|--|
|          |   |   |   |   |   | R | ese | erve | ed |   |   |   |   |   |    |   |   |   |   |   |   |   | тв | CA |   |   |   |   |   |   |   |  |
|          |   |   |   |   |   |   |     |      |    |   |   |   |   |   |    |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |  |
| <b>.</b> | ~ | ~ | ~ | ~ | ~ | ~ | ~   | ~    | ~  | ~ | ~ | ~ | ~ | ~ | ~  | ~ | ~ | ~ | ~ | ~ | ~ | ~ | ~  | ~  | ~ | ~ | ~ | ~ | ~ | ~ | ~ |  |

| Bits  | Name     | Description                                                       | RW |
|-------|----------|-------------------------------------------------------------------|----|
| 31:18 | Reserved | Writing has no effect, read as zero.                              | R  |
| 17:0  | TBCA     | Transmit Broadcast Packet Counter: Incremented for each Broadcast | RW |
|       |          | frame transmitted (excluding Multicast frames).                   |    |

#### 11.9.3.29 TXPF

|     | тх       | PF |    | 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 - |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | <b>0</b> x′ | 134 | B0( | )F0 |   |    |
|-----|----------|----|----|------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-------------|-----|-----|-----|---|----|
| Bit | 31       | 30 | 29 | 28                                                   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5           | 4   | 3   | 2   | 1 | 0  |
|     | Reserved |    |    |                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | тх | PF |   |   |   |   |             |     |     |     |   |    |
| RST | 0        | 0  | 0  | 0                                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0           | 0   | 0   | 0   | 0 | 0  |
|     |          |    |    |                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |             |     |     |     | 2 | 12 |



| Bits  | Name     | Description                                                  | RW |
|-------|----------|--------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                         | R  |
| 11:0  | TXPF     | Transmit PAUSE Frame Packet Counter: Incremented each time a | RW |
|       |          | valid PAUSE MAC Control frame is transmitted.                |    |

### 11.9.3.30 TDFR

|     | TD | R  |    |    |    |    |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   | <b>0</b> x′ | 134 | B00 | )F4 |
|-----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----|----|---|-------------|-----|-----|-----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4 | 3           | 2   | 1   | 0   |
|     |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |     |     |     |
|     |    |    |    |    |    |    |    |    | D  | ese | -   | d  |    |    |    |    |    |    |    |    |    |    |   |   |   | тп | FR |   |             |     |     |     |
|     |    |    |    |    |    |    |    |    | ĸ  | ese | ive | u  |    |    |    |    |    |    |    |    |    |    |   |   |   | 10 | ГК |   |             |     |     |     |
|     |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   | 1.          | V   |     |     |
| RST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0  | 0  | 0 | 0           | 0   | 0   | 0   |

| Bits     | Name     | Description 150                                                        | RW |
|----------|----------|------------------------------------------------------------------------|----|
| 31:12    | Reserved | Writing has no effect, read as zero.                                   | R  |
| 11:0     | TDFR     | Transmit Deferral Packet Counter: Incremented for each frame,          | RW |
|          |          | which was deferred on its first transmission attempt. Does not include |    |
|          |          | frames involved in collisions.                                         |    |
| 11.9.3.3 | 31 TEDF  | ffel@126.co.                                                           |    |

#### 11.9.3.31 TEDF

|     |     |    |    |    |    | •  | د کم | L K |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |     |             |     |
|-----|-----|----|----|----|----|----|------|-----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----|----|---|-------------|-----|-------------|-----|
|     | TEI | DF |    |    | Ç  | 27 | Y    |     |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   | <b>0</b> x′ | 134 | <b>B0</b> ( | )F8 |
| Bit | 31  | 30 | 29 | 28 | 27 | 26 | 25   | 24  | 23 | 22  | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4 | 3           | 2   | 1           | 0   |
|     |     |    |    |    |    |    |      |     |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |     |             |     |
|     |     |    |    |    |    |    |      |     |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |     |             |     |
|     |     |    |    |    |    |    |      |     | R  | ese | rve | d  |    |    |    |    |    |    |    |    |    |    |   |   |   | TE | DF |   |             |     |             |     |
|     |     |    |    |    |    |    |      |     |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |     |             |     |
|     |     |    |    |    |    |    |      |     |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |             |     |             |     |
| RST | 0   | 0  | 0  | 0  | 0  | 0  | 0    | 0   | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0  | 0  | 0 | 0           | 0   | 0           | 0   |

#### Bits Name Description RW 31:12 Reserved Writing has no effect, read as zero. R 11:0 TEDF Transmit Excessive Deferral Packet Counter: Incremented for frames RW aborted which were deferred for an excessive period of time (3036 byte times).

#### 11.9.3.32 TSCL

# **TSCL** 0x134B00FC Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved TSCL

| Bits            | Name        | Description                                                        | RW     |
|-----------------|-------------|--------------------------------------------------------------------|--------|
| 31:12           | Reserved    | Writing has no effect, read as zero.                               | R      |
| 11:0            | TSCL        | Transmit Single Collision Packet Counter: Incremented for each     | RW     |
|                 |             | frame transmitted which experienced exactly one collision during   |        |
|                 |             | transmission.                                                      |        |
| 11.9.3.3        | 33 TMCL     | Fernal Useu                                                        |        |
| тмс             | CL          | ຳ 1 <sup>7</sup> 0x13                                              | 4B0100 |
| <b>Bit</b> 31 3 | 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0    |

#### 11.9.3.33 TMCL

#### TMCL

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

|     |   |   |   |   |   |   |   |   | R | lese | erve | ed |   |   |   |   |   |   |   |   |   |   |   |   |   | τN | ICL |   |   |   |   |   |
|-----|---|---|---|---|---|---|---|---|---|------|------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|----|-----|---|---|---|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0   | 0 | 0 | 0 | 0 | 0 |

| Bits  | Name     | Description                                                          | RW |
|-------|----------|----------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                                 | R  |
| 11:0  | TMCL     | Transmit Multiple Collision Packet Counter: Incremented for each     | RW |
|       |          | frame transmitted which experienced 2-15 collisions (including any   |    |
|       |          | late collisions) during transmission as defined using the RETRY[3:0] |    |
|       |          | field of the TX function control register.                           |    |



### 11.9.3.34 TLCL

|     | TLC | CL |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   | <b>0</b> x | 134 | <b>B0</b> 1 | 04 |
|-----|-----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----|----|---|------------|-----|-------------|----|
| Bit | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4 | 3          | 2   | 1           | 0  |
|     |     |    |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |   |   |   | TL | CL |   |            |     |             |    |
| RST | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0  | 0  | 0 | 0          | 0   | 0           | 0  |

| Bits  | Name     | Description                                                           | RW |
|-------|----------|-----------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                                  | R  |
| 11:0  | TLCL     | Transmit Late Collision Packet Counter: Incremented for each frame    | RW |
|       |          | transmitted which experienced a late collision during a transmission  |    |
|       |          | attempt. Late collisions are defined using the LCOL[5:0] field of the |    |
|       |          | TX Function control register.                                         |    |

### 11.9.3.35 TXCL

316



| Bits  | Name     | Description                                                       | RW |
|-------|----------|-------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                              | R  |
| 11:0  | TXCL     | Transmit Excessive Collision Packet Counter: Incremented for each | RW |
|       |          | frame that experienced 16 collisions during transmission and was  |    |
|       |          | aborted.                                                          |    |

0x134B010C

#### 11.9.3.36 TNCL

#### TNCL

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

|     |   |   |   |   |   |   |   |   | Re | ser | ved |   |   |   |   |   |   |   |   |   |   |   |   |   | Т | NC | L |   |   |   |   |   |
|-----|---|---|---|---|---|---|---|---|----|-----|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0   | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0 | 0 | 0 | 0 | 0 | 0 |

| Bits  | Name     | Description                                                            | RW |
|-------|----------|------------------------------------------------------------------------|----|
| 31:13 | Reserved | Writing has no effect, read as zero.                                   | R  |
| 12:0  | TNCL     | Transmit Total Collision Counter: Incremented by the number of         | RW |
|       |          | collisions experienced during the transmission of a frame as defined   |    |
|       |          | as the simultaneous presence of signals on the DO and RD circuits      |    |
|       |          | (i.e. transmitting and receiving at the same time). Note this register |    |
|       |          | does not include collisions that result in an excessive collision      |    |
|       |          | condition.                                                             |    |

# 11.9.3.37 TPFH

# 26. com interné TPFH 0x134B0110 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved TPFH

| Bits  | Name     | Description                                                    | RW |
|-------|----------|----------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                           | R  |
| 11:0  | TPFH     | Transmit PAUSE Frames Honored Counter: Incremented each time a | RW |
|       |          | valid PAUSE MAC Control frame is transmitted and honored.      |    |



#### 11.9.3.38 TDRP

# TDRP 0x134B0114 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved TDRP

| Bi  | its          | Name        |       |        |      |      |      |      |      |     |      | De   | sci | ript | ior  |      |      |     |     |      |      |      |    |          |      | R۱              | N   |
|-----|--------------|-------------|-------|--------|------|------|------|------|------|-----|------|------|-----|------|------|------|------|-----|-----|------|------|------|----|----------|------|-----------------|-----|
| 31: | :12          | Reserved    |       | Writi  | ng l | has  | no   | effe | ect, | rea | ld a | is z | ero | ).   |      |      |      |     |     |      |      |      |    |          |      | R               |     |
| 11: | :0           | TDRP        |       | Tran   | smi  | it D | rop  | Fra  | me   | Со  | unt  | er:  | Inc | rer  | ner  | ntec | d ea | ach | tin | ne i | inpu | ut F | ۲F | l is     |      | R۷              | V   |
|     |              |             |       | asse   | rteo | d.   |      |      |      |     |      |      |     |      |      |      |      |     |     |      |      |      | ~  | <b>1</b> | Z    |                 |     |
| -   | Э.З.З<br>ТЈВ | 89 TJBR     |       |        |      |      |      |      |      |     |      |      |     |      |      | D.E  | 5)   | -   | US  | 38   | 6    | •    | ,ر | 01       | (134 | B0 <sup>,</sup> | 118 |
|     | 100          | IX          |       |        |      |      |      |      |      |     |      |      | X   | K    | عر ر |      |      |     |     |      |      |      |    |          |      | 50              |     |
| Bit | 31.3         | 30 29 28 27 | 26 25 | 5 24 2 | 23 2 | 2 2  | 1 20 | 19   | 18   | 17  | 16   | 15   | 14  | 13   | 12   | 11   | 10   | 9   | 8   | 7    | 6    | 5    | 4  | 3        | 2    | 1               | 0   |

#### 11.9.3.39 TJBR

#### **TJBR**

#### 0x134B0118

|     |       |      |      |    |    |    |    |     |     |    |    |    |    |    |    | _ X |    |    |    |    |   |   |   |    |    |   |   |   |   |   |
|-----|-------|------|------|----|----|----|----|-----|-----|----|----|----|----|----|----|-----|----|----|----|----|---|---|---|----|----|---|---|---|---|---|
| Bit | 31 30 | 29 2 | 8 27 | 26 | 25 | 24 | 23 | 22  | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4 | 3 | 2 | 1 | 0 |
|     |       |      |      |    |    |    |    |     |     |    |    |    |    |    |    |     |    |    |    |    |   |   |   |    |    |   |   |   |   |   |
|     |       |      |      |    |    |    |    |     |     |    |    |    |    |    |    |     |    |    |    |    |   |   |   |    |    |   |   |   |   |   |
|     |       |      |      |    |    |    | R  | ese | rve | d  |    |    |    |    |    |     |    |    |    |    |   |   |   | ΤJ | BR |   |   |   |   |   |
|     |       |      |      |    |    |    |    |     |     |    |    |    |    |    |    |     |    |    |    |    |   |   |   |    |    |   |   |   |   |   |
|     |       |      |      |    |    |    |    |     |     |    |    |    |    |    |    |     |    |    |    |    |   |   |   |    |    |   |   |   |   |   |

# 

| Bits  | Name     | Description                                                   | RW |
|-------|----------|---------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                          | R  |
| 11:0  | TJBR     | Transmit Jabber Frame Counter: Incremented for each oversized | RW |
|       |          | transmitted frame with an incorrect FCS value.                |    |

#### 11.9.3.40 TFCS

|     | TFO | cs |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   | <b>0</b> x1 | 134 | B01 | 1 <b>C</b> |
|-----|-----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----|----|---|-------------|-----|-----|------------|
| Bit | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4 | 3           | 2   | 1   | 0          |
|     |     |    |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |   |   |   | TF | CS |   |             |     |     |            |
| RST | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0  | 0  | 0 | 0           | 0   | 0   | 0          |

318

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| Bits  | Name     | Description                                                   | RW |
|-------|----------|---------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                          | R  |
| 11:0  | TFCS     | Transmit FCS Error Counter: Incremented for every valid sized | RW |
|       |          | packet with an incorrect FCS value.                           |    |

### 11.9.3.41 TXCF

|     | тхс  | F |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   | <b>0</b> x | 134 | <b>B0</b> 1 | 120 |
|-----|------|---|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----|----|---|------------|-----|-------------|-----|
| Bit | 31 3 | 0 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4 | 3          | 2   | 1           | 0   |
|     |      |   |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |            |     |             |     |
|     |      |   |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |            |     |             |     |
|     |      |   |    |    |    |    |    |    | R  | lese | erve | d  |    |    |    |    |    |    |    |    |    |    |   |   |   | тх | CF |   |            |     |             |     |
|     |      |   |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   |            |     |             |     |
|     |      |   |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |    |   | 1          | V   |             |     |
| RST | 0 (  | ) | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0  | 0  | 0 | 0          | 0   | 0           | 0   |

| Bits  | Name     | Description 🔨 🔧                                                  | RW |
|-------|----------|------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                             | R  |
| 11:0  | TXCF     | Transmit Control Frame Counter: Incremented for every valid size | RW |
|       |          | frame with a Type Field signifying a Control frame.              |    |

#### 11.9.3.42 TOVR

|      |            |    |    |          |    |    | 1  | rar | ne | with | ۱a   | l y | be | Fie | ld s | sign | ityi | ng | a C | on | trol | fra | me | • |   |    |    |   |    |     |                        |     |
|------|------------|----|----|----------|----|----|----|-----|----|------|------|-----|----|-----|------|------|------|----|-----|----|------|-----|----|---|---|----|----|---|----|-----|------------------------|-----|
| 11.9 | Э.З.<br>то |    | тс | <b>V</b> | R  |    | ¢. | ę   | 2) |      | 7    | LE  | )• | C(  | JUC  | 7    | Y    |    |     |    |      |     |    |   |   |    |    |   | 0x | 134 | <b>B0</b> <sup>2</sup> | 124 |
| Bit  | 31         | 30 | 29 | 28       | 27 | 26 | 25 | 24  | 23 | 22   | 21   | 20  | 19 | 18  | 17   | 16   | 15   | 14 | 13  | 12 | 11   | 10  | 9  | 8 | 7 | 6  | 5  | 4 | 3  | 2   | 1                      | 0   |
|      |            |    |    |          |    |    |    |     | R  | ese  | erve | d   |    |     |      |      |      |    |     |    |      |     |    |   |   | то | VR |   |    |     |                        |     |
| RST  | 0          | 0  | 0  | 0        | 0  | 0  | 0  | 0   | 0  | 0    | 0    | 0   | 0  | 0   | 0    | 0    | 0    | 0  | 0   | 0  | 0    | 0   | 0  | 0 | 0 | 0  | 0  | 0 | 0  | 0   | 0                      | 0   |

| Bits  | Name     | Description                                                     | RW |
|-------|----------|-----------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                            | R  |
| 11:0  | TOVR     | Transmit Oversize Frame Counter: Incremented for each oversized | RW |
|       |          | transmitted frame with an correct FCS value.                    |    |



#### 11.9.3.43 TUND

# TUND 0x134B0128 Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved TUND

| Bi   | ts    | Name        | Description                                                                                                                                                                                                        | RW    |
|------|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:  | 12    | Reserved    | Writing has no effect, read as zero.                                                                                                                                                                               | R     |
| 11:  | :0    | TUND        | Transmit Undersize Frame Counter: Incremented for every frame                                                                                                                                                      | RW    |
|      |       |             | less then 64 bytes, with a correct FCS value.                                                                                                                                                                      |       |
| 11.9 | 9.3.4 | 4 TFRG      | mal used or                                                                                                                                                                                                        |       |
|      | TFR   | G           | $\times \mathbb{C}^{\mathcal{V}}$ 0x134                                                                                                                                                                            | B012C |
| Bit  | 31.3  | 30 29 28 27 | 26       25       24       23       22       21       20       19       18       17       16       15       14       13       12       11       10       9       8       7       6       5       4       3       2 | 1 0   |

#### 11.9.3.44 TFRG

#### **TFRG**

#### 0x134B012C

|     |       |       |    |    |      |    |    |     |      |    |    |    |    |    |    | X  | C  |    |    |    |   |   |   |     |    |   |   |   |   |   |
|-----|-------|-------|----|----|------|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|----|---|---|---|---|---|
| Bit | 31 30 | 29 28 | 27 | 26 | 25 2 | 24 | 23 | 22  | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5  | 4 | 3 | 2 | 1 | 0 |
|     |       |       |    |    |      |    | R  | ese | erve | d  |    |    |    |    |    |    |    |    |    |    |   |   |   | TFI | RG |   |   |   |   |   |

# 

| Bits  | Name     | Description                                                      | RW |
|-------|----------|------------------------------------------------------------------|----|
| 31:12 | Reserved | Writing has no effect, read as zero.                             | R  |
| 11:0  | TFRG     | Transmit Fragment Counter: Incremented for every frame less then | RW |
|       |          | 64 bytes, with an incorrect FCS value.                           |    |

#### 11.9.3.45 CAR1



320

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



| Bits  | Name     | Description                               | RW |
|-------|----------|-------------------------------------------|----|
| 31    | C164     | Carry register 1 TR64 Counter Carry bit.  | R  |
| 30    | C1127    | Carry register 1 TR127 Counter Carry bit. | R  |
| 29    | C1255    | Carry register 1 TR255 Counter Carry bit. | R  |
| 28    | C1511    | Carry register 1 TR511 Counter Carry bit. | R  |
| 27    | C11K     | Carry register 1 TR1K Counter Carry bit.  | R  |
| 26    | C1MAX    | Carry register 1 TRMAX Counter Carry bit. | R  |
| 25    | C1MGV    | Carry register 1 TRMGV Counter Carry bit. | R  |
| 24:17 | Reserved | Writing has no effect, read as zero.      | R  |
| 16    | C1RBY    | Carry register 1 RBYT Counter Carry bit.  | R  |
| 15    | C1RPK    | Carry register 1 RPKT Counter Carry bit.  | R  |
| 14    | C1RFC    | Carry register 1 RFCS Counter Carry bit.  | R  |
| 13    | C1RMC    | Carry register 1 RMCA Counter Carry bit.  | R  |
| 12    | C1RBC    | Carry register 1 RBCA Counter Carry bit.  | R  |
| 11    | C1RXC    | Carry register 1 RXCF Counter Carry bit.  | R  |
| 10    | C1RXP    | Carry register 1 RXPF Counter Carry bit.  | R  |
| 9     | C1RXU    | Carry register 1 RXUO Counter Carry bit.  | R  |
| 8     | C1RAL    | Carry register 1 RALN Counter Carry bit.  | R  |
| 7     | C1RFL    | Carry register 1 RFLR Counter Carry bit.  | R  |
| 6     | C1RCD    | Carry register 1 RCDE Counter Carry bit.  | R  |
| 5     | C1RCS    | Carry register 1 RCSE Counter Carry bit.  | R  |
| 4     | C1RUN    | Carry register 1 RUND Counter Carry bit.  | R  |
| 3     | C1ROV    | Carry register 1 ROVR Counter Carry bit.  | R  |
| 2     | C1RFR    | Carry register 1 RFRG Counter Carry bit.  | R  |
| 1     | C1RJB    | Carry register 1 RJBR Counter Carry bit.  | R  |
| 0     | C1RDR    | Carry register 1 RDRP Counter Carry bit.  | R  |

# 11.9.3.46 CAR2

|     | CA | R2 |    |    |    |     |      |    |    |    |    |    |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | <b>0</b> x | 134   | <b>B0</b> ′ | 134   |
|-----|----|----|----|----|----|-----|------|----|----|----|----|----|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------------|-------|-------------|-------|
| Bit | 31 | 30 | 29 | 28 | 27 | 26  | 25   | 24 | 23 | 22 | 21 | 20 | 19    | 18    | 17    | 16    | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3          | 2     | 1           | 0     |
|     |    |    |    |    | R  | ese | erve | ed |    |    |    |    | C2TJB | C2TFC | C2TCF | C2TOV | C2TUN | C2TFG | C2TBY | C2TPK | C2TMC | C2TBC | C2TPF | C2TDF | C2TED | CZTSC | C2TMA | CZTLC | C2TXC      | C2TNC | C2TPH       | C2TDP |
| RST | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0          | 0     | 0           | 0     |

| Bits  | Name     | Description                              | RW |
|-------|----------|------------------------------------------|----|
| 31:20 | Reserved | Writing has no effect, read as zero.     | R  |
| 19    | C2TJB    | Carry register 2 TJBR Counter Carry bit. | R  |



| СА      | M1      | 10,120°                                   | 4 <b>B0</b> 138 |
|---------|---------|-------------------------------------------|-----------------|
| 11.9.3. | 47 CAM1 | oury register 2 refer counter carry picts |                 |
| 0       | C2TDP   | Carry register 2 TDRP Counter Carry bit   | R               |
| 1       | C2TPH   | Carry register 2 TPFH Counter Carry bit.  | R               |
| 2       | C2TNC   | Carry register 2 TNCL Counter Carry bit.  | R               |
| 3       | C2TXC   | Carry register 2 TXCL Counter Carry bit.  | R               |
| 4       | C2TLC   | Carry register 2 TLCL Counter Carry bit.  | R               |
| 5       | C2TMA   | Carry register 2 TMCL Counter Carry bit.  | R               |
| 6       | C2TSC   | Carry register 2 TSCL Counter Carry bit.  | R               |
| 7       | C2TED   | Carry register 2 TEDF Counter Carry bit.  | R               |
| 8       | C2TDF   | Carry register 2 TDFR Counter Carry bit.  | R               |
| 9       | C2TPF   | Carry register 2 TXPF Counter Carry bit.  | R               |
| 10      | C2TBC   | Carry register 2 TBCA Counter Carry bit.  | R               |
| 11      | C2TMC   | Carry register 2 TMCA Counter Carry bit.  | R               |
| 12      | C2TPK   | Carry register 2 TPKT Counter Carry bit.  | R               |
| 13      | C2TBY   | Carry register 2 TBYT Counter Carry bit.  | R               |
| 14      | C2TFG   | Carry register 2 TFRG Counter Carry bit.  | R               |
| 15      | C2TUN   | Carry register 2 TUND Counter Carry bit.  | R               |
| 16      | C2TOV   | Carry register 2 TOVR Counter Carry bit.  | R               |
| 17      | C2TCF   | Carry register 2 TXCF Counter Carry bit.  | R               |
| 18      | C2TFC   | Carry register 2 TFCS Counter Carry bit.  | R               |

# 11.9.3.47 CAM1

|     | СА   | M1    |       |       |        |       |       |    | 1  | 0  | <u></u> |     |    |    |    |       |       |       |       |       |       |       |       |       |       |       |       |       | 0x    | 134   | <b>B0</b> <sup>,</sup> | 138   |
|-----|------|-------|-------|-------|--------|-------|-------|----|----|----|---------|-----|----|----|----|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------------------------|-------|
| Bit | 31   | 30    | 29    | 28    | 27     | 26    | 25    | 24 | 23 | 22 | 21      | 20  | 19 | 18 | 17 | 16    | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1                      | 0     |
|     | M164 | M4127 | M1255 | M1614 | M11K 🔨 | M1MAX | M1MGV |    |    | R  | ese     | rve | d  |    |    | M1RBY | M1RPK | M1RFC | M1RMC | M1RBC | M1RXC | M1RXP | M1RXU | M1RAL | M1RFL | M1RCD | M1RCS | M1RUN | M1ROV | M1RFR | M1RJB                  | M1RDR |
| RST | 1    | 1     | 1     | 1     | 1      | 1     | 1     | 0  | 0  | 0  | 0       | 0   | 0  | 0  | 0  | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1                      | 1     |

| Bits  | Name     | Description                                   | RW |
|-------|----------|-----------------------------------------------|----|
| 31    | M164     | Mask register 1 TR64 Counter Carry bit Mask.  | RW |
| 30    | M1127    | Mask register 1 TR127 Counter Carry bit Mask. | RW |
| 29    | M1255    | Mask register 1 TR255 Counter Carry bit Mask. | RW |
| 28    | M1511    | Mask register 1 TR511 Counter Carry bit Mask. | RW |
| 27    | M11k     | Mask register 1 TR1K Counter Carry bit Mask.  | RW |
| 26    | M1MAX    | Mask register 1 TRMAX Counter Carry bit Mask. | RW |
| 25    | M1MGV    | Mask register 1 TRMGV Counter Carry bit Mask. | RW |
| 24:17 | Reserved | Writing has no effect, read as zero.          | R  |
| 16    | M1RBY    | Mask register 1 RBYT Counter Carry bit Mask.  | RW |

322



| CAI     | M2      | inte                                         | 0x134 | 4B013C |
|---------|---------|----------------------------------------------|-------|--------|
| 11.9.3. | 48 CAM2 | Mask register 1 RDRP Counter Carry bit Mask. | USEE  |        |
| 0       | M1RDR   | Mask register 1 RDRP Counter Carry bit Mask. |       | RW     |
| 1       | M1RJB   | Mask register 1 RJBR Counter Carry bit Mask. | ant i | RW     |
| 2       | M1RFR   | Mask register 1 RFRG Counter Carry bit Mask. | A 41  | RW     |
| 3       | M1ROV   | Mask register 1 ROVR Counter Carry bit Mask. |       | RW     |
| 4       | M1RUN   | Mask register 1 RUND Counter Carry bit Mask. |       | RW     |
| 5       | M1RCS   | Mask register 1 RCSE Counter Carry bit Mask. |       | RW     |
| 6       | M1RCD   | Mask register 1 RCDE Counter Carry bit Mask. |       | RW     |
| 7       | M1RFL   | Mask register 1 RFLR Counter Carry bit Mask. |       | RW     |
| 8       | M1RAL   | Mask register 1 RALN Counter Carry bit Mask. |       | RW     |
| 9       | M1RXU   | Mask register 1 RXUO Counter Carry bit Mask. |       | RW     |
| 10      | M1RXP   | Mask register 1 RXPF Counter Carry bit Mask. |       | RW     |
| 11      | M1RXC   | Mask register 1 RXCF Counter Carry bit Mask. |       | RW     |
| 12      | M1RBC   | Mask register 1 RBCA Counter Carry bit Mask. |       | RW     |
| 13      | M1RMC   | Mask register 1 RMCA Counter Carry bit Mask. |       | RW     |
| 14      | M1RFC   | Mask register 1 RFCS Counter Carry bit Mask. |       | RW     |
| 15      | M1RPK   | Mask register 1 RPKT Counter Carry bit Mask. |       | RW     |

#### 11.9.3.48 CAM2

|     |    |    |    |    |    |     |      |    |    |    |    |    |       |         |       |       | • •   | $^{\chi}$ | JE    |       |       |       |       |       |       |       |       |       |             |       |       |       |
|-----|----|----|----|----|----|-----|------|----|----|----|----|----|-------|---------|-------|-------|-------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------------|-------|-------|-------|
|     | CA | M2 |    |    |    |     |      |    |    |    |    |    |       |         |       |       | 2     | 11        |       |       |       |       |       |       |       |       |       |       | <b>0</b> x1 | 1341  | 301   | 3C    |
| Bit | 31 | 30 | 29 | 28 | 27 | 26  | 25   | 24 | 23 | 22 | 21 | 20 | 19    | 18      | 17    | 16    | 15    | 14        | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3           | 2     | 1     | 0     |
|     |    |    |    |    | R  | ese | erve | d  |    |    |    |    | M2TJB | M2TFC ( | M2TCF | M2TOV | M2TUN | M2TFG     | M2TBY | M2TPK | M2TMC | M2TBC | M2TPF | M2TDF | M2TED | M2TSC | M2TMA | M2TLC | M2TXC       | M2TNC | M2TPH | M2TDP |
| RST | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 1     | 1       | 1     | 1     | 1     | 1         | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1           | 1     | 1     | 1     |
|     |    | Γ. |    |    |    |     |      |    |    |    |    |    |       |         |       |       |       |           |       |       |       |       |       |       |       |       |       |       |             |       |       |       |

| Bits  | Name     | Description                                  | RW |
|-------|----------|----------------------------------------------|----|
| 31:20 | Reserved | Writing has no effect, read as zero.         | R  |
| 19    | M2TJB    | Mask register 2 TJBR Counter Carry bit Mask. | RW |
| 18    | M2TFC    | Mask register 2 TFCS Counter Carry bit Mask. | RW |
| 17    | M2TCF    | Mask register 2 TXCF Counter Carry bit Mask. | RW |
| 16    | M2TOV    | Mask register 2 TOVR Counter Carry bit Mask. | RW |
| 15    | M2TUN    | Mask register 2 TUND Counter Carry bit Mask. | RW |
| 14    | M2TFG    | Mask register 2 TFRG Counter Carry bit Mask. | RW |
| 13    | M2TBY    | Mask register 2 TBYT Counter Carry bit Mask. | RW |
| 12    | M2TPK    | Mask register 2 TPKT Counter Carry bit Mask. | RW |
| 11    | M2TMC    | Mask register 2 TMCA Counter Carry bit Mask. | RW |
| 10    | M2TBC    | Mask register 2 TBCA Counter Carry bit Mask. | RW |
| 9     | M2TPF    | Mask register 2 TXPF Counter Carry bit Mask. | RW |



| 8 | M2TDF | Mask register 2 TDFR Counter Carry bit Mask. | RW |
|---|-------|----------------------------------------------|----|
| 7 | M2TED | Mask register 2 TEDF Counter Carry bit Mask. | RW |
| 6 | M2TSC | Mask register 2 TSCL Counter Carry bit Mask. | RW |
| 5 | M2TMA | Mask register 2 TMCL Counter Carry bit Mask. | RW |
| 4 | M2TLC | Mask register 2 TLCL Counter Carry bit Mask. | RW |
| 3 | M2TXC | Mask register 2 TXCL Counter Carry bit Mask. | RW |
| 2 | M2TNC | Mask register 2 TNCL Counter Carry bit Mask. | RW |
| 1 | M2TPH | Mask register 2 TPFH Counter Carry bit Mask. | RW |
| 0 | M2TDP | Mask register 2 TDRP Counter Carry bit Mask. | RW |

10ng\_eiffel@126.com internal used only

324



#### **EFUSE Slave Interface (EFUSE)** 12

# 12.1 Overview

Total 256 bits of EFUSE are provided, separated into lower 128bits segment and higher 128bits segment.

Each segment can be programmed separately or together. Each segment has a protect bit, which has higher priority than program segment selection.

Programming frequency should be with in 133Mhz and 166Mhz. Programming time is around 3ms for either program in 128bits or 256bits.

Initial value of EFUSE is 0, when programmed to 1, it won't able to program back to 0 anymore. Do not attempt to program any bit that already programmed to 1, such action will result unpredictable rnal used status to whole effuse block.

Programming voltage supply pin VDDQ:

- In program mode, supply VDDQ with 2.5V. \_ Important: VDDQ pin should be kept 0v except during programming. Maximum accumulative time for VDDQ pin exposed under 2.5V+/-10% should be less than 1 sec.
- In read mode, leave VDDQ to QV.



# **12.2 Register Description**

Following table lists all the register definitions. All registers' 32bit addresses are physical addresses.

| Name   | Description            | RW | Reset Value | Address    | Access |
|--------|------------------------|----|-------------|------------|--------|
|        |                        |    |             |            | Size   |
| EFSCTL | EFUSE Control Register | RW | 0x00        | 0x134100DC | 32     |
| EFUSE0 | EFUSE Data 0 Register  | RW | 0x????????  | 0x134100E0 | 32     |
| EFUSE1 | EFUSE Data 1 Register  | RW | 0x????????  | 0x134100E4 | 32     |
| EFUSE2 | EFUSE Data 2 Register  | RW | 0x????????  | 0x134100E8 | 32     |
| EFUSE3 | EFUSE Data 3 Register  | RW | 0x????????  | 0x134100EC | 32     |
| EFUSE4 | EFUSE Data 4 Register  | RW | 0x????????  | 0x134100F0 | 32     |
| EFUSE5 | EFUSE Data 5 Register  | RW | 0x????????  | 0x134100F4 | 32     |
| EFUSE6 | EFUSE Data 6 Register  | RW | 0x????????  | 0x134100F8 | 32     |
| EFUSE7 | EFUSE Data 7 Register  | RW | 0x????????  | 0x134100FC | 32     |

#### **Table 12-1 EFUSE Register Description**

# 12.2.1 EFUSE Control Register (EFSCTL)



#### RST

| Bits | Name     | Description                                   | RW |
|------|----------|-----------------------------------------------|----|
| 7:2  | Reserved | Writing has no effect, read as zero.          | R  |
| 1    | HI_WEN   | High 128 bit write enable bit. * <sup>1</sup> | RW |
|      |          | 0: Disable                                    |    |
|      |          | 1: Enabled                                    |    |
| 0    | LO_WEN   | Low 128 bit write enable bit. *1              | RW |
|      |          | 0: Disable                                    |    |
|      |          | 1: Enabled                                    |    |

#### NOTE:

\*<sup>1</sup>: DATA[31]/PRTCT bits take higher priorities than HI\_WEN & LOW\_WEN.

326

JZ4770 Mobile Application Processor Peripherals Programming Manual

Copyright © 2005-2011 Ingenic Semiconductor Co., Ltd. All rights reserved.



# 12.2.2 EFUSE Data Register (EFUSEn)

#### EFUSEn (n=0,1,2,4,5,6)

#### 0x134100E0~0x134100FC

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

|     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | DA | <b>ATA</b> |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| RST | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit | s Name            |                  |               | Descriptio | on           |               | RW       |
|-----|-------------------|------------------|---------------|------------|--------------|---------------|----------|
| 31: | ) DATA            | EUFSE DATA       | register.     |            |              |               | RW       |
|     |                   | EFUSE7 [31]      | EFUSE7 [30]   | ~          | EFUSE7 [1]   | EFUSE7 [0]    |          |
|     |                   | EFUSE6 [31]      | EFUSE6 [30]   | ~          | EFUSE6 [1]   | EFUSE6 [0]    |          |
|     |                   | EFUSE5 [31]      | EFUSE5 [30]   | ~          | EFUSE5 [1]   | EFUSE5 [0]    |          |
|     |                   | EFUSE4 [31]      | EFUSE4 [30]   | ~          | EFUSE4 [1]   | EFUSE4 [0]    | V        |
|     |                   | EFUSE3 [31]      | EFUSE3 [30]   | ~          | EFUSE3 [1]   | EFUSE3 [0]    | _ J      |
|     |                   | EFUSE2 [31]      | EFUSE2 [30]   | ~          | EFUSE2 [1]   | EFUSE2 [0]    |          |
|     |                   | EFUSE1 [31]      | EFUSE1 [30]   | ~          | EFUSE1 [1]   | EFUSE1 [0]    |          |
|     |                   | EFUSE0 [31]      | EFUSE0 [30]   | ~          | EFUSE0 [1]   | EFUSE0 [0]    |          |
|     |                   |                  |               | 20         | TIL          |               |          |
|     | EFUSEn (n=3,7)    |                  |               | int        |              | 0x134100E0~0x | 134100FC |
| Bit | 31 30 29 28 27 20 | 6 25 24 23 22 21 | 20 19 18 17 1 | 6 15 14 13 | 12 11 10 9 8 | 7 6 5 4 3     | 2 1 0    |

#### 0x134100E0~0x134100FC

| Bit | 31          | 30 | 29 | 2 | 8 | 27 | 26 | 6 2 | 25 | 24 | 23 | 22 | 2 2 | 1 : | 20 | 19 | 18 | 17 | 16  | 15   | 14   | 13 | 12 | 2 1 | 1 1( | ) 9 | ) | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|-------------|----|----|---|---|----|----|-----|----|----|----|----|-----|-----|----|----|----|----|-----|------|------|----|----|-----|------|-----|---|---|---|---|---|---|---|---|---|---|
|     | N[31]/PRTCT |    |    |   |   |    |    |     |    |    | .1 | Ø  | ,\  | 2   | 6  | )• | C  | ار | TAC | -A [ | 0-30 | )] |    |     |      |     |   |   |   |   |   |   |   |   |   |   |
|     | DAT/        |    |    |   |   |    | 1  | z   | 1  |    |    |    |     |     |    |    |    |    |     |      |      |    |    |     |      |     |   |   |   |   |   |   |   |   |   |   |

| RST | 0 | 0 | 0 | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|-----|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|     |   |   |   | Y. |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

| Bits | Name           |                                                           | D                | escriptio             | on            |             | RW |  |  |  |  |  |
|------|----------------|-----------------------------------------------------------|------------------|-----------------------|---------------|-------------|----|--|--|--|--|--|
| 31   | DATA[31]/PRTCT | EUFSE DATA                                                | bit 31 / Protec  | t bit. * <sup>1</sup> |               |             | RW |  |  |  |  |  |
|      |                | EFSUE3: Whe                                               | en this bit prog | rammed                | to 1, EFUSE0~ | 3 lower 128 |    |  |  |  |  |  |
|      |                | bits become un-programmable forever.                      |                  |                       |               |             |    |  |  |  |  |  |
|      |                | EFUSE7: When this bit programmed to 1,EFUSE4~7 higher 128 |                  |                       |               |             |    |  |  |  |  |  |
|      |                | bits become un-programmable forever.                      |                  |                       |               |             |    |  |  |  |  |  |
| 30:0 | DATA [30:0]    | EUFSE DATA register.                                      |                  |                       |               |             |    |  |  |  |  |  |
|      |                | EFUSE7                                                    | EFUSE7           | ~                     | EFUSE7 [1]    | EFUSE7 [0]  |    |  |  |  |  |  |
|      |                | [30]                                                      | [29]             |                       |               |             |    |  |  |  |  |  |
|      |                | EFUSE6                                                    | EFUSE6           | ~                     | EFUSE6 [1]    | EFUSE6 [0]  |    |  |  |  |  |  |
|      |                | [30]                                                      | [29]             |                       |               |             |    |  |  |  |  |  |
|      |                | EFUSE5                                                    | EFUSE5           | ~                     | EFUSE5 [1]    | EFUSE5 [0]  |    |  |  |  |  |  |
|      |                | [30] [29]                                                 |                  |                       |               |             |    |  |  |  |  |  |
|      |                | EFUSE4                                                    | EFUSE4           | ~                     | EFUSE4 [1]    | EFUSE4 [0]  |    |  |  |  |  |  |



| [30]   | [29]   |   |            |            |  |
|--------|--------|---|------------|------------|--|
| EFUSE3 | EFUSE3 | ~ | EFUSE3 [1] | EFUSE3 [0] |  |
| [30]   | [29]   |   |            |            |  |
| EFUSE2 | EFUSE2 | ~ | EFUSE2 [1] | EFUSE2 [0] |  |
| [30]   | [29]   |   |            |            |  |
| EFUSE1 | EFUSE1 | ~ | EFUSE1 [1] | EFUSE1 [0] |  |
| [30]   | [29]   |   |            |            |  |
| EFUSE0 | EFUSE0 | ~ | EFUSE0 [1] | EFUSE0 [0] |  |
| [30]   | [29]   |   |            |            |  |

#### NOTE:

\*<sup>1</sup>: DATA[31]/PRTCT bits take higher priorities than HI\_WEN & LOW\_WEN.





# 12.3 Flow

#### 12.3.1 Write EFUSE Flow

- Write full-256 bit. 1
  - a Config AHB2 freq to 166Mhz.
  - b Connect VDDQ pin to 2.5V. \*1
  - c Write register EFUSE0~EFUSE7.
  - d Write register EFSCTL.HI WEN and EFSCTL.LO WEN to 1 at same time.
  - e Wait till register EFSCTL.HI WEN and EFSCTL.LO WEN is set to 0.
  - f Disconnect VDDQ pin from 2.5V and finish writing EFUSE.
- 2 Write low-128 bit.
  - a Config AHB2 freq to 166Mhz.
  - b Connect VDDQ pin to 2.5V.
  - c Write register EFUSE0~EFUSE3.
  - d Write register EFSCTL.LO\_WEN to 1.
  - e Wait till register EFSCTL.LO\_WEN is set to 0.
  - \_..\_vol 0 1. ....register EFSCTL.LO\_WEN is set to 0. Disconnect VDDQ pin from 2.5V and finish writing EFUSE. USEd f internal
- 3 Write high-128 bit.
  - a Config AHB2 freq to 166Mhz.
  - b Connect VDDQ pin to 2.5V.
  - c Write register EFUSE3~EFUSE7
  - d Write register EFSCTL.HI\_WEN to 1.
  - e Wait till register EFSCTL.HI\_WEN is set to 0.
  - Disconnect VDDQ pin from 2.5V and finish writing EFUSE. f

#### NOTE:

\*1: DONOT pre-charge VDDQ too early before fuse program started.

The maximum 2.5V supply time to VDDQ must be strictly controlled less than 1sec.

Programming window is below 3ms.

Use on-chip counter and GPIO to coordinate external supply source.

#### 12.3.2 Read EFUSE Flow

Read register EFUSE0~EFUSE7 after chip is reset.