# R8610 Datasheet

# 32-BIT RISC MICROCONTROLLER

**RDC** RISC DSP Communication

RDC Semiconductor Co., Ltd http://www.rdc.com.tw TEL: 886-3-666-2866

FAX: 886-3-563-1498



# CONTENTS

| 1. C                     | )vervie                            | w                                                                                                                     | 9  |
|--------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------|----|
| 2. F                     | eature                             | S                                                                                                                     | 9  |
| 3. B                     | Block D                            | )iagram                                                                                                               | 10 |
| 4. P                     | PIN Des                            | scription                                                                                                             | 11 |
| 4.1<br>4.2<br>4.3<br>4.4 | 4.1.1<br>4.1.2<br>Signal<br>PIN Ca | acement<br>MDC pulled low<br>MDC pulled high<br>Description<br>apacitance Description<br>Ill-up/Pull-down Description |    |
| 5. S                     | System                             | Address Map                                                                                                           | 24 |
| 5.1<br>5.2<br>5.3        | 5.1.1<br>5.1.2<br>Memor            | y Address Ranges<br>Dos Compatibility Region<br>Extended Memory Region<br>y Shadowing<br>dress Space                  |    |
| 6. C                     | )<br>perati                        | on Mode                                                                                                               | 27 |
| 7. R                     | legiste                            | er Sets                                                                                                               | 28 |
|                          | -                                  | Registers                                                                                                             |    |
|                          | 7.1.1                              | General-Purpose Registers                                                                                             |    |
|                          | 7.1.2                              | Segment Registers                                                                                                     |    |
|                          | 7.1.3                              | Flags Register                                                                                                        |    |
|                          | 7.1.4                              | Instruction Pointer                                                                                                   |    |
|                          | 7.1.5                              | Control Registers                                                                                                     |    |
|                          | 7.1.6                              | System Address Registers                                                                                              |    |
| 7.2                      |                                    | pped Registers                                                                                                        |    |
|                          | 7.2.1                              | PCI Configuration Registers                                                                                           |    |



|       | 7.2.2   | Slave DMA Controller Registers                                  | 29   |
|-------|---------|-----------------------------------------------------------------|------|
|       | 7.2.3   | DMA Page Registers                                              | 30   |
|       | 7.2.4   | Master DMA Controller Registers                                 | 30   |
|       | 7.2.5   | DMA High Page Registers                                         | 30   |
|       | 7.2.6   | Timer/Counter Registers                                         | 30   |
|       | 7.2.7   | Master Interrupt Controller Registers                           | 31   |
|       | 7.2.8   | Slave Interrupt Controller Registers                            | 31   |
|       | 7.2.9   | Interrupt Edge/Level Control Registers                          | 31   |
|       | 7.2.10  | NMI Status and Control Register                                 | 31   |
|       | 7.2.11  | CMOS Memory & RTC Registers                                     | 31   |
|       | 7.2.12  | System Control Register                                         | 31   |
|       | 7.2.13  | Serial Port Registers                                           | 31   |
|       | 7.2.14  | Fast Ethernet MAC Registers                                     | 32   |
|       | 7.2.15  | USB 1.1 OHCI Operation Registers                                | 33   |
|       | 7.2.16  | USB 2.0 EHCI Operation Registers                                | 34   |
| 7.3   | Configu | uration Space Registers                                         | . 34 |
|       | 7.3.1   | R8610_NB Configuration Space Registers (IDSEL = AD11/Device 0)  | 35   |
|       | 7.3.2   | R8610_SB Configuration Space Registers (IDSEL = AD18/Device 7)  | 36   |
|       | 7.3.3   | R8610_MAC1/2 Configuration Space Registers (IDSEL = AD19/Device |      |
|       | 8/MAC   | 1, AD20/Device 9/MAC2)                                          | 36   |
|       | 7.3.4   | R8610_USB1.1 Configuration Space Registers (IDSEL = AD21/Device |      |
|       | 10/Fun  | ction 0)                                                        | 37   |
|       | 7.3.5   | R8610_USB2.0 Configuration Space Registers (IDSEL = AD21/Device |      |
|       | 10/Fun  | ction 1)                                                        | 38   |
| 8. In | struct  | ion Set                                                         | 39   |
| 0     | 011 401 |                                                                 | 00   |
| 9. A  | ddress  | sing Modes                                                      | 40   |
| 9.1   | Registe | er and Immediate Modes                                          | . 40 |
| 9.2   | •       | Memory Addressing Modes                                         |      |
| 9.3   |         | nces between 16- and 32-bit Addresses                           |      |
|       |         | nal Description                                                 |      |
|       |         | •                                                               |      |
| 10.1  |         | RISC Processor                                                  |      |
| 10.2  | -       | ammable Interrupt Controller                                    |      |
|       | 10.2.1  | Programming the Interrupt Controller                            | 47   |





|      | 10.2.2 End-of-Interrupt Operation                                 |          |
|------|-------------------------------------------------------------------|----------|
|      | 10.2.3 Modes of Operation                                         |          |
|      | 10.2.4 Cascade Mode                                               |          |
|      | 10.2.5 Edge- and Level-Triggered Mode                             | 51       |
|      | 10.2.6 Interrupt Masks                                            | 52       |
|      | 10.2.7 Reading the Interrupt Controller Status                    | 53       |
|      | 10.2.8 Interrupt Steering                                         | 53       |
| 10.3 | DMA Controller                                                    | 54       |
|      | 10.3.1 DMA Transfer Modes                                         | 55       |
|      | 10.3.2 DMA Transfer Types                                         |          |
|      | 10.3.3 DMA Timings                                                |          |
|      | 10.3.4 DREQ and DACK_n Latency Control                            |          |
|      | 10.3.5 Channel Priority                                           | 57       |
|      | 10.3.6 Register Functionality                                     | 57       |
|      | 10.3.7 Address Compatibility Mode                                 | 57       |
|      | 10.3.8 Summary of DMA Transfer Sizes                              |          |
|      | 10.3.8.1 Address Shifting When Programmed for 16-Bit I/O Count by | Words 58 |
|      | 10.3.9 Autoinitialize                                             |          |
|      | 10.3.10 Software Commands                                         |          |
| 10.4 | FIFO UART                                                         | 60       |
|      | 10.4.1 Transmit Operation                                         | 60       |
|      | 10.4.2 Receive Operation                                          | 61       |
|      | 10.4.3 MODEM Control Lines                                        | 62       |
|      | 10.4.4 FIFO Interrupt Mode Operation                              | 62       |
|      | 10.4.5 FIFO Polled Mode Operation                                 | 63       |
|      | 10.4.6 Timing Waveforms                                           | 63       |
| 10.5 | PCI Bus Controller                                                | 65       |
| 10.6 | LPC Interface                                                     | 65       |
|      | 10.6.1 Block Diagram                                              | 66       |
|      | 10.6.2 Protocol Overview                                          | 67       |
|      | 10.6.2.1 Cycle Types                                              | 67       |
|      | 10.6.2.2 Cycle Overview                                           | 67       |
|      | 10.6.3 Target Overview                                            | 68       |
|      | 10.6.3.1 Memory Cycles                                            | 68       |
|      | 10.6.3.2 I/O Cycles                                               | 68       |
|      | 10.6.4 DMA Protocol                                               | 68       |



|        | 10.6.5 Bus Master Protocol                        |
|--------|---------------------------------------------------|
|        | 10.6.5.1 Cycle Formats and Timings68              |
| 10.7   | X-Bus Interface 69                                |
| 10.8   | SDRAM Controller 69                               |
| 10.9   | L1 Cache                                          |
| 10.10  | GPIO Interface                                    |
| 10.11  | Programmable Timer                                |
|        | 10.11.1 Programming the Interval Timer73          |
| 11. Re | gister Description76                              |
| 11.1   | Core Registers                                    |
|        | 11.1.1 General-Purpose Registers                  |
|        | 11.1.2 Segment Registers                          |
|        | 11.1.3 Instruction Pointer Register81             |
|        | 11.1.4 Flags Register                             |
|        | 11.1.5 Control Registers                          |
|        | 11.1.6 System Address Registers                   |
| 11.2   | I/O Mapped Registers                              |
|        | 11.2.1 PCI Configuration Registers90              |
|        | 11.2.2 Slave DMA Control Registers91              |
|        | 11.2.3 DMA Pager Registers                        |
|        | 11.2.4 Master DMA Control Registers               |
|        | 11.2.5 DMA High Page Registers                    |
|        | 11.2.6 Timer/Counter Registers 111                |
|        | 11.2.7 Master Interrupt Control Registers 113     |
|        | 11.2.8 Slave Interrupt Control Registers 114      |
|        | 11.2.9 Interrupt Edge/Level Control Registers 115 |
|        | 11.2.10 Serial Port Registers                     |
|        | 11.2.11 NMI Status and Control Register           |
|        | 11.2.12 CMOS Memory & RTC Register                |
|        | 11.2.13 System Function Register                  |
| 11.3   | PCI Configuration Space Registers126              |
|        | 11.3.1 R8610 North Bridge Configuration Registers |
|        | 11.3.2 R8610 South Bridge Configuration Registers |
|        | 11.3.3 MAC1 and MAC2 Configuration Registers      |
| 12. Fa | st Ethernet Control Unit                          |



| 12.1  | RX Descriptor Format                                              | 7 |
|-------|-------------------------------------------------------------------|---|
| 12.2  | TX Descriptor Format                                              |   |
| 12.3  | MCR0: MAC Control Register 0 (00h)182                             |   |
| 12.4  | MCR1: MAC Control Register 1 (04h)183                             |   |
| 12.5  | MBCR: MAC Bus Control Register (08h)184                           |   |
| 12.6  | MTICR: MAC TX Interrupt Control Register (0Ch)                    |   |
| 12.7  | MRICR: MAC RX Interrupt Control Register (10h)                    |   |
| 12.8  | MTPR: MAC TX Poll Command Register (14h)                          |   |
| 12.9  | MRBSR: MAC RX Buffer Size Register (18h)                          |   |
| 12.10 | MRDCR: MAC RX Descriptor Control Register (1Ah)                   |   |
| 12.11 | MLSR: MAC Last Status Register (1Ch)                              |   |
|       | MMDIO: MAC MDIO Control Register (20h)                            |   |
|       | MMRD: MAC MDIO Read Data Register (24h)                           |   |
|       | MMWD: MAC MDIO Write Data Register (28h)                          |   |
|       | MTDSA0: MAC TX Descriptor Start Address 0 (2Ch)                   |   |
|       | MTDSA1: MAC TX Descriptor Start Address 1 (30h)                   |   |
|       | MRDSA0: MAC RX Descriptor Start Address 0 (34h)                   |   |
|       | MRDSA1: MAC RX Descriptor Start Address 1 (38h)                   |   |
|       | MISR: MAC INT Status Register (3Ch)192                            |   |
| 12.20 | MIER: MAC INT Enable Register (40h)192                            | 2 |
|       | MECISR: MAC Event Counter INT Status Register (44h)193            |   |
|       | MECIER: MAC Event Counter INT Enable Register (48h)               |   |
|       | MRCNT: MAC Successfully Received Packet Counter Register (50h)194 |   |
| 12.24 | MECNT0: MAC Event Counter 0 Register (52h)                        | 5 |
| 12.25 | MECNT1: MAC Event Counter 1 Register (54h)                        | 5 |
| 12.26 | MECNT2: MAC Event Counter 2 Register (56h)                        | 6 |
| 12.27 | MCENT3: MAC Event Counter 3 Register (58h)                        | 6 |
| 12.28 | MTCNT: MAC Successfully Transmit Packet Counter Register (5Ah)197 | 7 |
| 12.29 | MCENT4: MAC Event Counter 4 Register (5Ch)197                     | 7 |
| 12.30 | MPCNT: MAC Pause Frame Counter Register (5Eh)                     | 3 |
| 12.31 | MAR0 ~3: MAC Hash Table Word 0 ~3 (60h, 62h, 64h, 66h)198         | 3 |
| 12.32 | MID0 (68h, 6Ah, 6Ch)200                                           | C |
| 12.33 | MID1 (70h, 72h, 74h)                                              | 1 |
|       | MID2 (78h, 7Ah, 7Ch)                                              |   |
|       | MID3 (80h, 82h, 84h)203                                           |   |
|       | MPSCCR: MAC PHY Status Change Configuration Register (88h)204     |   |
|       |                                                                   |   |



|              | MPSR: MAC PHY Status Register (8Ah)204<br>MACID: MAC Identifier Register                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13.US        | B2.0 Host Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 13.1<br>13.2 | Features20613.1.1 USB1.1 Host Controller20613.1.2 USB2.0 Host Controller206General Descriptions207                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13.3<br>13.4 | Functional Block Diagram208Functional Block Descriptions20913.4.1 DMA/Master Unit20913.4.2 List Processor20913.4.3 Host Parallel Interface Engine (HPIE) or Host Serial Interface Engine (HSIE) 21013.4.4 Port Router210                                                                                                                                                                                                                                                                                                             |
| 13.5         | 13.4.5 UTMI211Register Definition21113.5.1 USB1.1 Configuration Space21113.5.2 USB1.1 Operational Registers22013.5.2.1 Open Host Controller Interface Operational Registers22113.5.2.2 Control and Status Partition22213.5.2.3 Memory Pointer Partition22813.5.2.4 Frame Counter Partition23113.5.2.5 Root Hub Partition23413.5.2.6 Legacy Support Registers23913.5.3 EHCI Configuration Space24313.5.4 EHCI Operational Registers25413.5.4.1 Host Controller Capability Register25413.5.4.2 Host Controller Operational Register256 |
| 14.DC        | Electrical Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 14.1<br>14.2 | Absolute Maximum Ratings (25 )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15.AC        | Electrical Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15.1         | System Reset263                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



| 17. Re | 17.Revision History278       |     |  |  |  |  |
|--------|------------------------------|-----|--|--|--|--|
| 16. Pa | ckage Information            | 277 |  |  |  |  |
| 15.5   | Bus Interface                | 275 |  |  |  |  |
| 15.4   | LPC Interface                | 274 |  |  |  |  |
|        | 15.3.2 R8610 as a PCI Target |     |  |  |  |  |
|        | 15.3.1 R8610 as a PCI Master |     |  |  |  |  |
| 15.3   | PCI Interface                |     |  |  |  |  |
| 15.2   | SDRAM Interface              |     |  |  |  |  |
|        |                              |     |  |  |  |  |

The R8610 is a high performance and fully static 32-bit RISC microcontroller with the compatibility of Windows based, Linux and most popular 32-bit RTOS. It also integrates 16KB write direct map L1 cache, PCI rev. 2.1 32-bit bus interface at 33 MHz, SDRAM/ROM/memory controller, IPC (Internal Peripheral Controllers with DMA and interrupt timer/counter included), Fast Ethernet MAC, FIFO UART, 10/100M MAC and USB2.0 Host within a single 216-pin LQFP package to form a system-on-a-chip (SOC). It provides an ideal solution for the embedded system and communications products (such as thin client, NAT router, home gateway, access point and tablet PC) to bring about desired performance.

# 2. Features

# Embedded RISC Controller

- Full 32-bit RISC architecture
- Supports diverse operation systems, including Windows based, Linux and most popular 32-bit RTOS
- 6-stage pipeline
- Operation frequency: 133 MHz
- Supports MMU function which includes 32 TLB entries

# MAC Controller

- Supports two-port 10/100 Fast Ethernet MAC
- IEEE 802.3u MII interface
- IEEE 802.3x flow control in full-duplex mode
- Descriptor architecture for packet TX/RX

### Interrupt Controller

- Provides two 8259 compatible interrupt controllers which are cascaded internally
- Independent programmable level/edge-triggered interrupt channels
- Serial IRQ supported

# DMA Controller

- Provides two 8237 DMA compatible controllers which are cascaded internally
- 4 channels for 8-bit DMA transfer and 3 channels for 16-bit transfer
- Supports 8/16/32-bit channel 4 bus master on the LPC bus
- Two USB 2.0 Host Port Support
  - Supports HS, FS and LS
- FIFO UART Port

- A high performance UART port with transmit and receive FIFOs
- Supports the programmable baud rate generator with the data rates from 50 to 115,200 bps
- The character options are programmable for 1 start bit; 1, 1.5 or 2 stop bits; even, odd or no parity; 5~8 data bits

# PCI Control Interface

- Supports PCI Rev 2.1 specification
- 32-bit bus interface
- Supports PCI clock at 33 MHz
- Supports PCI host
- Supports PCI master/slave
- Up to 133 Mbytes/sec maximum bandwidth
- Supports up to 3 external master devices on PCI
- Provides four PCI interrupt channels

# ■ LPC (Low Pin Count) Bus Interface

- LPC revision 1.0 compliant
- Supports LPC/FWH (Firmware Hub) compliant interfaces
- Provides the interface to connect an LPC/FWH Flash ROM or Super I/O chip
- Supports LPC DMA
- Supports serial IRQ
- Supports bus master mode
- X-Bus Interface
  - Provides the interface to boot ROM BIOS & DOC (Disk On Chip).
  - Supports 8/16-bit data width
  - Provides ROMCS\_n for booting from X-bus Flash ROM

# RDC<sup>®</sup> RISC DSP Communication

R8610 32-Bit RISC MicroController

- Supports from 64K-byte to Max. 16M-byte ROM space addressing
- Supports two independent and programmable CSs (Chip Selects)
- SDRAM Control Interface
  - PC100/PC133 compliant
  - Supports 16-bit data bus width
  - Supports speeds up to 133 MHz and above
  - Supports maximum 128 MB memory space
- On-Chip L1 16KB Cache
  - Unifies instructions and data cache
  - Supports write through for cache write policy
  - Snooping mechanism support for data coherence between main memory and cache
  - Direct map

# General Programmable I/O

Supports 58 programmable I/O pins

 Each GPIO pin can be individually configured to be an input/output pin

# Counter/Timers

- 8254 compatible timers
- Provides three independent programmable timers / counters
- Supports a watchdog timer (WDT)
- Supports a speaker output

# Real Time Clock (External)

- Provides a direct interface to external RTC chips

# Operating Voltage Range

- Core voltage: 1.8 V ± 5%
- I/O voltage: 3.3 V ± 10%
- Package Type
  - 216-pin LQFP

# 3. Block Diagram



# 4. PIN Description



4.1.1 MDC pulled low







# 4.1.2 MDC pulled high



# 4.2 Signal Description

This chapter provides a detailed description of R8610 signals. A signal with the symbol "\_n" at the end of itself indicates that this

pin is low active. Otherwise, it is high active.

The following notations are used to describe the signal types:

I Input pin

- O Output pin
- I/O Bi-directional Input/Output pin

# • System (3 PINs)

| PIN No. | Symbol  | Туре | Description                                                                                                                                                                                   |
|---------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16      | PWRGOOD | I    | <b>Power-Good Input.</b> This signal comes from Power Good of the power supply to indicate that the power is available. The R8610 uses this signal to generate reset sequence for the system. |
| 52      | XIN     | I    | <i>Crystal-in.</i> 25MHz frequency input, <u>within 100 ppm tolerance</u> , to the amplifier (oscillator).                                                                                    |
| 53      | XOUT    | 0    | Crystal-out. Frequency output from the inverting amplifier (oscillator).                                                                                                                      |

# • PCI Bus Interface (54 PINs)

| PIN No.                                                                                                                                                     | Symbol      | Туре | Description                                                                                                                                                                                                                                                                                                         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 153                                                                                                                                                         | PCICLK      | 0    | <b>PCI Clock Output.</b> This clock is used by all of the R8610 logic that is in the PCI clock domain.                                                                                                                                                                                                              |
| 159                                                                                                                                                         | PCIRST_n    | 0    | <b>PCI Reset.</b> This pin is used to reset PCI devices. When it is asserted low, all the PCI devices will be reset.                                                                                                                                                                                                |
| 211,209,208,207,<br>206,205,204,203,<br>200,198,197,196,<br>194,193,192,190,<br>179,178,177,176,<br>175,174,173,172,<br>169,168,166,165,<br>164,162,161,160 | AD[31:0]    | I/O  | <b>PCI Address and Data.</b> The standard PCI address and data lines. The address is driven with PCI Frame assertion and data is driven or received in the following clocks.<br>MDC is pulled low: PIN211 is mapped to AD31, PIN 209 to AD30<br>MDC is pulled high: PIN211 is mapped to AD0, PIN 209 to AD1         |
| 201,189,180,170                                                                                                                                             | C/BE_n[3:0] | I/O  | <b>Bus Command and Byte Enables.</b> During the address phase, C/BE_n[3:0] define the Bus Command. During the data phase, C/BE[3:0]_n define the Byte Enables.<br>MDC is pulled low: PIN201 is mapped to C/BE_n[3], PIN 189 to C/BE_n[2]<br>MDC is pulled high: PIN201 is mapped to C/BE_n[0], PIN 189 to C/BE_n[1] |
| 188                                                                                                                                                         | FRAME_n     | I/O  | <b>PCI Frame.</b> This pin is driven by a PCI master to indicate the beginning and duration of a PCI transaction.                                                                                                                                                                                                   |
| 186                                                                                                                                                         | TRDY_n      | I/O  | <b>PCI Target Ready.</b> This pin is asserted low by the target to indicate that it is able to receive the current data transfer. A data was transferred if both IRDY_n and TRDY_n are asserted low during the rising edge of the PCI clock.                                                                        |
| 187                                                                                                                                                         | IRDY_n      | I/O  | <b>PCI Initiator Ready.</b> This pin is asserted low by the master to indicate that it is able to transfer the current data transfer. A data was transferred if both IRDY_n and TRDY_n are asserted low during the rising edge of the PCI clock.                                                                    |
| 183                                                                                                                                                         | STOP_n      | I/O  | <b>PCI Stop.</b> This pin is asserted low by the target to indicate that it is unable to receive the current data transfer.                                                                                                                                                                                         |
| 185                                                                                                                                                         | DEVSEL_n    | I/O  | <b>Device Select.</b> This pin is driven by the devices which have decoded the addresses belonging to them.                                                                                                                                                                                                         |
| 182                                                                                                                                                         | PAR         | I/O  | <b>PCI Parity.</b> This pin is driven to even parity by PCI master over the AD[31:0] and C/BE_n[3:0] bus during address and write data phases. It should be pulled high through a weak external pull-up resistor. The target drives parity during data read.                                                        |



| 158         | INTA_n/GPIO19                 | I/O | <b>PCI INTA_n.</b> PCI interrupt input A. It connects to PCI INTA_n when normal modes of PCI Interrupts are supported.<br><b>General-Purpose Input/Output GPIO19.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (INTA_n) is selected.     |
|-------------|-------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 157         | INTB_n/GPIO20                 | I/O | <b>PCI INTB_n.</b> PCI interrupt input B. It connects to PCI INTNB_n when normal modes of PCI Interrupts are supported.<br><b>General-Purpose Input/Output GPIO20.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (INTB_n) is selected.    |
| 156         | INTC_n/GPIO21                 | I/O | <b>PCI INTC_n.</b> PCI interrupt input C. It connects to PCI INTC_n when normal modes of PCI Interrupts are supported.<br><b>General-Purpose Input/Output GPIO21.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (INTC_n) is selected.     |
| 155         | INTD_n/GPIO22                 | I/O | <b>PCI INTD_n.</b> PCI interrupt input D. It connects to PCI INTD_n when the normal modes of PCI Interrupts are supported.<br><b>General-Purpose Input/Output GPIO22.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (INTD_n) is selected. |
| 215,216,1   | PREQ_n[2:0]/<br>GPIO25~GPIO23 | I/O | <b>PCI Bus Request.</b> These signals are the PCI bus request signals used as inputs by the internal PCI arbiter.<br><b>General-Purpose Input/Output GPIO25~23.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (PREQ_n) is selected.       |
| 212,213,214 | PGNT_n[2:0]/<br>GPIO28~GPIO26 | I/O | <b>PCI Grant.</b> These signals are the PCI bus grant output signals generated by the internal PCI arbiter.<br><b>General-Purpose Input/Output GPIO28~26.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (PGNT_n) is selected.             |

# • SDRAM Interface & X Bus (51 PINs)

| PIN No. | Symbol           | Туре | Description                                                                                   |                                                                            |                                                                        |                                                                                                                                                                                 |                       |   |   |
|---------|------------------|------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---|---|
| 45      | SDRAMCLK         | 0    | <b>SDRAM Clock output.</b> This pin provides the fundamental timing for the SDRAM controller. |                                                                            |                                                                        |                                                                                                                                                                                 |                       |   |   |
| 57,58   | MA[1:0]/SA[1:0]/ | 1/0  | addresses for<br>XD Bus Addr<br>Devices Addre<br>Flash ROM T<br>boot strapping                | SDRAM.<br>ress Bus SA<br>ess Bus SA[1<br><b>ype Select</b><br>options to s | <b>A[1:0].</b> These<br>I:0].<br><b>ROMSL[1:0].</b><br>select the Flas | s are used as the row and colu<br>pins should be connected to the<br>These two pins are used for sys<br>sh ROM types and physical location<br>sampled on the rising edge of sys | e XD<br>stem<br>ions. |   |   |
| ,       | ROMSL[1:0]       |      |                                                                                               | ROMSL1                                                                     | ROMSL0                                                                 | Flash ROM Type                                                                                                                                                                  |                       |   |   |
|         |                  |      |                                                                                               | 0                                                                          | 0                                                                      | X Bus 8-bit Flash ROM                                                                                                                                                           |                       |   |   |
|         |                  |      |                                                                                               |                                                                            | 0                                                                      | 1                                                                                                                                                                               | LPC Flash ROM         |   |   |
|         |                  |      |                                                                                               |                                                                            |                                                                        |                                                                                                                                                                                 |                       | 1 | 0 |
|         |                  |      |                                                                                               | 1                                                                          | 1                                                                      | FWH Flash ROM                                                                                                                                                                   |                       |   |   |

R8610 32-Bit RISC MicroController



| Memory Addres | s MA[4:2]. | Normally, | these | pins | are | used | as | the | row | and |
|---------------|------------|-----------|-------|------|-----|------|----|-----|-----|-----|

|                       | M0[4:2]/S0[4:2]/                  |     | column addresses for SDRAM.<br><b>XD Bus Address Bus SA[4:2].</b> These<br>Devices Address Bus SA[4:2].<br><b>CPU Clock Selection HCKSL[2:0].</b> The<br>boot strapping options to select the H                                                                                          | These three pins are used for system ost CPU clock/SDRAM clock which is lock (25MHz). The logic level of these                                                                                                                                                                                                                            |
|-----------------------|-----------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 33,48,49              | MA[4:2]/SA[4:2]/<br>HCKSL[2:0]    | I/O | 3'b000                                                                                                                                                                                                                                                                                   | 25MHz                                                                                                                                                                                                                                                                                                                                     |
|                       |                                   |     | 3'b001                                                                                                                                                                                                                                                                                   | 100MHz                                                                                                                                                                                                                                                                                                                                    |
|                       |                                   |     | 3'b010                                                                                                                                                                                                                                                                                   | 125MHz                                                                                                                                                                                                                                                                                                                                    |
|                       |                                   |     | 3'b011                                                                                                                                                                                                                                                                                   | 133MHz                                                                                                                                                                                                                                                                                                                                    |
|                       |                                   |     | 3'b100                                                                                                                                                                                                                                                                                   | 150MHz                                                                                                                                                                                                                                                                                                                                    |
|                       |                                   |     | 3'b101                                                                                                                                                                                                                                                                                   | Reserved                                                                                                                                                                                                                                                                                                                                  |
|                       |                                   |     | 3'b110                                                                                                                                                                                                                                                                                   | Reserved                                                                                                                                                                                                                                                                                                                                  |
|                       |                                   |     | 3'b111                                                                                                                                                                                                                                                                                   | 25MHz (bypass mode)                                                                                                                                                                                                                                                                                                                       |
| 34                    | 34 MA[5]/SA[5]/<br>HCKSL[3]       | I/O | options to select the PCI clock which<br>clock. The logic level of this pin will be<br>reset. The option table is listed as below                                                                                                                                                        | pin is used for system boot strapping<br>is an integer divisor of the SDRAM<br>sampled on the rising edge of system<br>w:                                                                                                                                                                                                                 |
|                       |                                   |     | HCKSL3                                                                                                                                                                                                                                                                                   | PCI Clock                                                                                                                                                                                                                                                                                                                                 |
|                       |                                   |     | 0                                                                                                                                                                                                                                                                                        | CPU Clock/5                                                                                                                                                                                                                                                                                                                               |
|                       |                                   |     | 1                                                                                                                                                                                                                                                                                        | CPU Clock/4                                                                                                                                                                                                                                                                                                                               |
| 36                    | MA[6]/SA[6]/DLLEN                 | I/O | <i>Memory Address MA6.</i> Normally, thi<br>addresses for SDRAM.<br><i>XD Bus Address Bus SA6.</i> This pin s<br>Address Bus SA6.<br><i>DeLayLine Enable.</i> This pin is used<br>select enabled or disabled SDRAM<br>normaly pulled high to enable the Dela<br>the internal Delay Line. | hould be connected to the XD Devices<br>for system boot strapping option to<br>clock output Delay Line circuit. It is                                                                                                                                                                                                                     |
| 42,40,59,39,38,<br>37 | MA[12:7]/SA[12:7]/<br>STRAP[12:7] | I/O | loopback mode.<br>STRAP[8]: Normally, it should be<br>OVRCUR_n pin as USB PLL clock inpu<br>STRAP[9]: Normally, it should be pull<br>pin as PLL test out.<br>STRAP[10]: Normally, it should be p<br>PHY parallel data out.<br>STRAP[11]: Normally, it should be p<br>JTAG.               | e pins should be connected to the XD<br>system boot strapping option.<br>bulled low. Pull it high to enter USB<br>pulled low. Pull it high to select<br>tt.<br>led low. Pull it high to select SPEAKER<br>bulled low. Pull it high to enable USB<br>ulled low. Pull it high to enable R8610<br>ce select. Pull it high to select external |

# **R8610**



|--|

| 90,89,86,85,84,<br>83,82,80,71,72,<br>73,74,76,77,78,<br>79 | MD[15:0]/XD[15:0] | I/O | <i>Memory Data MD[15:0].</i> These pins are connected to the SDRAM data bus. <i>XD Data Bus XD[15:0].</i> These pins should be connected to the XD Devices Data Bus.                                                                                                                                                                                       |
|-------------------------------------------------------------|-------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 61                                                          | BA0/MEMR_n        | 0   | <b>SDRAM Bank Address.</b> These pins are connected to SDRAM as bank address pins. <b>XD Bus Memory Read.</b> This memory read command signal is used for XD flash ROM read access cycle.                                                                                                                                                                  |
| 60                                                          | BA1/MEMW_n        | 0   | <b>SDRAM Bank Address.</b> These pins are connected to SDRAM as bank address pins. <b>XD Bus Memory Write.</b> This memory write command signal is used for XD flash ROM write access cycle.                                                                                                                                                               |
| 47,69                                                       | DQM[1:0]          | 0   | <b>SDRAM Data Mask DQM[1:0].</b> These pins act as synchronized output enables during read cycles and byte masks during write cycles.                                                                                                                                                                                                                      |
| 62,63                                                       | CS_n[1:0]         | 0   | <b>Chip Select CS[1:0].</b> These two pins activate the SDRAM devices. First Bank of SDRAM accepts any command when the CS0_n pin is active low. Second Bank of SDRAM accepts any command when the CS1_n pin is active low.                                                                                                                                |
| 64                                                          | RAS_n             | 0   | <b>SDRAM Row Address Strobe.</b> When asserted, this signal latches row address on positive edge of the SDRAM clock. This signal also allows row access and pre-charge.                                                                                                                                                                                    |
| 65                                                          | CAS_n             | 0   | <b>SDRAM Column Address Strobe.</b> When asserted, this signal latches column address on the positive edge of the SDRAM clock. This signal also allows column access and pre-charge.                                                                                                                                                                       |
| 68                                                          | WE_n              | 0   | <i>Memory Write Enable.</i> This pin is used as a write enable for the memory data bus.                                                                                                                                                                                                                                                                    |
| 104                                                         | ROMCS_n           | 0   | ROM Chip Select. This pin is used as a ROM chip select.                                                                                                                                                                                                                                                                                                    |
| 103,102,101,100,<br>98,97,95,94,93,<br>92,91                |                   | I/O | <b>XD Bus Address Bus SA[23:13].</b> These pins should be connected to the XD Devices Address Bus SA[23:13]. <b>General-Purpose Input/Output GPIO39~29.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (SA[23:13]) is selected. |

#### LPC Bus Interface (7 PINs) •

| PIN No.     | Symbol                   | Туре | Description                                                                                                                                                                                                                                                                                                                                                       |
|-------------|--------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22,20,19,18 | LAD[3:0]/<br>GPIO3~GPIO0 | I/O  | LPC Command, Address and Data LAD[3:0]. These pins are used to be command/address/data pins of Low-Pin-Count Function.<br>General-Purpose Input/Output GPIO3~GPIO0. The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (LAD[3:0]) is selected. |
| 23          | LFRAME_n/GPIO4           | I/O  | Low Pin Count FRAME_n Signal. This signal is used as a frame signal of<br>low pin count protocol.<br>General-Purpose Input/Output GPIO4. The General-Purpose Input/Output<br>function is selected by setting the corresponding bits of General-Purpose I/O<br>Control Register to '1', otherwise the normal function (LFRAME_n) is selected.                      |
| 24          | LDRQ_n/GPIO5             | I/O  | Low Pin Count DMA Request Signal. This signal is used as a DMA request signal of low pin count protocol.<br>General-Purpose Input/Output GPIO5. The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (LDRQ_n) is selected.                       |
| 25          | SERIRQ/GPIO6             | I/O  | <b>Serial Interrupt Request.</b> This pin is used to support the serial interrupt protocol of common architecture.<br><b>General-Purpose Input/Output GPIO6.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (SERIRQ) is selected.      |

#### Notes:

- 1. If these LPC pins are not treated as NC (No Connection) pins, a 10k Ohm external pull-up resistor must be added to each of these LPC pins.
- 2. If these LPC pins are used as NC pins, an external pull-up resistor must be added to LDRQ\_n to ensure the system works correctly.

# • MII Interface (28 PINs)

| PIN No.             | Symbol                                                           | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------|------------------------------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 129,130,131,<br>132 | TXD0_0/GPIO41<br>TXD0_1/GPIO42<br>TXD0_2/GPIO43<br>TXD0_3/GPIO44 | I/O  | <b>TXD0_[3:0]:</b> Four parallel transmit data lines. This data is synchronized to the assertion of the TXC signal and is latched by the external PHY on the rising edge of the TXC signal. <b>General-Purpose Input/Output GPI044~GPI041.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (TXD0_[3:0]) is selected.              |
| 128                 | TXC0/GPIO40                                                      | I/O  | <b>TXC0:</b> Supports the transmit clock supplied by the external PMD device.<br>This clock should always be active.<br><b>General-Purpose Input/Output GPIO40.</b> The General-Purpose<br>Input/Output function is selected by setting the corresponding bits of<br>General-Purpose I/O Control Register to '1', otherwise the normal<br>function (TXC0) is selected.                                                                                      |
| 127                 | RXC0/GPIO46                                                      | I/O  | <b>RXC0:</b> Supports the receive clock supplied by the external PMD device.<br>This clock should always be active.<br><b>General-Purpose Input/Output GPIO46.</b> The General-Purpose<br>Input/Output function is selected by setting the corresponding bits of<br>General-Purpose I/O Control Register to '1', otherwise the normal<br>function (RXC0) is selected.                                                                                       |
| 122                 | RXDV0/GPIO47                                                     | I/O  | <b>RXDV0:</b> Data valid is asserted by an external PHY when the received data is present on the RXD[3:0] lines and is de-asserted at the end of the packet. This signal should be synchronized with the RXC signal. <b>General-Purpose Input/Output GPI047.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (RXDV0) is selected. |
| 123,124,125,<br>126 | RXD0_0/GPIO48<br>RXD0_1/GPIO49<br>RXD0_2/GPIO50<br>RXD0_3/GPIO51 | I/O  | <b>RXD0_[3:0]:</b> Four parallel receiving data lines. This data is driven by an external PHY attached to the media and should be synchronized with the RXC signal.<br><b>General-Purpose Input/Output GPI051~GPI048.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (RXD0_[3:0]) is selected.                                   |
| 135                 | COL0/GPIO52                                                      | I/O  | <b>COLO:</b> This pin functions as the collision detection. When the external physical layer protocol (PHY) device detects a collision, it asserts this pin.<br><b>General-Purpose Input/Output GPIO52.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (COL0) is selected.                                                       |
| 134                 | TXEN0/GPIO45                                                     | I/O  | <b>TXEN0:</b> This pin functions as Transmit Enable. It indicates that a transmission to an external PHY device is active on the MII port. <b>General-Purpose Input/Output GPI045.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (TXEN0) is selected.                                                                           |
| 146,147,148,<br>149 | TXD1_0<br>TXD1_1<br>TXD1_2<br>TXD1_3                             | 0    | <b>TXD1_[3:0]:</b> Four parallel transmit data lines. This data is synchronized to the assertion of the TXC signal and is latched by the external PHY on the rising edge of the TXC signal.                                                                                                                                                                                                                                                                 |



| 150                 | TXEN1                                | I/O | <b>TXEN1:</b> This pin functions as Transmit Enable. It indicates that a transmission is active on the MII port to an external PHY device. For internal USB test mode, it is treated as an input.                                                                                                                                                                                                                                                              |
|---------------------|--------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 145                 | TXC1                                 | I   | <b>TXC1:</b> Supports the transmit clock supplied by the external PMD device. This clock should always be active.                                                                                                                                                                                                                                                                                                                                              |
| 144                 | RXC1                                 | I   | <b>RXC1:</b> Supports the receive clock supplied by the external PMD device. This clock should always be active.                                                                                                                                                                                                                                                                                                                                               |
| 140,141,142,<br>143 | RXD1_0<br>RXD1_1<br>RXD1_2<br>RXD1_3 | I/O | <b>RXD1_[3:0]:</b> Four parallel receive data lines. This data is driven by an external PHY that the media is attached and should be synchronized with the RXC signal.<br>For internal USB test mode, it is treated as an output                                                                                                                                                                                                                               |
| 139                 | RXDV1                                | I/O | <b>RXDV1:</b> Data valid is asserted by an external PHY when the received data is present on the RXD1_[3:0] lines and is de-asserted at the end of the packet. For internal USB test mode, it is treated as an output                                                                                                                                                                                                                                          |
| 151                 | COL1                                 | I/O | <b>COL1:</b> This pin functions as Collision Detection. When the external physical layer protocol (PHY) device detects a collision, it asserts this pin. For internal USB test mode, it is treated as output                                                                                                                                                                                                                                                   |
| 137                 | MDC/PCI_REVERSE                      | I/O | MDC: MII management data clock is sourced by the R8610 to the external PHY devices as a timing reference for the transfer of information on the MDIO signal. PCI_REVERSE: This pin is used for system boot strapping option to select pin sequence of PCI AD bus and CBE bus. Pull low will use the default sequence; pull high will select the reverse sequence of PCI AD bus and CBE bus, i.e., AD31 ⇔ AD0, AD30 ⇔ AD1, AD0 ⇔ AD31, CBE3 ⇔ CBE0, CBE0 ⇔ CBE3 |
| 136                 | MDIO                                 | I/O | <b>MDIO:</b> MII management data input/output transfers control information and status between the external PHY and the R8610.                                                                                                                                                                                                                                                                                                                                 |

# • FIFO UART (8 PINs)

| PIN No. | Symbol           | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 120     | SIN/GPI07        | I/O  | <b>Receive Data.</b> FIFO UART receiver serial data input signal.<br><b>General-Purpose Input/Output GPIO9.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (SIN) is selected.                                                                                                                                                                                                                                                                                                                                                                                         |
| 121     | SOUT/GPIO8       | I/O  | <b>Transmit Data.</b> FIFO UART transmitter serial data output from the serial port.<br><b>General-Purpose Input/Output GPIO9.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (SOUT) is selected.                                                                                                                                                                                                                                                                                                                                                                     |
| 114     | RTS_n/TDO /GPIO9 | I/O  | <b>Request to Send.</b> Active low Request to Send output for UART port.<br>A handshake output signal notifies the modem that the UART is ready to<br>transmit data. This signal can be programmed by writing to bit 1 of Modem<br>Control Register (MCR). The hardware reset will clear the RTS_n signal to be<br>inactive mode (high). It is forced to be inactive during the loop-mode<br>operation.<br><b>TDO:</b> JTAG Test Data Output pin.<br><b>General-Purpose Input/Output GPIO9.</b> The General-Purpose Input/Output<br>function is selected by setting the corresponding bits of General-Purpose I/O<br>Control Register to '1', otherwise the normal function (RTS_n) is selected. |
| 112     | DTR_n/GPIO10     | I/O  | <b>Data Terminal Ready.</b> This is an active low output for the UART port. A handshake output signal signifies the modem that the UART is ready to establish data communication link. This signal can be programmed by writing to bit 0 of Modem Control Register (MCR). The hardware reset will clear the DTR_n signal to be inactive during the loop-mode operation. <b>General-Purpose Input/Output GPIO10.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (DTR_n) is selected                                                                                    |

# **R8610**



32-Bit RISC MicroController

| 115 | CTS_n/TMS/GPIO11 | I/O | <i>Clear to Send.</i> This active low input for the primary and secondary serial ports. A handshake signal notifies the UART that the modem is ready to receive data. The CPU can monitor the status of the CTS_n signal by reading bit 4 of Modem Status Register (MSR). A CTS_n signal states the change from low to high after the last MSR read sets bit 0 of the MSR to a "1". If bit 3 of the Interrupt Enable Register is set, the interrupt is generated when CTS_n changes the state. The CTS_n signal has no effect on the transmitter. <i>Note: Bit 4 of the MSR is the complement of CTS_n. TMS:</i> JTAG Test Mode Select pin. <i>General-Purpose Input/Output GPI011.</i> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (CTS_n) is selected |
|-----|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 117 | DSR_n/TCK/GPIO12 | I/O | Data Set Ready.       This active low input is for the UART ports. A handshake signal notifies the UART that the modem is ready to establish the communication link. The CPU can monitor the status of the DSR_n signal by reading bit5 of the Modem Status Register (MSR). A DSR_n signal states the change from low to high after the last MSR read sets bit1 of the MSR to a "1". If bit 3 of the Interrupt Enable Register is set, the interrupt is generated when DSR_n changes state.         Note: Bit 5 of the MSR is the complement of DSR_n.         TCK: JTAG Test Clock Input pin.         General-Purpose Input/Output GPIO12.         The General-Purpose Input/Output GPIO12.         The General-Purpose Input/Output GPIO12.         To control Register to '1'. Otherwise, the normal function (DSR_n) is selected.                                             |
| 118 | DCD_n/TDI/GPIO13 | I/O | Data Carrier Detect. This active low input is for the UART ports. A handshake signal notifies the UART that the carrier signal is detected by the modem. The CPU can monitor the status of the DCD_n signal by reading bit 7 of the Modem Status Register (MSR). A DCD_n signal states the change from low to high after the last MSR read sets bit 3 of the MSR to a "1". If bit 3 of the Interrupt Enable Register is set, the interrupt is generated when DCDJ changes state.         Note: Bit 7 of the MSR is the complement of DCD_n.         TDI: JTAG Test Data Input pin.         General-Purpose Input/Output GPI013. The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (DCD_n) is selected                                                         |
| 113 | RI_n/GPIO14      | I/O | <b>Ring Indicator.</b> This active low input is for the UART ports. A handshake signal notifies the UART that the telephone ring signal is detected by the modem. The CPU can monitor the status of the RI_n signal by reading bit 6 of the Modem Status Register (MSR). An RI_n signal states the change from low to high after the last MSR read sets bit 2 of the MSR to a "1". If bit 3 of the Interrupt Enable Register is set, the interrupt is generated when RI_n changes state.<br><b>Note:</b> Bit 6 of the MSR is the complement of RI_n.<br><b>General-Purpose Input/Output GPIO14.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (RI_n) is selected                                                                                      |

#### External RTC Interface (4 PINs) ullet

| PIN No. | Symbol       | Туре | Description                                                                                                                                                                                                                           |
|---------|--------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |              |      | <b>RTC Address Strobe.</b> This pin is used as the RTC Address Strobe and should be connected to the RTC.                                                                                                                             |
| 29      | RTCAS/GPIO15 |      | <b>General-Purpose Input/Output GPIO15.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (RTCAS) is selected |
| 30      | RTCRD/GPIO16 | I/O  | RTC Read Command. This pin is used as the RTC Read Command and                                                                                                                                                                        |



|    |               |     | should be connected to the RTC.                                                                                                                                                                                                        |
|----|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |               |     | <b>General-Purpose Input/Output GPIO16.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (RTCRD) is selected  |
|    |               |     | <b>RTC Write Command.</b> This pin is used as the RTC Write Command and should be connected to the RTC.                                                                                                                                |
| 31 | RTCWR/GPI017  | I/O | <b>General-Purpose Input/Output GPIO17.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (RTCWR) is selected  |
|    |               |     | RTC Interrupt Input. This pin is used as the RTC Interrupt input.                                                                                                                                                                      |
| 32 | IRQ8_n/GPIO18 | I/O | <b>General-Purpose Input/Output GPIO18.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (IRQ8_n) is selected |

# • USB 2.0 Interface (6 PINs)

| PIN No. | Symbol   | Туре | Description                                                                                                       |
|---------|----------|------|-------------------------------------------------------------------------------------------------------------------|
| 6       | REXT     | I    | External Reference Resistance. 510 ±10%                                                                           |
| 14      | OVRCUR_n | I    | <b>Over Current Detect for USB Host Controller.</b><br>This pin is used to monitor USB Power Over Current Status. |
| 12,11   | DP1, DM1 | I/O  | <b>Universal Serial Bus Port 1.</b> These are the serial data pair for USB Port 0.                                |
| 3,4     | DP2, DM2 | I/O  | <b>Universal Serial Bus Port 2.</b> These are the serial data pair for USB Port 1.                                |

# • Miscellaneous & GPIO (6 PINs)

| PIN No. | Symbol                   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|--------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 111     | A20GATE_n/<br>GPIO54     | I/O  | Address Bit 20 Mask.<br>General-Purpose Input/Output GPI054. The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (A20GATE_n) is selected.                                                                                                                                                                     |
| 109     | KBRST_n/<br>GPIO55       | I/O  | <b>Keyboard Reset.</b><br><b>General-Purpose Input/Output GPI055.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (KBRST_n) is selected.                                                                                                                                                              |
| 108     | SPEAKER/GPIO53           | I/O  | <b>Speaker Output.</b> This pin is used to control the Speaker Output and should be connected to the Speaker.<br><b>General-Purpose Input/Output GPI053.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (SPEAKER) is selected.                                                                       |
| 27      | CLK25MOUT/<br>GPIO56     | I/O  | <b>25MHz Clock output.</b><br><b>General-Purpose Input/Output GPI053.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (CLK25MOUT) is selected.                                                                                                                                                        |
| 106     | XCS1_n/GPIO57            | I/O  | <b>XBUS Chip Select 1</b><br><b>General-Purpose Input/Output GPI057.</b> The General-Purpose Input/Output function is selected by setting the corresponding bits of General-Purpose I/O Control Register to '1', otherwise the normal function (XCS1_n) is selected.                                                                                                                                                            |
| 107     | XCS2_n/GPIO58/<br>CLK14M | I/O  | XBUS Chip Select 2<br>General-Purpose Input/Output GPI058. The General-Purpose Input/Output<br>function is selected by setting the corresponding bits of General-Purpose I/O<br>Control Register to '1', otherwise the normal function (XCS2_n) is selected.<br>CLK14M. External 14.318MHz Clock for timer. The R8610 timer will use this<br>pin as a clock source when MA[12]/STRAP[12] is pulled high during system<br>reset. |

## • Power (49 PINs)

| PIN No.                                           | Symbol    | Туре | Description                   |
|---------------------------------------------------|-----------|------|-------------------------------|
| 17,35,46,66,81,<br>96,119,154,181,<br>202         | VCC_IO    | I    | I/O power pin, pure 3.3V.     |
| 15,26,44,54,75,<br>88,105,116,152,<br>171,191,210 | GND_IO    | Ι    | I/O ground pin.               |
| 21,43,67,110,<br>133,167,199                      | VCC_CORE  | I    | Core power pin, pure 1.8V.    |
| 28,41,70,87,99,<br>138,163,184,<br>195            | GND_CORE  | I    | Core ground pin.              |
| 50,55                                             | VCC18A    | I    | PLL power pin, pure 1.8V.     |
| 51,56                                             | GND18A    | I    | PLL ground pin.               |
| 9                                                 | AVDD33    | I    | I/O power pin, pure 3.3V.     |
| 2,13                                              | AVDD[1:0] | I    | Analog power pin, pure 1.8V.  |
| 7                                                 | AVDDPLL   | I    | USB PLL power pin, pure 1.8V. |
| 5,10                                              | AVSS[1:0] |      | Analog ground pin.            |
| 8                                                 | AVSSPLL   | I    | USB PLL ground pin.           |

# 4.3 PIN Capacitance Description

| Symbol           | Parameter                       | Min. | Тур. | Max. | Unit |
|------------------|---------------------------------|------|------|------|------|
| C <sub>IN</sub>  | 3.3V Input Capacitance          |      | 4.8  |      | pF   |
| Cout             | 3.3V Output Capacitance         |      | 4.8  |      | pF   |
| C <sub>BID</sub> | 3.3V Bi-directional Capacitance |      | 4.8  |      | pF   |

# 4.4 PIN Pull-up/Pull-down Description

| PIN Name    | Туре | Driving<br>Current | Pull-<br>Up | Pull-<br>Down | Schmitt<br>Trigger | 5V I/O<br>Tolerant | Slew<br>Rate | Description   |
|-------------|------|--------------------|-------------|---------------|--------------------|--------------------|--------------|---------------|
| PWRGOOD     | I    |                    | 0           | 0             | 1                  | Y                  |              |               |
| XIN         | I    |                    |             |               |                    |                    |              | Note6         |
| XOUT        | 0    |                    |             |               |                    |                    |              | Note6         |
| PCICLK      | 0    |                    |             |               |                    |                    |              | Note7         |
| PCIRST_n    | 0    |                    | -           |               | -                  |                    |              | Note7         |
| AD[31:0]    | 10   |                    | 1           | 0             | -                  |                    |              | Note7 & Note8 |
| C/BE_n[3:0] | 10   |                    | 1           | 0             |                    |                    |              | Note7 & Note8 |
| FRAME_n     | 10   |                    | 1           | 0             | -                  |                    |              | Note7 & Note8 |
| TRDY_n      | 10   |                    | 1           | 0             |                    |                    |              | Note7 & Note8 |
| IRDY_n      | 10   |                    | 1           | 0             |                    |                    |              | Note7 & Note8 |
| STOP_n      | 10   |                    | 1           | 0             |                    |                    |              | Note7 & Note8 |



# R8610 32-Bit RISC MicroController

| PIN Name                          | Туре | Driving<br>Current | Pull-<br>Up | Pull-<br>Down | Schmitt<br>Trigger | 5V I/O<br>Tolerant | Slew<br>Rate | Description   |
|-----------------------------------|------|--------------------|-------------|---------------|--------------------|--------------------|--------------|---------------|
| DEVSEL_n                          | 10   |                    | 1           | 0             |                    |                    |              | Note7 & Note8 |
| PAR                               | 10   |                    | 1           | 0             |                    |                    |              | Note7 & Note8 |
| INTA_n/GPIO19                     | 10   |                    | Note4       | 0             |                    |                    |              | Note7 & Note9 |
| INTB_n/GPIO20                     | 10   |                    | Note4       | 0             |                    |                    |              | Note7 & Note9 |
| INTC_n/GPIO21                     | 10   |                    | Note4       | 0             |                    |                    |              | Note7 & Note9 |
| INTD_n/GPIO22                     | 10   |                    | Note4       | 0             |                    |                    |              | Note7 & Note9 |
| PREQ_n[2:0]/GPIO25~GPIO23         | 10   |                    | Note4       | 0             |                    |                    |              | Note7 & Note9 |
| PGNT_n[2:0]/GPIO28~GPIO26         | 10   |                    | Note4       | 0             |                    | -                  |              | Note7 & Note9 |
| SDRAMCLK                          | 0    | Note1              | 0           | 0             | 0                  | Ν                  | Note2        |               |
| MA[1:0]/SA[1:0]/<br>ROMSL[1:0]    | 10   | Note1              | 0           | 0             | 0                  | Y                  | F            |               |
| MA[4:2]/SA[4:2]/<br>HCKSL[2:0]    | Ю    | Note1              | 0           | 0             | 0                  | Y                  | F            |               |
| MA[5]/SA[5]/<br>HCKSL[3]          | Ю    | Note1              | 0           | 0             | 0                  | Y                  | F            |               |
| MA[6]/SA[6]/DLLEN                 | 10   | Note1              | 0           | 0             | 0                  | Y                  | F            |               |
| MA[12:7]/SA[12:7]/<br>STRAP[12:7] | Ю    | Note1              | 0           | 1             | 0                  | Y                  | F            |               |
| MD[15:0]/XD[15:0]                 | 10   | Note1              | 0           | 0             | 0                  | Y                  | F            |               |
| BA0/MEMR_n                        | 0    | Note1              |             |               |                    | Y                  | Note2        |               |
| BA1/MEMW_n                        | 0    | Note1              |             |               |                    | Y                  | Note2        |               |
| DQM[1:0]                          | 0    | Note1              |             |               |                    | Ν                  | Note2        |               |
| CS_n[1:0]                         | 0    | Note1              |             |               |                    | Ν                  | Note2        |               |
| RAS n                             | 0    | Note1              |             |               |                    | Ν                  | Note2        |               |
| <br>CAS_n                         | 0    | Note1              |             |               |                    | N                  | Note2        |               |
| <br>WE_n                          | 10   | Note1              | 1           | 0             | 0                  | N                  | Note2        |               |
| ROMCS n                           | 0    | Note3              |             |               |                    | Y                  | Note2        |               |
| SA[23:13]/ GPIO39~GPIO29          | 10   | 8mA                | Note4       | 0             | 0                  | N                  | F            |               |
| LAD[3:0]/GPIO3~GPIO0]             | 10   |                    | Note4       | 0             |                    |                    |              | Note7         |
| LFRAME n/GPIO4                    | 10   |                    | Note4       | 0             |                    |                    |              | Note7         |
| LDRQ n/GPIO5                      | 10   |                    | Note4       | 0             |                    |                    |              | Note7         |
| IRQSER/GPI06                      | 10   |                    | Note4       | 0             |                    |                    |              | Note7         |
| TXD0 0/GPIO41                     |      |                    |             |               |                    |                    |              |               |
| TXD0 1/GPIO42                     | 10   | 10                 | N           | •             | •                  | Ň                  | ~            |               |
| TXD0_2/GPIO43                     | 10   | 12mA               | Note4       | 0             | 0                  | Y                  | S            |               |
| TXD0_3/GPIO44                     |      |                    |             |               |                    |                    |              |               |
| TXC0/GPIO40                       | 10   | 12mA               | Note4       | 0             | 0                  | Y                  | S            |               |
| RXC0/GPIO46                       | 10   | 12mA               | Note4       | 0             | 0                  | Y                  | S            |               |
| RXDV0/GPIO47                      | 10   | 12mA               | Note4       | 0             | 0                  | Y                  | S            |               |
| RXD0_0/GPIO48                     |      |                    |             |               |                    |                    |              |               |
| RXD0_1/GPIO49                     | 10   | 12mA               | Note4       | 0             | 0                  | Y                  | S            |               |
| RXD0_2/GPIO50                     | 10   | 12110 (            | NOICH       | 0             | 0                  | I                  | 0            |               |
| RXD0_3/GPIO51                     |      |                    |             |               |                    |                    |              |               |
| COL0/GPIO52                       | 10   | 12mA               | Note4       | 0             | 0                  | Y                  | S            |               |
| TXEN0/GPIO45                      | 10   | 12mA               | Note4       | 0             | 0                  | Y                  | S            |               |
| TXD1_0                            |      |                    |             |               |                    |                    |              |               |
| TXD1_1                            | 0    | 12mA               |             |               |                    | Y                  | s            |               |
| TXD1_2                            |      |                    |             |               |                    |                    |              |               |
| TXD1_3                            | 10   | 10~^               | ^           |               |                    | V                  |              |               |
| TXEN1                             | 10   | 12mA               | 0           | 0             | 0                  | Y                  | S            |               |
| TXC1                              | 1    |                    | 0           | 0             | 1                  | Y                  |              |               |



# R8610 32-Bit RISC MicroController

| PIN Name             | Туре | Driving<br>Current | Pull-<br>Up | Pull-<br>Down | Schmitt<br>Trigger | 5V I/O<br>Tolerant | Slew<br>Rate | Description |
|----------------------|------|--------------------|-------------|---------------|--------------------|--------------------|--------------|-------------|
| RXC1                 | I    |                    | 0           | 0             | 1                  | Y                  |              |             |
| RXD1_0               |      |                    |             |               |                    |                    |              |             |
| RXD1_1               | 10   | 12mA               | 0           | 0             | 0                  | Y                  | S            |             |
| RXD1_2               | 10   | 121117             | 0           | 0             | 0                  | T                  | 3            |             |
| RXD1_3               |      |                    |             |               |                    |                    |              |             |
| RXDV1                | IO   | 12mA               | 0           | 0             | 0                  | Y                  | S            |             |
| COL1                 | Ю    | 12mA               | 0           | 0             | 0                  | Y                  | S            |             |
| MDC/PCI_REVERSE      | IO   | 12mA               | 0           | 1             | 0                  | Y                  | S            |             |
| MDIO                 | IO   | 12mA               | 0           | 0             | 0                  | Y                  | S            |             |
| SIN/GPIO7            | Ю    | Note3              | Note4       | 0             | 0                  | Y                  | Note5        |             |
| SOUT/GPIO8           | Ю    | Note3              | Note4       | 0             | 0                  | Y                  | Note5        |             |
| RTS_n/TDO/GPIO9      | IO   | Note3              | Note4       | 0             | 0                  | Y                  | Note5        |             |
| DTR_n/GPIO10         | Ю    | Note3              | Note4       | 0             | 0                  | Y                  | Note5        |             |
| CTS_n/TMS/GPIO11     | Ю    | Note3              | Note4       | 0             | 0                  | Y                  | Note5        |             |
| DSR_n/TCK/GPIO12     | 10   | Note3              | Note4       | 0             | 0                  | Y                  | Note5        |             |
| DCD_n/TDI/GPIO13     | Ю    | Note3              | Note4       | 0             | 0                  | Y                  | Note5        |             |
| RI_n/GPIO14          | Ю    | Note3              | Note4       | 0             | 0                  | Y                  | Note5        |             |
| RTCAS/GPIO15         | Ю    | Note3              | Note4       | 0             | 0                  | Y                  | S            |             |
| RTCRD/GPIO16         | 10   | Note3              | Note4       | 0             | 0                  | Y                  | S            |             |
| RTCWR/GPI017         | Ю    | Note3              | Note4       | 0             | 0                  | Y                  | S            |             |
| IRQ8_n/GPIO18        | Ю    | Note3              | Note4       | 0             | 0                  | Y                  | S            |             |
| REXT                 | I    |                    |             |               |                    |                    |              |             |
| OVRCUR_n             | I    |                    | 1           | 0             | 1                  | Y                  |              |             |
| DP0, DM0             | Ю    |                    |             |               |                    |                    |              |             |
| DP1, DM1             | IO   |                    |             |               |                    |                    |              |             |
| A20GATE_n/<br>GPIO54 | Ю    | 16mA               | Note4       | 0             | 0                  | Y                  | F            |             |
| KBRST_n/<br>GPI055   | ю    | 16mA               | Note4       | 0             | 0                  | Y                  | F            |             |
| SPEAKER/GPI053       | IO   | Note3              | Note4       | 0             | 0                  | Y                  | S            |             |
| CLK25MOUT/<br>GPIO56 | Ю    | 16mA               | Note4       | 0             | 0                  | Y                  | F            |             |
| XCS1_n/GPIO57        | Ю    | 16mA               | Note4       | 0             | 0                  | Y                  | F            |             |
| XCS2_n/GPIO58        | IO   | 16mA               | Note4       | 0             | 0                  | Y                  | F            |             |

Note 1: Programmable, default is 16mA.

- Note 2: Programmable, default is Fast.
- Note 3: Programmable, default is 4mA.
- Note 4: Programmed by the GPIO mode & dir. Register.
- Note 5: Programmable, default is slow.
- **Note 6:** The pins never in the driving current, pull-up, pull-down, schimitt trigger, I/O pad, and slew rate status are not shown in the above table.
- Note 7: A PCI type IO pad.
- Note 8: This Pin is programmable.
- Note 9: The Pulldown defaults to '0' but is programmable.

# 5. System Address Map

The R8610 MicroController supports 4 Gbytes of addressable memory space and 64 Kbytes of addressable I/O space. In order to be compatible with PC/AT system, the lower 1 Mbytes of this addressable memory is divided into regions which can be individually controlled with programmable attributes such as disable, read/write, write only, or read only (see Chapter 11, Register Description section for details on attribute programming).

# 5.1 <u>Memory Address Ranges</u>

Figure 5-1 represents R8610 mircoprocessor memory address map. It shows the main memory regions defined and supported by the R8610. At the highest level, the address space is divided into two main conceptual regions. One is the 0–1-Mbyte DOS compatibility region and the other is 1-Mbyte to 4-Gbyte extended memory region. The R8610 processor supports several main memory sizes from 2MB to 128MB. The main memory type and size in the system will be auto-detected by the system BIOS.



Figure 5-1. Memory Address Map

# 5.1.1 Dos Compatibility Region

The first region of memory is called the Dos Compatibility Region because it is defined for early PC. This area is divided into the following address regions:

- 0 640-Kbyte DOS Area
- 640 768-Kbyte Video Buffer Area
- 768 896-Kbyte in 16-Kbyte sections (total of 8 sections) Expansion Area
- 896 960-Kbyte in 16-Kbyte sections (total of 4 sections) Extended System BIOS Area
- 960-Kbyte 1-Mbyte Memory (BIOS Area) System BIOS Area

From 640 Kbytes – 1Mbytes: it can be divided into fourteen ranges which can be enabled or disabled independently for both read and write. These regions can also be mapped to either main DRAM or PCI by system BIOS. (See A/B Page and SMM Range Register and Memory Attribute Register in Section 3, Chapter 11.)

#### DOS Area (00000 – 9FFFh)

The DOS area (00000h – 9FFFFh) is 640 Kbytes in size. It is always mapped to the main memory controlled by the R8610 MicroController.

#### Video Buffer Area (A0000 – BFFFFh)

The 128-Kbyte graphics adapter memory region is normally mapped to a video device on the PCI bus (typically VGA controller). This area is controlled by the A/B Page and SMM Range Register. It can be mapped to either main DRAM or PCI for both read and write command.

This Region is also the default region for SMM space.

#### ISA Expansion Area (C0000 – DFFFFh)

This 128-Kbyte ISA Expansion region is divided into eight 16-Kbyte segments. Each segment can be assigned one of four Read/Write states: read-only, write-only, read/write, or disabled. Typically, these blocks are mapped through the PCI bridge to ISA space. Memory that is disabled is not remapped.

#### Extended System BIOS Area (E0000 – EFFFFh)

This 64-Kbyte area is divided into four 16-Kbyte segments. Each segment can be assigned independent read and write attributes so it can be mapped either to main DRAM or to PCI. Typically, this area is used for RAM or ROM. Memory that is disabled is not remapped.

#### System BIOS Area (F0000 – FFFFFh)

This area is a single 64-Kbyte segment that can be assigned read and write attributes. It is by default (after reset) read/write disabled and cycles are forwarded to PCI. By manipulating the read/write attributes, the R8610 MicroController can "shadow" BIOS into main memory. Memory that is disabled is not remapped.

# 5.1.2 Extended Memory Region

This memory region covers 10\_0000h (1 Mbytes) to FFFF\_FFFh (4 Gbytes minus 1) address range and is divided into the following regions:

- DRAM memory from 1 Mbytes to a top of memory (maximum: 128 Mbytes)
- PCI Memory space from the top of memory to 4 Gbytes
- APIC Configuration Space from FEC00000h (4 Gbytes minus 20 Mbytes) to FEC0\_FFFFh
- High BIOS area from 4 Gbytes to 4 Gbytes minus 2 Mbytes

#### Main DRAM Address Range (0010\_0000h to Top of Main Memory)

The address range from 1 Mbytes to the top of main memory is mapped to the main memory address range controlled by the R8610 MicroController. All accesses to addresses within this range are forwarded to the main memory.

#### PCI Memory Address Range (Top of Main Memory to 4 Gbytes)

The address range from the top of main DRAM to 4 Gbytes is normally mapped to PCI. The PMC forwards all accesses within this address range to PCI.

Within this address range, there are two sub-ranges defined as APIC Configuration Space and High BIOS Address Range.

#### 1. High BIOS Area (FFE0\_0000 – FFFF\_FFFh)

The top 2 Mbytes of the Extended Memory Region is reserved for System BIOS (High BIOS), extended BIOS for PCI devices, and the A20 alias of the system BIOS. The CPU begins execution from the High BIOS after reset. This region is mapped to the PCI so that the upper subset of this region is aliased to 16 Mbytes minus 256 Kbytes range. The actual address space required for the BIOS is less than 2 Mbytes. However, the minimum CPU MTRR range for this region is 2 Mbytes. Thus, the full 2 Mbytes must be considered.

# 5.2 <u>Memory Shadowing</u>

Any block of memory that can be designated as read only or write only can be "shadowed" into PMC DRAM memory. Typically, this is done to allow ROM code to execute more rapidly out of main DRAM. ROM is used as read only during the copy process while DRAM at the same time is designated write only. After copying, the DRAM is designated read only so that ROM is shadowed. CPU bus transactions are routed accordingly. The PMC does not respond to transactions originating from PCI or ISA masters and targeted at shadowed memory blocks.

# 5.3 I/O Address Space

The R8610 positively decodes accesses to all internal registers, including PCI configuration registers (CF8h and CFCh), PC/AT Compatible IO registers (8237, 8254 & 8259), and all relocatable IO space registers (UART).

# 6. Operation Mode

The R8610 MicroController supports three operation modes: protected mode, real-address mode, and system management mode. The operation mode determines which instructions and architectural features are accessible:

• **Protected mode.** In this mode all instructions and architectural features are available, providing the highest performance and capability. This is the recommended mode for all new applications and operating systems.

Among the capabilities of protected mode is the ability to directly execute "real-address mode" 8086 software in a protected, multitasking environment. This feature is called virtual-8086 mode, although it is not actually a processor mode. Virtual-8086 mode is actually a protected mode attribute that can be enabled for any task.

• **Real-address mode.** It provides the programming environment of the Intel 8086 processor with a few extensions (such as the ability to switch to protected or system management mode). The processor is placed in real-address mode following power-up or a reset.



# 7. Register Sets

The R8610 contains three sets of software accessible registers (Core registers, I/O Mapped registers and Configuration registers).

# 7.1 Core Registers

The R8610 MicroController provides 24 Core Registers. The 16 Base Architecture Registers (General-purpose Registers, Segment Registers, Flags Register and Instruction Pointer) are used in general system and application programming. The other 8 system-level registers (Control Registers and System Address Registers) can be used only by system-level programs. These registers are shown below. The details will be described in Register Description in Chapter 11.

## 7.1.1 <u>General-Purpose Registers</u>

| Register Name | Page |
|---------------|------|
| EAX           |      |
| EBX           |      |
| ECX           |      |
| EDX           |      |
| ESI           |      |
| EDI           |      |
| EBP           |      |
| ESP           |      |

## 7.1.2 <u>Segment Registers</u>

| Register Name               | Page |
|-----------------------------|------|
| Code Segment Register – CS  |      |
| Stack Segment Register – SS |      |
| Data Segment Register – DS  |      |
| Data Segment Register – ES  |      |
| Data Segment Register – FS  |      |
| Data Segment Register – GS  |      |

# 7.1.3 Flags Register

| Register Name  | Page |
|----------------|------|
| Flags Register |      |

### 7.1.4 Instruction Pointer

| Register Name       | Page |
|---------------------|------|
| Instruction Pointer |      |

# 7.1.5 Control Registers

| Register Name      | Page |
|--------------------|------|
| Control Register 0 |      |
| Control Register 1 |      |
| Control Register 2 |      |
| Control Register 3 |      |

## 7.1.6 System Address Registers

| Register Name                       | Page |
|-------------------------------------|------|
| Global Descriptor Table Register    |      |
| Interrupt Descriptor Table Register |      |
| Local Descriptor Table Register     |      |
| Task State Segment Register         |      |

# 7.2 I/O Mapped Registers

The I/O Mapped Registers are usually used to control the R8610 integrated peripherals or to store the peripherals' data, addresses and statuses. We divided these I/O Mapped Registers into fourteen subsets, including PCI Configurations Registers, Slave DMA Controller Registers, DMA Page Registers, Master DMA Controller Registers, DMA High Page Registers, Timer / Counter Registers, Interrupt Edge/Level Control Registers, NMI Status and Control Register, CMOS Memory & RTC Registers, System Control Register and Serial Port Registers. These registers have fixed IO Address except Serial Port Registers.

The base address of Serial Port Registers is programmable via the Internal UART IO Address Register in R8610\_SB Configuration Space Register.

These registers are listed as below. In Chapter 11, Register Description will show more detailed information about these registers.

## 7.2.1 PCI Configuration Registers

| IO Address  | Register Name                      | Page |
|-------------|------------------------------------|------|
| 0CFBh-0CF8h | PCI Configuration Address Register |      |
| 0CFFh-0CFCh | PCI Configuration Data Register    |      |

### 7.2.2 Slave DMA Controller Registers

| IO Address | Register Name                                       | Page |
|------------|-----------------------------------------------------|------|
| 00h        | Slave DMA Channel 0 Base/Current Address            |      |
| 01h        | Slave DMA Channel 0 Base/Current Count              |      |
| 02h        | Slave DMA Channel 1 Base/Current Address            |      |
| 03h        | Slave DMA Channel 1 Base/Current Count              |      |
| 04h        | Slave DMA Channel 2 Base/Current Address            |      |
| 05h        | Slave DMA Channel 2 Base/Current Count              |      |
| 06h        | Slave DMA Channel 3 Base/Current Address            |      |
| 07h        | Slave DMA Channel 3 Base/Current Count              |      |
| 08h        | Slave DMA Read Status / Write Command               |      |
| 09h        | Slave DMA Read Request / Write Request              |      |
| 0Ah        | Slave DMA Read Command / Write Single Mask          |      |
| 0Bh        | Slave DMA Read / Write Mode                         |      |
| 0Ch        | Slave DMA Set / Clear First / Last Clear F/F        |      |
| 0Dh        | Slave DMA Read Temporary / Master Clear             |      |
| 0Eh        | Slave DMA Clear Mode Register. Counter / Clear Mask |      |
| 0Fh        | Slave DMA Write Mask                                |      |

## 7.2.3 DMA Page Registers

| IO Address | Register Name            | Page |
|------------|--------------------------|------|
| 81h        | DMA Page – DMA Channel 2 |      |
| 82h        | DMA Page – DMA Channel 3 |      |
| 83h        | DMA Page – DMA Channel 1 |      |
| 87h        | DMA Page – DMA Channel 0 |      |
| 89h        | DMA Page – DMA Channel 6 |      |
| 8Ah        | DMA Page – DMA Channel 7 |      |
| 8Bh        | DMA Page – DMA Channel 5 |      |

# 7.2.4 Master DMA Controller Registers

| IO Address | Register Name                                        | Page |
|------------|------------------------------------------------------|------|
| C0h        | Master DMA Channel 4 Base/Current Address            |      |
| C2h        | Master DMA Channel 4 Base/Current Count              |      |
| C4h        | Master DMA Channel 5 Base/Current Address            |      |
| C6h        | Master DMA Channel 5 Base/Current Count              |      |
| C8h        | Master DMA Channel 6 Base/Current Address            |      |
| CAh        | Master DMA Channel 6 Base/Current Count              |      |
| CCh        | Master DMA Channel 7 Base/Current Address            |      |
| CEh        | Master DMA Channel 7 Base/Current Count              |      |
| D0h        | Master DMA Read Status / Write Command               |      |
| D2h        | Master DMA Read Request / Write Request              |      |
| D4h        | Master DMA Read Command / Write Single Mask          |      |
| D6h        | Master DMA Read / Write Mode                         |      |
| D8h        | Master DMA Set / Clear First / Last Clear F/F        |      |
| DAh        | Master DMA Read Temporary / Master Clear             |      |
| DCh        | Master DMA Clear Mode Register. Counter / Clear Mask |      |
| DEh        | Master DMA Read / Write Mask                         |      |

# 7.2.5 DMA High Page Registers

| IO Address | Register Name                  | Page |
|------------|--------------------------------|------|
| 481h       | DMA High Page – DMA Channel 2. |      |
| 482h       | DMA High Page – DMA Channel 3. |      |
| 483h       | DMA High Page – DMA Channel 1. |      |
| 487h       | DMA High Page – DMA Channel 0. |      |
| 489h       | DMA High Page – DMA Channel 6. |      |
| 48Ah       | DMA High Page – DMA Channel 7. |      |
| 48Bh       | DMA High Page – DMA Channel 5. |      |

## 7.2.6 <u>Timer/Counter Registers</u>

| IO Address | Register Name           | Page |
|------------|-------------------------|------|
| 40h        | Timer / Counter 0 Count |      |
| 41h        | Timer / Counter 1 Count |      |
| 42h        | Timer / Counter 2 Count |      |
| 43h        | Timer / Counter Control |      |

# 7.2.7 <u>Master Interrupt Controller Registers</u>

| IO Address | Register Name                                                | Page |
|------------|--------------------------------------------------------------|------|
| 20h        | Master Interrupt Control/Interrupt Service/Interrupt Command |      |
| 21h        | Master Interrupt Mask                                        |      |

#### 7.2.8 Slave Interrupt Controller Registers

| IO Address | Register Name                                               | Page |
|------------|-------------------------------------------------------------|------|
| A0h        | Slave Interrupt Request/Interrupt Service/Interrupt Command |      |
| A1h        | Slave Interrupt Mask                                        |      |

#### 7.2.9 Interrupt Edge/Level Control Registers

| IO Address | Register Name                       | Page |
|------------|-------------------------------------|------|
| 4D0h       | Master Interrupt Edge/Level Control |      |
| 4D1h       | Slave Interrupt Edge/Level Control  |      |

#### 7.2.10 NMI Status and Control Register

| IO Address | Register Name                   | Page |
|------------|---------------------------------|------|
| 61h        | NMI Status and Control Register |      |

#### 7.2.11 CMOS Memory & RTC Registers

| IO Address | Register Name                | Page |
|------------|------------------------------|------|
| 70h        | CMOS Memory Address Register |      |
| 71h        | CMOS Memory Data Register    |      |

#### 7.2.12 System Control Register

| IO Address | Register Name  | Page |
|------------|----------------|------|
| 92h        | System Control |      |

#### 7.2.13 Serial Port Registers

(Base Address Refers to the Register of index 57h-54h, IDSEL = AD18/SB of PCI Configuration Register)

| IO Address | Register Name                                       | Page |
|------------|-----------------------------------------------------|------|
| BA + 0h    | Transmit/Receive Data Buffer (DLAB=0)               |      |
| BA + 0h    | LSB of Baud Rate Generator Divisor Latches (DLAB=1) |      |
| BA + 1h    | Interrupt Enable Register (DLAB=0)                  |      |
| BA + 1h    | MSB of Baud Rate Generator Divisor Latches (DLAB=1) |      |
| BA + 2h    | Interrupt Identification Register                   |      |
| BA + 2h    | FIFO Control Register                               |      |
| BA + 3h    | Line Control Register                               |      |
| BA + 4h    | Modem Control Register                              |      |
| BA + 5h    | Line Status Register                                |      |
| BA + 6h    | Modem Status Register                               |      |
| BA + 7h    | Scratchpad Register                                 |      |

# 7.2.14 Fast Ethernet MAC Registers

(Base Address Refers to the Register of index 10h/14h, IDSEL = AD19/AD20 of PCI Configuration Register)

| IO Address | Register Name                                                                                     | Mnemonic         | Page     |
|------------|---------------------------------------------------------------------------------------------------|------------------|----------|
| BA + 00h   | MAC Control Register 0                                                                            | MCR0             |          |
| BA + 04h   | MAC Control Register 1                                                                            | MCR1             |          |
| BA + 08h   | MAC Bus Control Register                                                                          | MBCR             |          |
| BA + 0Ch   | MAC TX Interrupt Control Register                                                                 | MTICR            |          |
| BA + 10h   | MAC RX Interrupt Control Register                                                                 | MRICR            |          |
| BA + 14h   | MAC TX Poll Command Register                                                                      | MTPR             |          |
| BA + 18h   | MAC RX Buffer Size Register                                                                       | MRBSR            |          |
| BA + 1Ah   | MAC RX Descriptor Control Register                                                                | MRDCR            |          |
| BA + 1Ch   | MAC Last Status Register                                                                          | MLSR             |          |
| BA + 20h   | MAC MDIO Control Register                                                                         | MMDIO            |          |
| BA + 24h   | MAC MDIO Read Data Register                                                                       | MMRD             |          |
| BA + 28h   | MAC MDIO Write Data Register                                                                      | MMWD             |          |
| BA + 2Ch   | MAC TX Descriptor Start Address 0 Register                                                        | MTDSA0           |          |
| BA + 30h   | MAC TX Descriptor Start Address 1 Register                                                        | MTDSA1           | 1        |
| BA + 34h   | MAC RX Descriptor Start Address 0 Register                                                        | MRDSA0           | 1        |
| BA + 34h   | MAC RX Descriptor Start Address 1 Register                                                        | MRDSAU           | <u> </u> |
| BA + 3Ch   | MAC INT Status Register                                                                           | MISR             |          |
| BA + 40h   | MAC INT Enable Register                                                                           | MIER             | 1        |
| BA + 44h   | MAC Event Counter INT Status Register                                                             | MECISR           | 1        |
| BA + 48h   | MAC Event Counter INT Enable Register                                                             | MECIER           | -        |
| BA + 50h   | MAC Successfully Received Packet Counter Register                                                 | MRCNT            |          |
| BA + 52h   | MAC Event Counter 0 Register                                                                      | MECNTO           |          |
| BA + 54h   | MAC Event Counter 1 Register                                                                      | MECNT1           |          |
| BA + 56h   | MAC Event Counter 2 Register                                                                      | MECNT2           |          |
| BA + 58h   | MAC Event Counter 3 Register                                                                      | MECNT2<br>MECNT3 |          |
| BA + 5Ah   | MAC Successfully Transmit Packet Counter Register                                                 | MECNTS           |          |
| BA + 5Ch   | MAC Event Counter 4 Register                                                                      | MECNT4           |          |
| BA + 5Eh   | MAC Pause Frame Counter Register                                                                  | MPCNT            |          |
| BA + 60h   | MAC Hash Table Word 0                                                                             | MAR0             |          |
| BA + 62h   | MAC Hash Table Word 1                                                                             | MARU<br>MAR1     | -        |
|            | MAC Hash Table Word 1                                                                             | MAR1<br>MAR2     |          |
| BA + 64h   |                                                                                                   | MAR2<br>MAR3     |          |
| BA + 66h   | MAC Hash Table Word 3                                                                             |                  |          |
| BA + 68h   | MAC Multicast Address first two bytes Register<br>MAC Multicast Address second two bytes Register | MIDOL            |          |
| BA + 6Ah   | MAC Multicast Address second two bytes Register                                                   | MIDOM            |          |
| BA + 6Ch   | MAC Multicast Address last two bytes Register                                                     | MID0H            |          |
| BA + 70h   |                                                                                                   | MID1L<br>MID1M   |          |
| BA + 72h   | MAC Multicast Address second two bytes Register<br>MAC Multicast Address last two bytes Register  |                  |          |
| BA + 74h   |                                                                                                   | MID1H            |          |
| BA + 78h   | MAC Multicast Address first two bytes Register                                                    | MID2L            |          |
| BA + 7Ah   | MAC Multicast Address second two bytes Register                                                   | MID2M            |          |
| BA + 7Ch   | MAC Multicast Address last two bytes Register                                                     | MID2H            | <u> </u> |
| BA + 80h   | MAC Multicast Address first two bytes Register                                                    | MID3L            |          |
| BA + 82h   | MAC Multicast Address second two bytes Register                                                   | MID3M            |          |
| BA + 84h   | MAC Multicast Address last two bytes Register                                                     | MID3H            |          |
| BA + 88h   | MAC PHY Status Change Configuration Register                                                      | MPSCCR           |          |
| BA + 8Ah   | MAC PHY Status Register                                                                           | MPSR             |          |
| BA + BEh   | MAC Identifier Register                                                                           | MACID            |          |

# 7.2.15 USB 1.1 OHCI Operation Registers

(Base Address Refers to the Register of index 10hh, IDSEL = AD21, Function 0 of PCI Configuration Register)

| IO Address | Register Name                  | Mnemonic | Page |
|------------|--------------------------------|----------|------|
| BA + 00h   | HC Revision Register           |          |      |
| BA + 04h   | HC Control Register            |          |      |
| BA + 08h   | HC Command Status Regster      |          |      |
| BA + 0Ch   | HC Interrupt Status Regster    |          |      |
| BA + 10h   | HC Interrupt Enable Regster    |          |      |
| BA + 14h   | HC Interrupt Disable Register  |          |      |
| BA + 18h   | HC HCCA Register               |          |      |
| BA + 1Ch   | HC Period Current ED Regster   |          |      |
| BA + 20h   | HC Control Head ED Regster     |          |      |
| BA + 24h   | HC Control Current ED Register |          |      |
| BA + 28h   | HC Bulk Head ED Register       |          |      |
| BA + 2Ch   | HC Bulk Current ED Register    |          |      |
| BA + 30h   | HC Done Head Register          |          |      |
| BA + 34h   | HC Fm Interval Register        |          |      |
| BA + 38h   | HC Fm Remaining Register       |          |      |
| BA + 3Ch   | HC Fm Number Register          |          |      |
| BA + 40h   | HC Periodic Start Register     |          |      |
| BA + 44h   | HC LS Threshold Register       |          |      |
| BA + 48h   | HC Rh Descriptor A Register    |          |      |
| BA + 4Ch   | HC Rh Descriptor B Register    |          |      |
| BA + 50h   | HC Rh Status Register          |          |      |
| BA + 54h   | HC Rh Port Status [1] Register |          |      |
| BA + 58h   | HC Rh PortStatus [2] Register  |          |      |
| BA + 100h  | HC eControl Register           |          |      |
| BA + 104h  | HC eInput Register             |          |      |
| BA + 108h  | HC eOutput Register            |          |      |
| BA + 10Ch  | HC eStatus Register            |          |      |

# 7.2.16 USB 2.0 EHCI Operation Registers

(Base Address Refers to the Register of index 10h, IDSEL = AD21, Function 1 of PCI Configuration Register)

| IO Address     | Register Name                              | Mnemonic         | Page |
|----------------|--------------------------------------------|------------------|------|
| BA + 00h       | Capability Register Length Register        | CAPLENGTH        |      |
| BA + 03h – 02h | USB1.1 Port Override Register              | HCIVERSION       |      |
| BA + 07h – 04h | Structural Parameters Register             | HCSPARAMS        |      |
| BA + 0Bh – 08h | Capability Parameters Register             | HCCPARAMS        |      |
| BA + 23h – 20h | USB2.0 Command Register                    | USB2CMD          |      |
| BA + 27h – 24h | USB2.0 Status Register                     | USB2STS          |      |
| BA + 2Bh – 28h | USB2.0 Interrupt Enable Register           | USB2INTR         |      |
| BA + 2Fh – 2Ch | USB2.0 Frame Index register                | FRINDEX          |      |
| BA + 37h – 34h | Periodic Frame List Base Address Register  | PERIODICLISTBASE |      |
| BA + 3Bh – 38h | Current Asynchronous List Address Register | ASYNCLISTADDR    |      |
| BA + 63h – 60h | Configured Flag Register                   | CONFIGFLAG       |      |
| BA + 6Bh – 64h | Port Status/Control Register               | PORTSC(0-1)      |      |

# 7.3 Configuration Space Registers

The R8610 MicroController integrated two PCI base bridges – Host-to-PCI bridge, ISA-to-PCI bridge, two MACs, one USB1.1 host and one USB2.0 host. These two bridges contain their own PCI Configuration Space. Configuration Space Registers reside in PCI Configuration Space and specify PCI configuration, DRAM configuration, operating parameters, and optional system features.

During hardware reset, the R8610 sets its internal configuration registers to predetermine default states. The default state represents the minimum functionality feature set required to successfully bring up the system. Hence, it does not represent the optimal system configuration. It is the responsibility of the system initialization software (usually BIOS) to properly determine the DRAM configurations, operating parameters and optional system features that are applicable, and to program the registers accordingly.

| 7.3.1 | R8610 NB Configuration Space Registers (IDSEL = AD11/Device 0) |
|-------|----------------------------------------------------------------|
|       |                                                                |

| Offset (HEX) | Register Name                                | Page |
|--------------|----------------------------------------------|------|
| 01h – 00h    | Vendor ID Register                           |      |
| 03h – 02h    | Device ID Register                           |      |
| 05h – 04h    | Command Register                             |      |
| 07h – 06h    | Status Register                              |      |
| 08h          | Revision ID Register                         |      |
| 0Bh – 09h    | Class Code Register                          |      |
| 0Eh          | Header Type Register                         |      |
| 2Dh – 2Ch    | Subsystem Vendor ID Register                 |      |
| 2Fh – 2Eh    | Subsystem Device ID Register                 |      |
| 53h – 50h    | Non-Cache Region Register #1 for L1          |      |
| 57h – 40h    | Non-Cache Region Register #2 for L1          |      |
| 5Bh – 58h    | Non-Cache Region Register #3 for L1          |      |
| 5Fh – 5Ch    | Non-Cache Region Register #4 for L1          |      |
| 66h          | Memory Clock Phase Selection Register        |      |
| 69h – 68h    | Memory Timing Register                       |      |
| 6Bh – 6Ah    | Memory Control Register                      |      |
| 6Dh – 6Ch    | Memory Bank Register                         |      |
| 6E           | Memory Read/Write Reorder & Refresh Register |      |
| 83h          | A/B Page and SMM Range Register              |      |
| 87h – 84h    | Memory Attribute Register                    |      |
| 93h – 90h    | Customer ID Register                         |      |
| 97h – 94h    | Spare 1 Register                             |      |
| 9Bh – 98h    | Spare 2 Register                             |      |
| 9Fh – 9Ch    | Spare 3 Register                             |      |
| C3h – C0h    | USB PHY Control and BIST Control Register    |      |

# 7.3.2 <u>R8610 SB Configuration Space Registers (IDSEL = AD18/Device 7)</u>

| Offset (HEX) | Register Name                            | Page |
|--------------|------------------------------------------|------|
| 01h – 00h    | Vendor ID Register                       |      |
| 03h – 02h    | Device ID Register                       |      |
| 05h – 04h    | Command Register                         |      |
| 07h – 06h    | Status Register                          |      |
| 08h          | Revision ID Register                     |      |
| 0Bh – 09h    | Class Code Register                      |      |
| 0Eh          | Header Type Register                     |      |
| 2Dh – 2Ch    | Subsystem Vendor ID Register             |      |
| 2Fh – 2Eh    | Subsystem Device ID Register             |      |
| 40h          | Boot Strapping Register                  |      |
| 41h          | Write Lock and LPC Control Register      |      |
| 43h – 42h    | Flash ROM Chip Select Control Register   |      |
| 46h – 44h    | Watchdog Timer Control                   |      |
| 4Bh – 48h    | General-Purpose I/O Control Register I   |      |
| 4Fh – 4Ch    | General-Purpose I/O Data Register I      |      |
| 50h          | Serial IRQ (IRQSER) Control Register     |      |
| 51h          | LPC Control Register                     |      |
| 52h          | LPC Legacy COM Port Decoding Register    |      |
| 53h          | Internal UART Control Register           |      |
| 57h – 54h    | Internal UART IO Address Register        |      |
| 5Ah – 58h    | PCI Interrupt Routing Table Register     |      |
| 5Fh – 5Ch    | Buffer Strength Control Register I       |      |
| 63h – 60h    | Buffer Strength Control Register II      |      |
| 67h – 64h    | Buffer Strength Control Register III     |      |
| 6Bh – 68h    | Buffer Strength Control Register IV      |      |
| 80h          | Internal Peripherals Test Mode Register  |      |
| 87h – 84h    | General-Purpose I/O Control Register II  |      |
| 8Bh – 88h    | General-Purpose I/O Data Register II     |      |
| 93h – 90h    | Chip Select 1 Base Address Register      |      |
| 97h – 94h    | Chip Select 1 Base Address Mask Register |      |
| 9Bh – 98h    | Chip Select 2 Base Address Register      |      |
| 9Fh – 9Ch    | Chip Select 2 Base Address Mask Register |      |

# 7.3.3 <u>R8610\_MAC1/2 Configuration Space Registers (IDSEL = AD19/Device 8/MAC1, AD20/Device</u> <u>9/MAC2)</u>

| Offset (HEX) | Register Name                | Page |
|--------------|------------------------------|------|
| 01h – 00h    | Vendor ID Register           |      |
| 03h – 02h    | Device ID Register           |      |
| 05h – 04h    | Command Register             |      |
| 07h – 06h    | Status Register              |      |
| 08h          | Revision ID Register         |      |
| 0Bh – 09h    | Class Code Register          |      |
| 13h – 10h    | I/O Base Address Register    |      |
| 17h – 14h    | Memory Base Address Register |      |
| 2Dh – 2Ch    | Subsystem Vendor ID Register |      |
| 2Fh – 2Eh    | Subsystem Device ID Register |      |
| 3Dh – 3Ch    | Interrupt Control Register   |      |

| Offset (HEX) | Register Name                        | Page |  |  |  |  |
|--------------|--------------------------------------|------|--|--|--|--|
| 01h – 00h    | endor ID Register                    |      |  |  |  |  |
| 03h – 02h    | Device ID Register                   |      |  |  |  |  |
| 05h – 04h    | Command Register                     |      |  |  |  |  |
| 07h – 06h    | Status Register                      |      |  |  |  |  |
| 08h          | Revision ID Register                 |      |  |  |  |  |
| 0Bh – 09h    | Class Code Register                  |      |  |  |  |  |
| 0Ch          | Cache Line Size Register             |      |  |  |  |  |
| 0Dh          | Latency Timer Register               |      |  |  |  |  |
| 0Eh          | leader Type Register                 |      |  |  |  |  |
| 13h – 10h    | Base Address Register                |      |  |  |  |  |
| 2Dh – 2Ch    | Subsystem Vendor ID Register         |      |  |  |  |  |
| 2Fh – 2Eh    | Subsystem Device ID Register         |      |  |  |  |  |
| 3Dh – 3Ch    | nterrupt Control Register            |      |  |  |  |  |
| 3Eh          | Minimum Grant Register               |      |  |  |  |  |
| 3Fh          | /lax. Latency Register               |      |  |  |  |  |
| 44h          | Operational Mode Enable Register I   |      |  |  |  |  |
| 45h          | Operational Mode Enable Register II  |      |  |  |  |  |
| 46h          | Operational Mode Enable Register III |      |  |  |  |  |
| 49h – 48h    | Operational Mode Enable Register IV  |      |  |  |  |  |

## 7.3.4 <u>R8610 USB1.1 Configuration Space Registers (IDSEL = AD21/Device 10/Function 0)</u>

| Offset (HEX) | Register Name P                                 |  |  |  |
|--------------|-------------------------------------------------|--|--|--|
| 01h – 00h    | /endor ID Register                              |  |  |  |
| 03h – 02h    | Device ID Register                              |  |  |  |
| 05h – 04h    | Command Register                                |  |  |  |
| 07h – 06h    | Status Register                                 |  |  |  |
| 08h          | Revision ID Register                            |  |  |  |
| 0Bh – 09h    | Class Code Register                             |  |  |  |
| 0Ch          | Cache Line Size Register                        |  |  |  |
| 0Dh          | Latency Timer Register                          |  |  |  |
| 0Eh          | Header Type Register                            |  |  |  |
| 13h – 10h    | Base Address Register                           |  |  |  |
| 2Dh – 2Ch    | Subsystem Vendor ID Register                    |  |  |  |
| 2Fh – 2Eh    | Subsystem Device ID Register                    |  |  |  |
| 3Dh – 3Ch    | Interrupt Control Register                      |  |  |  |
| 3Eh          | Minimum Grant Register                          |  |  |  |
| 3Fh          | Max Latency Register                            |  |  |  |
| 43h – 40h    | Operational Mode Enable Register                |  |  |  |
| 60h          | USB Release Number Register                     |  |  |  |
| 61h          | Frame Length Adjustment Register                |  |  |  |
| 63h – 62h    | Port Wake Capability Register                   |  |  |  |
| 65h – 64h    | USB1.1 Port Override Register                   |  |  |  |
| 73h – 70h    | USB Legacy Support Extended Capability Register |  |  |  |
| 77h – 74h    | USB Legacy Support Control/Status Register      |  |  |  |
| 7Bh – 78h    | USB Legacy Support Control/Status Register      |  |  |  |

## 7.3.5 <u>R8610 USB2.0 Configuration Space Registers (IDSEL = AD21/Device 10/Function 1)</u>

# 8. Instruction Set

The R8610 RISC processor core instruction set can be divided into 11 categories of operations:

Data Transfer Arithmetic Shift/Rotate String Manipulation Bit Manipulation Control Transfer High Level Language Support Operating System Support Processor Control

All the R8610 RISC processor core instructions operate on 0, 1, 2 or 3 operands, where an operand resides in a register, in the instruction itself or in memory. Most zero operand instructions (e.g., CLI, STI) take only one byte. One operand instruction is generally two bytes long. The average instruction is 3.2 bytes long. Since the R8610 RISC has a 32-byte instruction queue, an average of 10 instructions will be prefetched. The use of two operands permits the following types of common instructions:

Register to Register Memory to Register Memory to Memory Immediate to Register Register to Memory Immediate to Memory

The operands can be 8-, 16-, or 32-bit long. As a general rule, when 32-bit code is being executed, operands are 8 or 32 bits; when the existing 80286 or 8086 code (16-bit code) is being executed, operands are 8 or 16 bits. Prefixes can be added to all instructions, which override the default length of the operands (i.e., use 32-bit operands for 16-bit code, or 16-bit operands for 32-bit code).

# 9. Addressing Modes

**RDC**<sup>®</sup>

The R8610 RISC processor core provides a total of 11 addressing modes for instructions to specify operands. The addressing modes are optimized to allow the efficient execution of high-level languages such as C and FORTRAN, and they cover the vast majority of data references needed by high-level languages.

# 9.1 Register and Immediate Modes

Two of the addressing modes provide for instructions that operate on register or immediate operands:

Register Operand Mode: The operand is located in one of the 8-, 16- or 32-bit general registers.

Immediate Operand Mode: The operand is included in the instruction as part of the opcode.

# 9.2 <u>32-Bit Memory Addressing Modes</u>

The remaining 9 modes provide a mechanism for specifying the effective address of an operand. The linear address consists of two components: the segment base address and an effective address. The effective address is calculated by using combinations of the following four address elements:

Displacement: An 8-, or 32-bit immediate value, following the instruction.

**Base:** The contents of any general-purpose register. The base registers are generally used by compilers to point to the start of the local variable area.

**Index:** The contents of any general-purpose register except for ESP. The index registers are used to access the elements of an array, or a string of characters.

**Scale:** The index register's value can be multiplied by a scale factor: 1, 2, 4 or 8. Scaled index mode is especially useful for accessing arrays or structures.

Combinations of these 4 components make up the 9 additional addressing modes. There is no performance penalty for using any of these addressing combinations, since the effective address calculation is pipelined with the execution of other instructions. The one exception is the simultaneous use of Base and Index components, which require one additional clock.

The effective address (EA) of an operand is calculated according to the following formula.

EA = Base Reg + (Index Reg • Scaling) + Displacement

Direct Mode: The operand's offset is contained as part of the instruction as an 8-, 16- or 32-bit displacement.

## Example: INC Word PTR [500]

Register Indirect Mode: A **Base** register contains the address of the operand.

## Example: MOV [ECX], EDX

Based Mode: A Base register's contents are added to a Displacement to form the operand's offset.

#### Example: MOV ECX, [EAX + 24]

Index Mode: An Index register's contents are added to a Displacement to form the operand's offset.

#### Example: ADD EAX, TABLE[ESI]

Scaled Index Mode: An **Index** register's contents are multiplied by a **Scaling** factor that is added to a **Displacement** to form the operand's offset.

#### Example: IMUL EBX, TABLE[ESI • 4], 7

Based Index Mode: The contents of a **Base** register are added to the contents of an **Index** register to form the effective address of an operand.

#### Example: MOV EAX, [ESI] [EBX]

Based Scaled Index Mode: The contents of an **Index** register is multiplied by a **Scaling** factor and the result is added to the contents of a **Base** register to obtain the operand's offset.

#### Example: MOV ECX, [EDX • 8] [EAX]

Based Index Mode with Displacement: The contents of an **Index** register and a **Base** register's contents and a **Displacement** are all summed together to form the operand offset.

#### Example: ADD EDX, [ESI] [EBP + 00FFFFF0H]

Based Scaled Index Mode with Displacement: The contents of an **Index** register are multiplied by a **Scaling** factor and the result is added to the contents of a **Base** register and a **Displacement** to form the operand's offset.

#### Example: MOV EAX, LOCALTABLE [EDI • 4] [EBP + 80]

## 9.3 Differences between 16- and 32-bit Addresses

In order to provide software compatibility with the 80286 and 8086, the R8610 RISC processor core can execute 16-bit instructions in Real and Protected Modes. The processor determines the size of the instructions it is executing by examining the D bit in the CS segment Descriptor. If the D bit is 0, all operand lengths and effective addresses are assumed to be 16 bits long. If the D bit is 1, the default length for operands and addresses is 32 bits. In Real Mode, the default size for operands and addresses is 16 bits.

Regardless of the default precision of the operands or addresses, the R8610 RISC processor core is able to execute either 16or 32-bit instructions. This is specified via the use of override prefixes. Two prefixes, the **Operand Size Prefix** and the **Address Length Prefix**, override the value of the D bit on an individual instruction basis.

Example: The R8610 RISC processor core is executing in Real Mode and the programmer needs to access the EAX registers. The assembler code for this might be MOV EAX, 32-bit MEMORYOP, and ASM486 Macro Assembler automatically determines that an Operand Size Prefix is needed and generates it.

Example: The D bit is 0, and the programmer wishes to use Scaled Index addressing mode to access an array. The Address Length Prefix allows the use of MOV DX, TABLE [ESI • 2]. The assembler uses an Address Length Prefix since, with D= 0, the default addressing mode is 16 bits.

# RDC<sup>®</sup> RISC DSP Communication

Example: The D bit is 1, and the program wants to store a 16-bit quantity. The Operand Length Prefix is used to specify only a 16-bit value: MOV MEM16, DX.

The OPERAND LENGTH and Address Length Prefixes can be applied separately or in combination to any instruction. The address Length Prefix does not allow addresses over 64 Kbytes to be accessed in Real Mode. A memory address that exceeds FFFFH will result in a General Protection Fault. An Address Length Prefix only allows the use of the additional R8610 RISC addressing modes.

When executing 32-bit code, the R8610 RISC processor core uses either 8- or 32-bit displacements, and any register can be used as base or index registers. When executing 16-bit code, the displacements are either 8 or 16 bits, and the base and index register conform to the 80286 mode 1

# 10. Functional Description

The core of the R8610 32-bit MicroController is an x86-like, 6-stage pipeline RISC CPU core. In addition, the R8610 includes a 16/32-bit SDRAM controller, PCI bus controller, AT/PC compatible peripheral (DMA controller, Interrupt controller and Timer), LPC Controller, X-bus interface and UART. The R8610 is a highly integrated SOC that is suitable for embedded system. With the inherent high performance of RDC CPU core, the R8610 enables the designers to take the advantage to implement a wide variety of performance intensive applications, such as IP sharing, access point, home gateway, and internet appliance, while still maintains the lowest overall system cost.

The following sections will discuss the sub-function of the R8610.

# 10.1 RDC RISC Processor

The R8610 integrates a high speed and high performance CPU core that is designed on RDC advanced 32-bit, 6-stage pipeline architecture and executes up to 66 MHz. The CPU core of R8610 implements an MMU (Memory Management Unit) with 32 TLB buffers. With the MMU, the R8610 is compatible with a wide variety of operating systems, including MS Windows, Linux and most popular modern RTOS.



64-Bit Interunit Transfer Bus



# RDC<sup>®</sup> RISC DSP Communication

This R8610 RISC processor core contains all the features of the 486SX MicroController with enhancements to increase its performance. The instruction set includes the complete 486SX MicroController instruction set along with extensions to serve new applications.

## **Bus Unit**

The bus unit manages data transfers, instruction prefetches and control functions between the processor's internal units and the R8610 NB. Internally, the bus unit communicates with the cache and the instruction prefetch units through the 32-bit bus. Externally, the bus unit provides the processor with bus functions, including external bus cycles, memory read/write, instruction fetch, cache line fill, etc.,

## **Prefetch Unit**

When the BUS UNIT is not performing bus cycles to execute an instruction, the instruction prefetch unit uses the BUS UNIT to prefetch instructions. By reading instructions before they are needed, the processor rarely needs to wait for an instruction prefetch cycle on the processor bus.

Instruction prefetch cycles read 16-byte blocks of instructions, starting at addresses numerically greater than the last-fetched instruction. The prefetch unit, which has a direct connection to the paging unit, generates the starting address. The 16-byte prefetched blocks are read into both the prefetch and cache units simultaneously. The prefetch queue in the prefetch unit stores 32 bytes of instructions. As each instruction is fetched from the queue, the code part is sent to the instruction decode unit and (depending on the instruction) the displacement part is sent to the segmentation unit, where it is used for address calculation. If loops are encountered in the program being executed, the prefetch unit gets copies of previously executed instructions from the cache.

## **Decode Unit**

The instruction decode unit receives instructions from the instruction prefetch unit and translates them in a two-stage process into low-level control signals and microcode entry points, as shown in Figure 10-1. Most instructions can be decoded at a rate of one per clock.

The decode unit simultaneously processes instruction prefix bytes, opcodes, modR/M bytes, and displacements. The outputs include hardwired microinstructions to the segmentation, and integer units. The instruction decode unit is flushed whenever the instruction prefetch unit is flushed.

## **Memory Management Unit**

The on-chip memory management unit (MMU) is completely compatible with the X86 MicroController.

The memory management unit (MMU) consists of a segmentation unit and a paging unit. Segmentation allows management of the logical address space by providing easy data and code relocatability and efficient sharing of global resources. The paging mechanism operates beneath segmentation and is transparent to the segmentation process. Paging is optional and can be disabled by system software. Each segment can be divided into one or more 4 Kbytes segments. To implement a virtual memory system, full restartability for all page and segment faults is supported.

Memory is organized into one or more variable length segments, each up to four gigabytes (2<sup>32</sup> bytes) in size. A segment can have attributes associated with it, which include its location, size, type (i.e., stack, code or data), and protection characteristics. Each task can have a maximum of 16,381 segments, each up to four gigabytes in size. Thus each task has a maximum of 64 terabytes (trillion bytes) of virtual memory.





Logical Address

## Figure 10-2. Segmentation and Paging Address Formats

The segmentation unit provides four levels of protection for isolating and protecting applications and the operating system from each other. The hardware-enforced protection allows the design of systems with a high degree of integrity.

## 10.2 Programmable Interrupt Controller

**RISC DSP Communication** 

RDC

R8610 SB provides an ISA-Compatible interrupt controller that incorporates the functionality of two 82C59 interrupt controllers (Figure 10-3). The two controllers are cascaded, providing 13 external and three internal interrupts. The master interrupt controller provides IRQ[7:0] and the slave interrupt controller provides IRQ[15:8]. The three internal interrupts are used for internal functions only. IRQ0 is available to the user only when an external IO APIC is enabled. IRQ2 is used to cascade the two controllers and is not available to the user. IRQ0 is used as a system timer interrupt and is tied to Interval Timer 0, Counter 0. IRQ13 is reserved. The remaining 13 interrupt lines (IRQ[15:14,12:3,1]) are available for external system interrupts. IRQ[1] is fixed to edge trigger mode , IRQ[15:14, 12:3] edge or level sense selections are programmable on an individual channel-by-channel basis.

The Interrupt unit also supports interrupt steering. R8610 SB can be programmed to allow the four PCI active low interrupts (PIRQ[A:D]\_n) to be internally routed to one of 11 interrupts (IRQ[15:14,12:9,7:3]).

The Interrupt Controller consists of two separate 82C59 cores. Interrupt Controller 1 (CNTRL-1) and Interrupt Controller 2 (CNTRL-2) are initialized separately and can be programmed to operate in different modes. The default settings are: 80x86 Mode, Edge Sensitive (IRQ[0:15]) Detection, Normal EOI, Non-Buffered Mode, Special Fully Nested Mode disabled, and Cascade Mode. CNTRL-1 is connected as the Master Interrupt Controller and CNTRL-2 is connected as the Slave Interrupt Controller.

Note that IRQ13 is generated internally (as part of the coprocessor error support) by R8610 SB. IRQ12/M is generated internally (as part of the mouse support) when bit-4 in the XBCS is set to a 1. When set to a 0, the standard IRQ12 function is provided and IRQ12 appears externally.



Figure 10-3. Interrupt Controller Block Diagram

## 10.2.1 Programming the Interrupt Controller

The Interrupt Controller accepts two types of command words generated by the CPU or bus master:

#### Initialization Command Words (ICWs)

Before normal operation begins, each Interrupt Controller in the system must be initialized. In the 82C59, this is a 2- to 4-byte sequence. However, for R8610 SB, each controller must be initialized with a 4-byte sequence. This 4-byte sequence is required to configure the interrupt controller correctly for the R8610 SB implementation. This implementation is ISA-Compatible.

The four initialization command words are referred to by their acronyms: ICW1, ICW2, ICW3, and ICW4. The base address for each interrupt controller is a fixed location in the I/O memory space, at 0020h for CNTRL-1 and at 00A0h for CNTRL-2. An I/O write to the CNTRL-1 or CNTRL-2 base address with data bit 4 equal to 1 is interpreted as ICW1. For R8610 SB-based ISA systems, three I/O writes to "base address + 1" (021h for CNTRL-1 and 0A1h for CNTRL-2) must follow the ICW1. The first write to "base address + 1" (021h/0A1h) performs ICW2, the second write performs ICW3, and the third write performs ICW4.

ICW1 starts the initialization sequence. ICW2 is programmed to provide bits[7:3] of the interrupt vector that will be released onto the data bus by the interrupt controller during an interrupt acknowledge. A different base [7:3] is selected for each interrupt controller. ICW3 is programmed differently for CNTRL-1 and CNTRL-2, and has a different meaning for each controller.

For CNTRL-1, the master controller, ICW3 is used to indicate which IRQx input line is used to cascade CNTRL-2, the slave controller. Within the R8610 SB interrupt unit, IRQ2 on CNTRL-1 is used to cascade the INTR output of CNTRL-2. Consequently, bit 2 of ICW3 on CNTRL-1 is set to a 1, and the other bits are set to 0's.

For CNTRL-2, ICW3 is the slave identification code used during an interrupt acknowledge cycle. CNTRL-1 broadcasts a code to CNTRL-2 over three internal cascade lines if an IRQ[x] line from CNTRL-2 won the priority arbitration on the master controller and was granted an interrupt acknowledge by the CPU. CNTRL-2 compares this identification code to the value stored in ICW3, and if the code is equal to bits[2:0] of ICW3, CNTRL-2 assumes responsibility for broadcasting the interrupt vector during the second interrupt acknowledge cycle pulse.

ICW4 must be programmed on both controllers. At the very least, bit 0 must be set to a 1 to indicate that the controllers are operating in an Intel Architecture-based system.

#### **Operation Command Words (OCWs)**

These are the command words which dynamically reprogram the Interrupt Controller to operate in various interrupt modes. Any interrupt line can be masked by writing an OCW1. A 1 written in any bit of this command word will mask incoming interrupt requests on the corresponding IRQx line.

OCW2 is used to control the rotation of interrupt priorities when operating in the rotating priority mode and to control the End of Interrupt (EOI) function of the controller. OCW3 is used to set up reads of the ISR and IRR, to enable or disable the Special Mask Mode (SMM), and to set up the interrupt controller in polled interrupt mode. The OCWs can be written into the Interrupt Controller any time after initialization.

## 10.2.2 End-of-Interrupt Operation

#### End of Interrupt (EOI)

The In Service (IS) bit can be set to 0 automatically following the trailing edge of the second INTA\_n pulse (when AEOI bit in ICW1 is set to 1) or by a command word that must be issued to the Interrupt Controller before returning from a service routine (EOI command). An EOI command must be issued twice with this cascaded interrupt controller configuration, once for the master and once for the slave.

There are two forms of EOI commands: Specific and Non-Specific. When the Interrupt Controller is operated in modes that preserve the fully nested structure, it can determine which IS bit to set to 0 on EOI. When a Non-Specific EOI command is issued, the Interrupt Controller automatically sets to 0 and the highest IS bit of those that are set to 1. Since in the fully nested mode, the highest IS level was necessarily the last level acknowledged and serviced. A Non-Specific EOI can be issued with OCW2 (EOI=1, SL=0, R=0).

When a mode is used that may disturb the fully nested structure, the Interrupt Controller may no longer be able to determine the last level acknowledged. In this case, a Specific End of Interrupt must be issued that includes as part of the command the IS level to be reset. A specific EOI can be issued with OCW2 (EOI=1, SL=1, R=0, and L0–L2 is the binary level of the IS bit to be set to 0).

Note that an IS bit that is masked by an IMR bit will not be cleared by a non-specific EOI if the Interrupt Controller is in the Special Mask Mode.

#### Automatic End of Interrupt (AEOI) Mode

If AEOI=1 in ICW4, then the Interrupt Controller operates in AEOI mode continuously until reprogrammed by ICW4. Note that reprogramming ICW4 implies that ICW1, ICW2, and ICW3 must be reprogrammed first, in sequence. In this mode, the Interrupt Controller automatically performs a Non-Specific EOI operation at the trailing edge of the last interrupt acknowledge pulse. Note that from a system standpoint, this mode should be used only when a nested multi-level interrupt structure is not required within a single Interrupt Controller. The AEOI mode can only be used in a master Interrupt Controller and not in a slave Interrupt Controller (on CNTRL-1 but not CNTRL-2).

## 10.2.3 Modes of Operation

#### **Fully Nested Mode**

This mode is entered after initialization unless another mode is programmed. The interrupt requests are ordered in priority from 0 through 7 (0 being the highest). When an interrupt is acknowledged, the highest priority request is determined and its vector placed on the bus. Additionally, a bit of the Interrupt Service Register (IS[0:7]) is set. This IS bit remains set until the MicroController issues an End of Interrupt (EOI) command immediately before returning from the service routine. Or, if the AEOI (Automatic End of Interrupt) bit is set, this IS bit remains set until the trailing edge of the second INTA\_n. While the IS bit is set, all further interrupts of the same or lower priority are inhibited, while higher levels will generate an interrupt (which will be acknowledged only if the MicroController internal interrupt enable flip-flop has been re-enabled through software).

After the initialization sequence, IRQ0 has the highest priority and IRQ7 the lowest. Priorities can be changed, as will be explained in the rotating priority mode.

#### The Special Fully Nested Mode

This mode will be used in the case of a system where cascading is used, and the priority has to be conserved within each slave. In this case, the special fully nested mode will be programmed to the master (using ICW4). This mode is similar to the normal nested mode with the following exceptions:

When an interrupt request from a certain slave is in service, this slave is not locked out from the master's priority logic and further interrupt requests from higher priority IRQs within the slave will be recognized by the master and will initiate interrupts to the processor. (In the normal nested mode, a slave is masked out when its request is in service and no higher requests from the same slave can be serviced.)

When exiting the Interrupt Service routine, the software has to check whether the interrupt serviced was the only one from that slave. This is done by sending a Non-Specific End of Interrupt (EOI) command to the slave and then reading its In-Service Register and checking for zero. If it is empty, a Non-Specific EOI can be sent to the master too. If not, no EOI should be sent.

#### Automatic Rotation (Equal Priority Devices)

In some applications, there are a number of interrupting devices of equal priority. Automatic rotation mode provides for a sequential 8-way rotation. In this mode, a device receives the lowest priority after being serviced. In the worst case, a device requesting an interrupt will have to wait until each of seven other devices are serviced at most once.

There are two ways to accomplish automatic rotation using OCW2: the Rotation on Non-Specific EOI Command (R=1, SL=0, EOI=1) and the Rotate in Automatic EOI Mode which is set by (R=1, SL=0 and EOI=0) and cleared by (R=0, SL=0 and EOI=0).

#### Specific Rotation (Specific Priority)

The programmer can change priorities by programming the bottom priority and thus fixing all other priorities. For example, if IRQ5 is programmed as the bottom priority device, IRQ6 will be the highest priority device.

The Set Priority Command is issued in OCW2 where: R=1, SL=1; L0–L2 is the binary priority level code of the bottom priority device. See the register description for the bit definitions.

Note that, in this mode, internal status is updated by software control during OCW2. However, it is independent of the End of

# RDC<sup>®</sup> RISC DSP Communication

Interrupt (EOI) command (also executed by OCW2). Priority changes can be executed during an EOI command by using the Rotate on Specific EOI Command in OCW2 (R=1, SL=1, EOI=1 and L0–L2=IRQ level to receive bottom priority).

#### **Poll Command**

The Polled Mode can be used to conserve space in the interrupt vector table. Multiple interrupts that can be serviced by one interrupt service routine do not need separate vectors if the service routine uses the poll command.

The Polled Mode can also be used to expand the number of interrupts. The polling interrupt service routine can call the appropriate service routine, instead of providing the interrupt vectors in the vector table.

In this mode, the INTR output is not used and the MicroController internal Interrupt Enable flip-flop is reset, disabling its interrupt input. Service to devices is achieved by software using a Poll Command.

The Poll command is issued by setting P=1 in OCW3. The Interrupt Controller treats the next I/O read pulse to the Interrupt Controller as an interrupt acknowledge, sets the appropriate IS bit if there is a request, and reads the priority level. Interrupts are frozen from the I/O write to the I/O read.

This mode is useful if there is a routine command common to several levels so that the INTA\_n sequence is not needed (saving ROM space).

## 10.2.4 Cascade Mode

The Interrupt Controllers in R8610 SB are interconnected in a cascade configuration with one master and one slave. This configuration can handle up to 15 separate priority levels.

The master controls the slaves through a three-line internal cascade bus. When the master drives 010b on the cascade bus, this bus acts like a chip select to the slave controller.

In a cascade configuration, the slave interrupt outputs are connected to the master interrupt request inputs. When a slave request line is activated and afterwards acknowledged, the master enables the corresponding slave to release the interrupt vector address during the second INTA\_n cycle of the interrupt acknowledge sequence.

Each Interrupt Controller in the cascaded system must follow a separate initialization sequence and can be programmed to work in a different mode. An EOI Command must be issued twice: once for the master and once for the slave.

## 10.2.5 Edge- and Level-Triggered Mode

In ISA systems, this mode is programmed by using bit 3 in ICW1. With R8610 SB, this bit is disabled and a new register for edge and level triggered mode selection, per interrupt input, is included. This is the Edge/Level control Registers ELCR1 and ELCR2. The default programming is equivalent to programming the LTIM bit (ICW1 bit 3) to a 0 (all interrupts selected for edge triggered mode). Note that IRQ0, 1, 2, 8, and 13 cannot be programmed for level sensitive mode and cannot be modified by software.

If an ELCR bit=0, an interrupt request is recognized by a low to high transition on the corresponding IRQx input. The IRQ input can remain high without generating another interrupt.

If an ELCR bit=1, an interrupt request is recognized by a high level on the corresponding IRQ input and there is no need for an edge detection. The interrupt request must be removed before the EOI command is issued to prevent a second interrupt from occurring.

In both the edge and level triggered modes, the IRQ inputs must remain active until the falling edge of the first INTA\_n. If the IRQ input goes inactive before this time, a default IRQ7 occurs when the CPU acknowledges the interrupt. This can be a useful safeguard for detecting interrupts caused by spurious noise glitches on the IRQ inputs. To implement this feature, the IRQ7 routine is used for "clean up" simply executing a return instruction, thus ignoring the interrupt. If IRQ7 is needed for other purposes, a default IRQ7 can still be detected by reading the ISR. A normal IRQ7 interrupt sets the corresponding ISR bit; a default IRQ7 does not set this bit. However, if a default IRQ7 routine occurs during a normal IRQ7 routine, the ISR remains set. In this case, it is necessary to keep track of whether or not the IRQ7 routine was previously entered. If another IRQ7 occurs, it is a default.

## 10.2.6 Interrupt Masks

#### Masking on an Individual Interrupt Request Basis

Each interrupt request input can be masked individually by the Interrupt Mask Register (IMR). This register is programmed through OCW1. Each bit in the IMR masks one interrupt channel if it is set to a 1. Bit 0 masks IRQ0, Bit 1 masks IRQ1, and so forth. Masking an IRQ channel does not affect the other channels' operation, with one exception. Masking IRQ2 on CNTRL-1 will mask off all requests for service from CNTRL-2. The CNTRL-2 INTR output is physically connected to the CNTRL-1 IRQ2 input.

#### Special Mask Mode

Some applications may require an interrupt service routine to dynamically alter the system priority structure during its execution under software control. For example, the routine may wish to inhibit lower priority requests for a portion of its execution but enable some of them for another portion.

The difficulty is that if an Interrupt Request is acknowledged and an End of Interrupt command did not reset its IS bit (i.e., while executing a service routine), the Interrupt Controller would have inhibited all lower priority requests with no easy way for the routine to enable them.

The Special Mask Mode enables all interrupts not masked by a bit set in the Mask Register. Interrupt service routines that require dynamic alteration of interrupt priorities can take advantage of the Special Mask Mode. For example, a service routine can inhibit lower priority requests during a part of the interrupt service, then enable some of them during another part.

In the Special Mask Mode, when a mask bit is set to 1 in OCW1, it inhibits further interrupts at that level and enables interrupts from all other levels (lower as well as higher) that are not masked.

Thus, any interrupt may be selectively enabled by loading the Mask Register with the appropriate pattern.

If there is no Special Mask Mode and an interrupt service routine acknowledges an interrupt without issuing an EOI to clear the IS bit, the interrupt controller inhibits all lower priority requests. The Special Mask Mode provides an easy way for the interrupt service routine to selectively enable only the interrupts needed by loading the Mask register.

The special Mask Mode is set by OCW3 where: SSMM=1and SMM=1, and cleared where SSMM=1 and SMM=0.

## 10.2.7 Reading the Interrupt Controller Status

The input status of several internal registers can be read to update the user information on the system. The Interrupt Request Register (IRR) and In-Service Register (ISR) can be read via OCW3. The Interrupt Mask Register (IMR) is read via a read of OCW1. Brief descriptions of the ISR, the IRR, and the IMR follow.

- Interrupt Request Register (IRR): 8-bit register which contains the status of each interrupt request line. Bits that are clear indicate interrupts that have not requested service. The Interrupt Controller clears the IRR's highest priority bit during an interrupt acknowledge cycle. (Not affected by IMR).
- In-Service Register (ISR): 8-bit register indicating the priority levels currently receiving service. Bits that are set indicate interrupts that have been acknowledged and their interrupt service routine started. Bits that are cleared indicate interrupt requests that have not been acknowledged, or interrupt request lines that have not been asserted. Only the highest priority interrupt service routine executes at any time. The lower priority interrupt services are suspended while higher priority interrupts are serviced. The ISR is updated when an End of Interrupt Command is issued.
- Interrupt Mask Register (IMR): 8-bit register indicating which interrupt request lines are masked.

The IRR can be read when, prior to the I/O read cycle, a Read Register Command is issued with OCW3 (RR=1 and RIS=0). The ISR can be read when, prior to the I/O read cycle, a Read Register Command is issued with OCW3 (RR=1 and RIS=1).

The interrupt controller retains the ISR/IRR status read selection following each write to OCW3. Therefore, there is no need to write an OCW3 before every status read operation, as long as the current status read corresponds to the previously selected register. For example, if the ISR is selected for status read by an OCW3 write, the ISR can be read over and over again without writing to OCW3 again. However, to read the IRR, OCW3 will have to be reprogrammed for this status read prior to the OCW3 read to check the IRR. This is not true when polling mode is used. Polling Mode overrides status read when P=1 and RR=1 in OCW3.

After initialization, the Interrupt Controller is set to read the IRR. As stated, OCW1 is used for reading the IMR. The output data bus will contain the IMR status whenever I/O read is active and the address is 021h or 061h (OCW1).

## 10.2.8 Interrupt Steering

R8610 SB can be programmed to allow four PCI programmable interrupts (PIRQ[A:D]\_n) to be internally routed to one of 11 interrupts IRQ[15,14,12:9,7:3]. PCLK is used to synchronize the PIRQx\_n inputs. The PIRQx\_n lines are run through an internal multiplexer that assigns, or routes, an individual PIRQx\_n line to any one of 11 IRQ inputs. The assignment is programmable through the PIRQx Route Control registers. One or more PIRQx\_n lines can be routed to the same IRQx input. If interrupt steering is not required, the Route Registers can be programmed to disable steering.

Bits[3:0] in each PIRQx Route Control register are used to route the associated PIRQx\_n line to an internal IRQ input. Bit 7 in each register is used to disable routing of the associated PIRQx\_n.

The PIRQx\_n lines are defined as active low, level sensitive to allow multiple interrupts on a PCI Board to share a single line across the connector. When a PIRQx\_n is routed to specify IRQ line, the software must change the IRQ's corresponding ELCR bit to level sensitive mode. This means that the selected IRQ can no longer be used by an ISA device.

## 10.3 DMA Controller

The DMA circuitry incorporates the functionality of two 82C37 DMA controllers with seven independently programmable channels (Figure 10-4). Master DMA Controller (DMA-1) corresponds to DMA Channels 0–3 and Slave DMA Controller (DMA-2) corresponds to Channels 5–7. DMA Channel 4 is used to cascade the two controllers and will default to cascade mode in the DMA Channel Mode (DCM) Register. This channel is not available for any other purpose. In addition to accepting requests from DMA slaves, the DMA controller also responds to requests that are initiated by software. Software may initiate a DMA service request by setting any bit in the DMA Channel Request Register to a 1.





Each DMA channel is hardwired to the compatible settings for DMA device size: channel 3-0 are hardwired to 8-bit, count-by-bytes transfers, and channel 7-5 are hardwired to 16-bit, count-by-words (address shifted) transfers. The R8610 SB provides the timing control and data size translation necessary for the DMA transfer between the memory (ISA or DRAM) and the ISA Bus IO.

The R8610 SB provides 24-bit addressing in compliance with the ISA-Compatible specification. Each channel includes a 16-bit ISA-Compatible Current Register, which holds the 16 least-significant bits of the 24-bit address, an ISA-Compatible Page Register which contains the eight next most significant bits of address.

The DMA controller also features refresh address generation, and auto-initialization following a DMA termination.

The DMA controller is at any time either in master mode or slave mode. In master mode, the DMA controller is either servicing a DMA slave's request for DMA cycles, or allowing a 16-bit ISA master to use the bus via a cascaded DREQ signal. In slave mode, the R8610 SB monitors both the ISA Bus and PCI, decoding and responding to I/O read and write commands that address its registers.

Note that a DMA device (I/O device) is always on the ISA Bus, but the memory referenced is located on either an ISA Bus device or on PCI. When the R8610 SB is running a compatible DMA cycle, it drives the MEMR\_n or MEMW\_n strobes if the address is less than 16 Mbytes (000000h–FFFFFh). These memory strobes are generated regardless of whether the cycle is decoded for PCI or ISA memory. The SMEMR\_n and SMEMW\_n are generated if the address is less than 1 Mbytes (000000h–00FFFFh). If the address is greater than 16 Mbytes (1000000h–7FFFFFh), the MEMR\_n or MEMW\_n strobe is not generated to avoid aliasing issues.

## 10.3.1 DMA Transfer Modes

The channels can be programmed for any of four transfer modes. The transfer modes include single, block, demand, or cascade. Each of the three active transfer modes (single, block, and demand) can perform three different types of transfers (read, write or verify). Please note that R8610 SB does not support memory-to-memory transfers.

#### Single Transfer Mode

In single transfer mode, the DMA is programmed to make one transfer only. The byte/word count is decremented and the address decremented or incremented following each transfer. When the byte/word count "rolls over" from zero to FFFFh, a Terminal Count (TC) causes an auto-initialization if the channel has been programmed to do so.

To be recognized, DREQ must be held active until DACK\_n becomes active. If DREQ is held active throughout the single transfer, the bus is released after a single transfer. With DREQ asserted high, the DMA I/O device rearbitrates for the bus. Upon winning the bus, another single transfer is performed. This allows other ISA bus masters a chance to acquire the bus.

#### Block Transfer Mode

In Block Transfer mode, the DMA is activated by DREQ to continue making transfers during the service until a TC, caused by either a byte/word count going to FFFFh, is encountered. DREQ need only be held active until DACK\_n becomes active. If the channel has been programmed for it, an auto-initialization occurs at the end of the service. In this mode, it is possible to lock out other devices for a period of time (including refresh) if the transfer count is programmed to a large number.

#### **Demand Transfer Mode**

In Demand Transfer mode, the DMA channel is programmed to continue making transfers until a TC (Terminal Count) is encountered, or until the DMA I/O device releases DREQ. Thus, transfers may continue until the I/O device has exhausted its data capacity. After the I/O device catches up, the DMA service is re-established when the DMA I/O device reasserts the channel's DREQ. During the time between services when the system is allowed to operate, the intermediate values of address and byte/word count are stored in the DMA controller Current Address and Current Byte/Word Count Registers. A TC can cause an auto-initialize at the end of the service, if the channel has been programmed for it.

#### Cascade Mode

In Cascade Mode, the DMA controller will respond to DREQ with DACK, but R8610 SB will not drive IOR\_n, IOW\_n, MEMR\_n, MEMW\_n, LA[23:17], SA[19:0], and SBHE\_n.

Cascade mode is also used to allow direct access of the system by 16-bit bus masters. These devices use the DREQ and DACK signals to arbitrate for the ISA Bus. The ISA master asserts its ISA master request line (DREQ[x]) to the DMA internal arbiter. If the ISA master wins the arbitration, R8610 SB responds with an ISA master acknowledge (DACK[x]) signal active. Upon sampling the DACK[x] line active, the ISA master takes control of the ISA Bus. While an ISA Master owns the bus, BALE is always driven high while AEN is always driven low. The ISA master has control of the ISA Bus and may run cycles until it negates the DREQ[x] line.

## 10.3.2 DMA Transfer Types

Each of the three active transfer modes (Single, Block, or Demand) can perform three different types of transfers. They are Read, Write and Verify.

#### Write Transfers

Write transfers move data from an ISA I/O device to memory located on the ISA Bus or in system DRAM. For transfers using compatible timing, R8610 SB will activate ISA Memory control signals to indicate a memory write as soon as the DMA provides the address. The PCI transfer is initiated after the data is valid on the ISA Bus. Data steering is used to steer the data to the correct byte lane during these DMA transfers. When the memory is located on the ISA Bus, a PCI cycle is not initiated.

The DMA device (I/O device) is either an 8- or 16-bit device and is located on the ISA Bus. The size of the DMA device is fixed for each channel.

#### **Read Transfers**

Read transfers move data from ISA memory or the system DRAM, to an ISA I/O device. R8610 SB activates the IOW\_n command and the appropriate DRAM and ISA Memory control signals to indicate a memory read. Data steering is used to steer the data to the correct byte lane during these DMA transfers. When the cycle involves DRAM, the PCI read transaction is initiated as soon as the DMA address is valid. When the memory is located on the ISA Bus, a PCI cycle is not initiated.

#### Verify Transfer

Verify transfers are pseudo transfers. The DMA controller generates addresses as in normal read or write transfers. However, R8610 SB does not activate the ISA memory and I/O control lines. Only the DACK lines will go active. R8610 SB asserts the appropriate DACK signal for nine SYSCLKs. If Verify transfers are repeated during Block or Demand DMA requests, each additional pseudo transfer will add eight SYSCLKs. The DACK lines will not be toggled for repeated transfers.

## 10.3.3 DMA Timings

ISA-Compatible timing is provided for ISA DMA slave devices that reside on add in cards. The repetition rate for ISA-Compatible DMA cycles is eight SYSCLK periods.

When R8610 SB negates PHOLD\_n one clock after driving FRAME\_n asserted for a bus master IDE transaction, and another transaction is pending which will cause R8610 SB to acquire the PCI bus, it will drive PHOLD\_n asserted for the next transaction three clocks after TRDY\_n is driven negated for the current transaction.

## 10.3.4 DREQ and DACK\_n Latency Control

The R8610 SB DMA arbiter maintains a minimum DREQ to DACK\_n latency on all DMA channels when programmed in compatible mode. This is to support older devices such as the 8272A. The DREQs are delayed by eight SYSCLKs prior to being seen by the arbiter logic. This delay guarantees a minimum 1 msec DREQ to DACK\_n latency. Software requests will not have this minimum request to DACK\_n latency.

## 10.3.5 Channel Priority

For priority resolution, the DMA consists of two logical channel groups: channel 0–3 and channel 4–7. Each group may be in either fixed or rotate mode, as determined by the DMA Command Register.

DMA I/O slaves normally assert their DREQ line to arbitrate for DMA service. However, a software request for DMA service can be presented through each channel's DMA Request Register. A software request is subject to the same prioritization as any hardware request. Please see the detailed register description for Request Register programming information in the DMA Register description section.

#### **Fixed Priority**

The initial fixed priority structure is as follows:

| High priorityLow priority |  |
|---------------------------|--|
| (0, 1, 2, 3) (5, 6, 7)    |  |

The fixed priority ordering is 0, 1, 2, 3, 5, 6, and 7. In this scheme, Channel 0 has the highest priority, and channel 7 has the lowest priority. Channel 3-0 of DMA-1 assume the priority position of Channel 4 in DMA-2, thus take the priority over channel 5, 6, and 7.

## **Rotating Priority**

Rotation allows for "fairness" in priority resolution. The priority chain rotates so that the last channel serviced is assigned the lowest priority in the channel group (0-3, 5-7).

Channel 0–3 rotate as a group of four. They are always placed between Channel 5 and Channel 7 in the priority list.

Channel 5–7 rotate as part of a group of four. That is, channel 5–7 form the first three positions in the rotation, while channel group (0–3) comprises the fourth position in the arbitration.

## 10.3.6 Register Functionality

Please see the "DMA Register description" section for detailed information on register programming, bit definitions, and default values/functions of the DMA registers after CPURST is valid.

DMA Channel 4 is used to cascade the two DMA controllers together and should not be programmed for any mode other than cascade. The DMA Channel Mode Register for channel 4 will default to cascade mode. Special attention should also be taken when programming the Command and Mask Registers as related to channel 4.

## 10.3.7 Address Compatibility Mode

Whenever the DMA is operating, the addresses do not increment or decrement through the High and Low Page Registers. This is compatible with the 82C37 and Page Register implementation used in the PC-AT. This mode is set after CPURST is valid.

## 10.3.8 Summary of DMA Transfer Sizes

Table 10.1 lists each of the DMA device transfer sizes. The column labeled "Current Byte/Word Count Register" indicates that the register contents represent either the number of bytes to be transferred or the number of 16-bit words to be transferred. The column labeled "Current Address Increment/Decrement" indicates the number added to or taken from the Current Address register after each DMA transfer cycle. The DMA Channel Mode Register determines the Current Address Register will be incremented or decremented.

#### Table 10.1: DMA Transfer Size

| DMA Device Date Size and Word Count          | Current Byte/Word Count Register | Current Address<br>Increment/Decrement |
|----------------------------------------------|----------------------------------|----------------------------------------|
| 8-Bit I/O, Count by Bytes                    | Bytes                            | Bytes                                  |
| 16-Bit I/O, Count by Words (Address Shifted) | Words                            | 1                                      |

#### 10.3.8.1 Address Shifting When Programmed for 16-Bit I/O Count by Words

The R8610 SB maintains compatibility with the implementation of the DMA in the PC AT that uses the 82C37. The DMA shifts the addresses for transfers to/from a 16-bit device count-by-words. Note that the least significant bit of the Low Page Register is dropped in 16-bit shifted mode. When the Current Address Register is programmed (when the DMA channel is in this mode), the Current Address must be programmed to an even address with the address value shifted right by 1 bit. The address shifting is as follows:

#### Table 10.2: Address Shifting in 16-bit I/O DMA Transfers

| Output Address | 8-Bit I/O Programmed Address<br>(Channel 0-3) | 16-Bit I/O Programmed Address<br>(Channel 5–7)<br>(Shifted) |
|----------------|-----------------------------------------------|-------------------------------------------------------------|
| A0             | A0                                            | 0                                                           |
| A[16:1]        | A[16:1]                                       | A[15:0]                                                     |
| A[23:17]       | A[23:17]                                      | A[23:17]                                                    |

Note:

The least significant bit of the Page Register is dropped in 16-bit shifted mode.

#### 10.3.9 Autoinitialize

By programming a bit in the DMA Channel Mode Register, a channel may be set up as an autoinitialize channel. When a channel undergoes autoinitialization, the original values of the Current Page, Current Address and Current Byte/Word Count Registers are automatically restored from the Base Page, Address, and Byte/Word Count Registers of that channel following TC. The Base Registers are loaded simultaneously with the Current Registers by the MicroController when the DMA channel is programmed and remains unchanged throughout the DMA service. The mask bit is not set when the channel is in autoinitialize. Following autoinitialize, the channel is ready to perform another DMA service, without CPU intervention, as soon as a valid DREQ is detected.

## 10.3.10 Software Commands

There are three additional special software commands that can be executed by the DMA controller. The three software commands are:

- 1. Clear Byte Pointer Flip-Flop
- 2. Master Clear
- 3. Clear Mask Register

They do not depend on any specific bit pattern on the data bus.

#### **Clear Byte Pointer Flip-Flop**

This command is executed prior to writing or reading new address or word count information to/from the DMA controller. This initializes the flip-flop to a known state so that subsequent accesses to register contents by the MicroController will address upper and lower bytes in the correct sequence.

When the Host CPU is reading or writing DMA registers, two Byte Pointer flip-flops are used, one for channel 0–3 and one for channel 4–7. Both of these act independently. There are separate software commands for clearing each of them (0Ch for channel 0–3, 0D8h for channel 4–7).

#### **DMA Master Clear**

This software instruction has the same effect as the hardware reset. The Command, Status, Request, and Internal First/Last Flip-Flop Registers are cleared and the Mask Register is set. The DMA controller will enter the idle cycle.

There are two independent master clear commands; 0Dh which acts on channel 0–3, and 0DAh which acts on channel 4–7.

#### **Clear Mask Register**

This command clears the mask bits of all four channels, enabling them to accept DMA requests. I/O port 00Eh is used for channel 0–3 and I/O port 0DCh for channel 4–7.

## 10.4 FIFO UART

The R8610 integrates an improved version of Universal Asynchronous Receiver/Transmitter (UART). The internal 16-byte FIFOs are activated and allowed to be stored in both receive and transmit modes. The UART performs serial-to-parallel conversion on data characters received from a peripheral device or a MODEM, and parallel-to-serial conversion on data characters received from the CPU. The CPU can read the complete status of the UART at any time during the functional operations. Reported status information includes the types and conditions of the transfer operations being performed by the FIFO UART, as well as any error conditions (parity, overrun, framing, or break interrupt).

- Programmable word length, stop bit and parity
- Programmable baud rate generator
- Interrupt generator
- Loop-back mode
- Scratch register
- Two 16-byte FIFOs

The UART clock is 1.8432MHz. The UART includes a programmable baud rate generator that is capable of dividing the timing reference clock input by divisors of 1 to (2<sup>16</sup>-1), and producing a 16x clock for driving the internal transmitter logic. Provisions are also included to use this 16x clock to drive the receiver logic. The UART has complete MODEM-control capability, and a processor interrupt system. Interrupts can be programmed to the user's requirements, minimizing the computing required to handle the communications link. The reference table of baud rates and 16x clock is as followed:

| Baud Rate | 1.8432 MHz Crystal<br>Decimal Divisor for 16x Clock |
|-----------|-----------------------------------------------------|
| 50        | 2304                                                |
| 75        | 1536                                                |
| 110       | 1047                                                |
| 134.5     | 857                                                 |
| 150       | 768                                                 |
| 300       | 384                                                 |
| 600       | 192                                                 |
| 1200      | 96                                                  |
| 1800      | 64                                                  |
| 2000      | 58                                                  |
| 2400      | 48                                                  |
| 3600      | 32                                                  |
| 4800      | 24                                                  |
| 7200      | 16                                                  |
| 9600      | 12                                                  |
| 19200     | 6                                                   |
| 38400     | 3                                                   |

## 10.4.1 Transmit Operation

Transmission is initiated by writing the data to be sent to the TX Holding Register or to the TX FIFO (if enabled). The data will then be transferred to the TX Shift Register together with a start bit and parity and stop bits as determined by the Line Control Register. The bits to be transmitted are then shifted out of the TX Shift Register with the output from the baud rate generator as the clock.

If enabled, an interrupt will be generated when the TX Holding Register becomes empty.

When FIFOs are enabled (i.e. Bit 0 of the FIFO Control Register is set), the FIFO UART can store up to 16 bytes of data for

# RDC<sup>®</sup> RISC DSP Communication

transmission at a time. Transmission will continue until the TX FIFO is empty. The FIFO readiness to accept more data is indicated by TXRDY\_n or, if the transfer is interrupt driven, by INTR.

## 10.4.2 Receive Operation

Data is sampled into the RX Shift Register with either the baud rate generator or RCLK. A filter is used to remove spurious inputs that last for less than two periods of the clock.

When the complete word has been clocked into the receiver, the data bits are transferred to the RX Buffer Register or to the RX FIFO (if enabled) to be read by the CPU. The receiver also checks for a stop bit and for correct parity as determined by the Line Control Register.

If enabled, an interrupt will be generated when data has been transferred to the RX Buffer Register. Interrupts can also be generated for incorrect parity or a missing stop bit (frame error).

When FIFOs are enabled (i.e. Bit 0 of the FIFO Control Register is set), the FIFO UART can store up to 16 bytes of received data at a time. Depending on the selected mode, either RXRDY\_n of INTR will go active to indicate that it is available when the RX FIFO contains 1, 4, 8 or 14 bytes of data.

## 10.4.3 MODEM Control Lines

The output Modem Control lines RTS\_n, DTR\_n, OUT1\_n, and OUT2\_n can be set or cleared by writing to the MODEM Control Register.

The current status of the input Modem Control lines DCD\_n, RI\_n, DSR\_n and CTS\_n can be read from the Modem Status Register. Bit 2 of this register will be set if the RI\_n line has been changed from low to high since the register was last read.

If enabled, an interrupt will be generated when any of DSR\_n, CTS\_n, RI\_n or DCD\_n is asserted.

## 10.4.4 FIFO Interrupt Mode Operation

When the RCVR FIFO and receiver interrupts are enabled (FCR0 = 1 and IER0 = 1), RCVR interrupts will occur as follows:

- A. The receive data available interrupt will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B. The IIR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt, it is cleared when the FIFO drops below the trigger level.
- C. The receiver line status interrupt (IIR = 6), as before, has higher priority than the received data available (IIR = 04)
- D. The data ready bit (LSR0) is set as soon as a character is transferred from the shift register to the RCVR FIFO. It is reset when the FIFO is empty.

When RCVR FIFO and receiver interrupts are enabled, RCVR FIFO timeout interrupts will occur as follows:

- A. A FIFO timeout interrupt will occur, if the following conditions exist:
  - at least one character is in the FIFO
  - the most recent serial character received was longer than 4 continuous character times ago (if 2 stop bits are programmed and the second one is included in this time delay).
  - the most recent CPU read of the FIFO was longer than 4 continuous character times ago.

The maximum time between a received character and a timeout interrupt will be 160 ms at 300 baud with a 12-bit receive character (i.e., 1 Start, 8 Data, 1 Parity and 2 Stop Bits).

- B. Character times are calculated by using the RCLK input for a clock signal (this makes the delay proportional to the baud rate).
- C. When a timeout interrupt has occurred, it is cleared and the timer is reset when the CPU reads one character from the RCVR FIFO.
- D. When a timeout interrupt has not occurred, the timeout timer is reset after a new character is received or after the CPU reads the RCVR FIFO.

When the XMIT FIFO and transmitter interrupts are enabled (FCR0 = 1 and IER1= 1), XMIT interrupts will occur as follows:

- A. The transmitter holding register interrupt (02) occurs when the XMIT FIFO is empty; it is cleared as soon as the transmitter holding register is written (1 to 16 characters may be written to the XMIT FIFO while servicing this interrupt) or the IIR is read.
- B. The transmitter FIFO empty indications will be delayed 1 character time minus the last stop bit time whenever the following occurs: THRE = 1 and there have not been at least two bytes at the same time in the transmit FIFO, since the last THRE = 1. The first transmitter interrupt after FCR0 is changed will be immediate if it is enabled. Character timeout and RCVR FIFO trigger level interrupts have the same priority as the current received data available interrupt; XMIT FIFO empty has the same priority as the current transmitter holding register empty interrupt.

## 10.4.5 FIFO Polled Mode Operation

With FCR0 = 1, resetting IER0, IER1, IER2, IER3 or all to zero puts the UART in the FIFO Polled Mode of operation. Since the RCVR and XMITTER are controlled separately, either one or both can be in the polled mode of operation. In this mode, the user's program will check RCVR and XMITTER status via the LSR, as stated previously:

LSR0 will be set as long as there is one byte in the RCVR FIFO.

LSR1 to LSR4 will specify which error(s) has occurred. Character error status is handled the same way as in the interrupt mode. The IIR is not affected since IER2 = 0.

LSR5 will indicate when the XMIT FIFO is empty.

LSR6 will indicate that both the XMIT FIFO and shift register are empty.

LSR7 will indicate whether there are any errors in the RCVR FIFO.

There is no trigger level reached or timeout condition indicated in the FIFO Polled Mode. However, the RCVR and XMIT FIFOs are still fully capable of holding characters.

## 10.4.6 Timing Waveforms

The following timing diagrams are given as a guide when inputs to the FIFO UART must be valid, and when outputs are valid. Many of the signals are synchronized with XIN. The actual set-up and delay time will also depend on the technology used for the FIFO UART.





#### **MODEM Control Timig**



## 10.5 PCI Bus Controller

In order to leverage the wide availability of low-cost peripherals, as well as to simplify the design off add-in functions, the R8610 integrates a full 32-bit PCI bus interface. Key attributes of the PCI bus include:

- Supports PCI Rev 2.1 specification.
- 32-bit bus interface
- Supports PCI clock at 33 MHz.
- On-chip PCI arbiter
- Supports PCI master/slave
- Up to 133 Mbytes/sec maximum bandwidth
- Supports up to 3 external master devices on PCI
- Provides four PCI interrupt channels

## **PCI Bus Arbitration**

The PCI Bus arbiter for the R8610 allows concurrent host and PCI transactions to main memory. The arbiter supports three external PCI masters in addition to the R8610. REQ\_n[2:0]/GNT\_n[2:0] are used by PCI masters.

## 10.6 LPC Interface

The LPC (Low Pin Count) interface enables a system without an ISA bus. It reduces the cost of traditional ISA-bus devices while providing the extension of legacy PC IO peripherals (such as Super IO, keyboard, mouse and Flash ROM), increasing the memory space from 16MB to 4GB to allow the BIOS size to become much bigger than 1MB and the other memory devices to exceed the traditional 16MB capacity. Software is transparent. Do not require special drivers or configuration for this interface. The LPC features are listed as below:

- LPC revision 1.0 compliant
- Supports LPC/FWH (Firmware Hub) compliant interface
- Provides the interface to LPC/FWH Flash ROM or Super IO Chip
- Supports LPC DMA
- Supports Serial IRQ
- Supports bus master mode



## 10.6.1 Block Diagram

Figure 10-5 contains a typical setup. In this setup, the LPC is connected through a host to a PCI or Host Bus, such as that of Intel CPUs.





## 10.6.2 Protocol Overview

## 10.6.2.1 Cycle Types

Table 10.3 shows the various types of cycles that are supported by the protocol.

| Table 10.3: Cycle Types |                                    |                                                                                      |  |
|-------------------------|------------------------------------|--------------------------------------------------------------------------------------|--|
| Cycle Type              | Cycle Type Sizes Supported Comment |                                                                                      |  |
| Memory Read             | 1 byte                             | Optional for both chip-sets and peripherals.                                         |  |
| Memory Write            | 1 byte                             | Optional for both chip-sets and peripherals.                                         |  |
| I/O Read                | 1 byte                             | Optional for peripherals.                                                            |  |
| I/O Write               | 1 byte                             | Optional for peripherals.                                                            |  |
| DMA Read                | 1, 2, 4 bytes                      | Optional for peripherals.                                                            |  |
| DMA Write               | 1, 2, 4 bytes                      | Optional for peripherals.                                                            |  |
| Bus Master Memory Read  | 1, 2, 4 bytes                      | Optional for both chip-sets and peripherals, but strongly recommended for chip-sets. |  |
| Bus Master Memory Write | 1, 2, 4 bytes                      | Optional for both chip-sets and peripherals, but strongly recommended for chip-sets. |  |
| Bus Master I/O Read     | 1, 2, 4 bytes                      | Optional for both chip                                                               |  |
| Bus Master I/O Write    | 1, 2, 4 bytes                      | Optional for both chip                                                               |  |

The following rules must be followed:

- The host will support all cycle types, unless otherwise indicated.
- Peripherals may implement cycles as needed. For example, a peripheral may be chosen to implement just I/O cycles, not memory, DMA, or bus master cycles.
- Peripherals must not attempt bus master cycles that are not supported by the chip-set. For example, if the chip-set does not support bus master I/O cycles, the peripheral must not attempt those cycles.
- Peripherals must ignore cycles that they do not support.

## 10.6.2.2 Cycle Overview

Data transfers on the LPC bus are serialized over a 4-bit bus. The general characteristics of this bus are:

- One control line, called LFRAME\_n, which is used by the host to start or stop transfers. No peripherals drive this signal.
- The LAD[3:0] bus, which communicates information serially. The information conveyed is cycle type, cycle direction, chip selection, address, data, and wait states.
- Side-band signals, optionally implemented, which convey interrupts and power management features. These signals are the same as many signals found on current motherboard implementations.

The general flow of cycles is as follows:

- 1. A cycle is started by the host when it drives LFRAME\_n to be active and puts appropriate information on the LAD[3:0] signal lines.
- 2. The host drives information relative to the cycle, such as address, or DMA channel number, or bus master grant. For DMA and target cycles, the host also drives cycle type (memory or I/O), read/write direction, and size of the transfer.
- 3. The host optionally drives data, and turns the bus around to monitor the peripheral for completion of the cycle.

- 4. The peripheral indicates completion of the cycle by driving appropriate values on the LAD[3:0] signal lines, and potentially drives data.
- 5. The peripheral turns the bus around to the host, ending the cycle.

For bus master cycles, there are small changes to this protocol, as the bus master must drive control and address information to the host, and the host is responsible for ending the cycle, but in general, the flow is the same.

## 10.6.3 Target Overview

## 10.6.3.1 Memory Cycles

In these cases, memory read or write cycles are intended for memory-mapped devices. The Sync time will depend on the speed of the device.

The ADDR field is full 32 bits, and transmitted with the most significant nibble first. Although a full 32 bits of addressing is supported, a memory device will typically support much less than this. It can ignore the address bits which it is capable of decoding.

## 10.6.3.2 I/O Cycles

In these cases, I/O read or write cycles are intended for the peripheral. These will generally be used for register or FIFO accesses, and will generally have minimal Sync times. The minimum number of wait-states between bytes is 1. EPP cycles will depend on the speed of the external device, and may have much longer Sync times. Data transfers are assumed to be exactly 1 byte. The host is responsible for breaking up larger data transfers into 8-bit cycles.

## 10.6.4 DMA Protocol

DMA on LPC is handled through the use of the LDRQ\_n lines from peripherals and special encodings on LAD[3:0] from the host. Single, demand, verify, and increment modes are supported on the LPC interface. Block, decrement, and cascade modes are not supported. Channel 0 - 3 are 8-bit channels. Channel 5 - 7 are 16-bit channels. Channel 4 is reserved as a generic bus master request (see section 7).

A new 32-bit transfer mode is supported on the LPC interface, which can be used to transfer multiple bytes from an 8- or 16-bit channel per request for faster throughput.

## 10.6.5 Bus Master Protocol

The LPC interface does not support cascaded ISA master mode access on DMA channels. Bus master accesses are performed through a reserved encoding on the LDRQ\_n signal line of '100b'. By using this reserved encoding, a peripheral is able to create any number of bus masters, and is not limited to the number of DMA channels in the system.

## 10.6.5.1 Cycle Formats and Timings

Bus master START fields are associated with either Bus Master 0 ('0010b') or Bus Master 1 ('0011b'). At this time, there are only two bus masters supported on the LPC interface. After sending this field, the host performs a TAR to transfer control to the peripheral.

RDC<sup>®</sup> RISC DSP Communication

## 10.7 X-Bus Interface

The R8610 provides an X-bus interface to connect to system boot flash ROM or DOC (Disk On Chip).

- Supports 8-/16-bit data width
- Provides ROMCS\_n for boot from X-bus Flash ROM
- Supports from 64 Kbytes to Max. 8 Mbytes ROM space addressing

## 10.8 SDRAM Controller

The R8610 integrates a main memory SDRAM controller that supports a 16-bit or 32-bit SDRAM data bus width. The R8610 SDRAM interface runs up to 133MHz. The thirteen multiplexed address lines, MA[12:0], and 2 SDRAM banks supported allow the R8610 to support maximum 128 Mbytes main memory space. All of SDRAM configurations provided by R8610 are listed as below:

## 16-bit data width:

| One Chip Select |              |               |
|-----------------|--------------|---------------|
| Memory Size     | SDRAM Type   |               |
| Memory Size     | x 8          | x 16          |
| 2MB             |              | 1Mb x 16 x 1  |
| 4MB             | 2Mb x 8 x 2  |               |
| 8MB             |              | 4Mb x 16 x 1  |
| 16MB            | 8Mb x 8 x 2  | 8Mb x 16 x 1  |
| 32MB            | 16Mb x 8 x 2 | 16Mb x 16 x 1 |
| 64MB            | 32Mb x 8 x 2 |               |

| Two Chip Selects |              |               |  |
|------------------|--------------|---------------|--|
| Memory Size      | SDRAM Type   |               |  |
| Memory Size      | x 8          | x 16          |  |
| 4MB              |              | 1Mb x 16 x 1  |  |
| 8MB              | 2Mb x 8 x 2  |               |  |
| 16MB             |              | 4Mb x 16 x 1  |  |
| 32MB             | 8Mb x 8 x 2  | 8Mb x 16 x 1  |  |
| 64MB             | 16Mb x 8 x 2 | 16Mb x 16 x 1 |  |
| 128MB            | 32Mb x 8 x 2 |               |  |



# 10.9 L1 Cache

In order to maximize the performance, the R8610 integrated a direct map, 16Kbyte unified code and data cache in it. The level 1 cache supports write through policy. The on-chip L1 cache allows frequently used data and code to be stored on chip reducing accesses to the external bus. It significantly reduces the penalty of performance to access these codes and data from external slower memory devices.





# 10.10 GPIO Interface

59 GPIO pins are provided by the R8610 for general usage in the system. All GPIO pins are independent and can be configured as inputs or outputs, with or without pull-up/pull-down resistors.

| GI IO pin is | PIN          | Symbol                         | Note                                     |
|--------------|--------------|--------------------------------|------------------------------------------|
| Number       |              | Symbol                         | Note                                     |
| Number<br>0  | Number<br>18 | LAD0/GPIO0                     | LPC Bus Interface                        |
| 1            | 10           | LADU/GPIO0                     | LPC Bus Interface                        |
| 2            | 20           |                                | LPC Bus Interface                        |
| 3            | 20           | LAD2/GPIO2                     | LPC Bus Interface                        |
|              |              |                                |                                          |
| 4 5          | 23           | LFRAME_n/GPI04                 | LPC Bus Interface                        |
|              | 24           | LDRQ_n/GPI05                   | LPC Bus Interface                        |
| 6            | 25           | SERIRQ/GPIO6                   | LPC Bus Interface                        |
| 7            | 120          | SIN/GPIO7                      | FIFO UART                                |
| 8            | 121          | SOUT/GPIO8                     | FIFO UART                                |
| 9            | 114          | RTS_n/TDO /GPIO9               | FIFO UART                                |
| 10           | 112          | DTR_n/GPI010                   | FIFO UART                                |
| 11           | 115          | CTS_n/TMS/GPI011               | FIFO UART                                |
| 12           | 117          | DSR_n/TCK/GPI012               | FIFO UART                                |
| 13           | 118          | DCD_n/TDI/GPI013               | FIFO UART                                |
| 14           | 113          | RI_n/GPI014                    | FIFO UART                                |
| 15           | 29           | RTCAS/GPI015                   | External RTC Interface                   |
| 16           | 30           | RTCRD/GPIO16                   | External RTC Interface                   |
| 17           | 31           | RTCWR/GPI017                   | External RTC Interface                   |
| 18           | 32           | IRQ8_n/GPI018                  | External RTC Interface                   |
| 19           | 158          | INTA_n/GPI019                  | PCI Bus Interface                        |
| 20           | 157          | INTB_n/GPIO20                  | PCI Bus Interface                        |
| 21           | 156          | INTC_n/GPIO21                  | PCI Bus Interface                        |
| 22           | 155          | INTD_n/GPIO22                  | PCI Bus Interface                        |
| 23           | 1            | PREQ_n0/GPIO23                 | PCI Bus Interface                        |
| 24           | 216          | PREQ_n1/GPI024                 | PCI Bus Interface                        |
| 25           | 215          | PREQ_n2/GPI025                 | PCI Bus Interface                        |
| 26           | 214          | PGNT_n0/GPIO26                 | PCI Bus Interface                        |
| 27           | 213          | PGNT_n1/GPI027                 | PCI Bus Interface                        |
| 28           | 212          | PGNT_n2/GPIO28                 | PCI Bus Interface                        |
| 29           | 91           | SA13/GPI029                    | XD Bus Address Bus                       |
| 30           | 92           | SA14/GPIO30                    | XD Bus Address Bus                       |
| 31           | 93           | SA15/GPI031                    | XD Bus Address Bus                       |
| 32           | 94           | SA16/GPI032                    | XD Bus Address Bus                       |
| 33           | 95           | SA17/GPIO33                    | XD Bus Address Bus                       |
| 34           | 97           | SA18/GPI034                    | XD Bus Address Bus                       |
| 35           | 98           | SA19/GPIO35                    | XD Bus Address Bus<br>XD Bus Address Bus |
| 36<br>37     | 100          | SA20/GPIO36                    |                                          |
|              | 101          | SA21/GPIO37                    | XD Bus Address Bus<br>XD Bus Address Bus |
| 38           | 102          | SA22/GPIO38                    |                                          |
| 39           | 103          | SA23/GPIO39<br>TXC0/GPIO40     | XD Bus Address Bus                       |
| 40           | 128<br>129   |                                | MII Interface                            |
| 41 42        | 129          | TXD0_0/GPIO41<br>TXD0_1/GPIO42 | MII Interface<br>MII Interface           |
| 42           | 130          | TXD0_1/GP1042<br>TXD0_2/GP1043 | MII Interface                            |
| 43           | 131          | TXD0_2/GPI043<br>TXD0_3/GPI044 |                                          |
|              |              |                                | MII Interface                            |
| 45<br>46     | 134<br>127   | TXEN0/GPIO45<br>RXC0/GPIO46    | MII Interface                            |
| 40           | 127          |                                | MII Interface<br>MII Interface           |
| 47           | 122          | RXDV0/GPIO47                   | MII Interface                            |
| -            |              | RXD0_0/GPIO48                  |                                          |
| 49           | 124          | RXD0_1/GPI049                  | MII Interface                            |
| 50           | 125          | RXD0_2/GPIO50                  | MII Interface                            |



| 51 | 126 | RXD0_3/GPIO51        | MII Interface             |
|----|-----|----------------------|---------------------------|
| 52 | 135 | COL0/GPIO52          | MII Interface             |
| 53 | 108 | SPEAKER/GPI053       | Speaker Output            |
| 54 | 111 | A20GATE_n/GPIO54     | Address Bit 20 Mask       |
| 55 | 109 | KBRST_n/GPIO55       | Keyboard Reset            |
| 56 | 27  | CLK25MOUT/GPIO56     | 25MHz Clock output        |
| 57 | 106 | XCS1_n/GPIO57        | XBUS Chip Select 1        |
| 58 | 107 | XCS2_n/GPIO58/CLK14M | XBUS Chip Select 2/CLK14M |

## 10.11 Programmable Timer

R8610 SB contains three counters that are equivalent to those found in the 82C54 programmable interval timer. The three counters are contained in one timer unit, referred to as Timer-1. Each counter output provides a key system function. Counter 0 is connected to interrupt controller IRQ0 and provides a system timer interrupt for a time-of-day, diskette time-out, or other system timing functions. Counter 1 generates a refresh request signal and Counter 2 generates the tone for the speaker. The 14.31818-MHz counters normally use OSC as a clock source.

#### Counter 0, System Timer

This counter functions as the system timer by controlling the state of IRQ0 and is typically programmed for Mode 3 operation. The counter produces a square wave with a period equal to the product of the counter period (838 ns) and the initial count value. The counter loads the initial count value one counter period after software writes the count value to the counter I/O address. The counter initially asserts IRQ0 and decrements the count value by two each counter period. The counter negates IRQ0 when the count value reaches 0. It then reloads the initial count value and again decrements the initial count value by two each counter period. The counter value by two each counter period. The counter then asserts IRQ0 when the count value reaches 0, reloads the initial count value, and repeats the cycle, alternately asserting and negating IRQ0.

#### **Counter 1, Refresh Request Signal**

This counter provides the refresh request signal and is typically programmed for Mode 2 operation. The counter negates refresh request for one counter period (838 ns) during each count cycle. The initial count value is loaded one counter period after being written to the counter I/O address. The counter initially asserts refresh request, and negates it for one counter period when the count value reaches 1. The counter then asserts refresh request and continues counting from the initial count value.

#### **Counter 2, Speaker Tone**

This counter provides the speaker tone and is typically programmed for Mode 3 operation. The counter provides a speaker frequency equal to the counter clock frequency (1.193 MHz) divided by the initial count value. The speaker must be enabled by a write to port 061h (see NMI Status and Control ports).

### 10.11.1 Programming the Interval Timer

The counter/timers are programmed by I/O accesses and are addressed as though they are contained in one 82C54 interval timer. A single Control Word Register controls the operation of all three counters. The interval timer is an I/O-mapped device. Several commands are available:

The Control Word Command specifies:

- which counter to read or write
- the operating mode
- the count format (binary or BCD)

The Counter Latch Command latches the current count so that it can be read by the system. The countdown process continues. The Read Back Command reads the count value, programmed mode, the current state of the OUT pins, and the state of the Null Count Flag of the selected counter.

The Read/Write Logic selects the Control Word Register during an I/O write when address lines A[1:0]=11. This condition occurs during an I/O write to port address 043h, the address for the Control Word Register on Timer 1. If the CPU writes to port 043h, the data is stored in the Control Word Register and is interpreted as the Control Word used to define the operation of the Counters.

The Control Word Register is write only. Counter status information is available with the read back Command.

Because the timer counters wake up in an unknown state after power up, multiple refresh requests may be queued. To avoid possible multiple refresh cycles after power up, program the timer counter immediately after power up.

#### Write Operations

Programming the interval timer is a simple process:

- 1. Write a control word.
- 2. Write an initial count for each counter.
- 3. Load the least and/or most significant bytes (as required by Control Word bit 5 and 4) of the 16-bit counter.

The programming procedure for the R8610 SB timer is very flexible. Only two conventions need to be observed. First, for each counter, the control word must be written before the initial count is written. Second, the initial count must follow the count format specified in the control word (least significant byte only, most significant byte only, or least significant byte and then most significant byte).

Since the Control Word Register and the three counters have separate addresses (selected by the A1 and A0 inputs), and each control word specifies the counter it applies to (SC0 and SC1 bits), no special instruction sequence is required. Any programming sequence that follows the conventions above is acceptable.

A new initial count may be written to a counter at any time without affecting the counter's programmed mode. Counting will be affected as described in the mode definitions. The new count must follow the programmed count format.

If a counter is programmed to read/write 2-byte counts, the following precaution applies: A program must not transfer control between writing the first and second byte to another routine which also writes into that same counter. Otherwise, the counter will be loaded with an incorrect count.

#### Interval Timer Control Word Format

The control word specifies the counter, the operating mode, the order and size of the count value, and whether it counts down in a 16-bit or binary-coded decimal (BCD) format. After writing the control word, a new count may be written at any time. The new value will take effect according to the programmed mode.

If a counter is programmed to read/write 2-byte counts, the following precaution applies: A program must not transfer control between writing the first and second byte to another routine which also writes into that same counter. Otherwise, the counter will be loaded with an incorrect count. The count must always be completely loaded with both bytes.

#### **Read Operations**

It is often desirable to read the value of a counter without disturbing the count in progress. There are three possible methods for reading the counters: a simple read operation, the Counter Latch Command, and the Read Back Command.

#### Counter I/O Port Read

The first method is to perform a simple read operation. To read the counter, which is selected with the A1 and A0 inputs (port 040h, 041h, or 042h), the CLK input of the selected counter must be inhibited by using either the GATE input or external logic. Otherwise, the count may be in the process of changing when it is read, giving an undefined result. When reading the count value directly, follow the format programmed in the control register: read LSB, read MSB, or read LSB then MSB. Within the R8610 SB timer unit, the GATE input on Counter 0 and Counter 1 is tied high. Therefore, the direct register read should not be used on these two counters. The GATE input of Counter 2 is controlled through I/O port 061h. If the GATE is disabled through this register, direct I/O reads of port 042h will return the current count value.

#### **Counter Latch Command**

The Counter Latch Command latches the count at the time the command is received. This command is used to ensure that the count read from the counter is accurate (particularly when reading a 2-byte count). The count value is then read from each counter's Count Register as was programmed by the Control Register.

The selected counter's output latch (OL) latches the count at the time the Counter Latch Command is received. This count is held in the latch until it is read by the CPU (or until the Counter is reprogrammed). The count is then unlatched automatically and the OL returns to "following" the counting element (CE). This allows reading the contents of the counters "on the fly" without affecting counting in progress. Multiple Counter Latch Commands may be used to latch more than one counter. Each latched counter's OL holds its count until it is read. Counter Latch Commands do not affect the programmed mode of the counter in any way. The Counter Latch Command can be used for each counter in the R8610 SB timer unit.

If a Counter is latched and then, some time later, latched again before the count is read, the second Counter Latch Command is ignored. The count read would be the count at the time the first Counter Latch Command was issued.

With either method, the count must be read according to the programmed format; specifically, if the counter is programmed for 2-byte counts, 2 bytes must be read. The 2 bytes do not have to be read one right after the other. Read, write, or programming operations for other counters may be inserted between them.

Another feature of the R8610 SB timer is that reads and writes of the same counter may be interleaved. For example, if the Counter is programmed for 2-byte counts, the following sequence is valid:

- Read least significant byte.
- Write new least significant byte.
- Read most significant byte.
- Write new most significant byte.

If a counter is programmed to read/write 2-byte counts, a program must not transfer control between reading the first and second byte to another routine which also reads from that same counter. Otherwise, an incorrect count will be read.

#### **Read Back Command**

The third method uses the Read Back Command. The Read Back Command is used to determine the count value, programmed mode, and current states of the OUT pin and Null Count flag of the selected counter or counters. The Read Back Command is written to the Control Word Register, which causes the current states of the above-mentioned variables to be latched. The value of the counter and its status may then be read by I/O access to the counter address.

The Read Back Command may be used to latch multiple counter output latches (OL) by setting the COUNT\_n bit D5=0 and selecting the desired counter(s). This single command is functionally equivalent to several counter latch commands, one for each counter latched. Each counter's latched count is held until it is read (or the counter is reprogrammed). Once read, a counter is automatically unlatched. The other counters remain latched until they are read. If multiple count Read Back Commands are issued to the same counter without reading the count, all but the first are ignored (i.e. the count which will be read is the count at the time the first Read Back Command was issued).

The Read Back Command may also be used to latch status information of selected counter(s) by setting STATUS\_n bit D4=0. Status must be latched to be read. The status of a counter is accessed by a read from that counter's I/O port address.

If multiple counter status latch operations are performed without reading the status, all but the first are ignored. The status returned from the read is the counter status at the time the first status Read Back Command was issued.

Both count and status of the selected counter(s) may be latched simultaneously by setting both the COUNT\_n and STATUS\_n bits[5:4]=00. This is functionally the same as issuing two consecutive, separate Read Back Commands. The above discussions apply here also. Specifically, if multiple count and/or status Read Back Commands are issued to the same counter(s) without any intervening reads, all but the first are ignored.

If both count and status of a counter are latched, the first read operation from that counter will return the latched status, regardless of which was latched first. The next one or two reads (depending on whether the counter is programmed for one or two type counts) return the latched count. Subsequent reads return unlatched count.

In this chapter, we give the detailed descriptions for each register in R8610 RISC MicroController.

## 11.1 Core Registers

**RDC**<sup>®</sup>

### 11.1.1 General-Purpose Registers

**RISC DSP Communication** 

The 32-bit general-purpose data registers EAX, EBX, ECX, EDX, ESI, EDI, EBP and ESP are provided for holding the Operands for logical and arithmetic operations, Operands for address calculations or Memory pointers.

As shown below, the lower 16 bits of the general-purpose registers map directly to the register set found in the 8086 and Intel 286 processors and can be referenced with the names AX, BX, CX, DX, BP, SP, SI, and DI. Each of the lower two bytes of the EAX, EBX, ECX, and EDX registers can be referenced by the names AH, BH, CH, and DH (high bytes) and AL, BL, CL, and DL (low bytes).

| Register Name: | EAX |
|----------------|-----|
| Reset Value:   |     |

| 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 |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|

|    | АН | AL |
|----|----|----|
|    | А  | x  |
| EA | AX |    |

| Bit  | Name | Attribute | Description                                                                                                                                                              |
|------|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | EAX  |           | The EAX registers are available for general storage of operands, results and pointers.<br>For special purpose, the EAX holds the accumulator's operands or results data. |

| Register Name: | EBX |
|----------------|-----|
| -              |     |

Reset Value:

#### 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

|     | ВН | BL |  |  |  |  |
|-----|----|----|--|--|--|--|
|     | В  | x  |  |  |  |  |
| EBX |    |    |  |  |  |  |

| Bit  | Name | Attribute | Description                                                                            |
|------|------|-----------|----------------------------------------------------------------------------------------|
| 31-0 | EBX  | R/W       | The EBX registers are available for general storage of operands, results and pointers. |
| 51-0 | LDX  |           | For special purpose, the EBX holds a pointer which points to data in the DS segment.   |



Register Name:ECXReset Value:-------

#### 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

|   | СН | CL |
|---|----|----|
|   | с  | x  |
| E | cx |    |

| Bit  | Name | Attribute | Description                                                                                                                                                                             |
|------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | ECX  |           | The ECX registers are available for general storage of operands, results and pointers.<br>For special purpose, the ECX holds a string pointer or the counter values of loop operations. |

| Register Name: | EDX |
|----------------|-----|
| Reset Value:   |     |

# 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

|    | DH | DL |
|----|----|----|
|    | D  | x  |
| ED | x  |    |

| Bit  | Name | Attribute | Description                                                                                                                                  |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | EDX  | R/W       | The EDX registers are available for general storage of operands, results and pointers.<br>For special purpose, the EDX holds an I/O pointer. |

| Register Name: | ESI |
|----------------|-----|
| Reset Value:   |     |

### 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

| SI  |  |
|-----|--|
| ESI |  |

| Bit  | Name | Attribute | Description                                                                                         |
|------|------|-----------|-----------------------------------------------------------------------------------------------------|
| 31-0 | ESI  |           | Pointer to data in the segment pointed to by the DS register; source pointer for string operations. |



| R  | Register Name: EDI<br>Reset Value: |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|------------------------------------|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R  | eset                               | Val | ue: |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
|    |                                    |     |     |    |    |    |    |    |    |    |    |    |    |    |    | DI |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |                                    |     |     |    |    |    |    |    |    |    |    |    |    |    | E  | DI |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                                                                               |
|------|------|-----------|---------------------------------------------------------------------------------------------------------------------------|
| 31-0 | EDI  | R/W       | Pointer to data (or destination) in the segment pointed to by the ES register; destination pointer for string operations. |

| Re | gis  | ter l | Nan | ne: |    | EBF | >  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|------|-------|-----|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Re | eset | Val   | ue: |     |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
|    |      |       |     |     |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | В | Ρ |   |   |   |   |   |   |   |

EBP

| Bit  | Name | Attribute | Description                        |
|------|------|-----------|------------------------------------|
| 31-0 | EBP  | R/W       | Stack pointer (in the SS segment). |

| Register Name:<br>Reset Value: | ESP<br>   |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------------------|-----------|------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 30 29 28 27 2               | 6 25 24 2 | 3 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| BP                             |           |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| EBP                            |           |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                       |
|------|------|-----------|---------------------------------------------------|
| 31-0 | EBP  | R/W       | Pointer to data on the stack (in the SS segment). |

RISC DSP Communication

**RDC**<sup>®</sup>

## 11.1.2 Segment Registers

Six 16-bit segment registers hold segment selector values identifying the currently addressable memory segments. In protected mode, each segment may range in size from one byte up to the entire linear and physical address space of the machine, which is 4 Gbytes (2<sup>32</sup> bytes). In real address mode, the maximum segment size is fixed at 64 Kbytes (2<sup>16</sup> bytes).

| Regis | ter Nam | ie: | Code se | egment l | Register | (CS) |   |   |   |   |   |   |   |   |   |
|-------|---------|-----|---------|----------|----------|------|---|---|---|---|---|---|---|---|---|
| Reset | Value:  |     |         |          |          |      |   |   |   |   |   |   |   |   |   |
| 15    | 14      | 13  | 12      | 11       | 10       | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |         |     |         |          |          |      | С | S |   |   |   |   |   |   |   |

|   | Bit  | Name | Attribute | Description                                                                                             |
|---|------|------|-----------|---------------------------------------------------------------------------------------------------------|
| 1 | 15-0 | CS   | R/W       | The Code Segment Register – CS holds the 16-bit code segment selector which points to the code segment. |

| -  | ter Nam<br>Value: | ne: | Stack se | egment | Register | (SS) |   |   |   |   |   |   |   |   |   |
|----|-------------------|-----|----------|--------|----------|------|---|---|---|---|---|---|---|---|---|
| 15 | 14                | 13  | 12       | 11     | 10       | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    | SS                |     |          |        |          |      |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                             |
|------|------|-----------|-------------------------------------------------------------------------|
| 15-0 | SS   | R/W       | The Stack Segment Register –SS holds the 16-bit stack segment selector. |

| Regis | ter Nam | ne:                                                                                                                                                            | Data se | gment F | Register | (DS) |   |   |   |   |   |   |   |   |   |
|-------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|----------|------|---|---|---|---|---|---|---|---|---|
| Reset | Value:  | Data segment Register (DS)            13       12       11       10       9       8       7       6       5       4       3       2       1       0         DS |         |         |          |      |   |   |   |   |   |   |   |   |   |
| 15    | 14      | 13                                                                                                                                                             | 12      | 11      | 10       | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |         |                                                                                                                                                                |         |         |          |      | D | S |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                     |
|------|------|-----------|-----------------------------------------------------------------|
| 15-0 | DS   | R/W       | The Data Segment Register – DS holds the data segment selector. |

|                                | RISC DSP Communication     | 32-Bi |
|--------------------------------|----------------------------|-------|
| Register Name:<br>Reset Value: | Data segment Register (ES) |       |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   | E | S |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                     |
|------|------|-----------|-----------------------------------------------------------------|
| 15-0 | ES   | R/W       | The Data Segment Register – ES holds the data segment selector. |

| -  | ter Nam<br>Value: | e: |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|-------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 15 | 14                | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |                   |    |    |    |    |   | F | S |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                     |
|------|------|-----------|-----------------------------------------------------------------|
| 15-0 | FS   | R/W       | The Data Segment Register – FS holds the data segment selector. |

| -  | ter Nam<br>Value: |    | Data seg | gment R | ≀egister ( | (GS) |   |    |   |   |   |   |   |   |   |
|----|-------------------|----|----------|---------|------------|------|---|----|---|---|---|---|---|---|---|
| 15 | 14                | 13 | 12       | 11      | 10         | 9    | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |                   |    |          |         |            |      | G | iS |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                     |
|------|------|-----------|-----------------------------------------------------------------|
| 15-0 | GS   | R/W       | The Data Segment Register – GS holds the data segment selector. |



IP

#### 11.1.3 Instruction Pointer Register

| Register Name: | Instruction Pointer (EIP) |
|----------------|---------------------------|
|                |                           |

Reset Value:

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

EIP

The instruction pointer is a 32-bit register named EIP.

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                     |
|------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | EIP  | R/W       | EIP holds the offset of the next instruction to be executed. The offset is always relative to the base of the code segment (CS). The lower 16 bits (bits 0-15) of the EIP contain the 16-bit instruction pointer named IP, which is used for 16-bit addressing. |

#### 11.1.4 Flags Register

 Register Name:
 Flags Register (EFLAGS)

 Reset Value:
 ------ 

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

| Rsvd | AC VM RF | Rsv<br>d NT | IOPL C | OF DF | IF T | F SF | ZF <sup>F</sup> | Rsv<br>d AF | Rsv<br>d | PF Rsv d | F |
|------|----------|-------------|--------|-------|------|------|-----------------|-------------|----------|----------|---|
|      |          |             |        |       | F    | LAGS |                 |             |          |          |   |
|      | EFL      | AGS         |        |       |      |      |                 |             |          |          |   |

The flags register is a 32-bit register named EFLAGS. The defined bits and bit fields within EFLAGS control certain operations and indicate the status of the R8610 RISC processor core. The lower 16 bits (bits 0-15) of EFLAGS contain the 16-bit register named FLAGS, which is most useful when the processor executes 8086 and 80286 codes.

EFLAGS bits 1, 3, 5, 15 and 19-31 are "undefined". When these bits are stored during interrupt processing or with a PUSHF instruction (push flags onto stack), a one is stored in bit 1 and zeros in bit 3, 5, 15 and 19-31.

| Bit   | Name | Attribute | Description |
|-------|------|-----------|-------------|
| 31-19 | Rsvd | RO        | Reserved.   |

|    |      |        | Alignment faults<br>odd address, a<br>reference to an<br>Alignment faults<br>is ignored at pri<br>selector loads)<br>instructions cau<br>through interrup                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ck.<br>bles the generation of faults if a rest<br>are enabled when AC is set to<br>dword access to an address that<br>address that is not on a 64-bit was<br>are only generated by program<br>vilege levels 0, 1 and 2. Note that<br>or the task state segment (TSS)<br>sing the reference are executed<br>ot 17, with an error code of 0. Tal<br>pocessor core data types.                                                                                                                                                                                                                                                                                                                                                             | 1. A misaligned address is a wo<br>at is not on a dword boundary, or<br>vord boundary.<br>Its running at privilege level 3. Th<br>at references to the descriptor ta<br>are implicitly level 0 references<br>at level 3. Alignment faults are | rd access to an<br>r an 8-byte<br>ne AC bit setting<br>ables (for<br>even if the<br>reported |  |  |  |
|----|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--|--|--|
|    |      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Memory Access                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Alignment (Byte Boundary)                                                                                                                                                                                                                     |                                                                                              |  |  |  |
|    |      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 2                                                                                                                                                                                                                                             |                                                                                              |  |  |  |
| 18 |      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Dword                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4                                                                                                                                                                                                                                             |                                                                                              |  |  |  |
| 10 | AC   | AC R/W |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Selector                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2                                                                                                                                                                                                                                             |                                                                                              |  |  |  |
|    |      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 48-bit Segmented Pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 4                                                                                                                                                                                                                                             |                                                                                              |  |  |  |
|    |      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 32-bit Flat Pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4                                                                                                                                                                                                                                             |                                                                                              |  |  |  |
|    |      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 32-bit Segmented Pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2                                                                                                                                                                                                                                             |                                                                                              |  |  |  |
|    |      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 48-bit "Pseudo-Descriptor"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 4                                                                                                                                                                                                                                             |                                                                                              |  |  |  |
|    |      |        | if their memory<br>global/internet<br>bytes from a "p<br>generate misal<br>RISC processo<br>has the proper                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | e, on this processor core, the S<br>ds/writes two bytes, and then<br>address. The R8610 RISC pro<br>ddress is on a 2 mod 4 bound                                                                                                              | GDT/SIDT (store<br>reads/writes four<br>ocessor core will<br>dary. The R8610                 |  |  |  |
| 17 | VM   | R/W    | The VM bit pro<br>processor core<br>handling segme<br>opcodes. The V<br>privilege level =<br>POPF. PUSHF<br>EFLAGS image                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | has the proper alignment.<br>Virtual 8086 Mode.<br>The VM bit provides virtual 8086 mode within protected mode. If set while the R8610 RISC<br>processor core is in protected mode, the processor core will switch to virtual 8086 operation,<br>handling segment loads as the 8086 does, but generating exception 13 faults on privileged<br>opcodes. The VM bit can be set only in protected mode, by the IRET instruction (if the current<br>privilege level = 0) and by task switches at any privilege level. The VM bit is unaffected by<br>POPF. PUSHF always pushes a 0 in this bit, even if executing in virtual 8086 mode. The<br>EFLAGS image pushed during interrupt processing or saved during task switches will contain a |                                                                                                                                                                                                                                               |                                                                                              |  |  |  |
| 16 | RF   | R/W    | 1 in this bit if the interrupted code was executing as a virtual 8086 task.<br>Resume Flag.<br>The RF flag is used in conjunction with the debug register breakpoints. It is checked at<br>instruction boundaries before breakpoint processing. When RF is set, it causes any debug fault<br>to be ignored on the next instruction. RF is then automatically reset at the successful<br>completion of every instruction (no faults are signaled) except the IRET instruction, the POPF<br>instruction, and JMP, CALL, and INT instructions causing a task switch. These instructions set<br>RF to the value specified by the memory image. For example, at the end of the breakpoint<br>service routine, the IRET instruction can pop an EFLAG image having the RF bit set and<br>resume the program's execution at the breakpoint address without generating another<br>breakpoint fault on the same location. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                               |                                                                                              |  |  |  |
| 15 | Rsvd | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                               |                                                                                              |  |  |  |
| 14 | NT   | R/W    | nested within au<br>(TSS) has a va<br>transfers to oth<br>determine whe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                               |                                                                                              |  |  |  |



| 13-12 | IOPL | R/W | Input/Output Privilege Level.<br>This two-bit field applies to Protected Mode. IOPL indicates the numerically maximum CPL (current privilege level) value permitted to execute I/O instructions without generating an exception 13 faults or consulting the I/O Permission Bitmap. It also indicates the maximum CPL value allowing alteration of the IF (INTR Enable Flag) bit when new values are popped into the EFLAG register. POPF and IRET instructions can alter the IOPL field when executed at CPL = 0. Task switches can always alter the IOPL field when the new flag image is loaded from the |
|-------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11    | OF   | R/W | incoming task's TSS.<br>Overflow Flag.<br>OF is set if the operation resulted in signed overflow. Signed overflow occurs when the<br>operation resulted in carry/borrow into the sign bit (high-order bit) of the result but did not result<br>in a carry/borrow out of the high-order bit, or vice-versa. For 8-, 16- and 32-bit operations, OF is<br>set according to overflow at bit 7, 15 and 31 respectively.                                                                                                                                                                                         |
| 10    | DF   | R/W | Direction Flag.<br>DF defines whether ESI and/or EDI register postdecrement or postincrement during the string instructions. Postinstruction occurs if DF is reset. Post decrement occurs if DF is set.                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9     | IF   | R/W | INTR Enable Flag.<br>The IF flag, when set, allows recognition of external interrupts signaled on the INTR pin. When<br>IF is reset, external interrupts signaled on the INTR are not recognized. IOPL indicates the<br>maximum CPL value allowing alteration of the IF bit when new values are popped into EFLAGS<br>or FLAGS.                                                                                                                                                                                                                                                                            |
| 8     | TF   | R/W | Trap Enable Flag.<br>TF controls the generation of exception 1 trap when single-stepping through code. When TF is set, the R8610 RISC processor core generates an exception 1 trap after the next instruction is executed. When TF is reset, exception 1 traps occur only as a function of the breakpoint addresses loaded into debug registers DR[0:3].                                                                                                                                                                                                                                                   |
| 7     | SF   | R/W | Sign Flag.<br>SF is set if the high-order bit of the result is set, it is reset otherwise. For 8-, 16- and 32-bit operations, SF reflects the state of bit 7, 15 and 31 respectively.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6     | ZF   | R/W | Zero Flag.<br>ZF is set if all bits of the result are 0. Otherwise it is reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5     | Rsvd | RO  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4     | AF   | R/W | Auxiliary Carry Flag.<br>The Auxiliary Flag is used to simplify the addition and subtraction of packed BCD quantities. AF<br>is set if the operation results in a carry out of bit 3 (addition) or a borrow into bit 3 (subtraction).<br>Otherwise AF is reset. AF is affected by carry out of, or borrow into bit 3 only, regardless of<br>overall operand length: 8, 16 or 32 bits.                                                                                                                                                                                                                      |
| 3     | Rsvd | RO  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2     | PF   | R/W | Parity Flags.<br>PF is set if the low-order eight bits of the operation contain an even number of "1"s (even parity). PF is reset if the low-order eight bits have odd parity. PF is a function of only the low-order eight bits, regardless of operand size.                                                                                                                                                                                                                                                                                                                                              |
| 1     | Rsvd | RO  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0     | CF   | R/W | Carry Flag.<br>CF is set if the operation results in a carry out of (addition), or a borrow into (subtraction) the<br>high-order bit. Otherwise CF is reset. For 8-, 16- or 32-bit operations, CF is set according to<br>carry/borrow at bit 7, 15 or 31 respectively.                                                                                                                                                                                                                                                                                                                                     |



### 11.1.5 Control Registers

| R  | egis | ter I | Nam | ne: |    | Con | Control Register 0 (CR0) |     |    |    |    |    |    |          |    |    |    |    |    |    |     |   |    |    |   |    |          |    |    |    |    |
|----|------|-------|-----|-----|----|-----|--------------------------|-----|----|----|----|----|----|----------|----|----|----|----|----|----|-----|---|----|----|---|----|----------|----|----|----|----|
| R  | eset | Val   | ue: |     |    |     |                          |     |    |    |    |    |    |          |    |    |    |    |    |    |     |   |    |    |   |    |          |    |    |    |    |
| 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  |
| РС | CD   | NW    |     |     |    |     | R                        | svd |    |    |    |    | АМ | Rsv<br>d | WP |    |    |    |    | Rs | svd |   |    |    |   | NE | Rsv<br>d | тs | EM | MP | PE |
|    |      |       |     |     |    |     |                          |     |    |    |    |    |    |          |    |    |    |    |    |    |     |   | MS | SW |   |    |          |    |    |    |    |

CR0 contains 10 bits for control and status purposes. The function of the bits in CR0 can be categorized as follows:

R8610 RISC Processor Core Operating Modes: PG, PE (Table 5.2)

On-Chip Cache Control Modes: CD, NW (Table 5.3)

On-Floating Point Unit Control: TS, EM, MP, NE (Table 5.4)

Alignment Check Control: AM

Supervisor Write Protect: WP

## Table 11.2. R8610 RISC Processor Core Operating Modes

| PG | PE | Mode                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0  | 0  | REAL Mode. Exact 8086 semantics, with 32-bit extensions available with prefixes.                                                                                                                                                                                           |  |  |  |  |  |
| 0  | 1  | Protected Mode. Exact 80286 semantics, plus 32-bit extensions through both prefixes and "default" prefix setting associated with code segment descriptors. Also, a submode is defined to support a virtual 8086 within the context of the extended 80286 protection model. |  |  |  |  |  |
| 1  | 0  | UNDEFINED. Loading CR0 with this combination of PG and PE bits will raise a GP fault with error code 0.                                                                                                                                                                    |  |  |  |  |  |
| 1  | 1  | Paged Protected Mode. All the facilities of Protected mode, with paging enabled underneath segmentation.                                                                                                                                                                   |  |  |  |  |  |

#### Table 11.3 On-Chip Cache Control Modes

| CD | NW | Operating Mode                                                                                   |  |  |  |  |  |
|----|----|--------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 1  | 1  | Cache fills disabled, write-through and invalidates disabled.                                    |  |  |  |  |  |
| 1  | 0  | Cache fills disabled, write-through and invalidates enabled.                                     |  |  |  |  |  |
| 0  | 1  | INVALID. If CR0 is loaded with this configuration of bits, a GP fault with error code is raised. |  |  |  |  |  |
| 0  | 0  | Cache fills enabled, write-through and invalidates enabled.                                      |  |  |  |  |  |

#### Table 11.4 R8610 RISC Processor Core Floating Point Instruction Control

|    | CR0 BIT |    | Instruction Type |         |  |  |  |  |
|----|---------|----|------------------|---------|--|--|--|--|
| EM | TS      | MP | Floating-Point   | Wait    |  |  |  |  |
| 0  | 1       | 0  | Trap 7           | Execute |  |  |  |  |
| 0  | 1       | 1  | Trap 7           | Trap 7  |  |  |  |  |
| 1  | 0       | 0  | Trap 7           | Execute |  |  |  |  |
| 1  | 0       | 1  | Trap 7           | Execute |  |  |  |  |
| 1  | 1       | 0  | Trap 7           | Execute |  |  |  |  |
| 1  | 1       | 1  | Trap 7           | Trap 7  |  |  |  |  |

The low-order 16 bits of CR0 are also known as the Machine Status Word (MSW), for compatibility with the 80286 protected mode. LMSW and SMSW (load and store MSW) instructions are taken as special aliases of the load and store CR0 operations, where only the low-order 16 bits of CR0 are involved. The LMSW and SMSW instructions in the R8610 RISC processor core work in an identical fashion to the LMSW and SMSW instructions in the 80286 (i.e., they only operate on the low-order 16 bits of CR0 and ignore the new bits). New R8610 RISC processor core operating systems should use the MOV CR0, Reg instruction.

The defined CR0 bits are described below.

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | PG   | R/W       | Paging Enable.<br>The PG bit is used to indicate whether paging is enabled (PG = 1) or disabled (PG = 0). See<br>Table 5.2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 30    | CD   | R/W       | Cache Disable.<br>The CD bit is used to enable the on-chip cache. When CD = 1, the cache will not be filled on cache misses. When CD = 0, cache fills may be performed on misses. See Table 5.3.<br>The state of the CD bit, the cache enable input pin (KEN_n), and the relevant page cache disable (PCD) bit determine if a line read in response to a cache miss will be installed in the cache. A line is installed in the cache only if CD = 0 and KEN_n and PCD are both zero. The relevant PCD bit comes from either the page table entry, page directory entry or control register 3. Refer to Section 5.6 for more details on page cacheability.<br>CD is set to one after RESET.                    |
| 29    | NW   | R/W       | Not Write-Through.<br>The NW bit enables on-chip cache write-through and write-invalidate cycles (NW = 0). When<br>NW = 0, all writes, including cache hits, are sent out to the pins. Invalidate cycles are enabled<br>when NW = 0. During an invalidate cycle, a line will be removed from the cache if the invalidate<br>address hits in the cache. See Table 5.3.<br>When NW = 1, write-through and write-invalidate cycles are disabled. A write will not be sent to<br>the pins if the write hits in the cache. With NW = 1, the only write cycles that reach the external<br>bus are cache misses. Write hits with NW = 1 will never update main memory. Invalidate cycles<br>are ignored when NW = 1. |
| 28-19 | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 18    | AM   | R/W       | Alignment Mask.<br>The AM bit controls whether the alignment check (AC) bit in the flag register (EFLAGS) can<br>allow an alignment fault. AM = 0 disables the AC bit. AM = 1 enables the AC bit. AM = 0 is the<br>386 MicroController compatible mode.<br>The 386 MicroController software may load incorrect data into the AC bit in the EFLAGS<br>register. Setting AM = 0 will prevent AC faults from occurring before the R8610 RISC processor<br>core has created the AC interrupt service routine.                                                                                                                                                                                                     |
| 17    | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16    | WP   | R/W       | Write Protect.<br>WP protects read-only pages from supervisor write access. The 386 MicroController allows a read-only page to be written from privilege level 0-2. The R8610 RISC processor core is compatible with the 386 MicroController when WP = 0. WP = 1 forces a fault on a write to a read-only page from any privilege level. Operating systems with Copy-on-Write features can be supported with the WP bit. Refer to Section 5.5.3 for further details on use of the WP bit.                                                                                                                                                                                                                     |
| 15-6  | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5     | NE   | R/W       | Numerics Exception.<br>For the R8610 RISC processor core, interrupt 7 will be generated upon encountering any floating-point instruction regardless of the value of the NE bit. It is recommended that NE = 1 for normal operation of the R8610 RISC processor core.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4     | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3     | TS   | R/W       | Task Switch.<br>The TS bit is set whenever a task switch operation is performed. Execution of floating point<br>instructions with TS = 1 will cause a "device not available" (DNA) fault (trap vector 7). With MP<br>= 0, the value of the TS bit is a "don't care" for the WAIT instructions, i.e., these instructions will<br>not generate trap 7.                                                                                                                                                                                                                                                                                                                                                          |



| 2 | EM | R/W | Emulate Coprocessor.<br>The EM bit should be set to one for the R8610 RISC processor core. This will cause the processor core to trap via interrupt vector 7 (Device Not Available) to a software exception handler whenever it encounters a floating-point instruction. If EM bit is 0, the system will hang.    |
|---|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | MP | R/W | Monitor Coprocessor.<br>For normal operation of the R8610 RISC processor core, it is required to set this bit as zero $(MP = 0)$ . The MP bit is used in conjunction with the TS bit to determine if WAIT instructions should trap. For MP = 0, the value of TS is a "don't care" for these type of instructions. |
| 0 | PE | R/W | Protection Enable.<br>The PE bit enables the segment based protection mechanism. If PE = 1, protection is enabled.<br>When PE = 0, the R8610 RISC processor core operates in REAL mode, with segment based<br>protection disabled, and addresses formed as in an 8086. Refer to Table 5.2.                        |

| Register Name: | Control Register 1 (CR1) |
|----------------|--------------------------|
| Reset Value:   |                          |

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

CR1

| Bit  | Name | Attribute | Description                                                                         |
|------|------|-----------|-------------------------------------------------------------------------------------|
| 31-0 | CR1  |           | Control Register 1.<br>CR1 is reserved for use in the oncoming RDC MicroController. |

| Register Name: | Control Register 2 (CR2) |
|----------------|--------------------------|
| Reset Value:   |                          |

| 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 |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|

## CR2

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                             |
|------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | CR2  | R/W       | Control Register 2. (Page Fault Linear Address Register)<br>CR2 holds the 32-bit linear address that caused the last page fault detected. The error code<br>pushed onto the page fault handler's stack when it is invoked provides additional status<br>information on this page fault. |



0

| R  | Register Name: |     |     |    |    | Con | trol | Reg | giste | r 3 ( | CR3 | 3) |    |    |    |    |    |    |    |    |    |   |      |   |   |   |         |         |   |      |   |
|----|----------------|-----|-----|----|----|-----|------|-----|-------|-------|-----|----|----|----|----|----|----|----|----|----|----|---|------|---|---|---|---------|---------|---|------|---|
| R  | eset           | Val | ue: |    |    |     |      |     |       |       |     |    |    |    |    |    |    |    |    |    |    |   |      |   |   |   |         |         |   |      |   |
| 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    |   |
|    |                |     |     |    |    |     |      |     | PD    | BR    |     |    |    |    |    |    |    |    |    |    |    |   | Rsvo | ł |   |   | PC<br>D | PW<br>T |   | Rsvo | d |

CR3 contains the physical base address of the page directory table. The page directory is always page aligned (4 Kbyte-aligned).

In the R8610 RISC processor core, CR3 contains two bits, page write-through (PWT, bit 3) and (PCD, bit 4), which control page cacheability. The page table entry (PTE) and page directory entry (PDE) also contain PWT and PCD bits. When a page is accessed in external memory, the state of PWT and PCD are driven out on the PWT and PCD pins. The source of PWT and PCD can be CR3, the PTE or the PDE. PWT and PCD are sourced from CR3 when the PDE is being updated. When paging is disabled (PG = 0 in CR0), PCD and PWT are assumed to be 0, regardless of their state in CR3.

A task switch through a task state segment (TSS) which changes the values in CR3, or an explicit load into CR3 with any value, will invalidate all cached page table entries in the translation look aside buffer (TLB).

The page directory base address in CR3 is a physical address. The page directory can be paged out while its associated task is suspended, but the operating system must ensure that the page directory is resident in physical memory before the task is dispatched. The entry in the TSS for CR3 has a physical address, with no provision for a present bit. This means that the page directory for a task must be resident in physical memory. The CR3 image in a TSS must point to this area, before the task can be dispatched through its TSS.

| Bit   | Name | Attribute | Description                                                                                                                                                        |
|-------|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12 | PDBR | R/W       | Page Directory Base Register.<br>The page directory is always page aligned (4 Kbyte-aligned). This alignment is enforced by the<br>only storing bits 20-31 in CR3. |
| 11-5  | Rsvd | RO        | Reserved.                                                                                                                                                          |
| 4     | PCD  | R/W       | Page Cache Disable.                                                                                                                                                |
| 3     | PWT  | R/W       | Page Write-Through.                                                                                                                                                |
| 2-0   | Rsvd | RO        | Reserved.                                                                                                                                                          |



#### 11.1.6 System Address Registers

Four special registers are defined to reference the tables or segments supported by the R8610 RISC processor core protection model. These tables or segments are:

GDT (Global Descriptor Table) IDT (Interrupt Descriptor Table)

LDT (Local Descriptor Table)

TSS (Task State Segment)

The address of these tables and segments are stored in special registers, the System Address and System Segment Registers. These registers are named GDTR, IDTR, LDTR and TR respectively.

| Register Name: | Global Descriptor Table Register (GDTR) |
|----------------|-----------------------------------------|
| Reset Value:   |                                         |

| 47 | 16   | 15    | 0 |
|----|------|-------|---|
|    | GLBA | GLIMT |   |

The GDTR holds the 32-bit linear base address and 16-bit limit of the GDT, respectively.

Since the GDT segments are global to all tasks in the system, the GDT are defined by 32-bit linear addresses (subject to page transition if paging is enabled) and 16-bit limit values.

| Bit   | Name | Attribute | Description                                                                                             |
|-------|------|-----------|---------------------------------------------------------------------------------------------------------|
| 47-16 | GLBA |           | Linear Base addresses of GDT.<br>This field saves the 32-bit linear address of Global Descriptor Table. |
| 15-0  | GLMT |           | Limit of GDT.<br>This field saves the 16-bit limit values of Global Descriptor Table.                   |

| Register Name: | Interrupt Descriptor Table Register | (IDTR) |
|----------------|-------------------------------------|--------|
|                |                                     |        |

\_\_\_\_\_

**Reset Value:** 

| 47 | 16   | 15 0  |
|----|------|-------|
|    | ILBA | ILIMT |

The IDTR holds the 32-bit linear base address and 16-bit limit of the IDT, respectively.

Since the IDT segments are global to all tasks in the system, the IDT are defined by 32-bit linear addresses (subject to page transition if paging is enabled) and 16-bit limit values.

|   | Bit   | Name | Attribute | Description                                                                                                |
|---|-------|------|-----------|------------------------------------------------------------------------------------------------------------|
| Ē | 47-16 | ILBA |           | Linear Base addresses of IDT.<br>This field saves the 32-bit linear address of Interrupt Descriptor Table. |
|   | 15-0  | ILMT |           | Limit of IDT.<br>This field saves the 16-bit limit values of Interrupt Descriptor Table.                   |



| Register Name: |        |    | Local De | Local Descriptor Table Register (LDTR) |    |   |   |   |   |   |   |   |   |   |   |
|----------------|--------|----|----------|----------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| Reset          | Value: |    |          |                                        |    |   |   |   |   |   |   |   |   |   |   |
| 15             | 14     | 13 | 12       | 11                                     | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                | LDTS   |    |          |                                        |    |   |   |   |   |   |   |   |   |   |   |

The LDTR holds the 16-bit selector for the LDT descriptor.

Since the LDT segment is task specific segment, the LDT are defined by selector value stored in the system segment register.

| Bit  | Name | Attribute | Description                                                                               |
|------|------|-----------|-------------------------------------------------------------------------------------------|
| 16-0 | LDTS | R/W       | Selector of LDT descriptor.<br>The LDTR holds the 16-bit selector for the LDT descriptor. |

| -  | ter Nam<br>Value: | ie: | Task Sta | ate Segr | nent Reg | gister (T | SSR) |    |   |   |   |   |   |   |   |
|----|-------------------|-----|----------|----------|----------|-----------|------|----|---|---|---|---|---|---|---|
| 15 | 14                | 13  | 12       | 11       | 10       | 9         | 8    | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |                   |     |          |          |          |           | TS   | SS |   |   |   |   |   |   |   |

The TSSR holds the 16-bit selector for the TSS descriptor.

Since the TSS segment is task specific segment, the TSS is defined by selector value stored in the system segment register.

| Bit  | Name | Attribute | Description                                                                               |
|------|------|-----------|-------------------------------------------------------------------------------------------|
| 16-0 | TSSS |           | Selector of TSS descriptor.<br>The TSSR holds the 16-bit selector for the TSS descriptor. |

## 11.2 I/O Mapped Registers

### 11.2.1 PCI Configuration Registers

| I/C | ) Pc | ort:  |                                             |      |    | CF8 | CF8h Accessed as a Dword |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |    |     |
|-----|------|-------|---------------------------------------------|------|----|-----|--------------------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----|-----|
| Re  | egis | ter l | er Name: PCI Configuration Address Register |      |    |     |                          |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |    |     |
| Re  | eset | : Val | ue:                                         |      |    | 000 | 000                      | 00h |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |    |     |
| 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   |
| CE  |      |       |                                             | Rsvo | I  |     |                          |     |    |    | В  | N  |    |    |    |    |    | DN |    |    |    | FN |   |   |   | R | N |   |   | R٤ | svd |

Configuration Address Register is a 32-bit register accessed only when referenced as a Dword. A byte or word reference will pass through the Configuration Address Register onto the PCI bus as an I/O cycle.

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | CE   | R/W       | Configuration Enable.<br>When this bit is set to 1, accesses to PCI configuration space are enabled. If this bit is reset to 0, accesses to PCI configuration space are disabled.                                                                                                                                                                                                                                                                                                         |
| 30-24 | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 23-16 | BN   | R/W       | Bus Number.<br>When the bus number is programmed to 00h, the target of the configuration cycle is either the<br>North-Bridge or the PCI Device that is connected to the North-Bridge. If the bus number is<br>programmed to 00h and the North-Bridge is not the target, a Type 0 configuration cycle is<br>generated on PCI Bus. IF the bus number is non-zero, a Type 1 configuration cycle is<br>generated on PCI bus with the bus number mapped to AD[23:16] during the address phase. |
| 15-11 | DN   | R/W       | Device Number.<br>This field selects one agent on the PCI bus. During a Type 1 configuration cycle, this field is<br>mapped to AD[15:11]. During a Type 0 configuration cycle, this field is decoded and one of<br>AD[31:11] is driven to 1. The R8870 is always Device number 0.                                                                                                                                                                                                         |
| 10-8  | FN   | R/W       | Function Number.<br>This field allows the configuration registers of a particular function in a multi-function device to<br>be accessed. The R8610 North Bridge only responds to configuration cycle with a function<br>number of 000b.                                                                                                                                                                                                                                                   |
| 7-2   | RN   | R/W       | Register Number.<br>This field selects one register within a particular Bus, Device, and Function as specified by the<br>other fields in the Configuration Address Register.                                                                                                                                                                                                                                                                                                              |
| 1-0   | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |



| I/O Port:      | CFCh      | Accessed as a Dword     |
|----------------|-----------|-------------------------|
| Register Name: | PCI Confi | iguration Data Register |
| Reset Value:   | 00000000  | Dh                      |

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

CDR

Configuration Data Register is a 32-bit read/write window into configuration space. The portion of configuration space that is referenced by Configuration Data Register is determined by the contents of Configuration Address Register.

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | CDR  | R/W       | If bit 31 of PCI Configuration Address Register is 1, any I/O reference that falls in the PCI Configuration Data Register space is mapped to configuration space using the contents of PCI Configuration Address Register. |

### 11.2.2 Slave DMA Control Registers

| I/O Port:      | 00h                                               |
|----------------|---------------------------------------------------|
| Register Name: | Slave DMA Channel 0 Base/Current Address Register |
| Reset Value:   |                                                   |

| 7 | 6 | 5 | 4  | 3   | 2 | 1 | 0 |
|---|---|---|----|-----|---|---|---|
|   |   |   | BA | /CA |   |   |   |

| Bit | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | BA/CA | R/W       | Read: Current Address Register<br>Read the 16-bit Current Address Register for DMA channel 0. The first 8-bit read will return the<br>low portion of the word, and the second read will return the upper portion of the word.<br>The current Address Register holds the current memory address used in a DMA transfer. It is<br>automatically incremented or decremented after each DMA memory transfer.<br>Write: Base and Current Address Register<br>Two sequential 8-bit I/O writes load a 16-bit value into this register. The first 8-bit write loads the<br>low portion of the word, and the second 8-bit write loads the high portion of the word. The Base<br>Address Register is Write-Only.<br>The Base Address Register is used to hold the original value of the Current Address Register,<br>and is not incremented or decremented during the DMA transfer. |

# 

| I/O Port:      | 01h                                    |
|----------------|----------------------------------------|
| Register Name: | Slave DMA Channel 0 Base/Current Count |
| Reset Value:   |                                        |

7 6 5 4 3 2 1 0 BC/CC

| Bit | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | BC/CC | R/W       | Read: Current Count Register<br>Read the 16-bit Current Count Register for DMA channel 0. The first 8-bit read will<br>return the low portion of the word, and the second read will return the upper portion of<br>the word.<br>The Current Count Register holds 1 plus the remaining number of transfers to occur.<br>A value of 100h indicates 101h transfers remain. This register is decremented after<br>each transfer. When the register rolls from 0 to FFFFh, the transfer is complete.<br>Write: Base and Current Count Register<br>Two sequential 8-bit I/O writes load a 16-bit value into this register. The first 8-bit write<br>loads the low portion of the word, and the second 8-bit write loads the high portion of<br>the word. The Base Count Register is Write-Only.<br>The Base Count Register is used to hold the original value of the Current Count<br>Register. |

| I/O Port:<br>Register Name:<br>Reset Value: |   |   | 02h<br>Slave DMA Channel 1 Base/Current Address Regi<br> |     |   |   |   |  | gister |
|---------------------------------------------|---|---|----------------------------------------------------------|-----|---|---|---|--|--------|
| 7                                           | 6 | 5 | 4                                                        | 3   | 2 | 1 | 0 |  |        |
|                                             |   |   | BA                                                       | /CA |   |   |   |  |        |

The definitions of bit[7:0] for Slave DMA Channel 1 Base/Current Address are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Address Register at I/O address 00h.

| I/O Port:<br>Register Name:<br>Reset Value: |   |   | 03h<br>Slave DMA Channel 1 Base/Current Count Registe |     |   |   |   |  |  |
|---------------------------------------------|---|---|-------------------------------------------------------|-----|---|---|---|--|--|
| 7                                           | 6 | 5 | 4                                                     | 3   | 2 | 1 | 0 |  |  |
|                                             |   |   | BC                                                    | /CC |   |   |   |  |  |

The definitions of bit[7:0] for Slave DMA Channel 1 Base/Current Count are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Count Register at I/O address 01h.



| I/O Port:      |   |   | 04h                                               |     |   |   |   |  |  |
|----------------|---|---|---------------------------------------------------|-----|---|---|---|--|--|
| Register Name: |   |   | Slave DMA Channel 2 Base/Current Address Register |     |   |   |   |  |  |
| Reset Value:   |   |   |                                                   |     |   |   |   |  |  |
| 7              | 6 | 5 | 4                                                 | 3   | 2 | 1 | 0 |  |  |
|                |   |   | BA                                                | /CA |   |   |   |  |  |

The definitions of bit[7:0] for Slave DMA Channel 2 Base/Current Address are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Address Register at I/O address 00h.

| Regis | I/O Port:<br>Register Name:<br>Reset Value: |   | 05h<br>Slave DMA Channel 2 Base/Current Count Regi<br> |     |   |   |   |  | er |
|-------|---------------------------------------------|---|--------------------------------------------------------|-----|---|---|---|--|----|
| 7     | 6                                           | 5 | 4                                                      | 3   | 2 | 1 | 0 |  |    |
|       |                                             |   | BC                                                     | /CC |   |   |   |  |    |

The definitions of bit[7:0] for Slave DMA Channel 2 Base/Current Count are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Count Register at I/O address 01h.

| I/O Port:<br>Register Name:<br>Reset Value: |   |   | 06h<br>Slave DMA Channel 3 Base/Current Address Register<br> |     |   |   |   |  |  |
|---------------------------------------------|---|---|--------------------------------------------------------------|-----|---|---|---|--|--|
| 7                                           | 6 | 5 | 4                                                            | 3   | 2 | 1 | 0 |  |  |
|                                             |   |   | BA                                                           | /CA |   |   |   |  |  |

The definitions of bit[7:0] for Slave DMA Channel 3 Base/Current Address are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Address Register at I/O address 00h.

| I/O Port:      |  |  | 07h                                             |   |   |   |   |  |  |
|----------------|--|--|-------------------------------------------------|---|---|---|---|--|--|
| Register Name: |  |  | Slave DMA Channel 3 Base/Current Count Register |   |   |   |   |  |  |
| Reset Value:   |  |  |                                                 |   |   |   |   |  |  |
| 7 6 5          |  |  | 4                                               | 3 | 2 | 1 | 0 |  |  |
| BC/CC          |  |  |                                                 |   |   |   |   |  |  |

The definitions of bit[7:0] for Slave DMA Channel 3 Base/Current Count are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Count Register at I/O address 01h.

| I/O Port:      | 08h                               |
|----------------|-----------------------------------|
| Register Name: | Slave DMA Status/Command Register |
| Reset Value:   | 0000010b/00x0x0x0                 |

### **READ: Status Register**

The Status register is available to be read out of the 82C37A by the MicroController. It contains information about the status of the devices at this point. This information includes which channels have reached a terminal count and which channels have pending DMA requests. Bit 0-3 are set every time a TC is reached by that channel or an external EOP is applied. These bits are cleared upon RESET, Master Clear, and on each Status Read. Bits 4-7 are set whenever their corresponding channel is requesting service, regardless of the mask bit state. If the mask bits are set, the Status register can be polled by software to determine which channels have DREQs, and selectively clear a mask bit, thus allowing user defined service priority. Status bit 4-7 are updated while the clock is high, and latched on the falling edge. Status Bit 4-7 are cleared upon RESET or Master Clear.

| 7     | 6     | 5     | 4     | 3    | 2    | 1    | 0    |
|-------|-------|-------|-------|------|------|------|------|
| C3REQ | C2REQ | C1REQ | COREQ | C3TC | C2TC | C1TC | COTC |

| Bit | Name  | Attribute | Description                                  |
|-----|-------|-----------|----------------------------------------------|
| 7   | C3REQ | R         | = 1 DMA Channel 0 request                    |
| 6   | C2REQ | R         | = 1 DMA Channel 0 request                    |
| 5   | C1REQ | R         | = 1 DMA Channel 0 request                    |
| 4   | COREQ | R         | = 1 DMA Channel 0 request                    |
| 3   | C3TC  | R         | = 1 DMA Channel 3 has reached terminal count |
| 2   | C2TC  | R         | = 1 DMA Channel 2 has reached terminal count |
| 1   | C1TC  | R         | = 1 DMA Channel 1 has reached terminal count |
| 0   | COTC  | R         | = 1 DMA Channel 0 has reached terminal count |

#### Write: Command Register

This 8-bit register controls the operation of the DMA. The register is cleared by a hardware reset or a Master Disable instruction (port 0Dh). The command value used by PCs is 0. Normally all bits are left at 0, except bit 2 is typically set to 1 to disable the controller while writing to DMA registers. This register is a write-only.

| 7     | 6     | 5  | 4   | 3   | 2   | 1  | 0   |
|-------|-------|----|-----|-----|-----|----|-----|
| ACKSL | REQSL | WS | PRI | TIM | CTL | AH | MMT |

| Bit | Name  | Attribute | Description                                                                                                                    |
|-----|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------|
| 7   | ACKSL | W         | = 1: DACK sense active high<br>= 0: DACK sense active low                                                                      |
| 6   | REQSL | W         | = 1: DREQ sense active low<br>= 0: DREQ sense active high                                                                      |
| 5   | WS    | W         | = 1: Extended write selection<br>= 0: Late write selection<br>= X: if bit-3 = 0                                                |
| 4   | PRI   | W         | = 1: Rotating priority<br>= 0: Fixed priority                                                                                  |
| 3   | TIM   | W         | = 1: Compressed timing<br>= 0: Normal timing<br>= X: if bit-1 = 0                                                              |
| 2   | CTL   | W         | = 1: Control disable<br>= 0: Control enable                                                                                    |
| 1   | AH    | W         | <ul> <li>= 1: Channel 0 address hold enable</li> <li>= 0: Channel 0 address hold disable</li> <li>= X: if bit-0 = 0</li> </ul> |
| 0   | MMT   | W         | = 1: Memory-to-memory transfers enable<br>= 0: Memory-to-memory transfers disable                                              |

| I/O Po        | ort:    |     | 09h                        |  |    |   |   |  |
|---------------|---------|-----|----------------------------|--|----|---|---|--|
| Regis         | ter Nam | ie: | Slave DMA Request Register |  |    |   |   |  |
| Reset         | Value:  |     |                            |  |    |   |   |  |
| 7 6 5 4 3 2 1 |         |     |                            |  |    | 1 | 0 |  |
| Reserved      |         |     |                            |  | SR | C | S |  |

In addition to initiating a request for DMA service by asserting a hardware request line, software can also initiate a DMA request. The Request Register is used to both set and clear any channel's request bit. The DMA controller does need to be in Block mode to use this function, as set in the Mode Register (port 0Bh). This register is write-only.

| Bit | Name | Attribute | Description                                                                                                                                |  |  |  |  |  |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7-3 | Rsvd | RO        | Reserved                                                                                                                                   |  |  |  |  |  |
| 2   | SR   |           | = 1: Set request bit<br>= 0: Clear request bit                                                                                             |  |  |  |  |  |
| 1-0 | CS   | 1/1/      | <ul> <li>= 00: Channel 0 select</li> <li>= 01: Channel 1 select</li> <li>= 10: Channel 2 select</li> <li>= 11: Channel 3 select</li> </ul> |  |  |  |  |  |

Rsvd

| I/O Po       | rt:     |     | 0Ah                     |   |   |   |  |  |
|--------------|---------|-----|-------------------------|---|---|---|--|--|
| Regist       | ter Nan | ne: | Slave DMA Mask Register |   |   |   |  |  |
| Reset Value: |         |     |                         |   |   |   |  |  |
| 7            | 6       | 5   | 4                       | 3 | 2 | 1 |  |  |

The mask register is used to disable or enable individual incoming requests. Setting a mask bit on disables the selected channel. Hardware reset disables all channels by setting all mask bits.

0

CS

SM

| Bit | Name | Attribute | Description                                                                                                                                |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 7-3 | Rsvd | RO        | Reserved                                                                                                                                   |
| 2   | SM   | 10/       | = 1: Set mask bit<br>= 0: Clear mask bit                                                                                                   |
| 1-0 | CS   | W         | <ul> <li>= 00: Channel 0 select</li> <li>= 01: Channel 1 select</li> <li>= 10: Channel 2 select</li> <li>= 11: Channel 3 select</li> </ul> |

| I/O Po       | ort:    |    | 0Bh                     |   |   |   |  |  |
|--------------|---------|----|-------------------------|---|---|---|--|--|
| Regis        | ter Nam | e: | Slave DMA Mode Register |   |   |   |  |  |
| Reset Value: |         |    |                         |   |   |   |  |  |
| 7            | 6       | 5  | 4                       | 3 | 2 | 1 |  |  |

| 7  | 6 | 5     | 4   | 3 | 2 | 1 | 0 |
|----|---|-------|-----|---|---|---|---|
| MT |   | AD/AI | ATI | Т | Т | C | S |

The Mode Register indicates the mode of operation for each of the four DMA channel 0 to 3. Each channel has a separate 6-bit mode register and each is loaded through the Mode Register port.

| Bit | Name  | Attribute | Description                                                                                                                                                   |  |  |  |
|-----|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7-6 | МТ    | W         | Mode Type Selection.<br>= 00: Demand mode<br>= 01: Single mode<br>= 10: Block mode<br>= 11: Cascade mode                                                      |  |  |  |
| 5   | AD/AI | w         | = 1: Address decrement select<br>= 0: Address increment select                                                                                                |  |  |  |
| 4   | ATI   | w         | <ul> <li>1: Autoinitialization enable</li> <li>0: Autoinitialization disable</li> </ul>                                                                       |  |  |  |
| 3-2 | TT    | w         | Transfer Type.<br>= 00: Verify operation<br>= 01: Write operation<br>= 10: Read operation<br>= 11: not valid<br>= xx: if they are in cascade mode (bit 6 & 7) |  |  |  |
| 1-0 | CS    | W         | Channel Selection.<br>= 00: Channel 0 select<br>= 01: Channel 1 select<br>= 10: Channel 2 select<br>= 11: Channel 3 select                                    |  |  |  |

| I/O Port     | t:      |   | 0Ch                                               |   |   |   |   |  |
|--------------|---------|---|---------------------------------------------------|---|---|---|---|--|
| Registe      | er Name | : | Slave DMA Set/Clear First/Last Clear F/F Register |   |   |   |   |  |
| Reset Value: |         |   |                                                   |   |   |   |   |  |
| 7            | 6       | 5 | 4                                                 | 3 | 2 | 1 | 0 |  |

CFF

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | CFF  | W         | Any value to this port causes the internal First/Last flip-flop to be cleared in DMA controller 1. This is done before any 8-bit reads or writes to 16-bit registers that require two successive 8-bit port accesses to complete the word transfer. After the flip-flop is cleared, a 16-bit DMA register is accessed by reading or writing the low byte followed by the high byte. The flip-flop can only be cleared, and is not readable. |

## I/O Port: 0Dh

| Register Name: | Slave DMA Temporary/Master Disable Register |
|----------------|---------------------------------------------|
| Reset Value:   |                                             |
|                |                                             |

| 7 | 6 | 5 | 4   | 3  | 2 | 1 | 0 |
|---|---|---|-----|----|---|---|---|
|   |   |   | TP/ | MD |   |   |   |

| Bit | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | TP/MD | R/W       | Read: Temporary Register.<br>The Temporary Register holds data during memory-to-memory data transfers. After the transfer<br>is complete, the Temporary Register holds the last data transfer. The Temporary Register can<br>be read when the DMA controller is not performing a DMA transfer. The register is cleared by a<br>reset.<br>Write: Master Disable Register.<br>Writing any value to this port resets the DMA controller. This command has the same action as<br>a hardware reset. The mask register is set (channel 0 to 3 are disabled). The Command,<br>Status, Request, Temporary, and the Byte flip-flop are all cleared. |

| I/O Port:      |              |   | 0Eh                           |   |   |   |   |  |  |
|----------------|--------------|---|-------------------------------|---|---|---|---|--|--|
| Register Name: |              |   | Slave DMA Clear Mask Register |   |   |   |   |  |  |
| Reset          | Reset Value: |   |                               |   |   |   |   |  |  |
| 7              | 6            | 5 | 4                             | 3 | 2 | 1 | 0 |  |  |
| СМ             |              |   |                               |   |   |   |   |  |  |

| Bit | Name | Attribute | Description                                                                                                                                                                                       |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | СМ   | W         | Clear Mask Register.<br>Writing any value to this port clears the mask register. Clearing the Mask Register will enable<br>all four channels to accept DMA requests. This register is write-only. |

| I/O Po       | ort:    |    | 0Fh                           |      |      |      |      |  |
|--------------|---------|----|-------------------------------|------|------|------|------|--|
| Regis        | ter Nam | e: | Slave DMA Write Mask Register |      |      |      |      |  |
| Reset Value: |         |    | xxxx_00                       | 00b  |      |      |      |  |
| 7            | 6       | 5  | 4                             | 3    | 2    | 1    | 0    |  |
|              | Rs      | vd |                               | C3SM | C2SM | C1SM | COSM |  |

| Bit | Name | Attribute | Description                                                  |
|-----|------|-----------|--------------------------------------------------------------|
| 7-4 | Rsvd | RO        | Reserved                                                     |
| 3   | C3SM | W         | = 1: Channel 3 set mask bit<br>= 0: Channel 3 clear mask bit |
| 2   | C2SM | W         | = 1: Channel 2 set mask bit<br>= 0: Channel 2 clear mask bit |
| 1   | C1SM | W         | = 1: Channel 1 set mask bit<br>= 0: Channel 1 clear mask bit |
| 0   | COSM | W         | = 1: Channel 0 set mask bit<br>= 0: Channel 0 clear mask bit |

### 11.2.3 DMA Pager Registers

| I/O Port:      |   |   | 81h               |   |   |               |   |  |
|----------------|---|---|-------------------|---|---|---------------|---|--|
| Register Name: |   |   | DMA Page Register |   |   | DMA Channel 2 |   |  |
| Reset Value:   |   |   |                   |   |   |               |   |  |
| 7              | 6 | 5 | 4                 | 3 | 2 | 1             | 0 |  |

DP2

| Bit | Name | Attribute | Description                                                                                                                                                                                                              |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | DP2  | W/R       | This register holds the address bits A[23:16] to use for DMA transfers to memory for channel 2. The lower 16 bits of address are generated by the DMA conrtoller. This allows DMA transfers in the first 16MB of memory. |

| I/O Port:    |         |    | 82h               |   |   |               |   |  |
|--------------|---------|----|-------------------|---|---|---------------|---|--|
| Regis        | ter Nam | e: | DMA Page Register |   |   | DMA Channel 3 |   |  |
| Reset Value: |         |    |                   |   |   |               |   |  |
| 7            | 6       | 5  | 4                 | 3 | 2 | 1             | 0 |  |
| DP3          |         |    |                   |   |   |               |   |  |

| Bit | Name | Attribute | Description                                                                                                                                                                                                              |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | DP3  |           | This register holds the address bits A[23:16] to use for DMA transfers to memory for channel 3. The lower 16 bits of address are generated by the DMA controller. This allows DMA transfers in the first 16MB of memory. |

| I/O Port:<br>Register Name:<br>Reset Value: |   |   | 83h<br>DMA Page Register<br> |   |   | DMA C | hannel 1 |  |
|---------------------------------------------|---|---|------------------------------|---|---|-------|----------|--|
| 7                                           | 6 | 5 | 4                            | 3 | 2 | 1     | 0        |  |
| DP1                                         |   |   |                              |   |   |       |          |  |

| Bit | Name | Attribute | Description                                                                                                                                                                                                              |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | DP1  | W/R       | This register holds the address bits A[23:16] to use for DMA transfers to memory for channel 1. The lower 16 bits of address are generated by the DMA controller. This allows DMA transfers in the first 16MB of memory. |

| I/O Port:<br>Register Name:<br>Reset Value: |   |   | 87h<br>DMA Page Register<br> |   |   | DMA CI | hannel 0 |  |
|---------------------------------------------|---|---|------------------------------|---|---|--------|----------|--|
| 7                                           | 6 | 5 | 4                            | 3 | 2 | 1      | 0        |  |
| DP0                                         |   |   |                              |   |   |        |          |  |

| Bit | Name | Attribute | Description                                                                                                                                                                                                              |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | DP0  |           | This register holds the address bits A[23:16] to use for DMA transfers to memory for channel 0. The lower 16 bits of address are generated by the DMA controller. This allows DMA transfers in the first 16MB of memory. |

| I/O Port:      | 89h               |               |
|----------------|-------------------|---------------|
| Register Name: | DMA Page Register | DMA Channel 6 |
| Reset Value:   |                   |               |
|                |                   |               |

7 6 5 4 3 2 1 0 DP6

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                           |
|-----|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | DP6  | W/R       | This register holds the address bits A[23:17] to use for DMA transfers to memory for channel 6. The lower 16 bits of address A[16:1] are generated by the DMA conttoller. A[0] is forced to 0. This allows DMA transfers in the first 16MB of memory. |

| I/O Port:<br>Register Name:<br>Reset Value: |   |   | 8Ah<br>DMA Pa<br> | age Regi | ster | DMA CI | nannel 7 |
|---------------------------------------------|---|---|-------------------|----------|------|--------|----------|
| 7                                           | 6 | 5 | 4                 | 3        | 2    | 1      | 0        |
|                                             |   |   | D                 | P7       |      |        |          |

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                           |
|-----|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | DP7  | W/R       | This register holds the address bits A[23:17] to use for DMA transfers to memory for channel 7. The lower 16 bits of address A[16:1] are generated by the DMA controller, A[0] is forced to 0. This allows DMA transfers in the first 16MB of memory. |

| I/O Po         | ort: |   | 8Bh                             |    |   |   |   |
|----------------|------|---|---------------------------------|----|---|---|---|
| Register Name: |      |   | DMA Page Register DMA Channel 5 |    |   |   |   |
| Reset Value:   |      |   |                                 |    |   |   |   |
| 7              | 6    | 5 | 4                               | 3  | 2 | 1 | 0 |
|                |      |   | DI                              | ⊃5 |   |   |   |

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                           |
|-----|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | DP5  | W/R       | This register holds the address bits A[23:17] to use for DMA transfers to memory for channel 5. The lower 16 bits of address A[16:1] are generated by the DMA controller, A[0] is forced to 0. This allows DMA transfers in the first 16MB of memory. |



## 11.2.4 Master DMA Control Registers

| I/O Port:      | C0h                                      |               |
|----------------|------------------------------------------|---------------|
| Register Name: | Master DMA Base/Current Address Register | DMA Channel 4 |
| Reset Value:   |                                          |               |

7 6 5 4 3 2 1 0

BA/CA

| Bit | Name  | Attribute | Description                                                                                              |
|-----|-------|-----------|----------------------------------------------------------------------------------------------------------|
| 7-0 | BA/CA | R/W       | DMA Channel 4 is used for a cascade function from slave DMA. Channel 4 is unavailable for<br>other uses. |

| I/O Po | ort:    |     | C2h      |        |          |          |             |               |
|--------|---------|-----|----------|--------|----------|----------|-------------|---------------|
| Regis  | ter Nam | ie: | Master [ | DMA Ba | se/Curre | ent Cour | nt Register | DMA Channel 4 |
| Reset  | Value:  |     |          |        |          |          |             |               |
| 7      | 6       | 5   | 4        | 3      | 2        | 1        | 0           |               |
|        |         |     | BC/      | 'CC    |          |          |             |               |

| Bit | Name  | Attribute | Description                                                                                           |
|-----|-------|-----------|-------------------------------------------------------------------------------------------------------|
| 7-0 | BC/CC | R/W       | DMA Channel 4 is used for a cascade function from slave DMA. Channel 4 is unavailable for other uses. |

| • | rt:<br>ter Nam<br>Value: | ie: | C4h<br>Master I<br> | OMA Ba   | se/Curre | ent Addr | ess Register | DMA Channel 5 |
|---|--------------------------|-----|---------------------|----------|----------|----------|--------------|---------------|
| 7 | 6                        | 5   | 4<br>BA             | 3<br>/CA | 2        | 1        | 0            |               |
|   |                          |     |                     |          |          |          |              |               |

On AT and EISA systems, DMA channel 5 is an unassigned channel, used for high-speed transfers between memory and the I/O bus. On PS/2, channel 5 is used for hard disk DMA operations.

The definitions of bit[7:0] for Slave DMA Channel 1 Base/Current Count are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Count Register at I/O address 00h.

| I/O Po | ort:    |    | C6h      |        |          |          |             |               |
|--------|---------|----|----------|--------|----------|----------|-------------|---------------|
| Regis  | ter Nam | e: | Master I | DMA Ba | se/Curre | ent Cour | nt Register | DMA Channel 5 |
| Reset  | Value:  |    |          |        |          |          |             |               |
| 7      | 6       | 5  | 4        | з      | 2        | 1        | 0           |               |

| BC/CC | U | U | -  | 0   | - | • | Ū |
|-------|---|---|----|-----|---|---|---|
|       |   |   | BC | /CC |   |   |   |

On AT and EISA systems, DMA channel 5 is an unassigned channel, used for high-speed transfers between memory and the I/O bus. On PS/2, channel 5 is used for hard disk DMA operations.

The definitions of bit[7:0] for Slave DMA Channel 1 Base/Current Count are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Count Register at I/O address 01h.

| I/O Port:<br>Register Name:<br>Reset Value: |   | e: | C8h<br>Master I<br> | OMA Ba | se/Curre | ent Addr | ess Registe | r DMA Channel 6 |
|---------------------------------------------|---|----|---------------------|--------|----------|----------|-------------|-----------------|
| 7                                           | 6 | 5  | 4<br>BA             | -      | 2        | 1        | 0           |                 |

DMA Channel 6 is an unassigned channel, used for high-speed transfers between memory and the I/O bus.

The definitions of bit[7:0] for Slave DMA Channel 6 Base/Current Address are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Address Register at I/O address 00h.

| I/O Port:<br>Register Name:<br>Reset Value: |   | CAh<br>Master I<br> | DMA Ba | se/Curre | er  | DMA | Channe | 16 |  |  |  |  |  |  |  |
|---------------------------------------------|---|---------------------|--------|----------|-----|-----|--------|----|--|--|--|--|--|--|--|
|                                             | 7 | 6                   | 5      | 4        | 3   | 2   | 1      | 0  |  |  |  |  |  |  |  |
|                                             |   |                     |        | BC       | /CC |     |        |    |  |  |  |  |  |  |  |

DMA Channel 6 is an unassigned channel, used for high-speed transfers between memory and the I/O bus.

The definitions of bit[7:0] for Slave DMA Channel 2 Base/Current Count are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Count Register at I/O address 01h.

| D |   | C® |                        |
|---|---|----|------------------------|
| K | D |    | RISC DSP Communication |

| I/O Port:      | CCh          |               |   |   |  |
|----------------|--------------|---------------|---|---|--|
| Register Name: | Master DMA E | DMA Channel 7 |   |   |  |
| Reset Value:   |              |               |   |   |  |
| 7 6 5          | 4 3          | 2             | 1 | 0 |  |
|                | BA/CA        |               |   |   |  |

DMA Channel 7 is an unassigned channel, used for high-speed transfers between memory and the I/O bus.

The definitions of bit[7:0] for Slave DMA Channel 3 Base/Current Address are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Address Register at I/O address 00h.

| - | ort:<br>ter Nam<br>Value: | ie: | CEh<br>Master I<br> | OMA Ba | se/Curre | ent Cour | it Register | DMA Channel 7 |
|---|---------------------------|-----|---------------------|--------|----------|----------|-------------|---------------|
| 7 | 6                         | 5   | 4                   | 3      | 2        | 1        | 0           |               |
|   |                           |     | BC/                 | CC     |          |          |             |               |

DMA Channel 7 is an unassigned channel, used for high-speed transfers between memory and the I/O bus.

The definitions of bit[7:0] for Slave DMA Channel 3 Base/Current Count are the same as those of bit[7:0] for Slave DMA Channel 0 Base/Current Count Register at I/O address 01h.

# 

| I/O Port:      | D0h                               |
|----------------|-----------------------------------|
| Register Name: | Slave DMA Status/Command Register |
| Reset Value:   | 0000010b/00x0x0x0                 |

#### **READ: Status Register**

| 7     | 6     | 5     | 4     | 3    | 2    | 1    | 0    |
|-------|-------|-------|-------|------|------|------|------|
| C7REQ | C6REQ | C5REQ | C4REQ | C7TC | C6TC | C5TC | C4TC |

The DMA Status Register holds flag (bit 0-3) indicating when each channel has reached the Terminal Count (transfer completed). When this register is read, these lower four bits are cleared. The status register also contains flags for pending DMA requests on each of the four channels. DMA requests occur by associating the desired DMA channel request line.

| Bit | Name  | Attribute | Description                                   |  |  |  |  |
|-----|-------|-----------|-----------------------------------------------|--|--|--|--|
| 7   | C7REQ | R         | 1: DMA Channel 7 request                      |  |  |  |  |
| 6   | C6REQ | R         | 1: DMA Channel 6 request                      |  |  |  |  |
| 5   | C5REQ | R         | 1: DMA Channel 5 request                      |  |  |  |  |
| 4   | C4REQ | R         | DMA Channel 4 used for cascade                |  |  |  |  |
| 3   | C7TC  | R         | 1: DMA Channel 7 has reached terminal count   |  |  |  |  |
| 2   | C6TC  | R         | = 1: DMA Channel 6 has reached terminal count |  |  |  |  |
| 1   | C5TC  | R         | = 1: DMA Channel 5 has reached terminal count |  |  |  |  |
| 0   | C4TC  | R         | DMA Channel 4 used for cascade                |  |  |  |  |

#### Write: Command Register

This 8-bit register controls the operation of the DMA. The register is cleared by a hardware reset or a Master Disable instruction (port DAh). The command value used by PCs is 0. Normally all bits are left at 0, except bit 2 is typically set to 1 to disable the controller while writing to DMA registers. This register is write-only.



| 7     | 6     | 5  | 4   | 3   | 2   | 1  | 0   |
|-------|-------|----|-----|-----|-----|----|-----|
| ACKSL | REQSL | WS | PRI | ТІМ | CTL | AH | MMT |

| Bit | Name  | Attribute | Description                                                                                                                    |
|-----|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------|
| 7   | ACKSL | W         | = 1: DACK sense active high<br>= 0: DACK sense active low                                                                      |
| 6   | REQSL | W         | = 1: DREQ sense active low<br>= 0: DREQ sense active high                                                                      |
| 5   | WS    | W         | <ul> <li>= 1: Extended write selection</li> <li>= 0: Late write selection</li> <li>= X: if bit 3 = 0</li> </ul>                |
| 4   | PRI   | W         | = 1: Rotating priority<br>= 0: Fixed priority                                                                                  |
| 3   | ТІМ   | W         | <ul> <li>= 1: Compressed timing</li> <li>= 0: Normal timing</li> <li>= X: if bit 1 = 0</li> </ul>                              |
| 2   | CTL   | W         | = 1: Control disable<br>= 0: Control enable                                                                                    |
| 1   | AH    | W         | <ul> <li>= 1: Channel 4 address hold enable</li> <li>= 0: Channel 4 addrese hold disable</li> <li>= X: if bit 0 = 0</li> </ul> |
| 0   | MMT   | W         | = 1: Memory-to-memory transfers enable<br>= 0: Memory-to-memory transfers disable                                              |

| I/O Po | ort:    |      | D2h                         |   |    |   |   |  |  |
|--------|---------|------|-----------------------------|---|----|---|---|--|--|
| Regis  | ter Nan | ne:  | Master DMA Request Register |   |    |   |   |  |  |
| Reset  | Value:  |      |                             |   |    |   |   |  |  |
| 7      | 6       | 5    | 4                           | 3 | 2  | 1 | 0 |  |  |
|        |         | Rsvd |                             |   | SR | C | S |  |  |

In addition to initiating a request for DMA service by asserting a hardware request line, software can also initiate a DMA request. The Request Register is used to both set and clear any channel's request bit. The DMA controller does need to be in Block mode to use this function, as set in the Mode Register (port D6h). This register is write-only.

| Bit | Name | Attribute | Description                                                                                                                                |  |  |  |  |  |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7-3 | Rsvd | RO        | Reserved.                                                                                                                                  |  |  |  |  |  |
| 2   | SR   | W         | = 1: Set request bit<br>= 0: Clear request bit                                                                                             |  |  |  |  |  |
| 1-0 | CS   | W         | <ul> <li>= 00: Channel 4 select</li> <li>= 01: Channel 5 select</li> <li>= 10: Channel 6 select</li> <li>= 11: Channel 7 select</li> </ul> |  |  |  |  |  |

| I/O Po | ort:    |     | D4h      |        |          |      |  |  |
|--------|---------|-----|----------|--------|----------|------|--|--|
| Regis  | ter Nam | ne: | Master I | DMA Ma | isk Regi | ster |  |  |
| Reset  | Value:  |     |          |        |          |      |  |  |
| 7      | 6       | 5   | 4        | 3      | 2        | 1    |  |  |

| 7 | 6 | 5    | 4 | 3 | 2  | 1 | 0 |
|---|---|------|---|---|----|---|---|
|   |   | Rsvd |   |   | SM | C | S |

The mask register is used to disable or enable individual incoming requests. Setting a mask bit on disables the selected channel. Hardware reset disables all channels by setting all mask bits.

| Bit | Name | Attribute | Description                                                                                                                                |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 7-3 | Rsvd | RO        | Reserved                                                                                                                                   |
| 2   | SM   | \\\/      | = 1: Set mask bit<br>= 0: Clear mask bit                                                                                                   |
| 1-0 | CS   | W         | <ul> <li>= 00: Channel 4 select</li> <li>= 01: Channel 5 select</li> <li>= 10: Channel 6 select</li> <li>= 11: Channel 7 select</li> </ul> |

| I/O Po | ort:    |     | D6h      |        |          |      |  |
|--------|---------|-----|----------|--------|----------|------|--|
| Regis  | ter Nam | ne: | Master I | DMA Mo | ode Regi | ster |  |
| Reset  | Value:  |     |          |        |          |      |  |
| 7      | 6       | 5   | 4        | 3      | 2        | 1    |  |

| 7  | 6 | 5     | 4   | 3 | 2 | 1 | 0 |
|----|---|-------|-----|---|---|---|---|
| МТ |   | AD/AI | ATI | Т | Т | C | s |

The Mode Register indicates the mode of operation for each of the four DMA channels 4 to 7. Each channel has a separate 6-bit mode register and each is loaded through the Mode Register port.

| Bit | Name  | Attribute | Description                                                                                                                                                    |
|-----|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-6 | МТ    | W         | Mode Type Selection.<br>= 00: Demand mode<br>= 01: Single mode<br>= 10: Block mode<br>= 11: Cascade mode                                                       |
| 5   | AD/AI | W         | = 1: Address decrement select<br>= 0: Address increment select                                                                                                 |
| 4   | ATI   | W         | = 1: Autoinitialization enable<br>= 0: Autoinitialization disable                                                                                              |
| 3-2 | TT    | w         | Transfer Type.<br>= 00: Verify operation<br>= 01: Write operation<br>= 10: Read operation<br>= 11: not valid<br>= xx: if they are in cascade mode (bits 6 & 7) |
| 1-0 | CS    | W         | Channel Selection.<br>= 00: Channel 4 select<br>= 01: Channel 5 select<br>= 10: Channel 6 select<br>= 11: Channel 7 select                                     |

| I/O Por | t:      |   | D8h      |       |           |          |           |             |
|---------|---------|---|----------|-------|-----------|----------|-----------|-------------|
| Registe | er Name | : | Master D | MA Se | t/Clear F | irst/Las | t Clear F | /F Register |
| Reset \ | /alue:  |   |          |       |           |          |           |             |
| 7       | 6       | 5 | 4        | 3     | 2         | 1        | 0         |             |

CFF

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | CFF  |           | Any value to this port causes the internal First/Last flip-flop to be cleared in DMA controller 1. This is done before any 8-bit reads or writes to 16-bit registers that require two successive 8-bit port accesses to complete the word transfer. After the flip-flop is cleared, a 16-bit DMA register is accessed by reading or writing the low byte followed by the high byte. The flip-flop can only be cleared, and is not readable. |

| I/O Po | rt:     |    | DAh      |         |         |         |         |          |
|--------|---------|----|----------|---------|---------|---------|---------|----------|
| Regis  | ter Nam | e: | Master I | DMA Tei | mporary | /Master | Disable | Register |
| Reset  | Value:  |    |          |         |         |         |         |          |
| 7      | 6       | 5  | 4        | 3       | 2       | 1       | 0       |          |
|        |         |    | тр       |         |         |         |         |          |

TP/MD

| Bit | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | TP/MD | R/W       | Read: Temporary Register.<br>The Temporary Register holds data during memory-to-memory data transfers. After the transfer<br>is complete, the Temporary Register holds the last data transfer. The Temporary Register can<br>be read when the DMA controller is not performing a DMA transfer. The register is cleared by a<br>reset.<br>Write: Master Disable Register.<br>Writing any value to this port resets master DMA control. This command has the same action<br>as a hardware reset. The mask register is set (channel 4 to 7 disabled). The Command, Status,<br>Request, Temporary, and the Byte flip-flop are all cleared. |

| I/O Port:<br>Register Name:<br>Reset Value:<br>7 6 5 |   | ne: | DCh<br>Master DMA Clear Mask Register<br> |   |   |   |   |  |
|------------------------------------------------------|---|-----|-------------------------------------------|---|---|---|---|--|
| 7                                                    | 6 | 5   | 4                                         | 3 | 2 | 1 | 0 |  |
|                                                      |   |     | C                                         | M |   |   |   |  |

| Bit | Name | Attribute | Description                                                                                                                                                                                          |
|-----|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | СМ   | W         | Clear Mask Register.<br>Writing any value to this port clears the mask register. Clearing the Mask Register will enable<br>channels 5, 6, and 7 to accept DMA requests. This register is write-only. |

| I/O Port:      |     |            | DEh                            |      |      |      |      |  |
|----------------|-----|------------|--------------------------------|------|------|------|------|--|
| Register Name: |     |            | Master DMA Write Mask Register |      |      |      |      |  |
| Reset Value:   |     | xxxx_0000b |                                |      |      |      |      |  |
| 7              | 6   | 5          | 4                              | 3    | 2    | 1    | 0    |  |
|                | Rsv | vd         |                                | C7SM | C6SM | C5SM | C4SM |  |

The mask register is used to disable or enable individual incoming requests. Setting a mask bit on disables the selected channel. A hardware reset disables all channels by setting all mask bits.

| Bit | Name | Attribute | Description                                                    |  |  |
|-----|------|-----------|----------------------------------------------------------------|--|--|
| 7-4 | Rsvd | RO        | Reserved                                                       |  |  |
| 3   | C7SM | W         | = 1: Channel 7 sets mask bit<br>= 0: Channel 7 clears mask bit |  |  |
| 2   | C6SM | W         | = 1: Channel 6 sets mask bit<br>= 0: Channel 6 clears mask bit |  |  |
| 1   | C5SM | W         | = 1: Channel 5 sets mask bit<br>= 0: Channel 5 clears mask bit |  |  |
| 0   | C4SM | W         | = 1: Channel 4 sets mask bit<br>= 0: Channel 4 clears mask bit |  |  |

### 11.2.5 DMA High Page Registers

| I/O Po         | ort:   |   | 481h                   |     |   |      |               |  |  |
|----------------|--------|---|------------------------|-----|---|------|---------------|--|--|
| Register Name: |        |   | DMA High Page Register |     |   | r Di | DMA Channel 2 |  |  |
| Reset          | Value: |   | 00h                    |     |   |      |               |  |  |
| 7              | 6      | 5 | 4                      | 3   | 2 | 1    | 0             |  |  |
|                |        |   | DH                     | IP2 |   |      |               |  |  |

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | DHP2 | W/R       | This register holds the address bits A[31:24] to use for DMA transfers for channel 2. Always write this register after the base and low page registers are written. A write to this channel's base address register or a write to the low page register at port 81h automatically clears this register. This ensures compatibility with DMA on AT system. |

| I/O Po         | rt:    |   | 482h                   |   |   |               |   |  |
|----------------|--------|---|------------------------|---|---|---------------|---|--|
| Register Name: |        |   | DMA High Page Register |   |   | DMA Channel 3 |   |  |
| Reset          | Value: |   | 00h                    |   |   |               |   |  |
| 7              | 6      | 5 | 4                      | 3 | 2 | 1             | 0 |  |

DHP3

| Bit | Name | Attribute | Description                                                                                          |
|-----|------|-----------|------------------------------------------------------------------------------------------------------|
| 7-0 | DHP3 | W/R       | This register holds the upper 8 bits of the 32-bit address for channel 3. See port 481h for details. |

| I/O Po | ort:    |    | 483h   |         |           |   |               |
|--------|---------|----|--------|---------|-----------|---|---------------|
| Regis  | ter Nam | e: | DMA Hi | gh Page | e Registe | - | DMA Channel 1 |
| Reset  | Value:  |    | 00h    |         |           |   |               |
| 7      | 6       | 5  | 4      | 3       | 2         | 1 | 0             |

DHP1

| Bi | it | Name | Attribute | Description                                                                                          |
|----|----|------|-----------|------------------------------------------------------------------------------------------------------|
| 7- | 0  | DHP1 | W/R       | This register holds the upper 8 bits of the 32-bit address for channel 1. See port 481h for details. |

| I/O Port:<br>Register Name:<br>Reset Value: |   |   | 487h<br>DMA High Page Register |     |   | r Di | DMA Channel ( |  |  |
|---------------------------------------------|---|---|--------------------------------|-----|---|------|---------------|--|--|
|                                             |   |   | 00h                            |     | C |      |               |  |  |
| 7                                           | 6 | 5 | 4                              | 3   | 2 | 1    | 0             |  |  |
|                                             |   |   |                                | IP0 |   |      |               |  |  |

| I | Bit | Name | Attribute | Description                                                                                          |
|---|-----|------|-----------|------------------------------------------------------------------------------------------------------|
| 7 | 7-0 | DHP0 | W/R       | This register holds the upper 8 bits of the 32-bit address for channel 0. See port 481h for details. |

| I/O Port:      | 489h                   |               |
|----------------|------------------------|---------------|
| Register Name: | DMA High Page Register | DMA Channel 6 |
| Reset Value:   | 00h                    |               |
|                |                        |               |

7 6 5 4 3 2 1 0 DHP6

| Bit | Name | Attribute | Description                                                                                          |
|-----|------|-----------|------------------------------------------------------------------------------------------------------|
| 7-0 | DHP6 | W/R       | This register holds the upper 8 bits of the 32-bit address for channel 6. See port 481h for details. |

| I/O Port:<br>Register Name:<br>Reset Value: | 48Ah<br>DMA High Page Register<br>00h | DMA Channel 7 |  |  |
|---------------------------------------------|---------------------------------------|---------------|--|--|
| 7 6 5                                       | 4 3 2                                 | 1 0           |  |  |

DHP7

| Bit | Name | Attribute | Description                                                                                          |
|-----|------|-----------|------------------------------------------------------------------------------------------------------|
| 7-0 | DHP7 | W/R       | This register holds the upper 8 bits of the 32-bit address for channel 7. See port 481h for details. |

| I/O Port:<br>Register Name:<br>Reset Value: |   |   | 48Bh<br>DMA High Page Register<br>00h |     |   |   | DMA Channel 5 |   |  |
|---------------------------------------------|---|---|---------------------------------------|-----|---|---|---------------|---|--|
| 7                                           | 6 | 5 | 4                                     | 3   | 2 | 1 | 0             | _ |  |
|                                             |   |   | DH                                    | IP5 |   |   |               |   |  |

| Bit | Name | Attribute | Description                                                                                          |
|-----|------|-----------|------------------------------------------------------------------------------------------------------|
| 7-0 | DHP5 | W/R       | This register holds the upper 8 bits of the 32-bit address for channel 5. See port 481h for details. |

### 11.2.6 <u>Timer/Counter Registers</u>

Note: The following clock is 14.318 MHz /12 (external) or 12.5 MHz /12 (internal).

| I/O Po | ort:    |     | 40h     |          |         |          |   |
|--------|---------|-----|---------|----------|---------|----------|---|
| Regis  | ter Nam | ne: | Timer/C | ounter ( | Count I | Register |   |
| Reset  | Value:  |     |         |          |         |          |   |
| 7      | 6       | 5   | 4       | 3        | 2       | 1        | 0 |
|        |         |     | Т       | 0        |         |          |   |

| Bit | Name | Attribute | Description                                                                                                                                                                      |
|-----|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | Т0   | R/W       | Timer 0 is used for system clocking. It is normally programmed for mode 3, periodic square wave operation. The Count is loaded with 0 to generate a pulse 18.2 times per second. |

| - | ort:<br>ter Nam<br>Value: |   | 41h<br>Timer/C<br> | ounter 1 | Count I | Register |   |
|---|---------------------------|---|--------------------|----------|---------|----------|---|
| 7 | 6                         | 5 | 4                  | 3        | 2       | 1        | 0 |
|   |                           |   | Т                  | .1       |         |          |   |

| Bit | Name | Attribute | Description                                                                                                                                                     |
|-----|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | T1   | R/W       | Timer 1 is used for DRAM refresh. It is normally programmed for mode 2, rate generator operation. The count is loaded with 12h to generate a pulse every 15 us. |

| I/O Po       | ort:    |     | 42h     |          |         |          |   |
|--------------|---------|-----|---------|----------|---------|----------|---|
| Regis        | ter Nam | ne: | Timer/C | ounter 2 | 2 Count | Register |   |
| Reset Value: |         |     |         |          |         |          |   |
| 7            | 6       | 5   | 4       | 3        | 2       | 1        | 0 |
| r            |         |     |         |          |         |          |   |

T2

| Bit | Name | Attribute | Description                                                 |
|-----|------|-----------|-------------------------------------------------------------|
| 7-0 | T2   | R/W       | Timer 2 is used for speaker operations and general purpose. |

| I/O Po | ort:    |     | 43h     |          |           |          |    |
|--------|---------|-----|---------|----------|-----------|----------|----|
| Regis  | ter Nam | ne: | Timer/C | ounter ( | Control F | Register |    |
| Reset  | Value:  |     |         |          |           |          |    |
| 7      | 6       | 5   | 4       | 3        | 2         | 1        | 0  |
|        | CN      | ИD  |         |          | MS        |          | СМ |

All the three timers are controlled by the modes set through this register.

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-4 | CMD  | W         | Command.<br>0h: Counter Latch Timer 0<br>1h: Timer 0 LSB Mode<br>2h: Timer 0 MSB Mode<br>3h: Timer 0 16-bit Mode<br>4h: Counter Latch Timer 1<br>5h: Timer 1 LSB Mode<br>6h: Timer 1 MSB Mode<br>7h: Timer 1 16-bit Mode<br>8h: Counter Latch Timer 2<br>9h: Timer 2 LSB Mode<br>Ah: Timer 2 MSB Mode<br>Bh: Timer 2 16-bit Mode<br>Dh: General Counter Latch<br>Eh: Latch Status of Timers |
| 3-1 | MS   | w         | 000b: Mode 0<br>001b: Mode 1<br>010b: Mode 2<br>011b: Mode 3<br>100b: Mode 4<br>101b: Mode 5<br>110b: Mode 2<br>111b: Mode 3                                                                                                                                                                                                                                                                |
| 0   | СМ   | W         | 0b: BCD Counter mode (4 Binary Coded Decimal digits)<br>1b: Binary Counter mode (16-bit)                                                                                                                                                                                                                                                                                                    |

#### 11.2.7 Master Interrupt Control Registers

| I/O Po | rt:     |    | 20h      |          |        |            |            |                       |          |
|--------|---------|----|----------|----------|--------|------------|------------|-----------------------|----------|
| Regist | ter Nam | e: | Master I | nterrupt | Reques | st/Interru | upt Servio | e/Interrupt Command I | Register |
| Reset  | Value:  |    |          |          |        |            |            |                       |          |
| 7      | 6       | 5  | 4        | 3        | 2      | 1          | 0          |                       |          |

**IRR/ISR/ICR** 

| Bit | Name            | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|-----------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | IRR/ISR/I<br>CR | R/W       | <ul> <li>Read: Interrupt Request/Interrupt Service Register.</li> <li>This function reads the contents of the Interrupt Request Register (IRR) or the Interrupt Service Register (ISR). You specify which register to read by sending a command to port 20h. A command value of 0Ah selects IRR, and value 0Bh selects ISR. Once a command is sent, multiple reads can be made to get the contents of the same register. It is not necessary to resend the register selection command.</li> <li>Write: Interrupt Command Register.</li> <li>This controls initialization and operation of the interrupt controller for interrupt request line 0 to 7.</li> </ul> |

| I/O Po | rt:     | :   | 21h      |          |        |         |     |
|--------|---------|-----|----------|----------|--------|---------|-----|
| Regis  | ter Nam | e:  | Master I | nterrupt | Mask R | egister |     |
| Reset  | Value:  |     |          |          |        |         |     |
| 7      | 6       | 5   | 4        | 3        | 2      | 1       | 0   |
| I7M    | I6M     | I5M | I4M      | I3M      | I2M    | I1M     | IOM |

The interrupt mask register indicates which interrupt requests are allowed (value 0) and disabled (value 1).

| Bit | Name | Attribute | Description                               |
|-----|------|-----------|-------------------------------------------|
| 7   | 17M  | R/W       | = 0: IRQ 7 Enabled<br>= 1: IRQ 7 Disabled |
| 6   | I6M  | R/W       | = 0: IRQ 6 Enabled<br>= 1: IRQ 6 Disabled |
| 5   | I5M  | R/W       | = 0: IRQ 5 Enabled<br>= 1: IRQ 5 Disabled |
| 4   | I4M  | R/W       | = 0: IRQ 4 Enabled<br>= 1: IRQ 4 Disabled |
| 3   | I3M  | R/W       | = 0: IRQ 3 Enabled<br>= 1: IRQ 3 Disabled |
| 2   | I2M  | R/W       | = 0: IRQ 2 Enabled<br>= 1: IRQ 2 Disabled |
| 1   | I1M  | R/W       | = 0: IRQ 1 Enabled<br>= 1: IRQ 1 Disabled |
| 0   | IOM  | R/W       | = 0: IRQ 0 Enabled<br>= 1: IRQ 0 Disabled |



#### 11.2.8 Slave Interrupt Control Registers

| I/O Port:      |   |   | A0h                                                                  |   |   |   |   |  |  |
|----------------|---|---|----------------------------------------------------------------------|---|---|---|---|--|--|
| Register Name: |   |   | Slave Interrupt Request/Interrupt Service/Interrupt Command Register |   |   |   |   |  |  |
| Reset Value:   |   |   |                                                                      |   |   |   |   |  |  |
| 7              | 6 | 5 | 4                                                                    | 3 | 2 | 1 | 0 |  |  |

IRR/ISR/ICR

| Bit | Name            | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-----------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | IRR/ISR/<br>ICR | R/W       | <ul> <li>Read: Interrupt Request/Interrupt Service Register.</li> <li>This function reads the contents of the Interrupt Request Register (IRR) or the Interrupt Service Register (ISR). You specify which register to read by sending a command to port A0h. A command value of 0Ah selects IRR, and value 0Bh selects ISR. Once a command is sent, multiple reads can be made to get the contents of the same register. It is not necessary to resend the register selection command.</li> <li>Write: Interrupt Command Register.</li> <li>This controls initialization and operation of the interrupt controller for interrupt request line 8 to 15.</li> </ul> |

| I/O Port:      | A1h                           |
|----------------|-------------------------------|
| Register Name: | Slave Interrupt Mask Register |
| Reset Value:   |                               |
|                |                               |

| 7    | 6    | 5    | 4    | 3    | 2    | 1   | 0   |  |
|------|------|------|------|------|------|-----|-----|--|
| I15M | I14M | 113M | I12M | I11M | 110M | 19M | 18M |  |

The interrupt mask register indicates which interrupt requests are allowed (value 0) and which are disabled (value 1).

| Bit | Name | Attribute | Description                                 |
|-----|------|-----------|---------------------------------------------|
| 7   | I15M | R/W       | = 0: IRQ 15 Enabled<br>= 1: IRQ 15 Disabled |
| 6   | I14M | R/W       | = 0: IRQ 14 Enabled<br>= 1: IRQ 14 Disabled |
| 5   | I13M | R/W       | = 0: IRQ 13 Enabled<br>= 1: IRQ 13 Disabled |
| 4   | I12M | R/W       | = 0: IRQ 12 Enabled<br>= 1: IRQ 12 Disabled |
| 3   | I11M | R/W       | = 0: IRQ 11 Enabled<br>= 1: IRQ 11 Disabled |
| 2   | I10M | R/W       | = 0: IRQ 10 Enabled<br>= 1: IRQ 10 Disabled |
| 1   | 19M  | R/W       | = 0: IRQ 9 Enabled<br>= 1: IRQ 9 Disabled   |
| 0   | 18M  | R/W       | = 0: IRQ 8 Enabled<br>= 1: IRQ 8 Disabled   |

#### 11.2.9 Interrupt Edge/Level Control Registers

| I/O Port:<br>Register Name:<br>Reset Value: |       |       | e:    | 4D0h<br>Master Interrupt Edge/Level Control Register<br>00h |       |       |       |       |  |
|---------------------------------------------|-------|-------|-------|-------------------------------------------------------------|-------|-------|-------|-------|--|
|                                             | 7     | 6     | 5     | 4                                                           | 3     | 2     | 1     | 0     |  |
|                                             | IR7TM | IR6TM | IR5TM | IR4TM                                                       | IR3TM | IR2TM | IR1TM | IR0TM |  |

This register controls the triggering type for each IRQ line. Clear the bit to program edge sensitive. Set the bit to program level sensitive mode. Before writing this register, read the contents first. Do not change the state of IRQ 0, 1 and 2 bits, as these are set by the motherboard manufacturer's BIOS to reflect the specific board design.

| Bit | Name  | Attribute | Description                            |
|-----|-------|-----------|----------------------------------------|
|     |       |           | IRQ7 Edge/Level Triggered Mode         |
| 7   | IR7TM | R/W       | 0: Edge Triggered Mode                 |
|     |       |           | 1: Level Triggered Mode                |
|     |       |           | IRQ6 Edge/Level Triggered Mode         |
| 6   | IR6TM | R/W       | 0: Edge Triggered Mode                 |
|     |       |           | 1: Level Triggered Mode                |
|     |       |           | IRQ5 Edge/Level Triggered Mode         |
| 5   | IR5TM | R/W       | 0: Edge Triggered Mode                 |
|     |       |           | 1: Level Triggered Mode                |
|     |       |           | IRQ4 Edge/Level Triggered Mode         |
| 4   | IR4TM | R/W       | 0: Edge Triggered Mode                 |
|     |       |           | 1: Level Triggered Mode                |
|     |       |           | IRQ3 Edge/Level Triggered Mode         |
| 3   | IR3TM | R/W       | 0: Edge Triggered Mode                 |
|     |       |           | 1: Level Triggered Mode                |
| 2   | IR2TM | RO        | IRQ2 Triggered Mode (do not change it) |
| 1   | IR1TM | RO        | IRQ1 Triggered Mode (do not change it) |
| 0   | IR0TM | RO        | IRQ0 Triggered Mode (do not change it) |

| I/O Port:      |        |        |        | 4D1h                                        |        |        |       |       |  |
|----------------|--------|--------|--------|---------------------------------------------|--------|--------|-------|-------|--|
| Register Name: |        |        | e: :   | Slave Interrupt Edge/Level Control Register |        |        |       |       |  |
| Reset Value:   |        |        | (      | 00h                                         |        |        |       |       |  |
|                | 7      | 6      | 5      | 4                                           | 3      | 2      | 1     | 0     |  |
|                | IR15TM | IR14TM | IR13TM | IR12TM                                      | IR11TM | IR10TM | IR9TM | IR8TM |  |

This register controls the triggering type for each IRQ line. Clear the bit to program edge sensitive. Set the bit to program level sensitive mode. Before writing this register, read the contents first. Do not change the state of IRQ 8 and IRQ 13, as these are set by the motherboard manufacturer's BIOS to reflect the specific board design.



| Bit | Name   | Attribute | Description                            |
|-----|--------|-----------|----------------------------------------|
|     |        |           | IRQ15 Edge/Level Triggered Mode        |
| 7   | IR15TM | R/W       | 0: Edge Triggered Mode                 |
|     |        |           | 1: Level Triggered Mode                |
|     |        |           | IRQ14 Edge/Level Triggered Mode        |
| 6   | IR14TM | R/W       | 0: Edge Triggered Mode                 |
|     |        |           | 1: Level Triggered Mode                |
| 5   | IR13TM | RO        | IRQ13 Triggered Mode (do not change)   |
|     |        |           | IRQ12 Edge/Level Triggered Mode        |
| 4   | IR12TM | R/W       | 0: Edge Triggered Mode                 |
|     |        |           | 1: Level Triggered Mode                |
|     |        |           | IRQ11 Edge/Level Triggered Mode        |
| 3   | IR11TM | R/W       | 0: Edge Triggered Mode                 |
|     |        |           | 1: Level Triggered Mode                |
|     |        |           | IRQ10 Edge/Level Triggered Mode        |
| 2   | IR10TM | R/W       | 0: Edge Triggered Mode                 |
|     |        |           | 1: Level Triggered Mode                |
|     |        |           | IRQ9 Edge/Level Triggered Mode         |
| 1   | IR9TM  | R/W       | 0: Edge Triggered Mode                 |
|     |        |           | 1: Level Triggered Mode                |
| 0   | IR8TM  | RO        | IRQ8 Triggered Mode (do not change it) |

#### 11.2.10 Serial Port Registers

The system programmer may access any of the UART registers. These registers control UART operations including transmission and reception of data.

(Base Address Refers to the Register of index 57h-54h, IDSEL = AD18 of PCI Configuration Register)

| I/O Port:      | Base Address + 0h                     |
|----------------|---------------------------------------|
| Register Name: | Transmit/Receive Data Buffer (DLAB=0) |
| Reset Value:   |                                       |
|                |                                       |



An output to this register stores a byte into the UART's transmit holding buffer. An input gets a byte from the receive buffer of the UART. These are two separate registers within the UART. To access this register, the Divisor Latch Access Bit (DLAB) must be zero. DLAB is bit 7 in the line control register 3.

| Bit | Name              | Attribute | Description                                                    |  |  |  |
|-----|-------------------|-----------|----------------------------------------------------------------|--|--|--|
| 7-0 | '-0 I ID/RD I R/W |           | Read: This register holds the received incoming data byte.     |  |  |  |
|     |                   |           | Write: This register contains the data byte to be transmitted. |  |  |  |

|   |   | C® |                        |
|---|---|----|------------------------|
| R | D | 6  | RISC DSP Communication |

| I/O Port: Base     | Base Address + 0h                                   |   |   |   |   |
|--------------------|-----------------------------------------------------|---|---|---|---|
| Register Name: LSB | LSB of Baud Rate Generator Divisor Latches (DLAB=1) |   |   |   |   |
| Reset Value: 01h   |                                                     |   |   |   |   |
| 7 6 5 4            | 3                                                   | 2 | 1 | 0 | _ |
|                    | LBR                                                 |   |   |   |   |

The UART contains a programmable baud generator that is capable of taking any clock input from DC to 24 MHz and dividing it by any divisor from 2 to 2<sup>16</sup>-1. The output frequency of the baud generator is 16 X the baud [divisor # = (frequency input) / (baud rate X 16)]. Two 8-bit latches store the divisor in a 16-bit binary format. These divisor latches must be loaded during initialization to ensure proper operation of the baud generator. Upon loading either of the divisor latches, a 16-bit baud counter is immediately loaded. The Table listed below provides decimal divisors to use with crystal frequencies of 1.8432 MHz, 3.072 MHz and 18.432 MHz, respectively. For baud rates of 38400 and below, the error obtained is minimal. The accuracy of the desired baud rate is dependent on the crystal frequency chosen. Using a divisor of zero is not recommended.

| Bit | Name | Attribute | Description                                                                 |
|-----|------|-----------|-----------------------------------------------------------------------------|
| 7-0 | LBR  | R/W       | This register contains the LSB (Least Significant Byte) of divisor latches. |

|           | 1.8432 MH       | Iz Crystal    |
|-----------|-----------------|---------------|
| Baud Rate | Decimal Divisor | Percent Error |
|           | for 16 X Clock  |               |
| 50        | 2304            | -             |
| 75        | 1536            | -             |
| 110       | 1047            | 0.026         |
| 134.5     | 857             | 0.058         |
| 150       | 768             | -             |
| 300       | 384             | -             |
| 600       | 192             | -             |
| 1200      | 96              | -             |
| 1800      | 64              | -             |
| 2000      | 58              | 0.69          |
| 2400      | 48              | -             |
| 3600      | 32              | -             |
| 4800      | 24              | -             |
| 7200      | 16              | -             |
| 9600      | 12              | -             |
| 19200     | 6               | -             |
| 38400     | 3               | -             |
| 56000     | 2               | 2.68          |
| 115200    | 1               | -             |

#### TABLE Baud Rates, Divisors and Crystals

| I/O Port:      | Base Address + 1h                  |
|----------------|------------------------------------|
| Register Name: | Interrupt Enable Register (DLAB=0) |
| Reset Value:   | 00h                                |

| 7 | 6    | 5     | 4 | 3   | 2    | 1     | 0    |
|---|------|-------|---|-----|------|-------|------|
|   | Rese | erved |   | MSI | RLSI | THREI | RDAI |

This register enables the five types of UART interrupts. Each interrupt can individually activate the interrupt (INTR) output signal. It is possible to totally disable the interrupt system by resetting bit 0 through 3 of the Interrupt Enable Register (IER). Similarly, setting bits of the IER register to a logic 1 enables the selected interrupt(s). Disabling an interrupt prevents it from being indicated as active in the IIR and from activating the INTR output signal. All other system functions operate in their normal manner, including the settings of the Line Status and MODEM Status Registers. Table II shows the contents of the IER. Details on each bit are listed as follows.

| Bit | Name  | Attribute | Description                                                             |
|-----|-------|-----------|-------------------------------------------------------------------------|
| 7-4 | Rsvd  | RO        | Reserved. Must be always '0'                                            |
| 3   | MSI   | R/W       | Modem Status Interrupt<br>0: Disable<br>1: Enable                       |
| 2   | RLSI  | R/W       | Received Line Status Interrupt<br>0: Disable<br>1: Enable               |
| 1   | THREI | R/W       | Transmitter Holding Register Empty Interrupt<br>0: Disable<br>1: Enable |
| 0   | RDAI  | R/W       | Received Data Available Interrupt<br>0: Disable<br>1: Enable            |

| I/O Port:      | Base Address + 1h                                   |
|----------------|-----------------------------------------------------|
| Register Name: | MSB of Baud Rate Generator Divisor Latches (DLAB=1) |
| Reset Value:   | 00h                                                 |

7 6 5 4 3 2 1 0 MBR

| Bit | Name | Attribute | Description                                                                |
|-----|------|-----------|----------------------------------------------------------------------------|
| 7-0 | MBR  | R/W       | This register contains the MSB (Most Significant Byte) of divisor latches. |



| I/O Port: Base Address + 2h |    |                                   |       |    |   |   |  |
|-----------------------------|----|-----------------------------------|-------|----|---|---|--|
| Register Nam                | e: | Interrupt Identification Register |       |    |   |   |  |
| Reset Value:                |    | 01h                               |       |    |   |   |  |
| 7 6                         | 5  | 4                                 | 3     | 2  | 1 | 0 |  |
| FIFOE                       | R  | svd                               | FIFOM | РТ |   |   |  |

In order to provide minimum software overhead during data character transfers, the UART prioritizes interrupts into four levels and records these in the interrupt Identification Register. The four levels of interrupt conditions in order of priority are Receiver Line Status, Received Data Ready, Transmitter Holding Register Empty, and MODEM Status.

When the CPU accesses the IIR, the UART freezes all interrupts and indicates the highest priority pending interrupt to the CPU. While this CPU access is occurring, the UART records new interrupts, but does not change its current indication until the access is complete. Table II shows the contents of the IIR. Details on each bit are listed as follows:

| Bit | Name  | Attribute | Description                                                                                                                                                                                                                                       |
|-----|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-6 | FIFOE | RO        | These two bits are set to '1' when the FIFO Control Register bit 0 = '1'.                                                                                                                                                                         |
| 5-4 | Rsvd  | RO        | Reserved. Must be returned all '0's.                                                                                                                                                                                                              |
| 3   | FIFOM | RO        | In non-FIFO Mode<br>This bit is a '0'.<br>In FIFO Mode<br>This bit is set to '1' along with bit 2 when a timeout interrupt is pending                                                                                                             |
| 2-1 | PT    |           | Indicate the Highest Priority Interrupt Pending<br>00: Modem Status Interrupt (Lowest Priority)<br>01: Transmitter Holding Register Empty Interrupt<br>10: Received Data Ready Interrupt<br>11: Receiver Line Status Interrupt (Highest Priority) |
| 0   | IP    | RO        | Interrupt Pending<br>0: Interrupt Pending<br>1: No Interrupt Pending                                                                                                                                                                              |

| FIFO<br>Mode<br>Only | Ider  | Interrupt<br>Identification<br>Register |      | Identification |                                       |                                                                                                                                                                            | Inter                                                                                                                        | rupt Set and Reset Functions |  |
|----------------------|-------|-----------------------------------------|------|----------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------|--|
| Bit 3                | Bit 2 | Bit 1                                   | Bit0 | Priority Level | Interrupt Type                        | Interrupt Source                                                                                                                                                           | Interrupt Rest Control                                                                                                       |                              |  |
| 0                    | 0     | 0                                       | 1    | -              | None                                  | None                                                                                                                                                                       | -                                                                                                                            |                              |  |
| 0                    | 1     | 1                                       | 0    | Highest        | received line status                  | overrun error, parity error,<br>framing error or break Interrupt                                                                                                           | reading the line status register                                                                                             |                              |  |
| 0                    | 1     | 0                                       | 0    | Second         | received data<br>available            | received data available or trigger level reached                                                                                                                           | reading the receiver buffer<br>register or the FIFO dropping<br>below the trigger level                                      |                              |  |
| 1                    | 1     | 0                                       | 0    | Second         | character timeout<br>Indication       | no characters have been<br>removed from or Input to the<br>RCVR FIFO during the last 4<br>Characters times and there is<br>at least 1 character in it during<br>this time. | reading the receiver buffer<br>register                                                                                      |                              |  |
| 0                    | 0     | 1                                       | 0    | Third          | transmitter holding<br>register empty | transmitter holding register<br>empty                                                                                                                                      | reading the IIR register (if the<br>source of interrupt is available)<br>or writing into the transmitter<br>holding register |                              |  |
| 0                    | 0     | 0                                       | 0    | Fourth         | MODEM Status                          | clear to send, data set ready ,<br>ring Indicator, or data carrier<br>detect                                                                                               | reading the MODEM Status register                                                                                            |                              |  |

### **TABLE Interrupt Control Functions**

| I/O Po | ort:    |    | Base Ac | Base Address + 2h<br>FIFO Control Register |   |   |  |  |
|--------|---------|----|---------|--------------------------------------------|---|---|--|--|
| Regis  | ter Nam | e: | FIFO Co |                                            |   |   |  |  |
| Reset  | Value:  |    | 00h     | 00h                                        |   |   |  |  |
| 7      | 6       | 5  | 4       | 3                                          | 2 | 1 |  |  |
|        |         |    |         |                                            |   |   |  |  |

Rsvd

CTF

CRF

This is a write only register at the same location as the IIR (the IIR is a read only register). This register is used to enable the FIFOs, clear the FIFOs, set the RCVR FIFO trigger level, and select the type of DMA signaling.

0

FE

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-6 | TL   |           | These two bits are used to set the trigger level (bytes) for Receive FIFO interrupt<br>00: 1 byte<br>01: 4 bytes<br>10: 8 bytes<br>11: 14 bytes                                                                                                                                                                                                                                                                  |
| 5-3 | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2   | CTF  | WO        | Writing a '1' to this bit will clear all bytes in transmitted FIFO and reset its counter to 0. The shift register is not cleared                                                                                                                                                                                                                                                                                 |
| 1   | CRF  | WO        | Writing a '1' to this bit will clear all bytes in received FIFO and reset its counter to 0. The shift register is not cleared                                                                                                                                                                                                                                                                                    |
| 0   | FE   |           | Setting this bit to a "1" enables both the transmitted and received FIFOs. Clearing this bit to a "0" disables both the transmitted and received FIFOs and clears all bytes from both FIFOs. When changing from FIFO Mode to non-FIFO (16450) mode, data are automatically cleared from the FIFOs. This bit must be a 1 when other bits in this register are written to or they will not be properly programmed. |

ΤL



| I/O Po       | rt:     |    | Base Ad               | dress + | 3h  |   |    |
|--------------|---------|----|-----------------------|---------|-----|---|----|
| Regis        | ter Nam | e: | Line Control Register |         |     |   |    |
| Reset Value: |         |    | 00h                   |         |     |   |    |
| 7            | 6       | 5  | 4                     | 3       | 2   | 1 | 0  |
| DLAB         | BC      | SP | EOP                   | PE      | NSB | S | CN |

The system programmer specifies the format of the asynchronous data communications exchange and sets the Divisor Latch Access bit via the Line Control Register (LCR). The programmer can also read the contents of the Line Control Register. The read capability simplifies system programming and eliminates the need for separate storage in system memory of the line characteristics. Table II shows the contents of the LCR. Details on each bit are listed as follows:

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | DLAB | R/W       | Divisor Latch Access Bit (DLAB). It must be set to '1' to access the divisor latch of the baud generator during a Read or Write operation. It must be set to a '0' to access the Receive Buffer, the Transmitter Holding Register or the interrupt Enable Register.                                                                                                                                                                             |
| 6   | BC   | R/W       | Break Control Bit. It causes a break condition to be transmitted to the receiving UART.<br>0: Disable the break<br>1: Force the serial out (SOUT) to the Spacing ('0') State                                                                                                                                                                                                                                                                    |
| 5   | SP   | R/W       | This bit is the Stick Parity bit. When bits 3, 4 and 5 are logic 1s, the Parity bit is transmitted and checked as a '0'. If bits 3 and 5 are '1's and bit 4 is a '0', the Parity bit is transmitted and checked as a '1'. If bit 5 is a logic 0, Stick Parity is disabled.                                                                                                                                                                      |
| 4   | EOP  | R/W       | Even/Odd parity bit selected when parity is enabled<br>0: Odd parity selected<br>1: Even parity selected                                                                                                                                                                                                                                                                                                                                        |
| 3   | PE   | R/W       | Parity Enabled/Disabled.<br>0: Parity disabled<br>1: Parity enabled<br>When this bit is set to a '1', a parity bit will be generated between the last data word and STOP<br>bit when data is being transmitted, and check the parity bit when data is being received.                                                                                                                                                                           |
| 2   | NSB  | R/W       | Stop bit.<br>This bit specifies the number of Stop bits transmitted and received in each serial character.<br>Set 0: One Stop bit is generated in the transmitted data.<br>Set 1: One and a half stop bits are generated for a 5-bit word length characters.<br>Two stop bits are generated for either 6-, 7-, or 8-bit word length characters. The receiver<br>checks the first Stop bit only, regardless of the number of Stop bits selected. |
| 1-0 | SCN  | R/W       | These two bits specify the number of bits in each transmitted and received serial characters.<br>00: 5 bits<br>01: 6 bits<br>10: 7 bits<br>11: 8 bits                                                                                                                                                                                                                                                                                           |



| I/O Po       | ort:     |    | Base Address + 4h      |      |      |     |     |  |
|--------------|----------|----|------------------------|------|------|-----|-----|--|
| Regis        | ster Nam | e: | Modem Control Register |      |      |     |     |  |
| Reset Value: |          |    | 00h                    |      |      |     |     |  |
| 7 6 5        |          | 5  | 4                      | 3    | 2    | 1   | 0   |  |
|              | Rsvd     |    | LBF                    | INTE | Rsvd | RTS | DTR |  |

This register controls the interface with the MODEM or data set (or a peripheral device emulating a MODEM). The contents of the MODEM Control Register are indicated in Table II and are described as below.

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|-----|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7-5 | Rsvd | RO        | Reserved. Must be all '0's                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| 4   | LBF  | R/W       | <ul> <li>This bit provides the loop back feature for diagnostic testing of the Serial Port. When this bit is set to '1', the following occurs:</li> <li>1) The Transmitter serial out (SOUT) is set to the Marking State ('1').</li> <li>2) The receiver Serial Input (SIN) is disconnected.</li> <li>3) The output of the Transmitter Shift Register is "looped back" into the Receiver Shift Register input.</li> <li>4) All MODEM Control inputs (CTS_n, DSR_n, RI_n and DCD_n) are disconnected.</li> <li>5) The four MODEM Control outputs (DTR_n, RTS_n, OUT1 and OUT2) are internally connected to the four MODEM Control inputs (CTS_n, DSR_n, RI_n and DCD_n).</li> <li>6) The Modem Control output pins are forced to be inactive high.</li> <li>7) Data transmitted are immediately received.</li> <li>This feature allows the processor to verify the transmit- and receive-data paths of the Serial Port. In the diagnostic mode, the receiver and the transmitter interrupts are fully operational.</li> <li>The MODEM Control Interrupts are also operational but the interrupts' sources are now the lower four bits of the MODEM Control Register instead of the MODEM Control inputs. The interrupts are still controlled by the Interrupt Enable Register.</li> </ul> |  |  |  |
| 3   | INTE | R/W       | Interrupt Enable. This bit is used to enable a UART interrupt. When OUT2 is a '0', the serial port interrupt output is forced to the high impedance state - disabled. When OUT2 is a '1', the serial port interrupt output is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 2   | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| 1   | RTS  | R/W       | This bit controls the Request To Send (RTS_n) output. When this bit is set to a '1', the RTS_n output is forced to a '0'. When this bit is a '0', the RTS_n output is forced to a '1'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 0   | DTR  | R/W       | This bit controls the Data Terminal Ready (DTR_n) output. When this bit is set to a '1', the DTR_n output is forced to a '0'. When this bit is a '0', the DTR_n output is forced to a '1'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |

|                | I/O Po       | ort: | I    | Base Address + 5h    |    |    |    |    |  |
|----------------|--------------|------|------|----------------------|----|----|----|----|--|
| Register Name: |              |      |      | Line Status Register |    |    |    |    |  |
|                | Reset Value: |      |      | 60h                  |    |    |    |    |  |
|                | 7            | 6    | 5    | 4                    | 3  | 2  | 1  | 0  |  |
|                | EB           | TEMT | THRE | BI                   | FE | PE | OE | DR |  |

This register provides status information to the CPU concerning the data transfer.

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                  |
|-----|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | EB   | R/W       | This bit is permanently set to a logic "0" in the 450 mode. In the FIFO mode, this bit is set to a logic "1" when there is at least one parity error, framing error or break indication in the FIFO. This bit is cleared when the LSR is read if there are no subsequent errors in the FIFO. |

| D | C <sup>®</sup> |                        |
|---|----------------|------------------------|
| K |                | RISC DSP Communication |

| 6 | ТЕМТ | R/W | Transmitter Empty (TEMT). This bit is set to a '1' whenever the Transmitter Holding Register (THR) and Transmitter Shift Register (TSR) are both empty. It is reset to a '0' whenever either the THR or TSR contains a data character. This bit is a read only bit. In the FIFO mode, this bit is set whenever the THR and TSR are both empty,                                                                                                                                                                                                                                                                                                                                                                   |
|---|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 | THRE | R/W | Transmitter Holding Register Empty (THRE). This bit indicates that the Serial Port is ready to accept a new character for transmission. In addition, this bit causes the Serial Port to issue an interrupt when the Transmitter Holding Register interrupt enable is set high. The THRE bit is set to a '1' when a character is transferred from the Transmitter Holding Register into the Transmitter Shift Register. This bit is reset to '0' whenever the CPU loads the Transmitter Holding Register. In the FIFO mode, this bit is set when the transmit FIFO is empty. It is cleared when at least 1 byte is written to the transmit FIFO. This bit is a read only bit.                                     |
| 4 | BI   | R/W | Break Interrupt (BI). This bit is set to a '1' whenever the received data input is held in the Spacing state ('0') for longer than a full word transmission time (that is, the total time of the start bit + data bits + parity bits + stop bits). The BI is reset after the CPU reads the contents of the Line Status Register. In the FIFO mode, this error is associated with the particular character in the FIFO it applies to. This error is indicated when the associated character is at the top of the FIFO. When a break occurs, only one zero character is loaded into the FIFO. Restarting after a break is received requires the serial data (RXD) to be '1' for at least 1/2 bit time.             |
| 3 | FE   | R/W | Framing Error (FE). This bit indicates that the received character does not have a valid stop bit. This bit is set to a '1' whenever the stop bit following the last data bit or parity bit is detected as a zero bit (Spacing level). The FE is reset to a '0' whenever the Line Status Register is read. In the FIFO mode, this error is associated with the particular character in the FIFO it applies to. This error is indicated when the associated character is at the top of the FIFO. The Serial Port will try to resynchronize after a framing error. To do this, it assumes that the framing error was due to the next start bit, so it samples this 'start' bit twice and then takes in the 'data'. |
| 2 | PE   | R/W | Parity Error (PE). This bit indicates that the received data character does not have the correct<br>even or odd parity, as selected by the even parity select bit. The PE is set to a '1' upon<br>detection of a parity error and is reset to a '0' whenever the Line Status Register is read. In the<br>FIFO mode, this error is associated with the particular character in the FIFO it applies to. This<br>error is indicated when the associated character is at the top of the FIFO.                                                                                                                                                                                                                        |
| 1 | OE   | R/W | Overrun Error (OE). This bit indicates that the data in the Receiver Buffer Register were not read before the next character was transferred into the register, thereby destroying the previous character. In FIFO mode, an overrun error will occur only when the FIFO is full and the next character has been completely received in the shift register. The character in the shift register is overwritten but not transferred to the FIFO. The OE indicator is set to a '1' immediately upon detection of an overrun condition, and reset whenever the Line Status Register is read.                                                                                                                         |
| 0 | DR   | R/W | Data Ready (DR). It is set to a '1' whenever a complete incoming character has been received<br>and transferred into the Receiver Buffer Register or the FIFO. This bit is reset to a '0' by<br>reading all of the data in the Receiver Buffer Register or the FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                             |



| I/O Po       | ort:    |    | Base Address + 6h     |   |   |   |  |  |
|--------------|---------|----|-----------------------|---|---|---|--|--|
| Regis        | ter Nam | e: | Modem Status Register |   |   |   |  |  |
| Reset Value: |         |    | x0h                   |   |   |   |  |  |
| 7            | 6       | 5  | 4                     | 3 | 2 | 1 |  |  |

| 7   | 6  | 5   | 4   | 3    | 2    | 1    | 0    |
|-----|----|-----|-----|------|------|------|------|
| DCD | RI | DSR | CTS | DDCD | TERI | DDSR | DCTS |

This register provides the current state of the control lines from the MODEM (or peripheral device) to the CPU. In addition to this current-state information, four bits of the MODEM Status Register provide change information. These bits are set to logic 1s whenever a control input from the MODEM changes state. They are reset to logic 0s whenever the CPU reads the MODEM Status Register. The contents of the MODEM Status Register are indicated in Table II and described as below.

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                            |
|-----|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | DCD  | R/W       | This bit is the complement of the Data Carrier Detect (DCD_n) input. If bit 4 of the MCR is set to '1', this bit is equivalent to OUT2 in the Modem Control Register.                                                                                                                                                  |
| 6   | RI   | R/W       | This bit is the complement of the Ring Indicator (RI_n) input. If bit 4 of the MCR is set to '1', this bit is equivalent to OUT1 in the Modem Control Register.                                                                                                                                                        |
| 5   | DSR  | R/W       | This bit is the complement of the Data Set Ready (DSR_n) input. If bit 4 of the MCR is set to '1', this bit is equivalent to DTR_n in the Modem Control Register.                                                                                                                                                      |
| 4   | CTS  | R/W       | This bit is the complement of the Clear To Send (CTS_n) input. If bit 4 of the MCR is set to '1', this bit is equivalent to RTS_n in the Modem Control Register.                                                                                                                                                       |
| 3   | DDCD | R/W       | Delta Data Carrier Detect (DDCD). This bit is set to '1' whenever the DCD_n input to the chip has changed the state since the last time the MSR (Modem Status Register) was read. It is reset to a '0' whenever the MODEM Status Register is read.                                                                     |
| 2   | TERI | R/W       | Trailing Edge of Ring Indicator (TERI). This bit is set to '1' whenever the RI_n input has been changed from '0' to '1'. It is reset to '0' whenever the MODEM Status Register is read.                                                                                                                                |
| 1   | DDSR | R/W       | Delta Data Set Ready (DDSR). This bit indicates that the DSR_n input to R8610 has changed the state since the last time the MSR (Modem Status Register) was read. This bit is set to '1'" whenever DSR_n input from the MODEM has changed the state. It is reset to '0' whenever the MODEM Status Register is read.    |
| 0   | DCTS | R/W       | Delta Clear To Send (DCTS). This bit indicates that the CTS_n input to the R8610 has changed the state since the last time the MSR (Modem Status Register) was read. This bit is set to '1'" whenever CTS_n input from the MODEM has changed the state. It is reset to '0' whenever the MODEM Status Register is read. |

Note: Whenever bit 0, 1, 2 or 3 is set to a logic "1", a MODEM Status Interrupt is generated.

| I/O Port:    |         |    | Base Address + 7h   |   |   |   |   |  |
|--------------|---------|----|---------------------|---|---|---|---|--|
| Regis        | ter Nam | e: | Scratchpad Register |   |   |   |   |  |
| Reset Value: |         |    |                     |   |   |   |   |  |
| 7            | 6       | 5  | 4                   | 3 | 2 | 1 | 0 |  |
| SR           |         |    |                     |   |   |   |   |  |

This 8-bit Read/Write Register does not control the UART in any way. It is intended as a scratchpad register used by the programmer to hold data temporarily.

| Bit | Name | Attribute | Description                                                                                                                                                                      |
|-----|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | SR   | R/W       | This 8-bit read/write register has no effect on the operation of the Serial Port. It is intended as a scratchpad register to be used by the programmer to hold data temporarily. |



#### 11.2.11 NMI Status and Control Register

| I/O Port:      | 61h                             |
|----------------|---------------------------------|
| Register Name: | NMI Status and Control Register |
| Reset Value:   |                                 |
|                |                                 |

| 1   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| SSS | ISS | T2S | RCT | IOE | PSE | SDE | T2E |

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                  |
|-----|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | SSS  | RO        | SERR_n NMI Source Status. Bit 7 is set if a system board agent (PCI devices or main memory) detects a system board error and pulses the PCI SERR_n line. This interrupt source is enabled by setting bit 2 to 0. To reset the interrupt, set bit 2 to 0 and then set it to '1'. When writing to port 061, bit 7 must be a 0. |
| 6   | ISS  | RO        | IOCHK_n NMI Source Status. Bit 6 is set if an expansion board asserts an IOCHK_n on the ISA Bus. This interrupt source is enabled by setting bit 3 to 0. To reset the interrupt, set bit 3 to 0 and then set it to '1'. When writing to port 061, bit 6 must be a 0.                                                         |
| 5   | T2S  | RO        | Timer Counter 2 OUT Status. The Counter 2 OUT signal state is reflected in Bit 5. The value on this bit following a read is the current state of the Counter 2 OUT signal. Counter 2 must be programmed by following a CPURST for this bit to have a determinate value. When writing to port 061, bit 5 must be a 0.         |
| 4   | RCT  | RO        | Refresh Cycle Toggle. The Refresh Cycle Toggle signal toggles from either 0 to 1 or 1 to 0 by following every refresh cycle. When writing to port 061, bit 5 must be a 0.                                                                                                                                                    |
| 3   | IOE  | R/W       | 1 = Clear and Disable. 0 = Enable IOCHK_n NMIs.                                                                                                                                                                                                                                                                              |
| 2   | PSE  | R/W       | PCI SERR_n Enable. 1 = Clear and Disable. 0 = Enable.                                                                                                                                                                                                                                                                        |
| 1   | SDE  | R/W       | Speaker Data Enable. 0 = SPKR output is 0. 1 = the SPKR output is the Counter 2 OUT signal value.                                                                                                                                                                                                                            |
| 0   | T2E  | R/W       | Timer Counter 2 Enable. 0 = Disable; 1 = Enable.                                                                                                                                                                                                                                                                             |

#### 11.2.12 CMOS Memory & RTC Register

| I/O Port:      |      |   | 70h |        |         |         |    |
|----------------|------|---|-----|--------|---------|---------|----|
| Register Name: |      |   |     | Летогу | Address | Registe | er |
| Reset Value:   |      |   |     |        |         |         |    |
| 7              | 6    | 5 | 4   | 3      | 2       | 1       | 0  |
| ND             | Rsvd |   | CRA |        |         |         |    |

This port is shared with the real-time clock. Do not modify the contents of this register without considering the effects on the state of the other bits. Reads and writes to this register address flow through to the ISA Bus. Reads to register 70h will cause X-Bus reads, but no RTCCS\_n or RTCALE will be generated. (The RTC has traditionally been write-only to port 70h.)

| Bit | Name | Attribute | Description                                                                                                                          |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------|
| 7   | ND   | 1/1/      | <ul><li>= 1: NMI disabled (used in normal access to CMOS RAM)</li><li>= 0: Allowed non-maskable interrupt, NMI interrupt 2</li></ul> |

# R8610

| 32-Bit F | RISC Mic | croCont | roller |
|----------|----------|---------|--------|
|          |          |         |        |

| 6   | Rsvd | RO | Reserved                                    |
|-----|------|----|---------------------------------------------|
| 5-0 | CRA  | W  | CMOS RAM address for the next read or write |

| Register Name: CMOS Memory Data Register | ort: 7       | I/O Port:    |                           |   | 71h |   |   |  |  |  |
|------------------------------------------|--------------|--------------|---------------------------|---|-----|---|---|--|--|--|
|                                          | ster Name: C | Regis        | CMOS Memory Data Register |   |     |   |   |  |  |  |
| Reset Value:                             | t Value:     | Reset Value: |                           |   |     |   |   |  |  |  |
| 7 6 5 4 3 2 1 0                          | 6 5          | 7            | 4                         | 3 | 2   | 1 | 0 |  |  |  |

CRD

| Bit | Name | Attribute | Description                                                                                          |
|-----|------|-----------|------------------------------------------------------------------------------------------------------|
| 7-0 | CRD  | 10///D    | RTC Data. Data written to standard RAM bank address selected via CMOS Memory Address Register (70h). |

### 11.2.13 System Function Register

| I/O Port:      |   |   | 92h                     |   |   |     |     |
|----------------|---|---|-------------------------|---|---|-----|-----|
| Register Name: |   |   | System Control Register |   |   |     |     |
| Reset Value:   |   |   | 00h                     |   |   |     |     |
| 7              | 6 | 5 | 4                       | 3 | 2 | 1   | 0   |
| Reserved       |   |   |                         |   |   | FGA | FSR |
|                |   |   |                         |   |   |     |     |

| Bit | Name | Attribute | Description                                                                                                       |
|-----|------|-----------|-------------------------------------------------------------------------------------------------------------------|
| 7-2 | Rsvd | RO        | Reserved. Returns "0" when read.                                                                                  |
| 1   | FGA  | R/W       | Fast Gate A20. Set '1' to this bit and '0' to Configuration Register Index 41 bit 1 to Turn ON the Fast Gate A20. |
| 0   | FSR  |           | Fast System Reset. Set '1' to this bit and '0' to Configuration Register Index 41 bit 1 to Reset System           |

### 11.3 PCI Configuration Space Registers

11.3.1 <u>R8610 North Bridge Configuration Registers</u>

ſ

| Regis | Register Offset:<br>Register Name:<br>Reset Value: |     | 01h – 00           | Dh |    |   |   |    |   |   |   |   |   |   |   |
|-------|----------------------------------------------------|-----|--------------------|----|----|---|---|----|---|---|---|---|---|---|---|
| Regis | ter Nam                                            | ne: | Vendor ID Register |    |    |   |   |    |   |   |   |   |   |   |   |
| Reset | Reset Value:                                       |     | 17F3h              |    |    |   |   |    |   |   |   |   |   |   |   |
| 15    | 14                                                 | 13  | 12                 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                                                    |     |                    |    |    |   | V | ID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                                   |
|------|------|-----------|-------------------------------------------------------------------------------|
| 15-0 | VID  | RO        | This register contains a 16-bit value assigned to RDC Semiconductor Co., Ltd. |

| Regis | Register Offset:<br>Register Name:<br>Reset Value:<br>15 14 13 |    | 03h – 02<br>Device I<br>6020h |    | ster |   |   |    |   |   |   |   |   |   |   |
|-------|----------------------------------------------------------------|----|-------------------------------|----|------|---|---|----|---|---|---|---|---|---|---|
| 15    | 14                                                             | 13 | 12                            | 11 | 10   | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                                                                |    |                               |    |      |   | D | ID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                         |
|------|------|-----------|---------------------------------------------------------------------|
| 15-0 | DID  | RO        | This register contains a 16-bit value assigned to the R8610 device. |

| Register Offset:<br>Register Name:<br>Reset Value:<br>15 14 13 |    |    |    | 05h – 04h<br>Command Register<br>000Eh |          |   |   |   |   |   |      |      |     |     |      |
|----------------------------------------------------------------|----|----|----|----------------------------------------|----------|---|---|---|---|---|------|------|-----|-----|------|
| 15                                                             | 14 | 13 | 12 | 11                                     | 10       | 9 | 8 | 7 | 6 | 5 | 4    | 3    | 2   | 1   | 0    |
|                                                                |    |    |    |                                        | Reserved | l |   |   |   |   | MWIC | SCOC | MDC | MAC | IOAC |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                   |
|------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-5 | Rsvd | RO        | Reserved.                                                                                                                                                                                                     |
| 4    | MWIC | RO        | Memory Write and Invalid Command.                                                                                                                                                                             |
| 3    | SCOC | RO        | Special Cycle operations control.                                                                                                                                                                             |
| 2    | MDC  | RO        | PCI Bus Master Device Control. This bit always returns '1'                                                                                                                                                    |
| 1    | MAC  | RW        | Memory Space Accesses Control. It controls a device's response to Memory Space accesses.<br>A value of 0 disables the device response. A value of 1 allows the device to respond to Memory<br>Space accesses. |
| 0    | IOAC | RO        | I/O Space Accesses Control.                                                                                                                                                                                   |



| Regis | ter Offs | set: | 07h – 06 | Sh       |    |   |   |   |   |   |          |   |   |   |   |
|-------|----------|------|----------|----------|----|---|---|---|---|---|----------|---|---|---|---|
| Regis | ter Nan  | ne:  | Status R | Register |    |   |   |   |   |   |          |   |   |   |   |
| Reset | Value:   |      | 0400h    |          |    |   |   |   |   |   |          |   |   |   |   |
| 15    | 14       | 13   | 12       | 11       | 10 | 9 | 8 | 7 | 6 | 5 | 4        | 3 | 2 | 1 | 0 |
| DPE   | SS       | RMAS | RTAS     | STAS     | D  | Т |   |   |   |   | Reserved | 1 |   |   |   |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                              |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | DPE  | RO        | Detected Parity Error. This bit must be set whenever the device detects a parity error. This is a read-only bit and is cleared by writing '1' to it.                                                                                                     |
| 14   | SS   | RO        | SERR_n status. This bit must be set whenever the device asserts SERR_n. This is a read-only bit and is cleared by writing '1' to it.                                                                                                                     |
| 13   | RMAS | RO        | Receive Master Abort Status when the R8610 acts as a master. This bit is set to '1' when the R8610 generates a transaction (except for Special Cycle), and is terminated with master abort. This is a read-only bit and is cleared by writing '1' to it. |
| 12   | RTAS | RO        | Receive Target Abort Status when the R8610 acts as a master. This bit is set to '1' when the R8610 encounters a target abort condition. This is a read-only bit and is cleared by writing a '1' to it.                                                   |
| 11   | STAS | RO        | Signal Target Abort Status when the R8610 acts as a slave.<br>The R8610 as a slave never generates a target abort. This bit is always 0.                                                                                                                 |
| 10-9 | DT   | RO        | DEVSEL_n Timing. Only support Medium decode "01" & Slow decode "10".                                                                                                                                                                                     |
| 8-0  | Rsvd | RO        | Reserved. These bits always return '0's.                                                                                                                                                                                                                 |

| • | ter Offs<br>ter Nam |   | 08h<br>Revisior | n ID Rec | lister |   |   |
|---|---------------------|---|-----------------|----------|--------|---|---|
| - | Value:              |   | 01h             |          | JISTO  |   |   |
| 7 | 6                   | 5 | 4               | 3        | 2      | 1 | 0 |
|   |                     |   |                 | ID       | 2      | ! | 0 |

|  | 1 |  |
|--|---|--|
|  |   |  |
|  |   |  |

| Bit | Name | Attribute | Description                  |
|-----|------|-----------|------------------------------|
| 7-0 | RID  | RO        | Version number of the R8610. |

| Register Offset: | 0Bh – 09h                                         |
|------------------|---------------------------------------------------|
| Register Name:   | Class Code Register                               |
| Reset Value:     | 060000h                                           |
| 23 22 21 20      | 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

СС

| Bit  | Name | Attribute | Description              |
|------|------|-----------|--------------------------|
| 23-0 | СС   | RO        | Class Code of the R8610. |

| Regis | ter Offs | et: | 0Eh                  | 0Eh |   |   |   |  |  |  |  |  |
|-------|----------|-----|----------------------|-----|---|---|---|--|--|--|--|--|
| Regis | ter Nam  | ne: | Header Type Register |     |   |   |   |  |  |  |  |  |
| Reset | Value:   |     | 00h                  |     |   |   |   |  |  |  |  |  |
| 7     | 7 6      |     | 4                    | 3   | 2 | 1 | 0 |  |  |  |  |  |
|       |          |     |                      |     |   |   |   |  |  |  |  |  |

00h

| Bit | Name | Attribute | Description                                                                                                                                                                                             |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | HT   | RO        | This register identifies the type of predefined header in the configuration space. Since the R8610 is a single function device (bit7='0') and not a PCI-to-PCI bridge, this byte should be read as 00h. |

| Register Offset:2Dh – 2ChRegister Name:Subsystem Vendor ID RegisterReset Value:FFFFh |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------------------------------------------------------------------------|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 15                                                                                   | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                                                                      | SVID |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Attribute Description |                                                 |  |  |
|------|------|-----------------------|-------------------------------------------------|--|--|
| 15-0 | SVID | RO                    | This register contains the subsystem Vendor ID. |  |  |



| Register Offset: 2Fh – 2Eh |         |     |                              |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------------------|---------|-----|------------------------------|----|----|---|---|---|---|---|---|---|---|---|---|
| Regis                      | ter Nam | ne: | Subsystem Device ID Register |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset Value:               |         |     | FFFFh                        |    |    |   |   |   |   |   |   |   |   |   |   |
| 15                         | 14      | 13  | 12                           | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                            | SDID    |     |                              |    |    |   |   |   |   |   |   |   |   |   |   |

| l | Bit  | Name | Attribute | Description                                     |
|---|------|------|-----------|-------------------------------------------------|
|   | 15-0 | SDID | RO        | This register contains the subsystem Device ID. |

| Register Offset: | 53h – 50h                          |
|------------------|------------------------------------|
| Register Name:   | NonCache Region Register #1 for L1 |
| Reset Value:     | 0000000h                           |

| 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 |
|-------------------------------------------|---------------------------------------------|
|-------------------------------------------|---------------------------------------------|

| Base Address | En | Reserved | Size |
|--------------|----|----------|------|

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
|-------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 31-11 | BA   | R/W       | se Address for the user-defined NonCache Region                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| 10    | REn  | R/W       | Region Enabled for the NonCache Region                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| 9-3   | Rsvd | R/W       | Reserved                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| 2-0   | RSz  | R/W       | Size of the NonCache Region         Bit 2       Bit 1       Bit 0       Size         0       0       2K Bytes         0       1       4K Bytes         0       1       4K Bytes         0       1       16K Bytes         0       1       16K Bytes         1       0       32K Bytes         1       0       128K Bytes         1       1       256K Bytes |  |  |  |  |  |  |  |  |

| R            | egi                                               | ster | Offs | set: |    | 57h | - 5 | 4h  |    |    |    |    |    |         |    |    |    |       |    |    |    |   |     |          |   |   |   |   |   |   |   |
|--------------|---------------------------------------------------|------|------|------|----|-----|-----|-----|----|----|----|----|----|---------|----|----|----|-------|----|----|----|---|-----|----------|---|---|---|---|---|---|---|
| R            | Register Name: NonCache Region Register #2 for L1 |      |      |      |    |     |     |     |    |    |    |    |    |         |    |    |    |       |    |    |    |   |     |          |   |   |   |   |   |   |   |
| Reset Value: |                                                   |      |      |      |    | 000 | 000 | 00h |    |    |    |    |    |         |    |    |    |       |    |    |    |   |     |          |   |   |   |   |   |   |   |
| 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 |
|              | Base Address                                      |      |      |      |    |     |     |     |    |    |    |    |    | RE<br>n |    |    | Re | eserv | ed |    |    |   | RSZ | <u>,</u> |   |   |   |   |   |   |   |

| Bit   | Name | Attribute | Description                                       |
|-------|------|-----------|---------------------------------------------------|
| 31-11 | BA   | R/W       | Base Address for the user-defined NonCache Region |



| 10  | REn  | R/W | Region Enabled for the NonCache Region                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9-3 | Rsvd | R/W | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2-0 | RSZ  | R/W | Size of the NonCache Region         Bit 2       Bit 1       Bit 0       Size         0       0       0       2K Bytes         0       0       1       4K Bytes         0       1       0       8K Bytes         0       1       1       16K Bytes         1       0       32K Bytes         1       0       1       64K Bytes         1       1       0       128K Bytes         1       1       128K Bytes         1       1       1256K Bytes |

| Register Offset: | 5Bh – 58h                          |
|------------------|------------------------------------|
| Register Name:   | NonCache Region Register #3 for L1 |
| Reset Value:     | 0000000h                           |

| 31 | 30 2 | 9 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 |
|----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Base Address | En | Reserved | Size |  |
|--------------|----|----------|------|--|
|--------------|----|----------|------|--|

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                       |
|-------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-11 | BA   | R/W       | Base Address for the user-defined NonCache Region                                                                                                                                                                                                                                                                                 |
| 10    | REn  | R/W       | Region Enabled for the NonCache Region                                                                                                                                                                                                                                                                                            |
| 9-3   | Rsvd | R/W       | Reserved                                                                                                                                                                                                                                                                                                                          |
| 2-0   | RSz  | R/W       | Size of the NonCache Region         Bit 2       Bit 1       Bit 0       Size         0       0       0       2K Bytes         0       1       4K Bytes         0       1       4K Bytes         0       1       16K Bytes         1       0       32K Bytes         1       0       128K Bytes         1       1       256K Bytes |

| Register Offset: | 5Fh – 5Ch                          |
|------------------|------------------------------------|
| Register Name:   | NonCache Region Register #4 for L1 |
| Reset Value:     | 0000000h                           |

#### 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

| Base Address En Reserved Size |
|-------------------------------|
|-------------------------------|

| Bit   | Name | Attribute | Description                                       |
|-------|------|-----------|---------------------------------------------------|
| 31-11 | BA   | R/W       | Base Address for the user-defined NonCache Region |



| 10  | REn  | R/W | Region                                                                                           | n Enat                                                                                    | oled fo | r the N                                                                                           | IonCache Reg | on |  |  |
|-----|------|-----|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------|--------------|----|--|--|
| 9-3 | Rsvd | R/W | Reserv                                                                                           | /ed                                                                                       |         |                                                                                                   |              |    |  |  |
| 2-0 | RSz  | R/W | Size of<br>Bit 3<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | the N<br>Bit 2<br>0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>0<br>0<br>0<br>0<br>1<br>1<br>1 |         | che Re<br><u>Bit 0</u><br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0 |              |    |  |  |

| Regis | ter Offs | et:  | 66h                                   |   |     |      |   |  |  |  |  |  |
|-------|----------|------|---------------------------------------|---|-----|------|---|--|--|--|--|--|
| Regis | ter Nam  | e:   | Memory Clock Phase Selection Register |   |     |      |   |  |  |  |  |  |
| Reset | Value:   |      | 00h                                   |   |     |      |   |  |  |  |  |  |
| 7     | 6        | 5    | 4                                     | 3 | 2   | 1    | 0 |  |  |  |  |  |
|       | MCP      | 'S_R |                                       |   | MCF | vs_w |   |  |  |  |  |  |

| Bit | Name   | Attribute | Description                             |
|-----|--------|-----------|-----------------------------------------|
| 7-4 | MCPS_R | R/W       | Memory Clock Phase Selection for Read.  |
| 3-0 | MCPS_w | R/W       | Memory Clock Phase Selection for Write. |

| -     | ter Offs<br>ter Nam |    | 69h – 68<br>Memory |     | Register | - |   |      |   |   |   |          |   |   |   |
|-------|---------------------|----|--------------------|-----|----------|---|---|------|---|---|---|----------|---|---|---|
| Reset | eset Value: C99Fh   |    |                    |     |          |   |   |      |   |   |   |          |   |   |   |
| 15    | 14                  | 13 | 12                 | 11  | 10       | 9 | 8 | 7    | 6 | 5 | 4 | 3        | 2 | 1 | 0 |
| tWR   | tRC                 |    |                    | tRP |          |   |   | tRCD |   |   |   | Reserved |   |   |   |

| Bit | Name | Attribute | Description                                         |
|-----|------|-----------|-----------------------------------------------------|
| 15  | tWR  |           | SDRAM cycle: Write Recovery Time.<br>0: 1T<br>1: 2T |



|       |       |     | SDRAM cycle: REF/ACT to REF/ACT delay                 |
|-------|-------|-----|-------------------------------------------------------|
|       |       |     | Bit 14 Bit 13 Bit 12 Bit 11 delay period              |
|       |       |     | 0 0 0 Reserved                                        |
|       |       |     | 0 0 0 1 1 Clock                                       |
|       |       |     | 0 0 1 0 2 Clocks                                      |
|       |       |     | 0 0 1 1 3 Clocks                                      |
|       |       |     | 0 1 0 0 4 Clocks                                      |
|       |       |     | 0 1 0 1 5 Clocks                                      |
|       | 100   |     | 0 1 1 0 6 Clocks                                      |
| 14-11 | tRC   | R/W | 0 1 1 1 7 Clocks                                      |
|       |       |     | 1 0 0 0 8 Clocks                                      |
|       |       |     | 1 0 0 1 9 Clocks                                      |
|       |       |     | 1 0 1 0 10 Clocks                                     |
|       |       |     | 1 0 1 1 11 Clocks                                     |
|       |       |     | 1 1 0 0 12 Clocks                                     |
|       |       |     | 1 1 0 1 13 Clocks                                     |
|       |       |     | 1 1 1 0 14 Clocks                                     |
|       |       |     | 1 1 1 1 15 Clocks                                     |
|       |       |     | SDRAM cycle: PRE to ACT command period                |
|       |       |     | Bit 10 Bit 9 Bit 8 Bit 7 delay period                 |
|       |       |     | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ |
|       |       |     | 0 0 0 1 1 Clock                                       |
|       |       |     | 0 0 1 0 2 Clocks                                      |
|       |       |     | 0 0 1 1 3 Clocks                                      |
|       |       |     | 0 1 0 0 4 Clocks                                      |
|       |       |     | 0 1 0 1 5 Clocks                                      |
|       |       |     | 0 1 1 0 6 Clocks                                      |
| 10-7  | tRP   | R/W | 0 1 1 1 7 Clocks                                      |
|       |       |     | 1 0 0 0 8 Clocks                                      |
|       |       |     | 1 0 0 1 9 Clocks                                      |
|       |       |     | 1 0 1 0 10 Clocks                                     |
|       |       |     | 1 0 1 1 11 Clocks                                     |
|       |       |     | 1 1 0 0 12 Clocks                                     |
|       |       |     | 1 1 0 1 13 Clocks                                     |
|       |       |     | 1 1 1 0 14 Clocks                                     |
|       |       |     | 1 1 1 1 15 Clocks                                     |
|       |       |     | SDRAM cycle: ACT to R/W command delay period          |
|       |       |     | Bit 6 Bit 5 Bit 4 Bit 3 delay period                  |
|       |       |     | 0 0 0 0 Reserved                                      |
|       |       |     | 0 0 0 1 1 Clock                                       |
|       |       |     | 0 0 1 0 2 Clocks                                      |
|       |       |     | 0 0 1 1 3 Clocks                                      |
|       |       |     | 0 1 0 0 4 Clocks                                      |
|       |       |     | 0 1 0 1 5 Clocks                                      |
|       |       | _   | 0 1 1 0 6 Clocks                                      |
| 6-3   | tRCD  | R/W | 0 1 1 1 7 Clocks                                      |
|       |       |     | 1 0 0 8 Clocks                                        |
|       |       |     | 1 0 0 1 9 Clocks                                      |
|       |       |     | 1 0 1 0 10 Clocks                                     |
|       |       |     | 1 0 1 1 11 Clocks                                     |
|       |       |     | 1 1 0 0 12 Clocks                                     |
|       |       |     | 1 1 0 1 13 Clocks                                     |
|       |       |     | 1 1 1 0 14 Clocks                                     |
|       |       |     | 1 1 1 1 15 Clocks                                     |
| 2-0   | Dourd | RO  | Reserved.                                             |
| 2-0   | Rsvd  | RU  |                                                       |



| Regis          | ter Offs | et:                     | 6Bh – 6 | 6Bh – 6Ah |      |       |   |   |   |   |   |     |     |     |      |  |
|----------------|----------|-------------------------|---------|-----------|------|-------|---|---|---|---|---|-----|-----|-----|------|--|
| Register Name: |          | Memory Control Register |         |           |      |       |   |   |   |   |   |     |     |     |      |  |
| Reset Value:   |          |                         | 0004h   |           |      |       |   |   |   |   |   |     |     |     |      |  |
| 15             | 14       | 13                      | 12      | 11        | 10   | 9     | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0    |  |
|                |          |                         |         |           | Rese | erved |   |   |   |   |   | LMR | Cas | Lat | Rsvd |  |

| Bit  | Name   | Attribute | Description                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|------|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 15-4 | Rsvd   | RO        | Reserved                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| 3    | LMR    | R/W       | Lode Mode Register. When this register is written by software, this bit is set by the DRAM controller to program the mode register of SDRAM. After the programming is complete, this bit will be auto-cleared by the DRAM controller.<br>0: Complete.<br>1: Programming the mode register of SDRAM. |  |  |  |  |  |
| 2-1  | CasLat | R/W       | SDRAM cycle: Cas Latency<br><u>Bit 2 Bit 1</u> <u>delay period</u><br>0 0 Reserved<br>0 1 Reserved<br>1 0 2 Clocks<br>1 1 3 Clocks                                                                                                                                                                  |  |  |  |  |  |
| 0    | Rsvd   | RO        | Reserved.                                                                                                                                                                                                                                                                                           |  |  |  |  |  |

| Register Offset: 6Dh – 6Ch          |    |     |       |        |    |   |   |   |     |   |   |    |   |     |   |
|-------------------------------------|----|-----|-------|--------|----|---|---|---|-----|---|---|----|---|-----|---|
| Register Name: Memory Bank Register |    |     |       |        |    |   |   |   |     |   |   |    |   |     |   |
| Reset Value:                        |    |     | 0331h |        |    |   |   |   |     |   |   |    |   |     |   |
| 15                                  | 14 | 13  | 12    | 11     | 10 | 9 | 8 | 7 | 6   | 5 | 4 | 3  | 2 | 1   | 0 |
| Reserved C1M                        |    | C1M | BWT   | BWT SS |    |   |   |   | RAT |   |   | BN |   | CAT |   |

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|-------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 15-14 | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| 13    | C1M  | RW        | SDRAM CS_n[1] Mask when set. CS_n[1] is activated when cleared.                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| 12    | BWT  | RW        | RAM Data Bus Width Type.<br>16-bit.<br>Reserved.                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| 11-8  | SS   | RW        | SDRAM Size:       SDRAM Size         Bit 11       Bit 10       Bit 9       Bit 8       SDRAM Size         0       0       0       2MB         0       0       1       4MB         0       0       1       4MB         0       0       1       16MB         0       1       1       16MB         0       1       0       32MB         0       1       0       128MB         0       1       1       Reserved         1       x       x       Reserved |  |  |  |  |  |  |
| 7-5   | RAT  | RW        | DRAM Row Address Type:<br>it 7 Bit 6 Bit 5 No. Bits of Row Address                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |



| r   |     |    |                                              |
|-----|-----|----|----------------------------------------------|
|     |     |    | 0 0 0 11 Bits of Row Address                 |
|     |     |    | 0 0 1 12 Bits of Row Address                 |
|     |     |    | 0 1 0 13 Bits of Row Address                 |
|     |     |    | 0 1 1 Reserved                               |
|     |     |    | 1 x x Reserved                               |
|     |     |    | Bank Number Supported by SDRAM               |
|     |     |    | Bit <u>4</u> Bit <u>3</u> Bank Number        |
|     |     | RW | 0 0 1 Bank                                   |
| 4-3 | BN  |    | 0 1 2 Banks                                  |
|     |     |    | 1 0 4 Banks                                  |
|     |     |    | 1 1 8 Banks                                  |
|     |     |    | SDRAM Column Address Type:                   |
|     |     |    | Bit 2 Bit 1 Bit 0 No. Bits of Column Address |
|     |     |    | 0 0 0 8 Bits of Column Address               |
| 2-0 | CAT | RW | 0 0 1 9 Bits of Column Address               |
|     |     |    | 0 1 0 10 Bits of Column Address              |
|     |     |    | 0 1 1 11 Bits of Column Address              |
|     |     |    | 1 x x Reserved                               |
|     |     | •  |                                              |

| Regis | ter Offs       | et: | 6Eh |                                              |   |   |   |  |  |  |  |
|-------|----------------|-----|-----|----------------------------------------------|---|---|---|--|--|--|--|
| Regis | Register Name: |     |     | Memory Read/Write Reorder & Refresh Register |   |   |   |  |  |  |  |
| Reset | Value:         |     | 00h |                                              |   |   |   |  |  |  |  |
| 7     | 6              | 5   | 4   | 3                                            | 2 | 1 | 0 |  |  |  |  |
| RWR   | Rsvd           |     |     |                                              |   |   |   |  |  |  |  |

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RWR  |           | Read/Write Reorder Enable<br>0: Disable                                                                                                                                                                                                                                                                                                                                                         |
|     |      | 1: Enable |                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6   | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
| 5-0 | RPT  | R/W       | Refresh Priority Threshold<br>The R8610 is built in a cumulated refresh counter. When the refresh trigger reaches the<br>threshold, the counter will increase and wait for service to decrease the counter. In order to<br>prevent the Refresh Counter being expired, the system gives highest priority for refresh request<br>to access DRAM when this Refresh Priority Threshold is exceeded. |

| Register Offset: | 83h                             |
|------------------|---------------------------------|
| Register Name:   | A/B Page and SMM Range Register |
| Reset Value:     | 08h                             |
|                  |                                 |

| 7     | 6     | 5   | 4   | 3     | 2 | 1       | 0 |
|-------|-------|-----|-----|-------|---|---------|---|
| SMREN | SMWEN | SMF | RAM | SDRRM |   | Reserve | d |

| Bit | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                    |
|-----|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | SMREN | R/W       | 000A0000h-000BFFFFh Read Enable (SMREN).<br>0: Disable.<br>1: Enable.<br>When this bit is disabled, the read requests of memory address 000A0000h-000BFFFFh will be<br>forwarded to the PCI bridge. Otherwise, the read requests of memory address<br>000A0000h-000BFFFFh are handled based on the SMRAM and SMMEN_n bits of the<br>corresponding requests.    |
| 6   | SMWEN | R/W       | 000A0000h-000BFFFFh Write Enable (SMWEN):<br>0: Disable.<br>1: Enable.<br>When this bit is disabled, the write requests of memory address 000A0000h-000BFFFFh will be<br>forwarded to the PCI bridge. Otherwise, the write requests of memory address<br>000A0000h-000BFFFFh are handled based on the SMRAM and SMMEN_n bits of the<br>corresponding requests. |
| 5-4 | SMRAM | R/W       | <ul> <li>SMM Memory Range Access Mode (SMRAM[1:0]).</li> <li>00: Close.</li> <li>01: Open.</li> <li>10: Lock.</li> <li>11: Protected.</li> <li>The requested handling is based on the SMM bit and code or data references and illustrated in the following table.</li> </ul>                                                                                   |
| 3   | SDRRM | R/W       | SMM Default Range Re-mapping.<br>0: Disable.<br>1: Enable.<br>When this bit is enabled, requested with the SMM bit set and targeted the<br>00038000h-0003FFFFh address range will be re-mapping to 000A0000h-000BFFFFh.<br>Otherwise, no re-mapping will be done.                                                                                              |
| 20  | Rsvd  | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                       |

Note: The following table shows the response of requests targeting at SMM space (000A0000h-000BFFFFh)

| SMREN/SMWEN | SMM      | Mode (SMRAM[1:0])       | Code    | Data    |
|-------------|----------|-------------------------|---------|---------|
| Disable     | Reserved | Reserved                | PCI Bus | PCI Bus |
| Enable      | No       | Close, Lock and Protect | PCI Bus | PCI Bus |
| Enable      | No       | Open                    | SDRAM   | SDRAM   |
| Enable      | Yes      | Open and Protect        | SDRAM   | SDRAM   |
| Enable      | Yes      | Close and Lock          | SDRAM   | PCI Bus |



| Register Offset: | 87h – 84h                 |
|------------------|---------------------------|
| Register Name:   | Memory Attribute Register |
| Reset Value:     | 0000h                     |

| 31 | 30 2 | 9 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 |
|----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Rsvd | F0A | ECA | E8A | E4A | E0A | DCA | D8A | D4A | D0A | CCA | C8A | C4A | C0A | Reserved |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----------|
|      |     |     |     |     |     |     |     |     |     |     |     |     |     |          |

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                             |
|-------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                                                                |
| 29-28 | F0A  | R/W       | Attribute of access to memory address 000F0000h-000FFFFFh Region.         Bit 29       Description         0       0       Read/Write from/to PCI Bus         0       1       Read from SDRAM, Write to PCI Bus         1       0       Read from PCI Bus, Write to SDRAM         1       1       Read/Write from/to SDRAM              |
| 27-26 | ECA  | R/W       | Attribute of access to memory address 000EC000h-000EFFFFh Region.         Bit 27       Bit 26       Description         0       0       Read/Write from/to PCI Bus         0       1       Read from SDRAM, Write to PCI Bus         1       0       Read from PCI Bus, Write to SDRAM         1       1       Read/Write from/to SDRAM |
| 25-24 | E8A  | R/W       | Attribute of access to memory address 000E8000h-000EBFFFh Region.         Bit 25 Bit 24       Description         0       0       Read/Write from/to PCI Bus         0       1       Read from SDRAM, Write to PCI Bus         1       0       Read from PCI Bus, Write to SDRAM         1       1       Read/Write from/to SDRAM       |
| 23-22 | E4A  | R/W       | Attribute of access to memory address 000E4000h-000E7FFFh Region.         Bit 23       Description         0       0       Read/Write from/to PCI Bus         0       1       Read from SDRAM, Write to PCI Bus         1       0       Read from PCI Bus, Write to SDRAM         1       1       Read/Write from/to SDRAM              |
| 21-20 | E0A  | RW        | Attribute of access to memory address 000E0000h-000E3FFFh Region.         Bit 21       Bit 20       Description         0       0       Read/Write from/to PCI Bus         0       1       Read from SDRAM, Write to PCI Bus         1       0       Read from PCI Bus, Write to SDRAM         1       1       Read/Write from/to SDRAM |
| 19-18 | DCA  | RW        | Attribute of access to memory address 000DC000h-000EFFFFh Region.         Bit 19 Bit 18       Description         0       0       Read/Write from/to PCI Bus         0       1       Read from SDRAM, Write to PCI Bus         1       0       Read from PCI Bus, Write to SDRAM         1       1       Read/Write from/to SDRAM       |
| 17-16 | D8A  | RW        | Attribute of access to memory address 000D8000h-000DBFFFh Region.         Bit 17       Bit 16       Description         0       0       Read/Write from/to PCI Bus         0       1       Read from SDRAM, Write to PCI Bus         1       0       Read from PCI Bus, Write to SDRAM         1       1       Read/Write from/to SDRAM |
| 15-14 | D4A  | RW        | Attribute of access to memory address 000D4000h-000D7FFFh Region.         Bit 15       Bit 14       Description         0       0       Read/Write from/to PCI Bus         0       1       Read from SDRAM, Write to PCI Bus         1       0       Read from PCI Bus, Write to SDRAM         1       1       Read/Write from/to SDRAM |



|       |          |      | Attribute of access to memory address 000D0000h-000D3FFFh Region. |
|-------|----------|------|-------------------------------------------------------------------|
|       |          |      | Bit 13 Bit 12 Description                                         |
|       |          |      | 0 0 Read/Write from/to PCI Bus                                    |
| 13-12 | D0A      | RW   | 0 1 Read from SDRAM, Write to PCI Bus                             |
|       |          |      | 1 0 Read from PCI Bus, Write to SDRAM                             |
|       |          |      | 1 1 Read/Write from/to SDRAM                                      |
|       |          |      | Attribute of access to memory address 000CC000h-000CFFFFh Region. |
|       |          |      | Bit 11 Bit 10 Description                                         |
|       |          |      | 0 0 Read/Write from/to PCI Bus                                    |
| 11-10 | 1-10 CCA | RW   | 0 1 Read from SDRAM, Write to PCI Bus                             |
|       |          |      | 1 0 Read from PCI Bus, Write to SDRAM                             |
|       |          |      | 1 1 Read/Write from/to SDRAM                                      |
|       |          |      | Attribute of access to memory address 000C8000h-000CBFFFh Region. |
|       |          | RW   | Bit 9 Bit 8 Description                                           |
|       |          |      | 0 0 Read/Write from/to PCI Bus                                    |
| 9-8   | 9-8 C8A  |      | 0 1 Read from SDRAM, Write to PCI Bus                             |
|       |          |      | 1 0 Read from PCI Bus, Write to SDRAM                             |
|       |          |      | 1 1 Read/Write from/to SDRAM                                      |
|       |          |      | Attribute of access to memory address 000C4000h-000C7FFFh Region. |
|       |          |      | Bit 7 Bit 6 Description                                           |
|       | <b></b>  |      | 0 0 Read/Write from/to PCI Bus                                    |
| 7-6   | C4A      | RW   | 0 1 Read from SDRAM, Write to PCI Bus                             |
|       |          |      | 1 0 Read from PCI Bus, Write to SDRAM                             |
|       |          |      | 1 1 Read/Write from/to SDRAM                                      |
|       |          |      | Attribute of access to memory address 000C0000h-000C3FFFh Region. |
|       |          |      | Bit 5 Bit 4 Description                                           |
|       |          |      | 0 0 Read/Write from/to PCI Bus                                    |
| 5-4   | C0A      | A RW | 0 1 Read from SDRAM, Write to PCI Bus                             |
|       |          |      | 1 0 Read from PCI Bus, Write to SDRAM                             |
|       |          |      | 1 1 Read/Write from/to SDRAM                                      |
| 3-0   | Rsvd     | RW   | Reserved                                                          |
| 00    | 1,010    | 1.11 |                                                                   |

| Register Offset: | 93h – 90h                                                              |
|------------------|------------------------------------------------------------------------|
| Register Name:   | Customer ID Register                                                   |
| Reset Value:     | 00321007h                                                              |
| 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 |

CID

| Bit  | Name | Attribute | Description  |
|------|------|-----------|--------------|
| 31-0 | CID  | RO        | Customer ID. |



| Register Offset: | 97h – 94h        |
|------------------|------------------|
| Register Name:   | Spare 1 Register |
| Reset Value:     | 00000000h        |

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

S1

| Bit  | Name | Attribute | Description                                                              |
|------|------|-----------|--------------------------------------------------------------------------|
| 31-0 | S1   | R/W       | Store Data. These registers can be used by BIOS to store temporary data. |

|    | •  | ster ( |    |    |    | 9Bh<br>Spa | -  | -  | niete | r  |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|--------|----|----|----|------------|----|----|-------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    | •  | t Val  |    |    |    | 000        |    |    | JISIC | 1  |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |

S2

| Bit  | Name | Attribute | Description                                                              |
|------|------|-----------|--------------------------------------------------------------------------|
| 31-0 | S2   | R/W       | Store Data. These registers can be used by BIOS to store temporary data. |

| Re | egis | ter ( | Offs | et: |    | 9Fh | - 9  | Ch  |       |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|------|-------|------|-----|----|-----|------|-----|-------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Re | egis | ter I | Nam  | ne: |    | Spa | re 3 | Reg | giste | er |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Re | eset | Val   | ue:  |     |    | 000 | 000  | 00h |       |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 04 | 20   | 20    | 20   | 07  | 20 | 05  | 04   | 00  | 22    | 04 | 00 | 10 | 10 | 47 | 10 | 45 |    | 40 | 10 |    | 10 | 0 | 0 | 7 | ~ | - | 4 | 2 | 0 | 4 | 0 |
| 31 | 30   | 29    | 28   | 21  | 20 | 25  | 24   | 23  |       | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | TT | 10 | 9 | 8 | / | 6 | 5 | 4 | 3 | 2 |   | 0 |
|    |      |       |      |     |    |     |      |     |       |    |    |    |    |    | 5  | 33 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                              |
|------|------|-----------|--------------------------------------------------------------------------|
| 31-0 | S3   | R/W       | Store Data. These registers can be used by BIOS to store temporary data. |



| Register Offset: | C3h – C0h            |
|------------------|----------------------|
| Register Name:   | USB Control Register |
| Reset Value:     | 0000_0000h           |

| 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       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|---------|----|----|----|-----|---------|---------|---------|---|------|---|----|----|---------|---------|
| Rsvd  |    |    |    |    |    |    | P  | CR |    |    |    |    |    |    | PB<br>E | PB<br>O | PE | BC | R  | svd | PB<br>F | PB<br>D | FB<br>E |   | Rsvo | ł | FI | BS | FB<br>F | FB<br>D |

| Bit   | Name | Attribute | Description                                                              |
|-------|------|-----------|--------------------------------------------------------------------------|
| 31-30 | Rsvd | RO        | Reserved.                                                                |
| 29-16 | PCR  | R/W       | USB PHY Control Register.                                                |
| 15    | PBE  | R/W       | USB PHY Bist Enable when set.                                            |
| 14    | PBO  | R/W       | USB PHY Bist Out.<br>0:port1 results in bit9.<br>1:port2 results in bit9 |
| 13-12 | PBC  | R/W       | USB PHY Bist Current.<br>01b: BIST test port1.<br>10b: BIST test port2   |
| 11-10 | Rsvd | RO        | Reserved.                                                                |
| 9     | PBF  | RO        | USB PHY Bist Fault when set.                                             |
| 8     | PBD  | RO        | USB PHY Bist Done when set.                                              |
| 7     | FBE  | R/W       | USB FIFO Bist Enable when set.                                           |
| 6-4   | Rsvd | RO        | Reserved.                                                                |
| 3-2   | FBS  | RO        | USB FIFO Bist Status.                                                    |
| 1     | FBF  | RO        | USB FIFO Bist Fault.                                                     |
| 0     | FBD  | RO        | USB FIFO Bist Done.                                                      |



### 11.3.2 R8610 South Bridge Configuration Registers

| Regist | ter Offs | et: | 01h – 00 | Dh       |      |   |   |    |   |   |   |   |   |   |   |
|--------|----------|-----|----------|----------|------|---|---|----|---|---|---|---|---|---|---|
| Regist | ter Nam  | ne: | Vendor   | ID Regis | ster |   |   |    |   |   |   |   |   |   |   |
| Reset  | Value:   |     | 17F3h    |          |      |   |   |    |   |   |   |   |   |   |   |
| 15     | 14       | 13  | 12       | 11       | 10   | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|        |          |     |          |          |      |   | V | ID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                      |
|------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | VID  |           | This register contains a 16-bit value assigned to RDC Semiconductor Co., Ltd. If the R8610 Configuration Register Index 41 Bit 0 = '1', this register can be read and written. Otherwise, this register is Read-Only. BIOS should be used to program a value to this register and then lock it by setting the R8610 Configuration Register Index 41 Bit 0 = '0'. |

| Regis | ter Offs<br>ter Nam<br>Value: |    | 03h – 02<br>Device I<br>6030h |    | ster |   |   |    |   |   |   |   |   |   |   |
|-------|-------------------------------|----|-------------------------------|----|------|---|---|----|---|---|---|---|---|---|---|
| 15    | 14                            | 13 | 12                            | 11 | 10   | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                               |    |                               |    |      |   | D | ID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                              |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | DID  | RO        | This register contains a 16-bit value to specify a particular device. If the R8610 Configuration Register Index 41 Bit 0 = '1', this register can be read and written. Otherwise, this register is Read-Only. BIOS should be used to program a value to this register and then lock it by setting the R8610 Configuration Register Index 41 Bit 0 = '0'. |





| Regis | ter Offs | et: | 05h – 04 | 1h      |      |   |     |   |          |   |     |      |      |      |       |
|-------|----------|-----|----------|---------|------|---|-----|---|----------|---|-----|------|------|------|-------|
| Regis | ter Nam  | ne: | Comma    | nd Regi | ster |   |     |   |          |   |     |      |      |      |       |
| Reset | Value:   |     | 000Fh    |         |      |   |     |   |          |   |     |      |      |      |       |
| 15    | 14       | 13  | 12       | 11      | 10   | 9 | 8   | 7 | 6        | 5 | 4   | 3    | 2    | 1    | 0     |
|       |          |     | Reserved | l       |      |   | SFE |   | Reserved |   | MWI | SCOC | PMDC | MSAC | IOSAC |

| Bit  | Name  | Attribute | Description                                                    |
|------|-------|-----------|----------------------------------------------------------------|
| 15-9 | Rsvd  | RO        | Reserved. These bits always return '0's.                       |
| 8    | SFE   | R/W       | SERR_n Function Enable/Disable<br>0: Disabled.<br>1: Enabled.  |
| 7-5  | Rsvd  | RO        | Reserved. These bits always return '0's.                       |
| 4    | MWI   | R/W       | Memory Write and Invalid Command. This bit always returns '0'. |
| 3    | SCOC  | R/W       | Special Cycle operation control. This bit always returns '1'.  |
| 2    | PMDC  | R/W       | PCI Bus Master Device Control. This bit always returns '1'.    |
| 1    | MSAC  | R/W       | Memory Space Access Control. This bit always returns '1'.      |
| 0    | IOSAC | R/W       | I/O Space Access Control. This bit always returns '1'.         |

**Register Offset:** 07h – 06h **Register Name:** Status Register **Reset Value:** 0400h 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 DPE SS RMAS RTAS STAS DT Reserved

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                              |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | DPE  | RO        | Detected Parity Error. This bit must be set whenever the device detects a parity error. This is a read only bit and is cleared by writing '1' to it.                                                                                                     |
| 14   | SS   | RO        | SERR_n Status. This bit must be set whenever the device asserts SERR_n. This is a read only bit and is cleared by writing '1' to it.                                                                                                                     |
| 13   | RMAS | RO        | Receive Master Abort Status when the R8610 acts as a master. This bit is set to '1' when the R8610 generates a transaction (Except for Special Cycle), and is terminated with master-abort. This is a read only bit and is cleared by writing '1' to it. |
| 12   | RTAS | RO        | Receive Target Abort Status when the R8610 acts as a master. This bit is set to '1' when the R8610 encounters a target abort condition. This is a read only bit and is cleared by writing a '1' to it.                                                   |
| 11   | STAS | RO        | Signal Target Abort Status when the R8610 acts as a slave.<br>The R8610 as a slave never generates a Target abort. This bit is always 0.                                                                                                                 |
| 10-9 | DT   | RO        | DEVSEL_n Timing. The R8610 always generates DEVSEL_n with low timing. These bits are always '11'.                                                                                                                                                        |
| 8-0  | Rsvd | RO        | Reserved. These bits always return '0's.                                                                                                                                                                                                                 |

| Regis | ter Offs | et: | 08h      |          |        |   |
|-------|----------|-----|----------|----------|--------|---|
| Regis | ter Nam  | ie: | Revisior | n ID Reg | jister |   |
| Reset | t Value: |     | 00h      |          |        |   |
| 7     | 6        | 5   | 4        | 3        | 2      | 1 |
|       |          |     | R        | ID       |        |   |

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                     |
|-----|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | RID  | R/W       | Version number of the R8610. If the R8610 Configuration Register Index 41 Bit 0 = '1', this register can be read and written. Otherwise, this register is Read-Only. BIOS should be used to program a value to this register and then lock it by setting the R8610 Configuration Register Index 41 Bit 0 = '0'. |

| Re | gister | Offs  | set: | 0B  | h – 0 | 9h    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|--------|-------|------|-----|-------|-------|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Re | gister | Nan   | ne:  | Cla | ass C | ode F | Regist | er |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Re | set Va | alue: |      | 06  | 0100  | h     |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 23 | 22     | 21    | 20   | 19  | 18    | 17    | 16     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |        |       |      |     |       |       |        |    |    |    | С  | С  |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description              |
|------|------|-----------|--------------------------|
| 23-0 | СС   | RO        | Class Code of the R8610. |

| Regis | ter Offs | et: | 0Eh    |         |         |   |   |
|-------|----------|-----|--------|---------|---------|---|---|
| Regis | ter Nam  | ie: | Header | Type Re | egister |   |   |
| Reset | Value:   |     | 00h    |         |         |   |   |
| 7     | 6        | 5   | 4      | 3       | 2       | 1 | 0 |
|       |          |     | Н      | IT      |         |   |   |

| Bit | Name | Attribute | Description                                                                                                                                                                                             |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | HT   | RO        | This register identifies the type of predefined header in the configuration space. Since the R8610 is a single function device (bit7='0') and not a PCI-to-PCI bridge, this byte should be read as 00h. |



| Register Offset: |         | 2Dh – 2 | Ch      |         |          |         |    |     |   |   |   |   |   |   |   |  |
|------------------|---------|---------|---------|---------|----------|---------|----|-----|---|---|---|---|---|---|---|--|
| Regis            | ter Nam | e:      | Subsyst | tem Ven | dor ID R | egister |    |     |   |   |   |   |   |   |   |  |
| Reset            | Value:  |         | 0000h   |         |          |         |    |     |   |   |   |   |   |   |   |  |
| 15               | 14      | 13      | 12      | 11      | 10       | 9       | 8  | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|                  |         |         |         |         |          |         | SI | /ID |   |   |   |   |   |   |   |  |
|                  |         |         |         |         |          |         |    |     |   |   |   |   |   |   |   |  |
|                  |         |         |         |         |          |         |    |     | _ |   |   |   |   |   |   |  |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                        |
|------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | SVID | R/WL      | This register contains the subsystem Vendor ID. If the R8610 Configuration Register Index 41 Bit 0 = '1', this register can be read and written. Otherwise, this register is Read-Only. BIOS should be used to program a value to this register and then lock it by setting the R8610 Configuration Register Index 41 Bit 0 = '0'. |

| Regis | ter Offs | et: | 2Fh – 21 | Eh     |          |         |    |     |   |   |   |   |   |   |   |
|-------|----------|-----|----------|--------|----------|---------|----|-----|---|---|---|---|---|---|---|
| Regis | ter Nam  | ne: | Subsyst  | em Dev | ice ID R | egister |    |     |   |   |   |   |   |   |   |
| Reset | Value:   |     | 3210h    |        |          |         |    |     |   |   |   |   |   |   |   |
| 15    | 14       | 13  | 12       | 11     | 10       | 9       | 8  | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |          |     |          |        |          |         | SE | DID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                        |
|------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | SDID | R/WL      | This register contains the subsystem Device ID. If the R8610 Configuration Register Index 41 Bit 0 = '1', this register can be read and written. Otherwise, this register is Read-Only. BIOS should be used to program a value to this register and then lock it by setting the R8610 Configuration Register Index 41 Bit 0 = '0'. |

| 40h                     |
|-------------------------|
| Boot Strapping Register |
| 00h                     |
|                         |

| 7        | 6 | 5 | 4 | 3 | 2 | 1  | 0  |
|----------|---|---|---|---|---|----|----|
| Reserved |   |   |   |   |   | FI | RS |

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|-----|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7-2 | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 1-0 | FRS  | RO        | X Bus/LPC/FWH Flash ROM Selected<br>00: 8-bit Flash ROM is located on X Bus<br>01: 16-bit Flash ROM is located on X Bus<br>10: Flash ROM is located on LPC<br>11: Flash ROM is located on LPC/FWH<br>These two bits reflect the boot strapping state of ROMTYPE[1:0] pins on the rising edge of<br>system reset. Pulling down ROMTYPE[1:0] pins on the rising edge of system reset will set the<br>corresponding bit to '0'. Pulling up ROMTYPE[1:0] pins on the rising edge of system reset will<br>set the corresponding bit to '1'. |  |  |



Rsvd

| Regis | ter Offs | et: | 41h                                 | 41h |   |   |   |  |  |  |  |  |
|-------|----------|-----|-------------------------------------|-----|---|---|---|--|--|--|--|--|
| Regis | ter Nam  | ne: | Write Lock and LPC Control Register |     |   |   |   |  |  |  |  |  |
| Reset | Value:   |     | 00h                                 |     |   |   |   |  |  |  |  |  |
| 7     | 6        | 5   | 4                                   | 3   | 2 | 1 | 0 |  |  |  |  |  |

DOCS P92FE

P92S

LB

SRC

| Bit | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-5 | Rsvd  | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4   | SRC   | R/W       | PCI Soft Reset Control.<br>0: When the CPU soft reset is initialized, PCIRST_n will not be active.<br>1: When the CPU soft reset is initialized, PCIRST_n will be active.<br>This bit is used to control the assertion of PCIRST_n when the CPU soft reset is initialized. It<br>may be necessary to reset some PCI cards during the CPU soft reset. BIOS can use this bit to<br>solve this issue by resetting the whole PCI bus. |
| 3   | DOCS  | R/W       | DMA Operating Clock Selected.<br>0: 4 MHz<br>1: 8 MHz                                                                                                                                                                                                                                                                                                                                                                             |
| 2   | P92FE | R/W       | Internal port 92 Write Function Enable/Disable<br>0: Disable<br>1: Enable<br>This bit is no effect when bit 1 of this register is set to '0'                                                                                                                                                                                                                                                                                      |
| 1   | P92S  | R/W       | Internal/LPC Port 92h Selection<br>0: LPC Port 92h Selected<br>1: Internal Port 92h Selected                                                                                                                                                                                                                                                                                                                                      |
| 0   | LB    | R/W       | R8610 Vendor ID, System ID and Revision ID Registers Read Only Control.<br>0: Read only.<br>1: Read/Write.                                                                                                                                                                                                                                                                                                                        |

| Regis | ter Offs | et: | 43h – 42 | 2h      |          |         |         |   |
|-------|----------|-----|----------|---------|----------|---------|---------|---|
| Regis | ter Nam  | e:  | Flash R  | OM Chip | o Select | Control | Registe | r |
| Reset | Value:   |     | 0000h    |         |          |         |         |   |
| 15    | 14       | 13  | 12       | 11      | 10       | 9       | 8       |   |

| 15    | 14 | 13   | 12   | 11 | 10    | 9     | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|----|------|------|----|-------|-------|------|------|------|------|------|------|------|------|------|
| FRWPM |    | Rese | rved |    | FRR11 | FRR10 | FRR9 | FRR8 | FRR7 | FRR6 | FRR5 | FRR4 | FRR3 | FRR2 | FRR1 |

| Bit   | Name  | Attribute | Description                                                                                                                                                                                                                        |
|-------|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | FRWPM |           | Flash ROM Write Protect Mode.<br>0: Write Disable.<br>1: Write Enable.<br>When this bit is '0', ROMCS_n will be asserted only in memory read cycle. When this bit is '1',<br>ROMCS_n will be asserted in memory read/write cycles. |
| 14-11 | Rsvd  | RO        | Reserved                                                                                                                                                                                                                           |
| 10    | FRR11 | R/W       | Flash ROM Region 11 (FFC00000h-FFCFFFFh) for ROMCS_n Decode<br>0: Disable.<br>1: Enable.                                                                                                                                           |
| 9     | FRR10 | R/W       | Flash ROM Region 10 (FFD00000h-FFDFFFFh) for ROMCS_n Decode<br>0: Disable.                                                                                                                                                         |



|   |      |     | 1: Enable.                                                                                                                                |
|---|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
| 8 | FRR9 | R/W | Flash ROM Region 9 (FFE00000h-FFE7FFFh) for ROMCS_n Decode<br>0: Disable.<br>1: Enable.                                                   |
| 7 | FRR8 | R/W | Flash ROM Region 8 (FFE80000h-FFEFFFFh) for ROMCS_n Decode<br>0: Disable.<br>1: Enable.                                                   |
| 6 | FRR7 | R/W | Flash ROM Region 7 (FFF00000h-FFF3FFFh) for ROMCS_n Decode<br>0: Disable.<br>1: Enable.                                                   |
| 5 | FRR6 | R/W | Flash ROM Region 6 (FFF40000h-FFF7FFFFh) for ROMCS_n Decode<br>0: Disable.<br>1: Enable.                                                  |
| 4 | FRR5 | R/W | Flash ROM Region 5 (FFF80000h-FFF9FFFh) for ROMCS_n Decode<br>0: Disable.<br>1: Enable.                                                   |
| 3 | FRR4 | R/W | Flash ROM Region 4 (FFFA0000h-FFFBFFFFh) for ROMCS_n Decode<br>0: Disable.<br>1: Enable.                                                  |
| 2 | FRR3 | R/W | Flash ROM Region 3 (FFFC0000h-FFFDFFFh) for ROMCS_n Decode<br>0: Disable.<br>1: Enable.                                                   |
| 1 | FRR2 | R/W | Flash ROM Region 2 (000C0000h-000DFFFFh) for ROMCS_n Decode<br>0: Disable.<br>1: Enable.                                                  |
| 0 | FRR1 | R/W | Flash ROM Region 1 for ROMCS_n Decode.<br>0: 000F0000h-000FFFFFh and FFFF0000h-FFFFFFFh<br>1: 000E0000h-000FFFFFh and FFFE0000h-FFFFFFFFh |

| Reg | gister | r Offs | et: | 46 | h – 44h               |    |    |      |       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|--------|--------|-----|----|-----------------------|----|----|------|-------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reg | gister | ' Nam  | ne: | Wa | atchdog Timer Control |    |    |      |       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Res | set Va | alue:  |     | 00 | 0002ł                 | ו  |    |      |       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 23  | 22     | 21     | 20  | 19 | 18                    | 17 | 16 | 15   | 14    | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| WTE | W      | 'TI    | RF  | NF | WIF                   |    |    | Rese | erved |    |    |    | IR | т |   |   |   |   | W | С |   |   |   |

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23    | WTE  | R/W       | Enable/Disable Watchdog Timer<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 22-21 | WTI  | R/W       | Generate a CPU Reset/NMI/WDT IRQ when WDT Timeout is reached<br>00: WDT generates a CPU reset when WDT timeout is reached.<br>01: WDT generates an NMI interrupt when WDT timeout is reached and NMI flag bit (Bit 19) is<br>set to '0'. And WDT generates a CPU reset when WDT timeout is reached and NMI flag bit (Bit<br>19) is set to '1'<br>10: WDT generates a WDT IRQ when WDT timeout is reached and WDT IRQ flag bit (Bit 18) is<br>set to '0'. And WDT generates a CPU reset when WDT timeout is reached and WDT IRQ flag bit (Bit 18) is<br>set to '0'. And WDT generates a CPU reset when WDT timeout is reached and WDT IRQ flag bit (Bit 18) is<br>set to '0'. And WDT generates a CPU reset when WDT timeout is reached and WDT IRQ flag<br>bit (Bit 18) is set to '1'<br>11: Reserved |
| 20    | RF   | R/W       | Reset Flag<br>This bit will be set to '1' when the WDT reset event has occurred. Write '1' to this bit to clear<br>Reset Flag bit to '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |





| NDT NMI interrupt event has occurred. Write '1' to | this t |
|----------------------------------------------------|--------|

| 19    | NF   | R/W | This bit will be set to '1' when the WDT NMI interrupt event h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NMI Flag<br>This bit will be set to '1' when the WDT NMI interrupt event has occurred. Write '1' to this bit to<br>clear NMI Flag bit to '0' |  |  |  |  |  |  |  |  |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 18    | WIF  | R/W | WDT IRQ Flag<br>This bit will be set to '1' when the WDT IRQ interrupt event has occurred. Write '1' to this bit to<br>clear WDT IRQ Flag bit to '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                              |  |  |  |  |  |  |  |  |
| 17-12 | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                              |  |  |  |  |  |  |  |  |
| 11-8  | IRT  | R/W | WDT IRQ Routing Table         Bit11 Bit10 Bit9 Bit8 Routing Table         0       0       0         0       0       1         0       0       1         0       0       1         0       0       1         0       0       1         0       0       1         0       0       1         0       0       1         0       1       1         0       1       1         0       1       1         0       1       1         0       1       1         0       1       1         0       1       1         0       1       1         1       0       1         1       0       1         1       0       1         1       0       1         1       1       1         1       0       1         1       1       1         1       0       1         1       1       1         1       1       1 <td< td=""></td<>                                                                                                                                                                                                                                        |                                                                                                                                              |  |  |  |  |  |  |  |  |
| 7-0   | WC   | R/W | WDT Count. The Count Setting determines the duration of the a. The duration equation: 2 <sup>Exponent</sup> /Frequency         b. The exponent of Count setting:       Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Exponent         0       0       0       0       0       N/A         x       x       x       x       x       10         x       x       x       x       x       10         x       x       x       x       1       0       20         x       x       x       x       1       0       21         x       x       x       x       1       0       0       22         x       x       x       1       0       0       23         x       x       1       0       0       0       24         x       1       0       0       0       26       0         c.       Frequency: 14.318MHz (external) or 12.5MHz (internal)         WDT Timer Duration Reference Table:         Frequency/       10       20       21       22       23         14.318MHz       71.5 us       73.2 ms       146 ms       293 ms       586         12.5MHz | 3         24         25         26           ms         1.17 s         2.34 s         4.69 s                                                 |  |  |  |  |  |  |  |  |



| Register Offset: | 4Bh – 48h                              |
|------------------|----------------------------------------|
| Register Name:   | General-Purpose I/O Control Register I |
| Reset Value:     | 000000h                                |

# 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 G31 G30 G29 G28 G27 G26 G25 G24 G23 G22 G21 G20 G19 G18 G17 G16 G15 G14 G13 G10 G9 G8 G7 G6 G5 G4 G3 G2 G1 G0 E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E

| Bit      | Name  | Attribute | Description                                                                            |
|----------|-------|-----------|----------------------------------------------------------------------------------------|
|          |       |           | GPIO31 Function Enable/Disable.                                                        |
| 31       | G31E  | R/W       | 0: Disable. This pin operates in normal (SA15) function.                               |
|          |       |           | 1: Enable. This pin operates as GPIO31 with an internal $75K\Omega$ pull-up resistor.  |
|          |       |           | GPIO30 Function Enable/Disable.                                                        |
| 30       | G30E  | R/W       | 0: Disable. This pin operates in normal (SA14) function.                               |
|          |       |           | 1: Enable. This pin operates as GPIO30 with an internal 75K $\Omega$ pull-up resistor. |
|          |       |           | GPIO29 Function Enable/Disable.                                                        |
| 29       | G29E  | R/W       | 0: Disable. This pin operates in normal (SA13) function.                               |
|          |       |           | 1: Enable. This pin operates as GPIO29 with an internal 75K $\Omega$ pull-up resistor. |
|          |       |           | GPIO28 Function Enable/Disable.                                                        |
| 28       | G28E  | R/W       | 0: Disable. This pin operates in normal (PGNT2_n) function.                            |
|          |       |           | 1: Enable. This pin operates as GPIO28 with an internal 75K $\Omega$ pull-up resistor. |
|          |       |           | GPIO27 Function Enable/Disable.                                                        |
| 27       | G27E  | R/W       | 0: Disable. This pin operates in normal (PGNT1_n) function.                            |
|          |       |           | 1: Enable. This pin operates as GPIO27 with an internal 75K $\Omega$ pull-up resistor. |
|          |       |           | GPIO26 Function Enable/Disable.                                                        |
| 26       | G26E  | R/W       | 0: Disable. This pin operates in normal (PGNT0 n) function.                            |
|          |       |           | 1: Enable. This pin operates as GPIO26 with an internal 75KΩ pull-up resistor.         |
|          |       |           | GPIO25 Function Enable/Disable.                                                        |
| 25       | G25E  | R/W       | 0: Disable. This pin operates in normal (PREQ2_n) function.                            |
|          |       |           | 1: Enable. This pin operates as GPIO25 with an internal $75K\Omega$ pull-up resistor.  |
|          |       |           | GPIO24 Function Enable/Disable.                                                        |
| 24       | G24E  | R/W       | 0: Disable. This pin operates in normal (PREQ1_n) function.                            |
| - ·      | 02.12 |           | 1: Enable. This pin operates as GPIO24 with an internal 75K $\Omega$ pull-up resistor. |
|          |       |           | GPIO23 Function Enable/Disable.                                                        |
| 23       | G23E  | R/W       | 0: Disable. This pin operates in normal (PREQ0_n) function.                            |
| 20       | OZOL  | 1000      | 1: Enable. This pin operates as GPIO23 with an internal $75K\Omega$ pull-up resistor.  |
| -        |       |           | GPIO22 Function Enable/Disable.                                                        |
| 22       | G22E  | R/W       | 0: Disable. This pin operates in normal (INTD n) function.                             |
|          | 0111  |           | 1: Enable. This pin operates as GPIO22 with an internal 75K $\Omega$ pull-up resistor. |
|          |       |           | GPIO21 Function Enable/Disable.                                                        |
| 21       | G21E  | R/W       | 0: Disable. This pin operates in normal (INTC n) function.                             |
| - ·      |       |           | 1: Enable. This pin operates as GPIO21 with an internal 75K $\Omega$ pull-up resistor. |
|          |       |           | GPIO20 Function Enable/Disable.                                                        |
| 20       | G20E  | R/W       | 0: Disable. This pin operates in normal (INTB_n) function.                             |
|          | 0101  |           | 1: Enable. This pin operates as GPIO20 with an internal 75K $\Omega$ pull-up resistor. |
|          |       |           | GPIO19 Function Enable/Disable.                                                        |
| 19       | G19E  | R/W       | 0: Disable. This pin operates in normal (INTA n) function.                             |
|          | 0.01  |           | 1: Enable. This pin operates as GPIO19 with an internal 75K $\Omega$ pull-up resistor. |
|          |       |           | GPIO18 Function Enable/Disable.                                                        |
| 18       | G18E  | R/W       | 0: Disable. This pin operates in normal (IRQ8_n) function.                             |
| 10       | GIGE  |           | 1: Enable. This pin operates as GPIO18 with an internal 75K $\Omega$ pull-up resistor. |
|          | 1     |           | GPI017 Function Enable/Disable.                                                        |
| 17       | G17E  | R/W       | 0: Disable. This pin operates in normal (RTCWR) function.                              |
|          |       | 1.7.4.4   | 1: Enable. This pin operates as GPIO17 with an internal 75K $\Omega$ pull-up resistor. |
| <u> </u> |       |           | GPIO16 Function Enable/Disable.                                                        |
| 16       | G16E  | R/W       | 0: Disable. This pin operates in normal (RTCRD) function.                              |
| 10       | GIOE  | FX/ V V   | 1: Enable. This pin operates as GPIO16 with an internal $75K\Omega$ pull-up resistor.  |
|          |       |           | GPIO15 Function Enable/Disable.                                                        |
| 15       | G15E  | R/W       | 0: Disable. This pin operates in normal (RTCAS) function.                              |
| L        | 1     | 1         |                                                                                        |



14

13

12

11

| Ļ | G14E | R/W | GPIO14 Function Enable/Disable.<br>0: Disable. This pin operates in normal (RI_n) function.<br>1: Enable. This pin operates as GPIO14 with an internal 75KΩ pull-up resistor.                                    |
|---|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| } | G13E | R/W | GPIO13 Function Enable/Disable.<br>0: Disable. This pin operates in normal (DCD_n/TDI) function.<br>1: Enable. This pin operates as GPIO13 with an internal 75KΩ pull-up resistor.                               |
| 2 | G12E | R/W | GPIO12 Function Enable/Disable.<br>0: Disable. This pin operates in normal (DSR_n/TCK) function.<br>1: Enable. This pin operates as GPIO12 with an internal 75KΩ pull-up resistor.                               |
|   | G11E | R/W | GPIO11 Function Enable/Disable.<br>0: Disable. This pin operates in normal (CTS_n/TMS) function.<br>1: Enable. This pin operates as GPIO11 with an internal 75KΩ pull-up resistor.                               |
| ) | G10E | R/W | GPIO10 Function Enable/Disable.<br>0: Disable. This pin operates in normal (DTR_n) function.<br>1: Enable. This pin operates as GPIO10 with an internal 75KΩ pull-up resistor.                                   |
|   | G9E  | R/W | <ul> <li>GPIO9 Function Enable/Disable.</li> <li>0: Disable. This pin operates in normal (RTS_n/TDO) function.</li> <li>1: Enable. This pin operates as GPIO9 with an internal 75KΩ pull-up resistor.</li> </ul> |
|   | G8E  | R/W | <ul> <li>GPIO8 Function Enable/Disable.</li> <li>0: Disable. This pin operates in normal (SOUT) function.</li> <li>1: Enable. This pin operates as GPIO8 with an internal 75KΩ pull-up resistor.</li> </ul>      |
|   | G7E  | R/W | GPIO7 Function Enable/Disable.<br>0: Disable. This pin operates in normal (SIN) function.                                                                                                                        |

1: Enable. This pin operates as GPIO15 with an internal 75K $\Omega$  pull-up resistor.

|    |      |     | T. Enable. This pin operates as GPTOTT with an internal 75K2 pull-up resistor.         |
|----|------|-----|----------------------------------------------------------------------------------------|
|    |      |     | GPIO10 Function Enable/Disable.                                                        |
| 10 | G10E | R/W | 0: Disable. This pin operates in normal (DTR_n) function.                              |
|    |      |     | 1: Enable. This pin operates as GPIO10 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO9 Function Enable/Disable.                                                         |
| 9  | G9E  | R/W | 0: Disable. This pin operates in normal (RTS_n/TDO) function.                          |
|    |      |     | 1: Enable. This pin operates as GPIO9 with an internal 75K $\Omega$ pull-up resistor.  |
|    |      |     | GPIO8 Function Enable/Disable.                                                         |
| 8  | G8E  | R/W | 0: Disable. This pin operates in normal (SOUT) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO8 with an internal 75K $\Omega$ pull-up resistor.  |
|    |      |     | GPIO7 Function Enable/Disable.                                                         |
| 7  | G7E  | R/W | 0: Disable. This pin operates in normal (SIN) function.                                |
|    |      |     | 1: Enable. This pin operates as GPIO7 with an internal 75K $\Omega$ pull-up resistor.  |
|    |      |     | GPIO6 Function Enable/Disable.                                                         |
| 6  | G6E  | R/W | 0: Disable. This pin operates in normal (IRQSER) function.                             |
|    |      |     | 1: Enable. This pin operates as GPIO6 with an internal 75K $\Omega$ pull-up resistor.  |
|    |      |     | GPIO5 Function Enable/Disable.                                                         |
| 5  | G5E  | R/W | 0: Disable. This pin operates in normal (LDRQ_n) function.                             |
|    |      |     | 1: Enable. This pin operates as GPIO5 with an internal 75K $\Omega$ pull-up resistor.  |
|    |      |     | GPIO4 Function Enable/Disable.                                                         |
| 4  | G4E  | R/W | 0: Disable. This pin operates in normal (LFRAME_n) function.                           |
|    |      |     | 1: Enable. This pin operates as GPIO4 with an internal 75K $\Omega$ pull-up resistor.  |
|    |      |     | GPIO3 Function Enable/Disable.                                                         |
| 3  | G3E  | R/W | 0: Disable. This pin operates in normal (LAD3) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO3 with an internal 75K $\Omega$ pull-up resistor.  |
|    |      |     | GPIO2 Function Enable/Disable.                                                         |
| 2  | G2E  | R/W | 0: Disable. This pin operates in normal (LAD2) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO2 with an internal 75K $\Omega$ pull-up resistor.  |
|    |      |     | GPIO1 Function Enable/Disable.                                                         |
| 1  | G1E  | R/W | 0: Disable. This pin operates in normal (LAD1) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO1 with an internal 75K $\Omega$ pull-up resistor.  |
|    |      |     | GPIO0 Function Enable/Disable.                                                         |
| 0  | G0E  | R/W | 0: Disable. This pin operates in normal (LAD0) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO0 with an internal 75K $\Omega$ pull-up resistor.  |



Register Offset:4Fh – 4ChRegister Name:General-Purpose I/O Data Register IReset Value:FFFFFh

#### 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

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|-----|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31  | G31D | R/W       | <ul> <li>GPIO31 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO31 pin to 'Low'. Write '1' to this bit to drive the GPIO31 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO31 from this bit. '1' means that the external device drives the<br/>GPIO31 pin to 'High', and '0' means that the external device drives GPIO31 to 'Low'. A '1'<br/>must be written to this bit when GPIO31 is in Input Mode.</li> </ul> |  |  |
| 30  | G30D | R/W       | <ul> <li>GPIO30 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO30 pin to 'Low'. Write '1' to this bit to drive the GPIO30 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO30 from this bit. '1' means that the external device drives the GPIO30 pin to 'High', and '0' means that the external device drives GPIO30 to 'Low'. A '1' must be written to this bit when GPIO30 is in Input Mode.</li> </ul>         |  |  |
| 29  | G29D | R/W       | <ul> <li>GPIO29 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO29 pin to 'Low'. Write '1' to this bit to drive the GPIO29 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO29 from this bit. '1' means that the external device drives the GPIO29 pin to 'High', and '0' means that the external device drives GPIO29 to 'Low'. A '1' must be written to this bit when GPIO29 is in Input Mode.</li> </ul>         |  |  |
| 28  | G28D | R/W       | <ul> <li>GPIO28 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO28 pin to 'Low'. Write '1' to this bit to drive the GPIO28 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO28 from this bit. '1' means that the external device drives the GPIO28 pin to 'High', and '0' means that the external device drives GPIO28 to 'Low'. A '1' must be written to this bit when GPIO28 is in Input Mode.</li> </ul>         |  |  |
| 27  | G27D | R/W       | GPIO27 Control/Data<br>In Output Mode:<br>Write '0' to this bit to drive the GPIO27 pin to 'Low'. Write '1' to this bit to drive the GPIO27<br>pin to 'High'.<br>In Input Mode:<br>Read input data of GPIO27 from this bit. '1' means that the external device drives the<br>GPIO27 pin to 'High', and '0' means that the external device drives GPIO27 to 'Low'. A '1'<br>must be written to this bit when GPIO27 is in Input Mode.                                  |  |  |
| 26  | G26D | R/W       | <ul> <li>GPIO26 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO26 pin to 'Low'. Write '1' to this bit to drive theGPIO26 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO26 from this bit. '1' means that the external device drives the GPIO26 pin to 'High', and '0' means that the external device drives GPIO26 to 'Low'. A '1' must be written to this bit when GPIO26 is in Input Mode.</li> </ul>          |  |  |
| 25  | G25D | R/W       | BPIO25 Control/Data<br>n Output Mode:<br>Write '0' to this bit to drive the GPIO25 pin to 'Low'. Write '1' to this bit to drive the GPIO25                                                                                                                                                                                                                                                                                                                            |  |  |



R/W

G24D

24

23

22

21

pin to 'High'. In Input Mode:

GPIO24 Control/Data In Output Mode:

pin to 'High'.

In Input Mode:

|      |       | must be written to this bit when GPIO24 is in Input Mode.                                                                                                                                                                                   |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       | GPIO23 Control/Data<br>In Output Mode:<br>Write '0' to this bit to drive the GPIO23 pin to 'Low'. Write '1' to this bit to drive the GPIO23                                                                                                 |
| G23D | R/W   | pin to 'High'.<br>In Input Mode:<br>Read input data of GPIO23 from this bit. '1' means that the external device drives the                                                                                                                  |
|      |       | GPIO23 pin to 'High', and '0' means that the external device drives GPIO23 to 'Low'. A '1' must be written to this bit when GPIO23 is in Input Mode.                                                                                        |
|      |       | GPIO22 Control/Data<br>In Output Mode:                                                                                                                                                                                                      |
|      |       | Write '0' to this bit to drive the GPIO22 pin to 'Low'. Write '1' to this bit to drive the GPIO22                                                                                                                                           |
| G22D | R/W   | pin to 'High'.<br>In Input Mode:                                                                                                                                                                                                            |
|      |       | Read input data of GPIO22 from this bit. '1' means that the external device drives the GPIO22 pin to 'High', and '0' means that the external device drives GPIO22 to 'Low'. A '1' must be written to this bit when GPIO22 is in Input Mode. |
|      |       | GPIO21 Control/Data<br>In Output Mode:                                                                                                                                                                                                      |
| G21D | R/W   | Write '0' to this bit to drive the GPIO21 pin to 'Low'. Write '1' to this bit to drive the GPIO21 pin to 'High'.                                                                                                                            |
| GZID | K/ VV | In Input Mode:<br>Read input data of GPIO21 from this bit. '1' means that the external device drives the                                                                                                                                    |
|      |       | GPIO21 pin to 'High', and '0' means that the external device drives GPIO21 to 'Low'. A '1' must be written to this bit when GPIO21 is in Input Mode.                                                                                        |
|      |       | GPIO20 Control/Data                                                                                                                                                                                                                         |
|      |       | In Output Mode:<br>Write '0' to this bit to drive the GPIO20 pin to 'Low'. Write '1' to this bit to drive the GPIO20                                                                                                                        |
| G20D | R/W   | pin to 'High'.                                                                                                                                                                                                                              |
|      |       | In Input Mode:                                                                                                                                                                                                                              |

Read input data of GPIO25 from this bit. '1' means that the external device drives the GPIO25 pin to 'High', and '0' means that the external device drives GPIO25 to 'Low'. A '1'

Write '0' to this bit to drive the GPIO24 pin to 'Low'. Write '1' to this bit to drive the GPIO24

Read input data of GPIO24 from this bit. '1' means that the external device drives the GPIO24 pin to 'High', and '0' means that the external device drives GPIO24 to 'Low'. A '1'

must be written to this bit when GPIO25 is in Input Mode.

| 20 | G20D R/W Write '0' to this bit to drive the GPIO20 pin to 'Low'. Write '1' to this bit to drive the pin to 'High'.<br>In Input Mode:<br>Read input data of GPIO20 from this bit. '1' means that the external device drives GPIO20 pin to 'High', and '0' means that the external device drives GPIO20 to 'Lo must be written to this bit when GPIO20 is in Input Mode. |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 19 | G19D                                                                                                                                                                                                                                                                                                                                                                   | R/W | <ul> <li>GPI019 Control/Data</li> <li>In Output Mode:</li> <li>Write '0' to this bit to drive the GPI019 pin to 'Low'. Write '1' to this bit to drive the GPI019 pin to 'High'.</li> <li>In Input Mode:</li> <li>Read input data of GPI019 from this bit. '1' means that the external device drives the GPI019 pin to 'High', and '0' means that the external device drives GPI019 to 'Low'. A '1' must be written to this bit when GPI019 is in Input Mode.</li> </ul> |  |
| 18 | G18D                                                                                                                                                                                                                                                                                                                                                                   | R/W | <ul> <li>GPIO18 Control/Data</li> <li>In Output Mode:</li> <li>Write '0' to this bit to drive the GPIO18 pin to 'Low'. Write '1' to this bit to drive theGPIO18 pin to 'High'.</li> <li>In Input Mode:</li> <li>Read input data of GPIO18 from this bit. '1' means that the external device drives the GPIO18 pin to 'High', and '0' means that the external device drives GPIO18 to 'Low'. A '1' must be written to this bit when GPIO18 is in Input Mode.</li> </ul>  |  |
| 17 | G17D                                                                                                                                                                                                                                                                                                                                                                   | R/W | GPIO17 Control/Data<br>In Output Mode:                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |





|    |      |     | Write '0' to this bit to drive the GPIO17 pin to 'Low'. Write '1' to this bit to drive the GPIO17                                                                                 |
|----|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |      |     | pin to 'High'.                                                                                                                                                                    |
|    |      |     | In Input Mode:                                                                                                                                                                    |
|    |      |     | Read input data of GPIO17 from this bit. '1' means that the external device drives the                                                                                            |
|    |      |     | GPIO17 pin to 'High', and '0' means that the external device drives GPIO17 to 'Low'. A '1'                                                                                        |
|    |      |     | must be written to this bit when GPIO17 is in Input Mode.                                                                                                                         |
|    |      |     | GPIO16 Control/Data                                                                                                                                                               |
|    |      |     | In Output Mode:<br>Write '0' to this bit to drive the CPIO16 pip to 'Low', Write '1' to this bit to drive the CPIO16                                                              |
|    |      |     | Write '0' to this bit to drive the GPIO16 pin to 'Low'. Write '1' to this bit to drive the GPIO16 pin to 'High'.                                                                  |
| 16 | G16D | R/W | In Input Mode:                                                                                                                                                                    |
|    |      |     | Read input data of GPIO16 from this bit. '1' means that the external device drives the                                                                                            |
|    |      |     | GPIO16 pin to 'High', and '0' means that the external device drives GPIO16 to 'Low'. A '1'                                                                                        |
|    |      |     | must be written to this bit when GPIO16 is in Input Mode.                                                                                                                         |
|    |      |     | GPIO15 Control/Data                                                                                                                                                               |
|    |      |     | In Output Mode:                                                                                                                                                                   |
|    |      |     | Write '0' to this bit to drive the GPIO15 pin to 'Low'. Write '1' to this bit to drive the GPIO15                                                                                 |
| 15 | G15D | R/W | pin to 'High'.                                                                                                                                                                    |
|    |      |     | In Input Mode:<br>Read input data of GPIO15 from this bit. '1' means that the external device drives the                                                                          |
|    |      |     | GPIO15 pin to 'High', and '0' means that the external device drives GPIO15 to 'Low'. A '1'                                                                                        |
|    |      |     | must be written to this bit when GPIO15 is in Input Mode.                                                                                                                         |
|    |      |     | GPIO14 Control/Data                                                                                                                                                               |
|    |      |     | In Output Mode:                                                                                                                                                                   |
|    |      |     | Write '0' to this bit to drive the GPIO14 pin to 'Low'. Write '1' to this bit to drive the GPIO14                                                                                 |
| 14 | G14D | R/W | pin to 'High'.                                                                                                                                                                    |
| 14 | G14D | R/W | In Input Mode:                                                                                                                                                                    |
|    |      |     | Read input data of GPIO14 from this bit. '1' means that the external device drives the                                                                                            |
|    |      |     | GPIO14 pin to 'High', and '0' means that the external device drives GPIO14 to 'Low'. A '1'                                                                                        |
| -  |      |     | must be written to this bit when GPIO14 is in Input Mode.<br>GPIO13 Control/Data                                                                                                  |
|    |      |     | In Output Mode:                                                                                                                                                                   |
|    |      |     | Write '0' to this bit to drive the GPIO13 pin to 'Low'. Write '1' to this bit to drive the GPIO13                                                                                 |
|    |      |     | pin to 'High'.                                                                                                                                                                    |
| 13 | G13D | R/W | In Input Mode:                                                                                                                                                                    |
|    |      |     | Read input data of GPIO13 from this bit. '1' means that the external device drives the                                                                                            |
|    |      |     | GPIO13 pin to 'High', and '0' means that the external device drives GPIO13 to 'Low'. A '1'                                                                                        |
| -  |      |     | must be written to this bit when GPIO13 is in Input Mode.                                                                                                                         |
|    |      |     | GPIO12 Control/Data                                                                                                                                                               |
|    |      |     | In Output Mode:<br>Write '0' to this bit to drive the GPIO12 pin to 'Low'. Write '1' to this bit to drive the GPIO12                                                              |
|    |      |     | pin to 'High'.                                                                                                                                                                    |
| 12 | G12D | R/W | In Input Mode:                                                                                                                                                                    |
|    |      |     | Read input data of GPIO12 from this bit. '1' means that the external device drives the                                                                                            |
|    |      |     | GPIO12 pin to 'High', and '0' means that the external device drives GPIO12 to 'Low'. A '1'                                                                                        |
|    |      |     | must be written to this bit when GPIO12 is in Input Mode.                                                                                                                         |
|    |      |     | GPIO11 Control/Data                                                                                                                                                               |
|    |      |     | In Output Mode:                                                                                                                                                                   |
|    |      |     | Write '0' to this bit to drive the GPIO11 pin to 'Low'. Write '1' to this bit to drive the GPIO11 pin to 'Live'.                                                                  |
| 11 | G11D | R/W | to 'High'.<br>In Input Mode:                                                                                                                                                      |
|    |      |     | Read input data of GPIO11 from this bit. '1' means that the external device drives the GPIO11                                                                                     |
|    |      |     | pin to 'High', and '0' means that the external device drives GPIO11 to 'Low'. A '1' must be                                                                                       |
|    |      |     | written to this bit when GPIO11 is in Input Mode.                                                                                                                                 |
|    |      |     | GPIO10 Control/Data                                                                                                                                                               |
|    |      |     | In Output Mode:                                                                                                                                                                   |
|    |      |     | Write '0' to this bit to drive the GPIO10 pin to 'Low'. Write '1' to this bit to drive the GPIO10                                                                                 |
| 10 | G10D | R/W | pin to 'High'.                                                                                                                                                                    |
|    |      |     | In Input Mode:<br>Read input data of CRIO10 from this hit. '1' means that the external device drives the                                                                          |
|    |      |     | Read input data of GPIO10 from this bit. '1' means that the external device drives the GPIO10 pin to 'High', and '0' means that the external device drives GPIO10 to 'Low'. A '1' |
|    |      |     | must be written to this bit when GPIO10 is in Input Mode.                                                                                                                         |
| L  | 1    | 1   |                                                                                                                                                                                   |



|   | 1   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9 | G9D | R/W | <ul> <li>GPIO9 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO9 pin to 'Low'. Write '1' to this bit to drive the GPIO9 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO9 from this bit. '1' means that the external device drives the GPIO9 pin to 'High', and '0' means that the external device drives GPIO9 to 'Low'. A '1' must be written to this bit when GPIO9 is in Input Mode.</li> </ul>           |
| 8 | G8D | R/W | <ul> <li>GPIO8 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO8 pin to 'Low'. Write '1' to this bit to drive the GPIO8 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO8 from this bit. '1' means that the external device drives the GPIO8 pin to 'High', and '0' means that the external device drives GPIO8 to 'Low'. A '1' must be written to this bit when GPIO8 is in Input Mode.</li> </ul>           |
| 7 | G7D | R/W | <ul> <li>GPIO7 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO7 pin to 'Low'. Write '1' to this bit to drive the GPIO7 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO7 from this bit. '1' means that the external device drives the GPIO7 pin to 'High', and '0' means that the external device drives GPIO7 to 'Low'. A '1' must be written to this bit when GPIO7 is in Input Mode.</li> </ul>           |
| 6 | G6D | R/W | <ul> <li>GPIO6 Control/Data</li> <li>In Output Mode:</li> <li>Write '0' to this bit to drive the GPIO6 pin to 'Low'. Write '1' to this bit to drive the GPIO6 pin to 'High'.</li> <li>In Input Mode:</li> <li>Read input data of GPIO6 from this bit. '1' means that the external device drives the GPIO6 pin to 'High', and '0' means that the external device drives GPIO6 to 'Low'. A '1' must be written to this bit when GPIO6 is in Input Mode.</li> </ul> |
| 5 | G5D | R/W | <ul> <li>GPIO5 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO5 pin to 'Low'. Write '1' to this bit to drive the GPIO5 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO5 from this bit. '1' means that the external device drives the GPIO5 pin to 'High', and '0' means that the external device drives GPIO5 to 'Low'. A '1' must be written to this bit when GPIO5 is in Input Mode.</li> </ul>           |
| 4 | G4D | R/W | <ul> <li>GPIO4 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO4 pin to 'Low'. Write '1' to this bit to drive the GPIO4 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO4 from this bit. '1' means that the external device drives the GPIO4 pin to 'High', and '0' means that the external device drives GPIO4 to 'Low'. A '1' must be written to this bit when GPIO4 is in Input Mode.</li> </ul>           |
| 3 | G3D | R/W | GPIO3 Control/Data<br>In Output Mode:<br>Write '0' to this bit to drive the GPIO3 pin to 'Low'. Write '1' to this bit to drive the GPIO3 pin<br>to 'High'.<br>In Input Mode:<br>Read input data of GPIO3 from this bit. '1' means that the external device drives the GPIO3<br>pin to 'High', and '0' means that the external device drives GPIO3 to 'Low'. A '1' must be<br>written to this bit when GPIO3 is in Input Mode.                                    |
| 2 | G2D | R/W | <ul> <li>GPIO2 Control/Data</li> <li>In Output Mode:</li> <li>Write '0' to this bit to drive the GPIO2 pin to 'Low'. Write '1' to this bit to drive the GPIO2 pin to 'High'.</li> <li>In Input Mode:</li> <li>Read input data of GPIO2 from this bit. '1' means that the external device drives the GPIO2 pin to 'High', and '0' means that the external device drives GPIO2 to 'Low'. A '1' must be</li> </ul>                                                  |



|   |     |     | written to this bit when GPIO2 is in Input Mode.                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | G1D | R/W | <ul> <li>GPIO1 Control/Data</li> <li>In Output Mode:</li> <li>Write '0' to this bit to drive the GPIO1 pin to 'Low'. Write '1' to this bit to drive the GPIO1 pin to 'High'.</li> <li>In Input Mode:</li> <li>Read input data of GPIO1 from this bit. '1' means that the external device drives the GPIO1 pin to 'High', and '0' means that the external device drives GPIO1 to 'Low'. A '1' must be written to this bit when GPIO1 is in Input Mode.</li> </ul> |
| 0 | G0D | R/W | <ul> <li>GPIO0 Control/Data</li> <li>In Output Mode:</li> <li>Write '0' to this bit to drive the GPIO0 pin to 'Low'. Write '1' to this bit to drive the GPIO0 pin to 'High'.</li> <li>In Input Mode:</li> <li>Read input data of GPIO0 from this bit. '1' means that the external device drives the GPIO0 pin to 'High', and '0' means that the external device drives GPIO0 to 'Low'. A '1' must be written to this bit when GPIO0 is in Input Mode.</li> </ul> |

| Register Offset:<br>Register Name:<br>Reset Value: |   |   | 50h<br>Serial IRQ (IRQSER) Control Register<br>12h |   |   |     |    |   |
|----------------------------------------------------|---|---|----------------------------------------------------|---|---|-----|----|---|
|                                                    | 7 | 6 | 5                                                  | 4 | 3 | 2   | 1  | 0 |
| SIE SPFPW                                          |   |   | IF                                                 | N |   | STF | PW |   |

| Bit | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|-----|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7   | SIE   | R/W       | Serial IRQ (IRQSER) Enable/Disable<br>0: Disable; 1: Enable.<br>To enable the Serial IRQ, follow the programming sequences:<br>1. Program Bit 6 of this register first to enable the continuous mode repetition.<br>2. Program this bit to enable the Serial IRQ function.                                                                                                    |  |  |  |  |  |
| 6   | SPFPW | R/W       | pp Frame Pulse Width. This Stop Frame Pulse Width is used to decide what kind of mode<br>be entered from next cycle.<br>2 PCICLK (Quiet Mode).<br>3 PCICLK (Continuous Mode).                                                                                                                                                                                                 |  |  |  |  |  |
| 5-2 | IFN   | R/W       | Number of IRQ/Data Frames. 0000: 17 Slots.<br>0001: 18 Slots.<br>0010: 19 Slots.<br>0011: 20 Slots.<br>0100: 21 Slots. (default recommended for BIOS setting)<br>0101-1111: reserved.<br>These four bits are used to define the number of IRQ/Data Frame Slots (PCICLK). 21 Slots are<br>recommended for BIOS setting.                                                        |  |  |  |  |  |
| 1-0 | STFPW | R/W       | Start Frame Pulse Width. 00: 4 PCICLK.<br>01: 6 PCICLK.<br>10: 8 PCICLK<br>11: Reserved.<br>These two bits are used to select the Start Frame pulse width from 4 PCICLK to 8 PCICLK. 8<br>PCICLK are recommended when the R8610 resides in Primary PCI bus. For some special<br>applications, when the R8610 does not reside in Primary PCI bus, 6 PCICLK are<br>recommended. |  |  |  |  |  |



| Regis          | ter Offs | et: | 51h                  |    |      |      |
|----------------|----------|-----|----------------------|----|------|------|
| Register Name: |          |     | LPC Control Register |    |      |      |
| Reset Value:   |          |     | 10h                  |    |      |      |
| 7              | 6        | 5   | 4                    | 3  | 2    | 1    |
| Reserved       |          |     | PP                   | DC | ICME | Rsvd |

| Bit | Name | Attribute | Description                                                                                                                                                                                                                  |  |  |  |
|-----|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7-5 | Rsvd | RO        | served                                                                                                                                                                                                                       |  |  |  |
| 4-3 | PPDC | R/W       | 3.3/5.0V PAD Pull Up/Down control register, for next version.<br>01: PULL DOWN<br>10: PULL UP<br>Other: NONE                                                                                                                 |  |  |  |
| 2   | ICME | R/W       | Repeat Serial IRQ Continuous Mode Enable/Disable.<br>0: Disable.<br>1: Enable.<br>This bit is used to enable the Serial IRQ Continuous mode repetition. This bit must be enabled<br>when the Serial IRQ function is enabled. |  |  |  |
| 1   | Rsvd | RO        | Reserved                                                                                                                                                                                                                     |  |  |  |
| 0   | LIC  | R/W       | <ul> <li>LPC Interface Control.</li> <li>0: Disable LPC function if bit 1 of Boot Strapping Register is a '0'. Otherwise, LPC function is enabled</li> <li>1: Enable LPC function.</li> </ul>                                |  |  |  |

0

LIC

| Register Offset: | 52h                                   |
|------------------|---------------------------------------|
| Register Name:   | LPC Legacy COM Port Decoding Register |
| Reset Value:     | 00h                                   |
|                  |                                       |

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| DP7E | DP6E | DP5E | DP4E | DP3E | DP2E | DP1E | DP0E |

| Bit | Name | Attribute | Description                                                                             |
|-----|------|-----------|-----------------------------------------------------------------------------------------|
| 7   | DP7E | R/W       | Enable/Disable Decode Port 3F8h-3FFh (COM1) as an LPC Access<br>0: Disable<br>1: Enable |
| 6   | DP6E | R/W       | Enable/Disable Decode Port 3E8h-3EFh (COM3) as an LPC Access<br>0: Disable<br>1: Enable |
| 5   | DP5E | R/W       | Enable/Disable Decode Port 338h-33Fh as an LPC Access<br>0: Disable<br>1: Enable        |
| 4   | DP4E | R/W       | Enable/Disable Decode Port 2F8h-2FFh (COM2) as an LPC Access<br>0: Disable<br>1: Enable |
| 3   | DP3E | R/W       | Enable/Disable Decode Port 2E8h-2EFh (COM4) as an LPC Access<br>0: Disable<br>1: Enable |
| 2   | DP2E | R/W       | Enable/Disable Decode Port 238h-23Fh as an LPC Access<br>0: Disable<br>1: Enable        |



| 1 | DP1E | R/W | Enable/Disable Decode Port 228h-22Fh as an LPC Access<br>0: Disable<br>1: Enable |
|---|------|-----|----------------------------------------------------------------------------------|
| 0 | DP0E | R/W | Enable/Disable Decode Port 220h-227h as an LPC Access<br>0: Disable<br>1: Enable |

| Regist       | ter Offs | et:     | 53h                            |   |    |    |   |  |
|--------------|----------|---------|--------------------------------|---|----|----|---|--|
| Regist       | ter Nam  | ne:     | Internal UART Control Register |   |    |    |   |  |
| Reset Value: |          |         | 00h                            |   |    |    |   |  |
| 7            | 6        | 5       | 4                              | 3 | 2  | 1  | 0 |  |
| UIADE        |          | Reserve | d                              |   | UI | RT |   |  |

| Bit | Name  | Attribute | e Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|-----|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 7   | UIADE | R/W       | Enable/Disable Internal UART IO Address Decode<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| 6-4 | Rsvd  | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| 3-0 | UIRT  | R/W       | UART IRQ Routing Table         Bit 3 Bit 2 Bit 1 Bit 0 Routing Table         0       0       0         0       0       1         0       0       1         0       0       1         0       0       1         0       0       1         0       0       1         0       0       1         0       1       1         0       1       1         0       1       1         0       1       1         0       1       1         0       1       1         0       1       1         0       1       1         0       1       1         1       0       0         1       1       1         1       0       1         1       1       1         1       1       1         1       1       1         1       1       1         1       1       1         1       1       1         1       1       1        < |  |  |  |  |  |  |

## RDC<sup>®</sup> RISC DSP Communication

Register Offset:57h – 54hRegister Name:Internal UART IO Address RegisterReset Value:03F8h

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

| Bit  | Name | Attribute | Description                                                                                   |
|------|------|-----------|-----------------------------------------------------------------------------------------------|
| 31-3 | UIOA | R/W       | Internal UART IO Address. The Bit[31:3] contain the base IO address A[31:3] of internal UART. |
| 2-0  | Rsvd | RO        | Reserved. All are '0's. To write any value to these bits causes no effect.                    |

| Register Offset: | 5Bh – 58h                                                             |
|------------------|-----------------------------------------------------------------------|
| Register Name:   | PCI Interrupt Routing Table Register                                  |
| Reset Value:     | 000000h                                                               |
| 31 30 29 28 27 2 | 6 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 |

| EHCIH | OHCIH | MAC1 | MAC0 | RT3 | RT2 | RT1 | RT0 |
|-------|-------|------|------|-----|-----|-----|-----|

| Bit   | Name   | Attribute | Description |        |         |          |                    |  |
|-------|--------|-----------|-------------|--------|---------|----------|--------------------|--|
|       |        |           | USB20       | ) EHC  | I Host  | t Interr | upt Routing Table. |  |
|       |        |           |             |        |         |          | Routing Table      |  |
|       |        |           | 0           | 0      | 0       | 0        | Disable.           |  |
|       |        |           | 0           | 0      | 0       | 1        | IRQ[9]             |  |
|       |        |           | 0           | 0      | 1       | 0        | IRQ[3]             |  |
|       |        |           | 0           | 0      | 1       | 1        | IRQ[10]            |  |
|       |        |           | 0           | 1      | 0       | 0        | IRQ[4]             |  |
|       |        |           | 0           | 1      | 0       | 1        | IRQ[5]             |  |
| 04.00 | FUOILI |           | 0           | 1      | 1       | 0        | IRQ[7]             |  |
| 31-28 | EHCIH  | R/W       | 0           | 1      | 1       | 1        | IRQ[6]             |  |
|       |        |           | 1           | 0      | 0       | 0        | IRQ[1]             |  |
|       |        |           | 1           | 0      | 0       | 1        | IRQ[11]            |  |
|       |        |           | 1           | 0<br>0 | 1       | 0        | Reserved           |  |
|       |        |           | 1           |        | 1       | 1        | IRQ[12]            |  |
|       |        |           | 1           | 1      | 0<br>0  | 0        | Reserved           |  |
|       |        |           | 1           | 1      | 0       | 1        | IRQ[14]            |  |
|       |        |           | 1           | 1      | 1       | 0        | Reserved           |  |
|       |        |           | 1           | 1      | 1       | 1        | IRQ[15]            |  |
|       |        |           | USB1.       | 1 OH(  | CI inte | rrupt F  | Routing Table.     |  |
|       |        |           |             |        |         |          | Routing Table      |  |
|       |        |           | 0           | 0      | 0       | 0        | Disable.           |  |
|       |        |           | 0           | 0      | 0       | 1        | IRQ[9]             |  |
|       |        |           | 0           | 0      | 1       | 0        | IRQ[3]             |  |
| 27-24 | OHCII  | R/W       | 0           | 0      | 1       | 1        | IRQ[10]            |  |
|       |        |           | 0           | 1      | 0       | 0        | IRQ[4]             |  |
|       |        |           | 0           | 1      | 0       | 1        | IRQ[5]             |  |
|       |        |           | 0           | 1      | 1       | 0        | IRQ[7]             |  |
|       |        |           | 0           | 1      | 1       | 1        | IRQ[6]             |  |
|       |        |           | 1           | 0      | 0       | 0        | IRQ[1]             |  |



|       |      |                | 1 0 0 1 IRQ[11]                                               |
|-------|------|----------------|---------------------------------------------------------------|
|       |      |                | 1 0 1 0 Reserved                                              |
|       |      |                | 1 0 1 1 IRQ[12]                                               |
|       |      |                | 1 1 0 0 Reserved                                              |
|       |      |                | 1 1 0 1 IRQ[14]                                               |
|       |      |                | 1 1 1 0 Reserved                                              |
|       |      |                | 1 1 1 1 IRQ[15]                                               |
|       |      |                | MAC1 interrupt Routing Table.                                 |
|       |      |                | Bit 23 Bit 22 Bit 21 Bit 20 Routing Table                     |
|       |      |                |                                                               |
|       |      |                | 0 0 0 1 IRQ[9]                                                |
|       |      |                | 0 0 1 0 IRQ[3]                                                |
|       |      |                | 0 0 1 1 IRQ[10]                                               |
|       |      |                | 0 1 0 0 IRQ[4]                                                |
|       |      |                | 0 1 0 1 IRQ[5]                                                |
| 23-20 | MAC1 | R/W            | 0 1 1 0 IRQ[7]                                                |
|       |      |                | 0 1 1 1 IRQ[6]                                                |
|       |      |                | 1 0 0 0 IRQ[1]                                                |
|       |      |                | 1 0 0 1 IRQ[11]                                               |
|       |      |                | 1 0 1 0 Reserved                                              |
|       |      |                | 1 0 1 1 IRQ[12]                                               |
|       |      |                | 1 1 0 0 Reserved                                              |
|       |      |                | 1 1 0 1 IRQ[14]                                               |
|       |      |                | 1 1 1 0 Reserved                                              |
|       |      |                | 1 1 1 1 IRQ[15]                                               |
|       |      |                | MAC0 Interrupt Routing Table.                                 |
|       |      |                | Bit 19 Bit 18 Bit 17 Bit 16 Routing Table<br>0 0 0 0 Disable. |
|       |      |                | 0 0 0 0 1 IRQ[9]                                              |
|       |      |                | 0 0 1 0 IRQ[3]                                                |
|       |      |                |                                                               |
|       |      |                | 0 0 1 1 IRQ[10]<br>0 1 0 0 IRQ[4]                             |
|       |      |                | 0  1  0  0   RQ[4]<br>0 1 0 1 $ RQ[5]$                        |
|       |      |                | $0 \ 1 \ 1 \ 0 \ RQ[7]$                                       |
| 19-16 | MAC0 | R/W            | 0  1  1  0     RQ[6]                                          |
|       |      |                | 1  0  0   RQ[1]                                               |
|       |      |                | 1  0  0  1  IRQ[11]                                           |
|       |      |                | 1 0 1 0 Reserved                                              |
|       |      |                | 1 0 1 1 IRQ[12]                                               |
|       |      |                | 1 1 0 0 Reserved                                              |
|       |      |                | 1 1 0 1 IRQ[14]                                               |
|       |      |                | 1 1 1 0 Reserved                                              |
|       |      |                | 1 1 1 1 IRQ[15]                                               |
|       |      |                | INTD_n Routing Table.                                         |
|       |      |                | Bit 15 Bit 14 Bit 13 Bit 12 Routing Table                     |
|       |      |                | 0 $0$ $0$ Disable.                                            |
|       |      |                | 0 0 0 1 IRQ[9]                                                |
|       |      |                | 0 0 1 0 IRQ[3]                                                |
|       |      |                | 0 0 1 1 IRQ[10]                                               |
|       |      |                | 0 1 0 0 IRQ[4]                                                |
|       |      |                | 0 1 0 1 IRQ[5]                                                |
| 4- 14 | D.T. | <b>B</b> 4 • 4 | 0 1 1 0 IRQ[7]                                                |
| 15-12 | RT3  | R/W            | 0 1 1 1 IRQ[6]                                                |
|       |      |                | 1 0 0 0 IRQ[1]                                                |
|       |      |                | 1 0 0 1 IRQ[11]                                               |
|       |      |                | 1 0 1 0 Reserved                                              |
|       |      |                | 1 0 1 1 IRQ[12]                                               |
|       |      |                | 1 1 0 0 Reserved                                              |
|       |      |                | 1 1 0 1 IRQ[14]                                               |
|       |      |                | 1 1 1 0 Reserved                                              |
|       |      |                | 1 1 1 1 IRQ[15]                                               |
| 11-8  | DTO  | R/W            | INTC_n Routing Table.                                         |
| 11-ð  | RT2  | R/W            | Bit 11 Bit 10 Bit 9 Bit 8 Routing Table                       |
|       |      |                |                                                               |



### **R8610** 32-Bit RISC MicroController

|     |     |         | 0 0 0 Disable.                                                        |
|-----|-----|---------|-----------------------------------------------------------------------|
|     |     |         | 0 0 0 1 IRQ[9]<br>0 0 1 0 IRQ[3]                                      |
|     |     |         | 0 0 1 1 IRQ[10]                                                       |
|     |     |         | 0 1 0 0 IRQ[4]                                                        |
|     |     |         | 0 1 0 1 IRQ[5]                                                        |
|     |     |         | 0 1 1 0 IRQ[7]<br>0 1 1 1 IRQ[6]                                      |
|     |     |         | 1 0 0 0 IRQ[1]                                                        |
|     |     |         | 1 0 0 1 IRQ[11]                                                       |
|     |     |         | 1 0 1 0 Reserved                                                      |
|     |     |         | 1 0 1 1 IRQ[12]<br>1 1 0 0 Reserved                                   |
|     |     |         | 1 1 0 1 IRQ[14]                                                       |
|     |     |         | 1 1 1 0 Reserved                                                      |
|     |     |         | 1 1 1 1 IRQ[15]                                                       |
|     |     |         | INTB_n Routing Table.<br><u>Bit 7 Bit 6 Bit 5 Bit 4</u> Routing Table |
|     |     |         | 0 $0$ $0$ Disable.                                                    |
|     |     |         | 0 0 0 1 IRQ[9]                                                        |
|     |     |         | 0 0 1 0 IRQ[3]                                                        |
|     |     |         | 0 0 1 1 IRQ[10]<br>0 1 0 0 IRQ[4]                                     |
|     |     |         | $0 \ 1 \ 0 \ 1 \ \text{IRQ[5]}$                                       |
| 7-4 | RT1 | R/W     | 0 1 1 0 IRQ[7]                                                        |
| /-4 |     | FX/ V V | 0 1 1 1 IRQ[6]                                                        |
|     |     |         | 1 0 0 0 IRQ[1]<br>1 0 0 1 IRQ[11]                                     |
|     |     |         | 1 0 1 0 Reserved                                                      |
|     |     |         | 1 0 1 1 IRQ[12]                                                       |
|     |     |         | 1 1 0 0 Reserved                                                      |
|     |     |         | 1 1 0 1 IRQ[14]<br>1 1 1 0 Reserved                                   |
|     |     |         | 1 1 1 1 IRQ[15]                                                       |
|     |     |         | INTA_n Routing Table.                                                 |
|     |     |         | <u>Bit 3 Bit 2 Bit 1 Bit 0</u> Routing Table                          |
|     |     |         | 0 0 0 Disable.<br>0 0 0 1 IRQ[9]                                      |
|     |     |         | 0 0 1 0  IRQ[9]                                                       |
|     |     |         | 0 0 1 1 IRQ[10]                                                       |
|     |     |         | 0 1 0 0 IRQ[4]                                                        |
|     |     |         | 0 1 0 1 IRQ[5]                                                        |
| 3-0 | RT0 | R/W     | 0 1 1 0 IRQ[7]<br>0 1 1 1 IRQ[6]                                      |
|     |     |         | $1 \ 0 \ 0 \ IRQ[1]$                                                  |
|     |     |         | 1 0 0 1 IRQ[11]                                                       |
|     |     |         | 1 0 1 0 Reserved                                                      |
|     |     |         | 1 0 1 1 IRQ[12]<br>1 1 0 0 Reserved                                   |
|     |     |         | 1 1 0 1 IRQ[14]                                                       |
|     |     |         | 1 1 1 0 Reserved                                                      |
|     |     |         | 1 1 1 1 IRQ[15]                                                       |





| 5Fh – 5Ch                          |
|------------------------------------|
| Buffer Strength Control Register I |
| 00002EEEh                          |
|                                    |

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

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15-14 | DC3  | R/W       | Output Driving Capability of the ROMCS_n Pin. These three bits are used to select the output driving capability of the ROMCS_n pin.         Bit 15 Bit 14 Driving Current         0       0         0       1         0       1         8 mA         1       0         1       16 mA                                                                                                                                                                                                   |
| 13    | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12    | SR3  | R/W       | Output Slew Rate Control of the ROMCS_n Pin. This bit is used to select the output slew rate<br>of the ROMCS_n pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                                                                                                                          |
| 11-9  | DC2  | R/W       | Output Driving Capability of the SDRAM Control Signal Output Pins. These three bits are used to select the output driving capability of the SDRAM control signal output pins which include CKE, CS_n, SRAS_n, SCAS_n, and WE_n.         Bit 11       Bit 10       Bit 9       Driving Current         0       0       0       2 mA         0       1       4 mA         0       1       8 mA         1       0       10 mA         1       0       12 mA         1       1       16 mA |
| 8     | SR2  | R/W       | Output Slew Rate Control of the SDRAM Control Signal Output Pins. This bit is used to select<br>the output slew rate of the SDRAM control signal output pins which include CKE, CS_n,<br>SRAS_n, SCAS_n, and WE_n.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                           |
| 7-6   | DC1  | R/W       | Output Driving Capability of the SDRAM MA[12:0] and BA[1:0] Pins. These three bits are used to select the output driving capability of the SDRAM MA[12:0] and BA[1:0] pins.         Bit 7 Bit 6 Driving Current         0       0       4 mA         0       1       8 mA         1       0       12 mA         1       16 mA                                                                                                                                                          |
| 5     | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4     | SR1  | R/W       | Output Slew Rate Control of the SDRAM MA[12:0] and BA[1:0] Pins. This bit is used to select the output slew rate for the SDRAM MA[12:0] and BA[1:0] pins.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                                                                                    |
| 3-2   | DC0  | R/W       | Output Driving Capability of the SDRAM MD[31:0] and DQM[3:0] Pins. These three bits are<br>used to select the output driving capability of the SDRAM MD[31:0] and DQM[3:0] pins.Bit 3Bit 2Bit 1Driving Current (DQM[3:0])0002 mA0014 mA4mA4mA                                                                                                                                                                                                                                          |



R8610 32-Bit RISC MicroController

|   |     |     | 0 | 1              | 0                | 6 mA  | 8mA                                                                            |  |  |  |  |  |  |  |
|---|-----|-----|---|----------------|------------------|-------|--------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|   |     |     | 0 | 1              | 1                | 8 mA  | 8mA                                                                            |  |  |  |  |  |  |  |
|   |     |     | 1 | 0              | 0                | 10 mA | 12mA                                                                           |  |  |  |  |  |  |  |
|   |     |     | 1 | 0              | 1                | 12 mA | 12mA                                                                           |  |  |  |  |  |  |  |
|   |     |     | 1 | 1              | 0                | 14 mA | 16mA                                                                           |  |  |  |  |  |  |  |
|   |     |     | 1 | 1              | 1                | 16 mA | 16mA                                                                           |  |  |  |  |  |  |  |
| 0 | SR0 | R/W |   | the ou<br>Slew | tput sle<br>Rate |       | 1D[31:0] and DQM[3:0] Pins. This bit is used to<br>MD[31:0] and DQM[3:0] pins. |  |  |  |  |  |  |  |

| Register Offset: | 63h – 60h                           |
|------------------|-------------------------------------|
| Register Name:   | Buffer Strength Control Register II |
| Reset Value:     | 4444443h                            |

Reserved

| DC0 Rsv SI | R<br>) |
|------------|--------|
|------------|--------|

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                     |
|------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                                                        |
| 3-2  | DC0  | R/W       | Output Driving Capability of the SOUT/GPIO8 and SIN/GPIO7 Pin. These three bits are used to select the output driving capability of the SOUT/GPIO8 and SIN/GPIO7 pin.         Bit 3 Bit 2 Driving Current         0       0       4 mA         0       1       8 mA         1       0       12 mA         1       1       16 mA |
| 1    | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                                                        |
| 0    | SR0  |           | Output Slew Rate Control of the SOUT/GPIO8 and SIN/GPIO7 Pin. This bit is used to select the output slew rate of the SOUT/GPIO8 and SIN/GPIO7 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                    |

| Register Offset: | 67h – 64h                            |
|------------------|--------------------------------------|
| Register Name:   | Buffer Strength Control Register III |
| Reset Value:     | 33333333h                            |

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0 |
|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---|
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |   |

|  | DC7 | Rsv SR<br>d 7 | DC6 | Rsv<br>d | SR<br>6 | DC5 | Rsv<br>d | SR<br>5 | DC4 | Rsv<br>d | SR<br>4 | DC3 | Rsv<br>d | SR<br>3 | DC2 | Rsv<br>d | SR<br>2 | DC1 | Rsv<br>d | SR<br>1 | DC0 | Rsv<br>d | SR<br>0 | I |
|--|-----|---------------|-----|----------|---------|-----|----------|---------|-----|----------|---------|-----|----------|---------|-----|----------|---------|-----|----------|---------|-----|----------|---------|---|
|--|-----|---------------|-----|----------|---------|-----|----------|---------|-----|----------|---------|-----|----------|---------|-----|----------|---------|-----|----------|---------|-----|----------|---------|---|

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                      |
|-------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | DC7  |           | Output Driving Capability of the RTS_n/TDO/GPIO9 Pin. These three bits are used to select the output driving capability of the RTS_n/TDO/GPIO9 pin.<br><u>Bit 31 Bit 30 Driving Current</u><br>0 0 4 mA<br>0 1 8 mA<br>1 0 12 mA |



|       |      |     | 1 1 16 mA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29    | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 28    | SR7  | R/W | Output Slew Rate Control of the RTS_n/TDO/GPIO9 Pin. This bit is used to select the output slew rate of the RTS_n/TDO/GPIO9 Pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 27-26 | DC6  | R/W | Output Driving Capability of the DTR_n/GPIO10 Pin. These three bits are used to select the output driving capability of the DTR_n/GPIO10 pin.         Bit 27 Bit 26 Driving Current         0       0         0       1         0       1         0       1         1       0         1       1         1       16 mA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 25    | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 24    | SR6  | R/W | Output Slew Rate Control of the DTR_n/GPIO10 Pin. This bit is used to select the output slew rate of the DTR_n/GPIO10 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 23-22 | DC5  | R/W | Output Driving Capability of the CTS_n/TMS/GPIO11 Pin. These three bits are used to select the output driving capability of the CTS_n/TMS/GPIO11 pin.         Bit 23 Bit 22 Driving Current         0       0         0       1         0       1         0       1         1       0         1       1         1       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       12         0       1         0       1         0       1         0       1         0       1         0       12         0       1         0       1         0       1         0       1         0       1         0       1         0       12         0       16         0       1         0       1         0       1         0       1         0       < |
| 21    | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 20    | SR5  | R/W | Output Slew Rate Control of the CTS_n/TMS/GPIO11 Pin. This bit is used to select the output slew rate of the CTS_n/TMS/GPIO11 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 19-18 | DC4  | R/W | Output Driving Capability of the DSR_n/TCK/GPIO12 Pin. These three bits are used to select the output driving capability of the DSR_n/TCK/GPIO12 pin.         Bit 19 Bit 18 Driving Current         0       0         0       1         0       1         1       0         1       1         1       16 mA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 17    | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 16    | SR4  | R/W | Output Slew Rate Control of the DSR_n/TCK/GPIO12 Pin. This bit is used to select the output slew rate of the DSR_n/TCK/GPIO12 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15-14 | DC3  | R/W | Output Driving Capability of the DCD_n/TDI/GPI013 Pin. These three bits are used to select the output driving capability of the DCD_n/TDI/GPI013 pin.         Bit 15 Bit 14 Driving Current         0       0         0       1         0       1         1       0         1       1         1       1         1       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       12         1       1         1       1         1       1         1       1         1       1         1       1                                                                                                                                                                                                                                              |
| 13    | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 12    | SR3  | R/W | Output Slew Rate Control of the DCD_n/TDI/GPIO13 Pin. This bit is used to select the output slew rate of the DCD_n/TDI/GPIO13 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11-10 | DC2  | R/W | Output Driving Capability of the RI_n/GPIO14 Pin. These three bits are used to select the output driving capability of the RI_n/GPIO14 pin.         Bit 11       Bit 10       Driving Current         0       0       4 mA         0       1       8 mA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



|     |      |     | 1 0 12 mA                                                                                                                                                                                                                                                                                                   |
|-----|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |     | 1 1 16 mA                                                                                                                                                                                                                                                                                                   |
| 9   | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                    |
| 8   | SR2  | R/W | Output Slew Rate Control of the RI_n/GPIO14 Pin. This bit is used to select the output slew rate of the RI_n/GPIO14 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                          |
| 7-6 | DC1  | R/W | Output Driving Capability of the RTCAS/GPIO15 Pin. These three bits are used to select the output driving capability of the RTCAS/GPIO15 pin.         Bit 7       Bit 6       Driving Current         0       0       4 mA         0       1       8 mA         1       0       12 mA         1       16 mA |
| 5   | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                    |
| 4   | SR1  | R/W | Output Slew Rate Control of the RTCAS/GPIO15 Pin. This bit is used to select the output slew rate of the RTCAS/GPIO15 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                        |
| 3-2 | DC0  | R/W | Output Driving Capability of the RTCRD/GPIO16 Pin. These three bits are used to select the output driving capability of the RTCRD/GPIO16 pin.         Bit 3 Bit 2 Driving Current         0       0         4 mA         0       1         8 mA         1       0         1       16 mA                     |
| 1   | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                    |
| 0   | SR0  | R/W | Output Slew Rate Control of the RTCRD/GPIO16 Pin. This bit is used to select the output slew rate of the RTCRD/GPIO16 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                        |

| Register Offset: | 6Bh – 68h                           |
|------------------|-------------------------------------|
| Register Name:   | Buffer Strength Control Register IV |
| Reset Value:     | 33333323h                           |

| DC7 Rsv SR DC6 Rsv SR DC5 Rsv SR d 7 DC6 d 6 DC5 d 5 | Reserved |
|------------------------------------------------------|----------|
|------------------------------------------------------|----------|

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |
|-------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| 31-30 | DC7  | R/W       | Output Driving Capability of the RTCWR/GPI017 Pin. These three bits are used to select the output driving capability of the RTCWR/GPI017 pin.         Bit 31 Bit 30 Driving Current         0       0         4 mA         0       1         8 mA         1       0         1       16 mA |  |  |  |  |  |  |  |  |  |  |
| 29    | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |
| 28    | SR7  | R/W       | Output Slew Rate Control of the RTCWR/GPIO17 Pin. This bit is used to select the output slew rate of the RTCWR/GPIO17 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                      |  |  |  |  |  |  |  |  |  |  |



| 27-26 | DC6  | R/W | Output Driving Capability of the IRQ8_n/GPIO18 Pin. These three bits are used to select the output driving capability of the IRQ8_n/GPIO18 pin.<br>Bit 27 Bit 26 Driving Current<br>0 0 4 mA<br>0 1 8 mA<br>1 0 12 mA                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     | 1 1 16 mA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 25    | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 24    | SR6  | R/W | Output Slew Rate Control of the IRQ8_n/GPIO18 Pin. This bit is used to select the output slew rate of the IRQ8_n/GPIO18 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 23-22 | DC5  | R/W | Output Driving Capability of the SPKR/GPIO19 Pin. These three bits are used to select the output driving capability of the SPKR/GPIO19 pin.         Bit 23 Bit 22 Driving Current         0       0         0       1         0       1         1       0         1       1         1       1         1       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1         0       1 |
| 21    | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 20    | SR5  | R/W | Output Slew Rate Control of the SPKR/GPIO19 Pin. This bit is used to select the output slew rate of the SPKR/GPIO19 pin.<br>0: Fast Slew Rate<br>1: Slow Slew Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 19-0  | Rsvd | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Register Offset: | 80h                                                |
|------------------|----------------------------------------------------|
| Register Name:   | Internal Peripherals Controller Test Mode Register |
| Reset Value:     | 00h                                                |
|                  |                                                    |

| 7 | 6 | 5        | 4 | 3 | 2    | 1    | 0    |  |  |
|---|---|----------|---|---|------|------|------|--|--|
|   | F | Reserved | þ |   | UTME | DCTM | тстм |  |  |

| Bit | Name | Attribute | Description                                                                                                                                                                                                           |
|-----|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-3 | Rsvd | RO        | Reserved                                                                                                                                                                                                              |
| 2   | UTME | R/W       | 16550 UART Test Mode Enable/Disable<br>0: Disable<br>1: Enable<br>This bit can be read and written when the R8610 Configuration Register Index 41 Bit 0 = '1'.<br>Otherwise, this bit is read only                    |
| 1   | DCTM | R/W       | Master/Slave DMA Controllers Test Mode Enable/Disable<br>0: Disable<br>1: Enable<br>This bit can be read and written when the R8610 Configuration Register Index 41 Bit 0 = '1'.<br>Otherwise, this bit is read only  |
| 0   | тстм | R/W       | 8254 Timer/Counter Controller Test Mode Enable/Disable<br>0: Disable<br>1: Enable<br>This bit can be read and written when the R8610 Configuration Register Index 41 Bit 0 = '1'.<br>Otherwise, this bit is read only |

## RDC<sup>®</sup> RISC DSP Communication

| Register Offset: | 87h – 84h                               |
|------------------|-----------------------------------------|
| Register Name:   | General-Purpose I/O Control Register II |
| Reset Value:     | 000000h                                 |

| Reserved | G58<br>E | G57 | G56 | G55<br>E | G53 | G52 | G51 | G50 | G49 | G48 |   | G46 | G45<br>E | G44 | G43 | G42 | G41 | G40 | G39<br>E | G38<br>E | G37 | G36 | G35 |   |   | G32 |
|----------|----------|-----|-----|----------|-----|-----|-----|-----|-----|-----|---|-----|----------|-----|-----|-----|-----|-----|----------|----------|-----|-----|-----|---|---|-----|
|          | L        |     | L   | L        | L   | L   | L   | L   | L   | L   | _ | 1   | L        | L   | L   | L   | L   | L   | L        | L        | 1   | 1   | L   | 1 | L |     |

| Bit   | Name | Attribute | Description                                                                                                                                                                                |
|-------|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27 | Rsvd | RO        | Reserved                                                                                                                                                                                   |
| 26    | G58E | R/W       | GPIO58 Function Enable/Disable.<br>0: Disable. This pin operates in normal (CS2_n/CLKIN14.318) function.<br>1: Enable. This pin operates as GPIO58 with an internal 75KΩ pull-up resistor. |
| 25    | G57E | R/W       | GPIO57 Function Enable/Disable.<br>0: Disable. This pin operates in normal (CS1_n) function.<br>1: Enable. This pin operates as GPIO57 with an internal 75K $\Omega$ pull-up resistor.     |
| 24    | G56E | R/W       | GPIO56 Function Enable/Disable.<br>0: Disable. This pin operates in normal (CLK25MOUT) function.<br>1: Enable. This pin operates as GPIO56 with an internal 75KΩ pull-up resistor.         |
| 23    | G55E | R/W       | GPIO55 Function Enable/Disable.<br>0: Disable. This pin operates in normal (KBRST_n) function.<br>1: Enable. This pin operates as GPIO55 with an internal 75KΩ pull-up resistor.           |
| 22    | G54E | R/W       | GPIO54 Function Enable/Disable.<br>0: Disable. This pin operates in normal (A20GATE_n) function.<br>1: Enable. This pin operates as GPIO54 with an internal 75KΩ pull-up resistor.         |
| 21    | G53E | R/W       | GPIO53 Function Enable/Disable.<br>0: Disable. This pin operates in normal (SPEAKER) function.<br>1: Enable. This pin operates as GPIO53 with an internal 75KΩ pull-up resistor.           |
| 20    | G52E | R/W       | GPIO52 Function Enable/Disable.<br>0: Disable. This pin operates in normal (COL0) function.<br>1: Enable. This pin operates as GPIO52 with an internal 75KΩ pull-up resistor.              |
| 19    | G51E | R/W       | GPIO51 Function Enable/Disable.<br>0: Disable. This pin operates in normal (RXD0_3) function.<br>1: Enable. This pin operates as GPIO51 with an internal 75KΩ pull-up resistor.            |
| 18    | G50E | R/W       | GPIO50 Function Enable/Disable.<br>0: Disable. This pin operates in normal (RXD0_2) function.<br>1: Enable. This pin operates as GPIO50 with an internal 75KΩ pull-up resistor.            |
| 17    | G49E | R/W       | GPIO49 Function Enable/Disable.<br>0: Disable. This pin operates in normal (RXD0_1) function.<br>1: Enable. This pin operates as GPIO49 with an internal 75KΩ pull-up resistor.            |
| 16    | G48E | R/W       | GPIO48 Function Enable/Disable.<br>0: Disable. This pin operates in normal (RXD0_0) function.<br>1: Enable. This pin operates as GPIO48 with an internal 75KΩ pull-up resistor.            |
| 15    | G47E | R/W       | GPIO47 Function Enable/Disable.<br>0: Disable. This pin operates in normal (RXDV0) function.<br>1: Enable. This pin operates as GPIO47 with an internal 75KΩ pull-up resistor.             |
| 14    | G46E | R/W       | GPIO46 Function Enable/Disable.<br>0: Disable. This pin operates in normal (RXC0) function.<br>1: Enable. This pin operates as GPIO46 with an internal 75KΩ pull-up resistor.              |
| 13    | G45E | R/W       | GPIO45 Function Enable/Disable.<br>0: Disable. This pin operates in normal (TXEN0) function.<br>1: Enable. This pin operates as GPIO45 with an internal 75KΩ pull-up resistor.             |
| 12    | G44E | R/W       | GPIO44 Function Enable/Disable.<br>0: Disable. This pin operates in normal (TXD0_3) function.<br>1: Enable. This pin operates as GPIO44 with an internal 75KΩ pull-up resistor.            |
| 11    | G43E | R/W       | GPIO43 Function Enable/Disable.<br>0: Disable. This pin operates in normal (TXD0_2) function.<br>1: Enable. This pin operates as GPIO43 with an internal 75KΩ pull-up resistor.            |

**R8610** 32-Bit RISC MicroController

|    |      |     | GPIO42 Function Enable/Disable.                                                        |
|----|------|-----|----------------------------------------------------------------------------------------|
| 10 | G42E | R/W | 0: Disable. This pin operates in normal (TXD0_1) function.                             |
|    |      |     | 1: Enable. This pin operates as GPIO42 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO41 Function Enable/Disable.                                                        |
| 9  | G41E | R/W | 0: Disable. This pin operates in normal (TXD0_0) function.                             |
|    |      |     | 1: Enable. This pin operates as GPIO41 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO40 Function Enable/Disable.                                                        |
| 8  | G40E | R/W | 0: Disable. This pin operates in normal (TXC0) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO40 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO39 Function Enable/Disable.                                                        |
| 7  | G39E | R/W | 0: Disable. This pin operates in normal (SA23) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO39 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO38 Function Enable/Disable.                                                        |
| 6  | G38E | R/W | 0: Disable. This pin operates in normal (SA22) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO38 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO37 Function Enable/Disable.                                                        |
| 5  | G37E | R/W | 0: Disable. This pin operates in normal (SA21) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO37 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO36 Function Enable/Disable.                                                        |
| 4  | G36E | R/W | 0: Disable. This pin operates in normal (SA20) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO36 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO35 Function Enable/Disable.                                                        |
| 3  | G35E | R/W | 0: Disable. This pin operates in normal (SA19) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO35 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO34 Function Enable/Disable.                                                        |
| 2  | G34E | R/W | 0: Disable. This pin operates in normal (SA18) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO34 with an internal 75KΩ pull-up resistor.         |
|    |      |     | GPIO33 Function Enable/Disable.                                                        |
| 1  | G33E | R/W | 0: Disable. This pin operates in normal (SA17) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO33 with an internal 75K $\Omega$ pull-up resistor. |
|    |      |     | GPIO32 Function Enable/Disable.                                                        |
| 0  | G32E | R/W | 0: Disable. This pin operates in normal (SA16) function.                               |
|    |      |     | 1: Enable. This pin operates as GPIO32 with an internal 75K $\Omega$ pull-up resistor. |

| Register Offset: | 8Bh – 88h                            |
|------------------|--------------------------------------|
| Register Name:   | General-Purpose I/O Data Register II |
| Reset Value:     | FFFFFh                               |

RDC<sup>®</sup> RISC DSP Communication

| - ·      | G58 | G57 | G56 | G55 |   | G53 | G52 | G51 | G50 | G49 | G48 | G47 | G46 | G45 | G44 |   | G42 | G41 | G40 | G39 | G38 | G37 | G36 | G35 | G34 | G33 | G32 |
|----------|-----|-----|-----|-----|---|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Reserved | D   | D   | D   | D   | D | D   | D   | D   | D   | D   | D   | D   | D   | D   | D   | D | D   | D   | D   | D   | D   | D   | D   | D   | D   | D   | D   |

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27 | Rsvd | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 26    | G58D | R/W       | <ul> <li>GPIO58 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO58 pin to 'Low'. Write '1' to this bit to drive theGPIO58 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO58 from this bit. '1' means that the external device drives the GPIO58 pin to 'High', and '0' means that the external device drives GPIO58 to 'Low'. A '1' must be written to this bit when GPIO58 is in Input Mode.</li> </ul> |
| 25    | G57D | R/W       | GPIO57 Control/Data<br>In Output Mode:<br>Write '0' to this bit to drive the GPIO57 pin to 'Low'. Write '1' to this bit to drive the GPIO57<br>pin to 'High'.                                                                                                                                                                                                                                                                                                |



|          |       |         | In Input Mode:                                                                                                                                       |
|----------|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |       |         | Read input data of GPIO57 from this bit. '1' means that the external device drives the                                                               |
|          |       |         | GPIO57 pin to 'High', and '0' means that the external device drives GPIO57 to 'Low'. A '1'                                                           |
|          |       |         | must be written to this bit when GPI057 is in Input Mode.                                                                                            |
|          |       |         | GPIO56 Control/Data                                                                                                                                  |
|          |       |         | In Output Mode:                                                                                                                                      |
|          |       |         | Write '0' to this bit to drive the GPIO56 pin to 'Low'. Write '1' to this bit to drive the GPIO56                                                    |
|          | 0.505 |         | pin to 'High'.                                                                                                                                       |
| 24       | G56D  | R/W     | In Input Mode:                                                                                                                                       |
|          |       |         | Read input data of GPIO56 from this bit. '1' means that the external device drives the                                                               |
|          |       |         | GPIO56 pin to 'High', and '0' means that the external device drives GPIO56 to 'Low'. A '1'                                                           |
|          |       |         | must be written to this bit when GPIO56 is in Input Mode.                                                                                            |
|          |       |         | GPIO55 Control/Data                                                                                                                                  |
|          |       |         | In Output Mode:                                                                                                                                      |
|          |       |         | Write '0' to this bit to drive the GPIO55 pin to 'Low'. Write '1' to this bit to drive the GPIO55                                                    |
| 00       | 0550  |         | pin to 'High'.                                                                                                                                       |
| 23       | G55D  | R/W     | In Input Mode:                                                                                                                                       |
|          |       |         | Read input data of GPI055 from this bit. '1' means that the external device drives the                                                               |
|          |       |         | GPIO55 pin to 'High', and '0' means that the external device drives GPIO55 to 'Low'. A '1'                                                           |
|          |       |         | must be written to this bit when GPI055 is in Input Mode.                                                                                            |
|          |       |         | GPIO54 Control/Data                                                                                                                                  |
|          |       |         | In Output Mode:                                                                                                                                      |
|          |       |         | Write '0' to this bit to drive the GPIO54 pin to 'Low'. Write '1' to this bit to drive the GPIO54                                                    |
|          | 0540  |         | pin to 'High'.                                                                                                                                       |
| 22       | G54D  | R/W     | In Input Mode:                                                                                                                                       |
|          |       |         | Read input data of GPI054 from this bit. '1' means that the external device drives the                                                               |
|          |       |         | GPIO54 pin to 'High', and '0' means that the external device drives GPIO54 to 'Low'. A '1'                                                           |
|          |       |         | must be written to this bit when GPIO54 is in Input Mode.                                                                                            |
|          |       |         | GPIO53 Control/Data                                                                                                                                  |
|          |       |         | In Output Mode:                                                                                                                                      |
|          |       |         | Write '0' to this bit to drive the GPIO53 pin to 'Low'. Write '1' to this bit to drive the GPIO53                                                    |
| 21       | G53D  | R/W     | pin to 'High'.                                                                                                                                       |
| 21       | GSSD  | R/W     | In Input Mode:                                                                                                                                       |
|          |       |         | Read input data of GPIO53 from this bit. '1' means that the external device drives the                                                               |
|          |       |         | GPIO53 pin to 'High', and '0' means that the external device drives GPIO53 to 'Low'. A '1'                                                           |
|          |       |         | must be written to this bit when GPIO53 is in Input Mode.                                                                                            |
|          |       |         | GPIO52 Control/Data                                                                                                                                  |
|          |       |         | In Output Mode:                                                                                                                                      |
|          |       |         | Write '0' to this bit to drive the GPIO52 pin to 'Low'. Write '1' to this bit to drive the GPIO52                                                    |
| 20       | G52D  | R/W     | pin to 'High'.                                                                                                                                       |
| <b>_</b> |       |         | In Input Mode:                                                                                                                                       |
|          |       |         | Read input data of GPIO52 from this bit. '1' means that the external device drives the                                                               |
|          |       |         | GPIO52 pin to 'High', and '0' means that the external device drives GPIO52 to 'Low'. A '1' must be written to this bit when GPIO52 is in Input Mode. |
|          |       |         | GPIO51 Control/Data                                                                                                                                  |
|          |       |         |                                                                                                                                                      |
|          |       |         | In Output Mode:<br>Write '0' to this bit to drive the GPIO51 pin to 'Low'. Write '1' to this bit to drive the GPIO51                                 |
|          |       |         | pin to 'High'.                                                                                                                                       |
| 19       | G51D  | R/W     | In Input Mode:                                                                                                                                       |
|          |       |         | Read input data of GPIO51 from this bit. '1' means that the external device drives the                                                               |
|          |       |         | GPIO51 pin to 'High', and '0' means that the external device drives GPIO51 to 'Low'. A '1'                                                           |
|          |       |         | must be written to this bit when GPIO51 is in Input Mode.                                                                                            |
|          |       |         | GPIO50 Control/Data                                                                                                                                  |
|          |       |         | In Output Mode:                                                                                                                                      |
|          |       |         | Write '0' to this bit to drive the GPIO50 pin to 'Low'. Write '1' to this bit to drive the GPIO50 pin                                                |
|          |       |         | to 'High'.                                                                                                                                           |
| 18       | G50D  | R/W     | In Input Mode:                                                                                                                                       |
|          |       |         | Read input data of GPIO50 from this bit. '1' means that the external device drives the                                                               |
|          |       |         | GPIO50 pin to 'High', and '0' means that the external device drives GPIO50 to 'Low'. A '1'                                                           |
|          |       |         | must be written to this bit when GPIO50 is in Input Mode.                                                                                            |
|          |       |         | GPIO49 Control/Data                                                                                                                                  |
| 17       | G49D  | R/W     | In Output Mode:                                                                                                                                      |
|          | 0.00  | 1.1.4.4 | Write '0' to this bit to drive the GPIO49 pin to 'Low'. Write '1' to this bit to drive the GPIO49                                                    |
| L        | •     |         |                                                                                                                                                      |

\_\_\_\_



|    |       |                  | pin to 'High'.                                                                                                                                                                    |
|----|-------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       |                  | In Input Mode:                                                                                                                                                                    |
|    |       |                  | Read input data of GPIO49 from this bit. '1' means that the external device drives the                                                                                            |
|    |       |                  | GPIO49 pin to 'High', and '0' means that the external device drives GPIO49 to 'Low'. A '1'                                                                                        |
|    |       |                  | must be written to this bit when GPIO49 is in Input Mode.                                                                                                                         |
|    |       |                  | GPIO48 Control/Data                                                                                                                                                               |
|    |       |                  | In Output Mode:                                                                                                                                                                   |
|    |       |                  | Write '0' to this bit to drive the GPIO48 pin to 'Low'. Write '1' to this bit to drive the GPIO48                                                                                 |
| 16 | G48D  | R/W              | pin to 'High'.                                                                                                                                                                    |
|    |       |                  | In Input Mode:                                                                                                                                                                    |
|    |       |                  | Read input data of GPIO48 from this bit. '1' means that the external device drives the GPIO48 pin to 'High', and '0' means that the external device drives GPIO48 to 'Low'. A '1' |
|    |       |                  | must be written to this bit when GPIO48 is in Input Mode.                                                                                                                         |
|    |       |                  | GPIO47 Control/Data                                                                                                                                                               |
|    |       |                  | In Output Mode:                                                                                                                                                                   |
|    |       |                  | Write '0' to this bit to drive the GPIO47 pin to 'Low'. Write '1' to this bit to drive the GPIO47                                                                                 |
|    | o /== |                  | pin to 'High'.                                                                                                                                                                    |
| 15 | G47D  | R/W              | In Input Mode:                                                                                                                                                                    |
|    |       |                  | Read input data of GPIO47 from this bit. '1' means that the external device drives the                                                                                            |
|    |       |                  | GPIO47 pin to 'High', and '0' means that the external device drives GPIO47 to 'Low'. A '1'                                                                                        |
|    |       |                  | must be written to this bit when GPIO47 is in Input Mode.                                                                                                                         |
|    |       |                  | GPIO46 Control/Data                                                                                                                                                               |
|    |       |                  | In Output Mode:                                                                                                                                                                   |
|    |       |                  | Write '0' to this bit to drive the GPIO46 pin to 'Low'. Write '1' to this bit to drive the GPIO46                                                                                 |
| 14 | G46D  | R/W              | pin to 'High'.                                                                                                                                                                    |
|    | 0.02  |                  | In Input Mode:                                                                                                                                                                    |
|    |       |                  | Read input data of GPIO46 from this bit. '1' means that the external device drives the GPIO46 pin to 'High', and '0' means that the external device drives GPIO46 to 'Low'. A '1' |
|    |       |                  | must be written to this bit when GPIO46 is in Input Mode.                                                                                                                         |
|    |       |                  | GPIO45 Control/Data                                                                                                                                                               |
|    |       |                  | In Output Mode:                                                                                                                                                                   |
|    |       |                  | Write '0' to this bit to drive the GPIO45 pin to 'Low'. Write '1' to this bit to drive the GPIO45                                                                                 |
|    |       |                  | pin to 'High'.                                                                                                                                                                    |
| 13 | G45D  | R/W              | In Input Mode:                                                                                                                                                                    |
|    |       |                  | Read input data of GPIO45 from this bit. '1' means that the external device drives the                                                                                            |
|    |       |                  | GPIO45 pin to 'High', and '0' means that the external device drives GPIO45 to 'Low'. A '1'                                                                                        |
|    |       |                  | must be written to this bit when GPIO45 is in Input Mode.                                                                                                                         |
|    |       |                  | GPIO44 Control/Data                                                                                                                                                               |
|    |       |                  | In Output Mode:                                                                                                                                                                   |
|    |       |                  | Write '0' to this bit to drive the GPIO44 pin to 'Low'. Write '1' to this bit to drive the GPIO44                                                                                 |
| 12 | G44D  | R/W              | pin to 'High'.                                                                                                                                                                    |
|    |       |                  | In Input Mode:<br>Read input data of GPIO44 from this bit. '1' means that the external device drives the                                                                          |
|    |       |                  | GPIO44 pin to 'High', and '0' means that the external device drives GPIO44 to 'Low'. A '1'                                                                                        |
|    |       |                  | must be written to this bit when GPIO44 is in Input Mode.                                                                                                                         |
|    |       |                  | GPIO43 Control/Data                                                                                                                                                               |
|    |       |                  | In Output Mode:                                                                                                                                                                   |
|    |       |                  | Write '0' to this bit to drive the GPIO43 pin to 'Low'. Write '1' to this bit to drive the GPIO43                                                                                 |
| 44 | 0405  |                  | pin to 'High'.                                                                                                                                                                    |
| 11 | G43D  | R/W              | In Input Mode:                                                                                                                                                                    |
|    |       |                  | Read input data of GPIO43 from this bit. '1' means that the external device drives the                                                                                            |
|    |       |                  | GPIO43 pin to 'High', and '0' means that the external device drives GPIO43 to 'Low'. A '1'                                                                                        |
| L  |       |                  | must be written to this bit when GPIO43 is in Input Mode.                                                                                                                         |
|    |       |                  | GPIO42 Control/Data                                                                                                                                                               |
|    |       |                  | In Output Mode:                                                                                                                                                                   |
|    |       |                  | Write '0' to this bit to drive the GPIO42 pin to 'Low'. Write '1' to this bit to drive the GPIO42 pin to 'Ligh'                                                                   |
| 10 | G42D  | R/W              | pin to 'High'.<br>In Input Mode:                                                                                                                                                  |
|    |       |                  | Read input data of GPIO42 from this bit. '1' means that the external device drives the                                                                                            |
|    |       |                  | GPIO42 pin to 'High', and '0' means that the external device drives GPIO42 to 'Low'. A '1'                                                                                        |
|    |       |                  | must be written to this bit when GPIO42 is in Input Mode.                                                                                                                         |
| _  | 0.115 | <b>B</b> 4 · · · | GPIO41 Control/Data                                                                                                                                                               |
| 9  | G41D  | R/W              | In Output Mode:                                                                                                                                                                   |
|    |       |                  |                                                                                                                                                                                   |

|   |   | C <sup>®</sup> |                        |
|---|---|----------------|------------------------|
| K | D |                | RISC DSP Communication |

Write '0' to this bit to drive the GPIO41 pin to 'Low'. Write '1' to this bit to drive the GPIO41

|   |      |         | pin to 'High'.                                                                                                                                       |
|---|------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |      |         | In Input Mode:                                                                                                                                       |
|   |      |         | Read input data of GPIO41 from this bit. '1' means that the external device drives the                                                               |
|   |      |         | GPIO41 pin to 'High', and '0' means that the external device drives GPIO41 to 'Low'. A '1'                                                           |
|   |      |         | must be written to this bit when GPIO41 is in Input Mode.                                                                                            |
|   |      |         | GPIO40 Control/Data                                                                                                                                  |
|   |      |         | In Output Mode:                                                                                                                                      |
|   |      |         | Write '0' to this bit to drive the GPIO40 pin to 'Low'. Write '1' to this bit to drive the GPIO40                                                    |
| 8 | G40D | R/W     | pin to 'High'.                                                                                                                                       |
| 0 | 0400 | 1.7.4.4 | In Input Mode:                                                                                                                                       |
|   |      |         | Read input data of GPIO40 from this bit. '1' means that the external device drives the                                                               |
|   |      |         | GPIO40 pin to 'High', and '0' means that the external device drives GPIO40 to 'Low'. A '1'                                                           |
|   |      |         | must be written to this bit when GPIO40 is in Input Mode.<br>GPIO39 Control/Data                                                                     |
|   |      |         | In Output Mode:                                                                                                                                      |
|   |      |         | Write '0' to this bit to drive the GPIO39 pin to 'Low'. Write '1' to this bit to drive the GPIO39                                                    |
|   |      |         | pin to 'High'.                                                                                                                                       |
| 7 | G39D | R/W     | In Input Mode:                                                                                                                                       |
|   |      |         | Read input data of GPIO39 from this bit. '1' means that the external device drives the                                                               |
|   |      |         | GPIO39 pin to 'High', and '0' means that the external device drives GPIO39 to 'Low'. A '1'                                                           |
|   |      |         | must be written to this bit when GPIO39 is in Input Mode.                                                                                            |
|   |      |         | GPIO38 Control/Data                                                                                                                                  |
|   |      |         | In Output Mode:                                                                                                                                      |
|   |      |         | Write '0' to this bit to drive the GPIO38 pin to 'Low'. Write '1' to this bit to drive the GPIO38                                                    |
| 6 | G38D | R/W     | pin to 'High'.                                                                                                                                       |
| Ŭ | COOD | 1.0.4.4 | In Input Mode:                                                                                                                                       |
|   |      |         | Read input data of GPIO38 from this bit. '1' means that the external device drives the                                                               |
|   |      |         | GPIO38 pin to 'High', and '0' means that the external device drives GPIO38 to 'Low'. A '1'                                                           |
|   |      |         | must be written to this bit when GPIO38 is in Input Mode.<br>GPIO37 Control/Data                                                                     |
|   |      |         | In Output Mode:                                                                                                                                      |
|   |      |         | Write '0' to this bit to drive the GPIO37 pin to 'Low'. Write '1' to this bit to drive the GPIO37                                                    |
|   |      |         | pin to 'High'.                                                                                                                                       |
| 5 | G37D | R/W     | In Input Mode:                                                                                                                                       |
|   |      |         | Read input data of GPIO37 from this bit. '1' means that the external device drives the                                                               |
|   |      |         | GPIO37 pin to 'High', and '0' means that the external device drives GPIO37 to 'Low'. A '1'                                                           |
|   |      |         | must be written to this bit when GPIO37 is in Input Mode.                                                                                            |
|   |      |         | GPIO36 Control/Data                                                                                                                                  |
|   |      |         | In Output Mode:                                                                                                                                      |
|   |      |         | Write '0' to this bit to drive the GPIO36 pin to 'Low'. Write '1' to this bit to drive the GPIO36 pin to 'Ligh'                                      |
| 4 | G36D | R/W     | pin to 'High'.<br>In Input Mode:                                                                                                                     |
|   |      |         | Read input data of GPIO36 from this bit. '1' means that the external device drives the                                                               |
|   |      |         | GPIO36 pin to 'High', and '0' means that the external device drives GPIO36 to 'Low'. A '1'                                                           |
|   |      |         | must be written to this bit when GPIO36 is in Input Mode.                                                                                            |
|   |      |         | GPIO35 Control/Data                                                                                                                                  |
|   |      |         | In Output Mode:                                                                                                                                      |
|   |      |         | Write '0' to this bit to drive the GPIO35 pin to 'Low'. Write '1' to this bit to drive the GPIO35                                                    |
| 3 | G35D | R/W     | pin to 'High'.                                                                                                                                       |
|   | 0000 | 1.7.4.4 | In Input Mode:                                                                                                                                       |
|   |      |         | Read input data of GPIO35 from this bit. '1' means that the external device drives the                                                               |
|   |      |         | GPIO35 pin to 'High', and '0' means that the external device drives GPIO35 to 'Low'. A '1' must be written to this bit when GPIO35 is in Input Mode. |
|   |      |         | GPIO34 Control/Data                                                                                                                                  |
|   |      |         | In Output Mode:                                                                                                                                      |
|   |      |         | Write '0' to this bit to drive the GPIO34 pin to 'Low'. Write '1' to this bit to drive the GPIO34                                                    |
| _ |      |         | pin to 'High'.                                                                                                                                       |
| 2 | G34D | R/W     | In Input Mode:                                                                                                                                       |
|   |      |         | Read input data of GPIO34 from this bit. '1' means that the external device drives the                                                               |
|   |      |         | GPIO34 pin to 'High', and '0' means that the external device drives GPIO34 to 'Low'. A '1'                                                           |
|   |      |         | must be written to this bit when GPIO34 is in Input Mode.                                                                                            |
|   |      |         | · · · · · · · · · · · · · · · · · · ·                                                                                                                |



| 1 | G33D | R/W | <ul> <li>GPIO33 Control/Data</li> <li>In Output Mode:</li> <li>Write '0' to this bit to drive the GPIO33 pin to 'Low'. Write '1' to this bit to drive the GPIO33 pin to 'High'.</li> <li>In Input Mode:</li> <li>Read input data of GPIO33 from this bit. '1' means that the external device drives the GPIO33 pin to 'High', and '0' means that the external device drives GPIO33 to 'Low'. A '1' must be written to this bit when GPIO33 is in Input Mode.</li> </ul> |
|---|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | G32D | R/W | <ul> <li>GPIO32 Control/Data</li> <li>In Output Mode:<br/>Write '0' to this bit to drive the GPIO32 pin to 'Low'. Write '1' to this bit to drive the GPIO32 pin to 'High'.</li> <li>In Input Mode:<br/>Read input data of GPIO32 from this bit. '1' means that the external device drives the GPIO32 pin to 'High', and '0' means that the external device drives GPIO32 to 'Low'. A '1' must be written to this bit when GPIO32 is in Input Mode.</li> </ul>           |

| Register Offset:<br>Register Name:<br>Reset Value: | 93h – 90h<br>Chip Select 1 Base Address Register<br>0000000h |    |         |                  |
|----------------------------------------------------|--------------------------------------------------------------|----|---------|------------------|
| 31 30 29 28 27                                     | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8       | 76 | 54      | 3 2 1 0          |
|                                                    | Base Address                                                 | Re | eserved | Bit1<br>6 MIO En |

| Bit  | Name  | Attribute | Description                                                                                                                      |
|------|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | BA    | R/W       | Chip Select 1 Base Address A[31:8]. I/O map only uses A[15:8]; others are reserved.<br>Chip Select 1 starts at the base address. |
| 7-3  | Rsvd  | R         | Reserved                                                                                                                         |
| 2    | BIT16 | R/W       | 0: 8-bit<br>1: 16-bit                                                                                                            |
| 1    | MIO   |           | 0: I/O map<br>1: Memory maps I/O                                                                                                 |
| 0    | En    | R/W       | Chip Select 1 Base Address is enabled when set                                                                                   |

| Register Offset: | 97h – 94h                       |
|------------------|---------------------------------|
| Register Name:   | Chip Select 1 Base Address Mask |
| Reset Value:     | FFFFF00h                        |

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

BAM

Reserved

| Bit  | Name | Attribute | Description                                                                   |  |  |  |  |  |  |  |  |  |
|------|------|-----------|-------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 31-8 | BAM  | R/W       | Chip Select 1 Base Address Mask bit [31:8].                                   |  |  |  |  |  |  |  |  |  |
| 7-0  | Rsvd |           | Reserved. All are '0's.<br>To write any value to these bits causes no effect. |  |  |  |  |  |  |  |  |  |



| Register Offset: | 9Bh – 98h                           |
|------------------|-------------------------------------|
| Register Name:   | Chip Select 2 Base Address Register |
| Reset Value:     | 0000000h                            |

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

| Base Address | Reserved | Bit1<br>6 MIO En |
|--------------|----------|------------------|

| Bit  | Name  | Attribute | Description                                                                                                                      |
|------|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | BA    | R/W       | Chip Select 2 Base Address A[31:8]. I/O map only uses A[15:8]; others are reserved.<br>Chip Select 2 starts at the base address. |
| 7-3  | Rsvd  | R         | Reserved                                                                                                                         |
| 2    | BIT16 | R/W       | 0: 8-bit<br>1: 16-bit                                                                                                            |
| 1    | MIO   | R/W       | 0: I/O map<br>1: Memory maps I/O                                                                                                 |
| 0    | En    | R/W       | Chip Select 2 Base Address is enabled when set                                                                                   |

| Register Offset: | 9Fh – 9Ch                       |
|------------------|---------------------------------|
| Register Name:   | Chip Select 2 Base Address Mask |
| Reset Value:     | FFFFF00h                        |

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

BAM

Reserved

| Bit  | Name | Attribute | Description                                                                   |
|------|------|-----------|-------------------------------------------------------------------------------|
| 31-8 | BAM  | R/W       | Chip Select 2 Base Address Mask bit [31:8].                                   |
| 7-0  | Rsvd |           | Reserved. All are '0's.<br>To write any value to these bits causes no effect. |

#### 11.3.3 MAC1 and MAC2 Configuration Registers

| -  | er Offse<br>er Name<br>Value: |    | 01h – 00<br>Vendor I<br>17F3h |    | ster |   |     |     |   |   |   |   |   |   |   |
|----|-------------------------------|----|-------------------------------|----|------|---|-----|-----|---|---|---|---|---|---|---|
| 15 | 14                            | 13 | 12                            | 11 | 10   | 9 | 8   | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |                               |    |                               |    |      |   | 176 | =3h |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                                   |
|------|------|-----------|-------------------------------------------------------------------------------|
| 15-0 | VID  | RO        | This register contains a 16-bit value assigned to RDC Semiconductor Co., Ltd. |

| Regis | Register Offset:<br>Register Name:<br>Reset Value: |    |    | 03h – 02h<br>Device ID Register<br>6040h |    |   |   |   |   |   |   |   |   |   |   |
|-------|----------------------------------------------------|----|----|------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| 15    | 14                                                 | 13 | 12 | 11                                       | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 6040h |                                                    |    |    |                                          |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                           |
|------|------|-----------|-----------------------------------------------------------------------|
| 15-0 | DID  | RO        | This register contains a 16-bit value to specify a particular device. |

| Regis | ster Offs | et: | 05h – 04         | 4h |    |          |   |   |   |   |   |   |      |      |       |
|-------|-----------|-----|------------------|----|----|----------|---|---|---|---|---|---|------|------|-------|
| Regis | ster Nam  | ne: | Command Register |    |    |          |   |   |   |   |   |   |      |      |       |
| Reset | t Value:  |     | 0007h            |    |    |          |   |   |   |   |   |   |      |      |       |
| 15    | 14        | 13  | 12               | 11 | 10 | 9        | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0     |
|       |           |     |                  |    | I  | Reserved | ł |   |   |   |   |   | PMDC | MSAC | IOSAC |

| Bit  | Name  | Attribute | Description                                                 |  |  |  |
|------|-------|-----------|-------------------------------------------------------------|--|--|--|
| 15-3 | Rsvd  | RO        | Reserved. These bits always return '0's.                    |  |  |  |
| 2    | PMDC  | R/W       | PCI Bus Master Device Control. This bit always returns '1'. |  |  |  |
| 1    | MSAC  | R/W       | Memory Space Access Control. This bit always returns '1'.   |  |  |  |
| 0    | IOSAC | R/W       | I/O Space Access Control. This bit always returns '1'.      |  |  |  |



| Regis                          | Register Offset: 07h – 06h |      |       |      |    |   |   |   |   |   |          |   |   |   |   |
|--------------------------------|----------------------------|------|-------|------|----|---|---|---|---|---|----------|---|---|---|---|
| Register Name: Status Register |                            |      |       |      |    |   |   |   |   |   |          |   |   |   |   |
| Reset                          | Value:                     |      | 0200h |      |    |   |   |   |   |   |          |   |   |   |   |
| 15                             | 14                         | 13   | 12    | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4        | 3 | 2 | 1 | 0 |
| DPE                            | SS                         | RMAS | RTAS  | STAS | D  | т |   |   |   |   | Reserved | 1 |   |   |   |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                             |
|------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | DPE  | RO        | Detected Parity Error. This bit must be set whenever the device detects a parity error. This is a read-only bit and is cleared by writing '1' to it.                                                                                                    |
| 14   | SS   | RO        | SERR_n Status. This bit must be set whenever the device asserts SERR_n. This is a read-only bit and is cleared by writing '1' to it.                                                                                                                    |
| 13   | RMAS | RO        | Receive Master Abort Status when the MAC acts as a master. This bit is set to '1' when the R8610 generates a transaction (except for special cycles), and is terminated with master-abort. This is a read-only bit and is cleared by writing '1' to it. |
| 12   | RTAS | RO        | Receive Target Abort Status when the MAC acts as a master. This bit is set to '1' when the MAC encounters a target abort condition. This is a read-only bit and is cleared by writing a '1' to it.                                                      |
| 11   | STAS | RO        | Signal Target Abort Status when the MAC acts as a slave.<br>The R6040 as a slave never generates a Target abort. This bit is always 0.                                                                                                                  |
| 10-9 | DT   | RO        | DEVSEL_n Timing. The MAC always generates DEVSEL_n with low timing. These bits are<br>always '10'.                                                                                                                                                      |
| 8-0  | Rsvd | RO        | Reserved. These bits always return '0's.                                                                                                                                                                                                                |

| Regis        | ter Offs | et: | 08h                  |    |   |   |   |  |  |
|--------------|----------|-----|----------------------|----|---|---|---|--|--|
| Regis        | ter Nam  | ne: | Revision ID Register |    |   |   |   |  |  |
| Reset Value: |          |     | 00h                  |    |   |   |   |  |  |
| 7            | 6        | 5   | 4                    | 3  | 2 | 1 | 0 |  |  |
|              |          |     | R                    | ID |   |   |   |  |  |

| Bit | Name | Attribute | Description                     |
|-----|------|-----------|---------------------------------|
| 7-0 | RID  | R/W       | Version number of the R6040 MAC |



| Reg | gister | r Offs | set: | 0B  | h – 0 | 9h    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|-----|--------|--------|------|-----|-------|-------|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| Reg | giste  | r Nan  | ne:  | Cla | ass C | ode F | Regist | er |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Res | set Va | alue:  |      | 02  | 0000  | ٦     |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| 23  | 22     | 21     | 20   | 19  | 18    | 17    | 16     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |

СС

| Bit  | Name | Attribute | Description                                      |
|------|------|-----------|--------------------------------------------------|
| 23-0 | СС   | RO        | Class Code of the R6040 FastEthernet Controller. |

| Regis | ster Offs<br>ster Nam<br>t Value: |   | 0Eh<br>Header<br>00h | Type Re | egister |   |   |
|-------|-----------------------------------|---|----------------------|---------|---------|---|---|
| 7     | 6                                 | 5 | 4                    | 3       | 2       | 1 | 0 |
|       |                                   |   | Н                    | Т       |         |   |   |

| Bit | Name | Attribute | Description                                                                        |
|-----|------|-----------|------------------------------------------------------------------------------------|
| 7-0 | HT   | RO        | This register identifies the type of predefined header in the configuration space. |

| Register Offset: | 13h – 10h                                                              |
|------------------|------------------------------------------------------------------------|
| Register Name:   | I/O Base Address Register                                              |
| Reset Value:     | XXXXX01h                                                               |
| 31 30 29 28 27 2 | 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 |

| BAD | Reserved 1 |
|-----|------------|
|-----|------------|

| Bit  | Name | Attribute | Description                    |  |  |  |  |  |
|------|------|-----------|--------------------------------|--|--|--|--|--|
| 31-8 | BAD  | R/W       | I/O Base Address.              |  |  |  |  |  |
| 7-1  | Rsvd | RO        | Reserved.                      |  |  |  |  |  |
| 0    | 1    | RO        | Always 1, I/O space indicator. |  |  |  |  |  |

## RDC<sup>®</sup> RISC DSP Communication

| Register Offset: | 17h – 14h                    |
|------------------|------------------------------|
| Register Name:   | Memory Base Address Register |
| Reset Value:     | XXXXXX00h                    |

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

BAD

Reserved

0

| Bit  | Name | Attribute | Description                       |
|------|------|-----------|-----------------------------------|
| 31-8 | BAD  | R/W       | Memory Base Address.              |
| 7-1  | Rsvd | RO        | Reserved.                         |
| 0    | 0    | RO        | Always 0, memory space indicator. |

| Regis                       | ter Offs | et: | 2Dh – 2 | Ch |          |         |    |     |   |   |   |   |   |   |   |
|-----------------------------|----------|-----|---------|----|----------|---------|----|-----|---|---|---|---|---|---|---|
| Register Name: Subsystem Ve |          |     |         |    | dor ID R | egister |    |     |   |   |   |   |   |   |   |
| Reset Value:                |          |     | 0000h   |    |          |         |    |     |   |   |   |   |   |   |   |
| 15                          | 14       | 13  | 12      | 11 | 10       | 9       | 8  | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                             |          |     |         |    |          |         | S١ | /ID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                     |
|------|------|-----------|-------------------------------------------------|
| 15-0 | SVID | R/WL      | This register contains the subsystem Vendor ID. |

| Register Offset:<br>Register Name:<br>Reset Value: |    |    | 2Fh – 2I<br>Subsyst<br>0000h |    | ice ID R | egister |    |     |   |   |   |   |   |   |   |
|----------------------------------------------------|----|----|------------------------------|----|----------|---------|----|-----|---|---|---|---|---|---|---|
| 15                                                 | 14 | 13 | 12                           | 11 | 10       | 9       | 8  | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                                    |    |    |                              |    |          |         | SE | DID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                     |
|------|------|-----------|-------------------------------------------------|
| 15-0 | SDID | R/WL      | This register contains the subsystem Device ID. |



| Register Offset:<br>Register Name:<br>Reset Value: |    |    | 3Dh – 3Ch<br>Interrupt Control Register<br>01XXh |    |    |   |   |   |   |   |    |    |   |   |   |
|----------------------------------------------------|----|----|--------------------------------------------------|----|----|---|---|---|---|---|----|----|---|---|---|
| 15                                                 | 14 | 13 | 12                                               | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|                                                    |    |    | IN                                               | TP |    |   |   |   |   |   | IN | TL |   |   |   |
|                                                    |    |    |                                                  |    |    |   |   |   |   |   |    |    |   |   |   |

| Bit  | Name | Attribute | Description                             |
|------|------|-----------|-----------------------------------------|
| 15-8 | INTP | R         | Interrupt Pin. Use INT_A.               |
| 7-0  | INTL | R/W       | Interrupt Line. Index Interrupt Vector. |

### 12. Fast Ethernet Control Unit



#### 12.1 RX Descriptor Format

|      | 3            |                           | 2                                                        | 1                                                     | 0                                                                 |
|------|--------------|---------------------------|----------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------|
| -    |              |                           |                                                          |                                                       |                                                                   |
| N    |              |                           |                                                          |                                                       |                                                                   |
| DRBP |              |                           |                                                          |                                                       | 0                                                                 |
|      | D            | RB                        | P[3                                                      | 31:16                                                 | 5]                                                                |
| DRNX |              |                           |                                                          |                                                       | 0                                                                 |
|      | 1            | DRN                       | X[                                                       | 31:1                                                  | 6]                                                                |
|      |              |                           |                                                          |                                                       |                                                                   |
| ~ve2 |              |                           |                                                          |                                                       |                                                                   |
| rve3 |              |                           |                                                          |                                                       |                                                                   |
|      | DRBP<br>DRNX | N<br>DRBP<br>DRNX<br>DRNX | N<br>DRBP<br>DRNX<br>DRNX<br>DRNX<br>IDRN<br>HID<br>rve2 | N<br>DRBP<br>DRBP[3<br>DRNX<br>DRNX[<br>HIDX[<br>rve2 | N<br>DRBP<br>DRBP[31:16<br>DRNX<br>DRNX[31:1<br>HIDX[5:0]<br>rve2 |

#### 1. DRST

| 15 | 14   | 13   | 12    | 11         | 10          | 9   | 8    | 7    | 6          | 5             | 4             | 3   | 2    | 1 | 0  |
|----|------|------|-------|------------|-------------|-----|------|------|------------|---------------|---------------|-----|------|---|----|
| 0  | RXOK | Rese | erved | PHY<br>ERR | DRI<br>BBLE | OBL | LONG | RUNT | CRC<br>ERR | BROAD<br>CAST | MULTI<br>CAST | MCH | MIDH | М | ID |

The RX circuit will stop receiving packets if the Owner bit=0.

DRST[14:0]: RX status. The MAC will update the RX status field after frame receiving is complete.

| Bit | Name | Description                                      |
|-----|------|--------------------------------------------------|
| 15  | 0    | Owner bit.<br>Set 1: the MAC.<br>Set 0: the CPU. |



| 14    | RXOK      | RX successful.         This bit indicates that the packet was received successfully without errors. It includes:         (1) RX_ER = 0 (MII interface).         (2) Ignore DRIBBLE status.         (3) No over buffer length.         (4) Without CRC errors.         (5) Not a LONG packet.         (6) Not a RUNT packet.         (7) No FIFO Full. |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13-12 | Rsvd      | Reserved.                                                                                                                                                                                                                                                                                                                                             |
| 11    | PHYERR    | PHY RX Error packet.<br>Reading "1" means that an error occurred in receiving packets on the MII interface.                                                                                                                                                                                                                                           |
| 10    | DRIBBLE   | Dribble packet. Reading "1" means the received packet is a dribble packet.                                                                                                                                                                                                                                                                            |
| 9     | OBL       | Over Buffer Length. Reading "1" means the received packet length > buffer maximum length.                                                                                                                                                                                                                                                             |
| 8     | LONG      | Long packet. Reading "1" means the received packet length > maximum packet length.                                                                                                                                                                                                                                                                    |
| 7     | RUNT      | Runt packet. Reading "1" means the received packet length < 64 bytes.                                                                                                                                                                                                                                                                                 |
| 6     | CRCERR    | CRC Error packet. Reading "1" means receiving a packet with CRC errors.                                                                                                                                                                                                                                                                               |
| 5     | BROADCAST | It indicates that the received packet is a broadcast packet.                                                                                                                                                                                                                                                                                          |
| 4     | MULTICAST | It indicates that the received packet is a multicast packet.                                                                                                                                                                                                                                                                                          |
| 3     | MCH       | Multicast Hit.<br>It indicates that the received packet hits one of the hash-table bits.                                                                                                                                                                                                                                                              |
| 2     | MIDH      | MID table is hit.                                                                                                                                                                                                                                                                                                                                     |
| 1-0   | MID       | Index of matched MIDx. These two bits indicate that the received packet hits one of the MID groups.                                                                                                                                                                                                                                                   |

#### 2. DRLEN

| 15 | 14 | 13       | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4 | 3 | 2 | 1 | 0 |
|----|----|----------|----|----|----|---|---|---|---|-------|---|---|---|---|---|
|    | F  | Reserved | ł  |    |    |   |   |   |   | DRLEN |   |   |   |   |   |

| Bit   | Name  | Description                     |
|-------|-------|---------------------------------|
| 15-11 | Rsvd  | Reserved.                       |
| 10-0  | DRLEN | The size of the received frame. |

#### 3. DRBP

| 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 |
|-----------------------------------------------------------------------------|-----------|
|-----------------------------------------------------------------------------|-----------|

DRBP

Reserved

| Bit   | Name | Description                                                                        |
|-------|------|------------------------------------------------------------------------------------|
| 31-24 | Rsvd | Reserved                                                                           |
| 23-0  | DRBP | RX Data Buffer Pointer.<br>This is a 32-bit address pointer and DRBP0 is always 0. |



#### 4. DRNX

| 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 |
|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    | Rese | ervec | ł  |    |    |    |    |    |    |    |    |    |    |    |    |    | DR | NX |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name | Description                                                                                                                                                                            |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24 | Rsvd | Reserved                                                                                                                                                                               |
| 23-0  |      | RX Next Frame Descriptor Pointer. This is a 32-bit descriptor address pointer and DRNX0 is always 0. This field must be pointed to next descriptor start address or its start address. |

#### 5. HIDX

| 15 | 14 | 13 | 12 | 11   | 10    | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2  | 1 | 0 |
|----|----|----|----|------|-------|---|---|---|---|---|---|----|----|---|---|
|    |    |    |    | Rese | erved |   |   |   |   |   |   | HI | DX |   |   |

| Bit  | Name | Description                                                                                                        |
|------|------|--------------------------------------------------------------------------------------------------------------------|
| 15-6 | Rsvd | Reserved.                                                                                                          |
| 5-0  | HIDX | HIDX[5:0] is a hash index. If MCR1[14] is set to 1, the hash index number will be written into the RX description. |

#### 6. Reserve 2.

#### 7. Reserve 3.

#### Notes:

- 1. The RX descriptor start address and data buffer start address must be double-word alignment.
- 2. The RX packet will be filtered out if its length is less than 6 (not complete DA information).

#### 12.2 TX Descriptor Format



#### 1. DTST

| 15 | 14   | 13         | 12 | 11 | 10   | 9    | 8 | 7 | 6     | 5     | 4           | 3 | 2   | 1   | 0 |
|----|------|------------|----|----|------|------|---|---|-------|-------|-------------|---|-----|-----|---|
| 0  | тхок | DIS<br>CRC |    |    | Rese | rved |   |   | TXFUR | LATEC | EXCEE<br>DC |   | COL | CNT |   |

The TX circuit will stop transmitting packets if the Owner bit=0

DTST[14:0]: TX status and packet control. The MAC will update the TX status field after frame transmission is complete. The control bit is for each packet usage.

| Bit  | Name    | Description                                                                                                                                                                                                                                                                  |
|------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | 0       | Owner bit.<br>Set 1: the MAC.<br>Set 0: the CPU.                                                                                                                                                                                                                             |
| 14   | тхок    | <ul> <li>TX packet successful. This bit indicates that the packet was transmitted successfully without errors. It includes:</li> <li>(1) No late collision.</li> <li>(2) No excessive collision.</li> <li>(3) No TX FIFO under-run.</li> <li>(4) No lost carrier.</li> </ul> |
| 13   | DISCRC  | Disable the appended CRC field.<br>This is a control bit.<br>=1: disable the CRC appending.<br>=0: enable the CRC appending on the TX packet.<br>When the status is updated, this bit will be kept in the previous setting.                                                  |
| 12-7 | Rsvd    | Reserved                                                                                                                                                                                                                                                                     |
| 6    | TXFUR   | FIFO Under-Run.                                                                                                                                                                                                                                                              |
| 5    | LATEC   | Late Collision.                                                                                                                                                                                                                                                              |
| 4    | EXCEEDC | Exceed Collision.                                                                                                                                                                                                                                                            |
| 3-0  | COLCNT  | Collision Counts.                                                                                                                                                                                                                                                            |



#### 2. DTLEN

| _ | 15 | 14 | 13       | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----------|----|----|----|---|---|---|---|-------|---|---|---|---|---|
|   |    | F  | Reserved | ł  |    |    |   |   |   |   | DTLEN |   |   |   |   |   |

| Bit   | Name  | Description                           |
|-------|-------|---------------------------------------|
| 15-11 | Rsvd  | Reserved.                             |
| 10-0  | DTLEN | The length of the transmitted packet. |

#### 3. DTBP

| 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                | DTBP                                                          |

| Bit   | Name | Description                                             |
|-------|------|---------------------------------------------------------|
| 31-24 | Rsvd | Reserved                                                |
| 23-0  | DTBP | TX Buffer Pointer.<br>This is a 32-bit address pointer. |

#### 4. DTNP

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

| Reserved | DTNP |
|----------|------|
|----------|------|

| Bit   | Name | Description                                                                                                                                                                      |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24 | Rsvd | Reserved                                                                                                                                                                         |
| 23-0  | DTNP | TX Next Descriptor Pointer. This is a 32-bit descriptor address pointer and DTNP0 is always 0. This field must be pointed to next descriptor start address or its start address. |

#### Notes:

- 1. The TX descriptor start address must be double-word alignment.
- 2. The TX data buffer start address can be any byte alignment address.
- 3. The transmitted data are less than 60 bytes when drivers are run.

# 12.3 MCR0: MAC Control Register 0 (00h)

| Register Offset:<br>Register Name: |    |      | 00h   |                              |      |      |      |       |      |      |      |       |       |        |        |
|------------------------------------|----|------|-------|------------------------------|------|------|------|-------|------|------|------|-------|-------|--------|--------|
|                                    |    |      | MCR0  | MCR0: MAC Control Register 0 |      |      |      |       |      |      |      |       |       |        |        |
| Reset Value                        |    | :    | 0000h |                              |      |      |      |       |      |      |      |       |       |        |        |
| 15                                 | 14 | 13   | 12    | 11                           | 10   | 9    | 8    | 7     | 6    | 5    | 4    | 3     | 2     | 1      | 0      |
| FULLD TXEIE                        |    | Rsvd | XMTEN | Rese                         | rved | FCEN | AMCP | RXEIE | FBCP | PROM | ADRB | ALONG | ARUNT | RCV EN | ACRCER |

| Bit   | Name   | Attribute | Description                                                                                                                                                                                                                                    |
|-------|--------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | FULLD  | R/W       | Full Duplex.<br>Set 1: Full duplex. Set 0: Half duplex (default).                                                                                                                                                                              |
| 14    | TXEIE  | R/W       | <ul> <li>TX Early Interrupt Enable.</li> <li>Set 1: The MAC will generate one TX early interrupt when data are transmitted over early interrupt threshold (see MCR1[7:6]).</li> <li>Set 0: The TX early interrupt will be disabled.</li> </ul> |
| 13    | Rsvd   | RO        | Reserved                                                                                                                                                                                                                                       |
| 12    | XMTEN  | R/W       | Transmission Enable                                                                                                                                                                                                                            |
| 11-10 | Rsvd   | RO        | Reserved                                                                                                                                                                                                                                       |
| 9     | FCEN   | R/W       | Flow Control Function Enable.<br>Set 1: will enable flow control. Set 0: will disable flow control.                                                                                                                                            |
| 8     | AMCP   | R/W       | Accept Multicast Packet.<br>Set 1: will enable hash table function.<br>Set 0: will disable hash table function.                                                                                                                                |
| 7     | RXEIE  | R/W       | <ul> <li>RX Early Interrupt Enable.</li> <li>Set 1: The MAC will generate one RX early interrupt when data are received over early interrupt threshold (see MCR1[7:6]).</li> <li>Set 0: The RX early interrupt will be disabled.</li> </ul>    |
| 6     | FBCP   | R/W       | Filter Broadcast Packet.<br>Set 1: to filter broadcast packets. Set 0: to accept broadcast packets.                                                                                                                                            |
| 5     | PROM   | R/W       | Promiscuous Mode.<br>Set 1: The MAC will receive all packets without checking the MAC address.<br>Set 0: The MAC will only receive the packet that hits the MAC address.                                                                       |
| 4     | ADRB   | R/W       | Accept DRIBBLE packet.<br>Set 1: Enable to accept dribble packets. Set 0: Disable.                                                                                                                                                             |
| 3     | ALONG  | R/W       | Accept Long packet.<br>Set 1: Enable to accept long packets. Set 0: Disable.                                                                                                                                                                   |
| 2     | ARUNT  | R/W       | Accept RUNT packet.<br>Set 1: Enable to accept runt packets. The packets which length > 6 and < 64 will be<br>accepted, but the packets which length >0 and < 6 will be rejected.<br>Set 0: Disable to accept runt packets.                    |
| 1     | RCVEN  | R/W       | Receive Enable.<br>Set 1: Enable the packet receive. Set 0: Disable the packet receive.                                                                                                                                                        |
| 0     | ACRCER | R/W       | Accept CRC Error packet.<br>Set 1: Enable. Set 0: Disable.                                                                                                                                                                                     |

0

MRST

# 12.4 MCR1: MAC Control Register 1 (04h)

| Regis     | ster Off | set: | 04h  |        |        |          |      |      |        |      |         |   |   |     |  |
|-----------|----------|------|------|--------|--------|----------|------|------|--------|------|---------|---|---|-----|--|
| Regis     | ster Nai | me:  | MCR  | 1: MAC | Contro | l Regist | er 1 |      |        |      |         |   |   |     |  |
| Rese      | t Value  | :    | 0010 | n      |        |          |      |      |        |      |         |   |   |     |  |
| 15        | 14       | 13   | 12   | 11     | 10     | 9        | 8    | 7    | 6      | 5    | 4       | 3 | 2 | 1   |  |
| AUCP WIDX |          |      | Rese | erved  |        | TPF      | ECR  | EITH | I[1:0] | MAXL | EN[1:0] | 0 | 0 | LBM |  |

| Bit   | Name            | Attribute | Description                                                                                                                                                                                                                                                                              |
|-------|-----------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | AUCP            | R/W       | Filter uni-cast packets by hash-table.<br>Set 1: Enable.<br>Set 0: Disable.                                                                                                                                                                                                              |
| 14    | WIDX            | R/W       | Write the hash index number that was hit by hash-table.<br>Set 1: Enable to write the HIDX[5:0] into the RX descriptor.<br>Set 0: Disable this function.                                                                                                                                 |
| 13-10 | Rsvd            | RO        | Reserved                                                                                                                                                                                                                                                                                 |
| 9     | TPF             | RO        | Trigger Pause Frame to be transmitted.<br>If flow control (the FCEN bit in MCR0 [9]) is enabled, this bit will be set automatically when<br>received descriptors unavailable happen. TPF refers to the XMTEN bit (MCR0 [12]). When<br>the XMTEN bit is set, the pause frame can be sent. |
| 8     | ECR             | R/W       | Excessive Collision Retransmit times.<br>0: 16 times (default).<br>1: 32 times.                                                                                                                                                                                                          |
| 7-6   | EITH[1:0]       | R/W       | Early Interrupt Threshold.<br>00: 1129 bytes (default).<br>01: 1257 bytes.<br>10: 1385 bytes.<br>11: 1513 bytes.                                                                                                                                                                         |
| 5-4   | MAXLEN<br>[1:0] | R/W       | Maximum Packet Length Selector. Define the length of long packets.<br>01: 1518 bytes (default).<br>10: 1522 bytes.<br>11: 1534 bytes.<br>00: 1537 bytes.                                                                                                                                 |
| 3-2   | Rsvd            | R/O       | Reserved                                                                                                                                                                                                                                                                                 |
| 1     | LBM             | R/W       | Loop-Back mode.<br>0: Normal mode (default).<br>1: MAC loop-back.                                                                                                                                                                                                                        |
| 0     | MRST            | R/W       | MAC Reset.<br>Set 1 to reset the MAC.<br>After resets, this bit will be cleared to 0.                                                                                                                                                                                                    |

# 12.5 MBCR: MAC Bus Control Register (08h)

| Regis          | ster Off | set: | 08h |        |          |          |          |          |   |            |   |            |   |      |         |
|----------------|----------|------|-----|--------|----------|----------|----------|----------|---|------------|---|------------|---|------|---------|
| Register Name: |          |      | MBC | r: Mac | Bus C    | ontrol F | Register |          |   |            |   |            |   |      |         |
| Reset Value :  |          | 1F1A | h   |        |          |          |          |          |   |            |   |            |   |      |         |
| 15             | 14       | 13   | 12  | 11     | 10       | 9        | 8        | 7        | 6 | 5          | 4 | 3          | 2 | 1    | 0       |
| Reserved       |          |      |     | F      | RHPT[4:0 | )]       |          | Reserved |   | RXFTH[1:0] |   | TXFTH[1:0] |   | FIFO | TL[1:0] |

| Bit   | Name        | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-13 | Rsvd        | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                        |
| 12-8  | RHPT[4:0]   | R/W       | SDRAM Bus Request High Priority Timer.<br>When the MAC issues a bus request to the SDRAM arbiter, this timer will start to count<br>down. After this timer is timeout, if the SDRAM arbiter is still not granted to the MAC, the<br>SDRAM bus request will become high priority.<br>Wait time = 1 ~15 host clocks. (Default=15 host clocks)<br>RHPT = 0, disable this function. |
| 7-6   | Rsvd        | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                        |
| 5-4   | RXFTH[1:0]  | R/W       | RX FIFO Data Threshold.<br>The MAC receive machine starts to move the received data into the host memory when<br>receiving data over the RX FIFO threshold.<br>00: 8 bytes.<br>01: 16 bytes (default).<br>10: 32 bytes.<br>11: 64 bytes.                                                                                                                                        |
| 3-2   | TXFTH[1:0]  | R/W       | <ul> <li>TX FIFO Data Threshold.</li> <li>The MAC transmit machine starts to send out packets to the PHY when data is transmitted into the TX FIFO over the threshold.</li> <li>00: 16 bytes.</li> <li>01: 32 bytes.</li> <li>10: 64 bytes (default).</li> <li>11: 96 bytes.</li> </ul>                                                                                         |
| 1-0   | FIFOTL[1:0] | R/W       | FIFO Transfer Length.<br>Every transfer data length between the MAC FIFO and SDRAM.<br>00: 4 bytes.<br>01: 8 bytes.<br>10: 16 bytes (default).<br>11: 32 bytes.                                                                                                                                                                                                                 |

Note: This register is updated only when RCVEN=0.

# 12.6 MTICR: MAC TX Interrupt Control Register (0Ch)

| Regis                                                   | ster Off | set:  | 0Ch   |    |       |        |   |      |       |   |   |       |         |   |   |
|---------------------------------------------------------|----------|-------|-------|----|-------|--------|---|------|-------|---|---|-------|---------|---|---|
| Register Name: MTICR: MAC TX Interrupt Control Register |          |       |       |    |       |        |   |      |       |   |   |       |         |   |   |
| Rese                                                    | t Value  | :     | 10000 | า  |       |        |   |      |       |   |   |       |         |   |   |
| 15                                                      | 14       | 13    | 12    | 11 | 10    | 9      | 8 | 7    | 6     | 5 | 4 | 3     | 2       | 1 | 0 |
|                                                         | Rese     | erved |       |    | TXINT | C[3:0] |   | Rese | erved |   |   | TXTIM | ER[5:0] |   |   |

| Bit   | Name             | Attribute | Description                                                                                                                  |
|-------|------------------|-----------|------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Rsvd             | RO        | Reserved                                                                                                                     |
| 11-8  | TXINTC[3:0]      | R/W       | TX Interrupt Control.<br>0: Turn off this function.<br>N: An interrupt is generated after N packets (1~15 packets) are sent. |
| 7-6   | Rsvd             | RO        | Reserved                                                                                                                     |
| 5-0   | TXTIMER<br>[5:0] | R/W       | Wait TX Timer.<br>When timeout, an interrupt is automatically generated.<br>Timer waiting time: (63 + TXTIMER * 64) TX clock |

#### 12.7 MRICR: MAC RX Interrupt Control Register (10h)

| Regi | ster Of<br>ster Na<br>et Value | me:   | 10h<br>MRIC<br>0000l |    | C RX In | terrupt | Control | Regist | er    |   |   |       |         |   |   |
|------|--------------------------------|-------|----------------------|----|---------|---------|---------|--------|-------|---|---|-------|---------|---|---|
| 15   | 14                             | 13    | 12                   | 11 | 10      | 9       | 8       | 7      | 6     | 5 | 4 | 3     | 2       | 1 | 0 |
|      | Rese                           | erved |                      |    | RXINT   | C[3:0]  |         | Rese   | erved |   |   | RXTIM | ER[5:0] |   |   |

| Bit   | Name             | Attribute | Description                                                                                                                      |
|-------|------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Rsvd             | RO        | Reserved                                                                                                                         |
| 11-8  | RXINTC[3:0]      | R/W       | RX Interrupt Control.<br>0: Turn off this function.<br>N: An interrupt is generated after N packets (1~15 packets) are received. |
| 7-6   | Rsvd             | RO        | Reserved                                                                                                                         |
| 5-0   | RXTIMER<br>[5:0] | R/W       | Wait RX Timer.<br>When timeout, an interrupt is automatically generated.<br>Timer waiting time: (63 + RXTIMER * 64) RX clock     |

### 12.8 MTPR: MAC TX Poll Command Register (14h)

| Regis         | ster Off | set: | 14h  |        |        |        |          |        |   |   |   |   |   |   |       |
|---------------|----------|------|------|--------|--------|--------|----------|--------|---|---|---|---|---|---|-------|
| Regis         | ster Nar | ne:  | MTPF | R: MAC | TX Pol | l Comn | nand Re  | gister |   |   |   |   |   |   |       |
| Reset Value : |          |      | 0000 | ۱      |        |        |          |        |   |   |   |   |   |   |       |
| 15            | 14       | 13   | 12   | 11     | 10     | 9      | 8        | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
|               |          |      |      |        |        | I      | Reserved | 1      |   |   |   |   |   |   | тм2тх |

| Bit  | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                     |
|------|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-1 | Rsvd  | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                        |
| 0    | TM2TX | R/W       | Trigger the MAC to Transmit.<br>When Write: Trigger the MAC to check the TX description owner bit. If the owner bit=0, the<br>MAC will standby until the owner bit=1 to start transmission.<br>When Read: TM2TX is current transmission status.<br>When TM2TX= 1, it means the MAC is in transmitting.<br>When TM2TX= 0, it means the transmission is complete. |

#### 12.9 MRBSR: MAC RX Buffer Size Register (18h)

| Regi | ster Off<br>ster Na<br>t Value | me:     |    | 18h<br>MRBSR: MAC RX Buffer Size Register<br>0600h |    |   |   |   |         |    |   |   |   |     |        |
|------|--------------------------------|---------|----|----------------------------------------------------|----|---|---|---|---------|----|---|---|---|-----|--------|
| 15   | 14                             | 13      | 12 | 11                                                 | 10 | 9 | 8 | 7 | 6       | 5  | 4 | 3 | 2 | 1   | 0      |
|      |                                | Reserve | d  |                                                    |    |   |   | R | BSZ[10: | 0] |   |   |   | RBS | Z[1:0] |

Note: This register is updated onely when RCVEN=0.

| Bit   | Name       | Attribute | Description                                                             |
|-------|------------|-----------|-------------------------------------------------------------------------|
| 15-11 | Rsvd       | RO        | Reserved                                                                |
| 10-2  | RBSZ[10:2] | R/W       | RX Buffer Size bits [10:2] for all RX frame data buffer of descriptors. |
| 1-0   | RBSZ[1:0]  | R/W       | RX Buffer Size bits [1:0] must be 00.                                   |

# 12.10 MRDCR: MAC RX Descriptor Control Register (1Ah)

| Register Offset:       1Ah         Register Name:       MRDCR: MAC RX Descriptor Control Register |         |     |      |    |    |   |   |   |   |   |       |          |   |   |   |
|---------------------------------------------------------------------------------------------------|---------|-----|------|----|----|---|---|---|---|---|-------|----------|---|---|---|
| Rese                                                                                              | t Value | ə : | 0000 | h  |    |   |   |   |   |   |       |          |   |   |   |
| 15                                                                                                | 14      | 13  | 12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4     | 3        | 2 | 1 | 0 |
| RXPT[7:0]                                                                                         |         |     |      |    |    |   |   |   |   |   | RXDES | PAN[7:0] |   |   |   |

| Bit  | Name              | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | RXPT[7:0]         | R/W       | RX Descriptor Threshold value.<br>The MAC controller will send TX Pause Frame when the available RX descriptor reaches this threshold value.                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7-0  | RXDESPAN<br>[7:0] | R/W       | RX Descriptor Available Number for flow-control.<br>When the MAC finishes one descriptor data transfer into the RX buffer, the RX<br>descriptor available number will decrease 1 automatically.<br>Use the "IN" instruction to read this register and "OUT" instruction to increase the<br>register value.<br>When RCVEN=0, use the "OUT" instruction to setup the RX descriptor available<br>number.<br>When RCVEN=1, use the "OUT" instruction to increase the RX descriptor available<br>number.<br>This register must be initialized before RCVEN = 1. |

### 12.11 MLSR: MAC Last Status Register (1Ch)

| Regis     | Register Offset: |             |      |       |              |         |        |            |             |     |      |      |            |                   |               |
|-----------|------------------|-------------|------|-------|--------------|---------|--------|------------|-------------|-----|------|------|------------|-------------------|---------------|
| Regis     | Register Name:   |             |      | : MAC | Last St      | atus Re | gister |            |             |     |      |      |            |                   |               |
| Rese      | Reset Value :    |             |      |       |              |         |        |            |             |     |      |      |            |                   |               |
| 15        | 14               | 13          | 12   | 11    | 10           | 9       | 8      | 7          | 6           | 5   | 4    | 3    | 2          | 1                 | 0             |
| RXFO<br>R | LATEC            | EXCE<br>EDC | Rese | rved  | RXDE<br>SPUA | TXFUR   | Rsvd   | PHYE<br>ER | DRIBB<br>LE | OBL | LONG | RUNT | CRCE<br>RR | BROA<br>DCAS<br>T | MULTI<br>CAST |

| Bit   | Name     | Attribute | Description                |
|-------|----------|-----------|----------------------------|
| 15    | RXFOR    | RO        | RX FIFO Over-Run.          |
| 14    | LATEC    | RO        | Transmit Late Collision.   |
| 13    | EXCEEDC  | RO        | Transmit Exceed Collision. |
| 12-11 | Rsvd     | RO        | Reserved.                  |
| 10    | RXDESPUA | RO        | RX Descriptor Unavailable. |
| 9     | TXFUR    | RO        | TX FIFO Under-Run.         |
| 8     | Rsvd     | RO        | Reserved.                  |
| 7     | PHYERR   | RO        | PHY RX Error.              |





| 6 | DRIBBLE   | RO | Dribble Packet.                            |
|---|-----------|----|--------------------------------------------|
| 5 | OBL       | RO | Received Packet Length Over Buffer Length. |
| 4 | LONG      | RO | Received Packets Too Long.                 |
| 3 | RUNT      | RO | Received Packets Too Short.                |
| 2 | CRCERR    | RO | Received Packets with CRC Errors.          |
| 1 | BROADCAST | RO | Received Broadcast Packets.                |
| 0 | MULTICAST | RO | Received Multicast Packets.                |

Note: The MAC last time status is updated by next packet coming.

#### 12.12 MMDIO: MAC MDIO Control Register (20h)

| Register Offset: | 20h                              |
|------------------|----------------------------------|
| Register Name:   | MMDIO: MAC MDIO Control Register |
| Reset Value :    |                                  |

|   | 15   | 14    | 13    | 12 | 11 | 10       | 9  | 8 | 7 | 6        | 5 | 4 | 3 | 2       | 1  | 0 |
|---|------|-------|-------|----|----|----------|----|---|---|----------|---|---|---|---------|----|---|
| F | Rsvd | MIIWR | MIIRD |    | Ρ  | HYAD[4:0 | 0] |   | F | Reserved | þ |   | R | EGAD[4: | 0] |   |

| Bit  | Name       | Attribute | Description                                                                                                              |
|------|------------|-----------|--------------------------------------------------------------------------------------------------------------------------|
| 15   | Rsvd       | RO        | Reserved                                                                                                                 |
| 14   | MIIWR      | R/W       | MDIO Write.<br>Set 1 to write MIIWDATA [15:0] to the MDIO. It will be cleared after the operation is complete.           |
| 13   | MIIRD      | R/W       | MDIO Read.<br>Set 1 to read data from the MDIO into MIIRDATA [15:0]. It will be cleared after the operation is complete. |
| 12-8 | PHYAD[4:0] | R/W       | PHY address.                                                                                                             |
| 7-5  | Rsvd       | RO        | Reserved                                                                                                                 |
| 4-0  | REGAD[4:0] | R/W       | REG address.                                                                                                             |



# 12.13 MMRD: MAC MDIO Read Data Register (24h)

| Regis | ster Off       | set: | 24h  | 24h                               |    |   |   |   |   |   |   |   |   |   |   |  |  |
|-------|----------------|------|------|-----------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|
| Regis | ster Na        | me:  | MMR  | MMRD: MAC MDIO Read Data Register |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Rese  | t Value        | :    | 0000 | n                                 |    |   |   |   |   |   |   |   |   |   |   |  |  |
| 15    | 14             | 13   | 12   | 11                                | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|       | MIIRDATA[15:0] |      |      |                                   |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Bit  | Name           | Attribute | Description                                                               |
|------|----------------|-----------|---------------------------------------------------------------------------|
| 15-0 | MIIRDATA[15:0] | RO        | MII Read Data.<br>The data, read from the MDIO, are put in this register. |

#### 12.14 MMWD: MAC MDIO Write Data Register (28h)

| Regis | ster Off      | iset: | 28h  |       |        |         |         |          |   |   |   |   |   |   |   |
|-------|---------------|-------|------|-------|--------|---------|---------|----------|---|---|---|---|---|---|---|
| Regis | ster Na       | me:   | MMW  | D: MA | C MDIO | Write I | Data Re | egister  |   |   |   |   |   |   |   |
| Rese  | Reset Value : |       | 0000 | ٦     |        |         |         |          |   |   |   |   |   |   |   |
| 4-    |               | 40    | 10   |       | 40     | •       | •       | _        | • | _ |   | • | • |   |   |
| 15    | 14            | 13    | 12   | 11    | 10     | 9       | 8       | 1        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |               |       |      |       |        |         | MIIWDA  | TA[15:0] |   |   |   |   |   |   |   |

| Bit  | Name               | Attribute | Description                                                                                    |
|------|--------------------|-----------|------------------------------------------------------------------------------------------------|
| 15-0 | MIIWDATA<br>[15:0] | R/W       | MII Write Data.<br>The data, intended for being written to the MDIO, are put in this register. |



#### 12.15 MTDSA0: MAC TX Descriptor Start Address 0 (2Ch)

| Regis | ster Off | set: | 2Ch  |                            |         |         |          |         |      |  |  |  |  |  |   |   |
|-------|----------|------|------|----------------------------|---------|---------|----------|---------|------|--|--|--|--|--|---|---|
| Regis | ster Nai | me:  | MTD  | SA0: M                     | AC TX [ | Descrip | tor Star | t Addre | ss 0 |  |  |  |  |  |   |   |
| Rese  | t Value  | :    | 0000 | า                          |         |         |          |         |      |  |  |  |  |  |   |   |
| 15    | 14       | 13   | 12   | 12 11 10 9 8 7 6 5 4 3 2 1 |         |         |          |         |      |  |  |  |  |  | 0 | _ |
|       |          |      |      |                            |         | Т       | DSA[15:  | 1]      |      |  |  |  |  |  | 0 |   |

| Bit  | Name       | Attribute | Description                                                           |
|------|------------|-----------|-----------------------------------------------------------------------|
| 15-1 | TDSA[15:1] | R/W       | TX Descriptor Start Address bit [15:1] that are currently being sent. |
| 0    | 0          | RO        | This bit must be 0.                                                   |

#### Notes:

- 1. This register is initialized only when XMTEN=0.
- 2. The first TX descriptor start address TDSA[31:0] = {MTDSA1[15:0], MTDSA0[15:0]} must be double-word alignment. The

MAC will update the TX descriptor start address when the previous TX is finished.

#### 12.16 MTDSA1: MAC TX Descriptor Start Address 1 (30h)

| 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>TDSA[31:16] | Register Offset:<br>Register Name:<br>Reset Value : |    |    |    | 30h<br>MTDSA1: MAC TX Descriptor Start Address 1<br>0000 |    |   |   |  |   |   |   |   |   |   |   |
|------------------------------------------------------|-----------------------------------------------------|----|----|----|----------------------------------------------------------|----|---|---|--|---|---|---|---|---|---|---|
|                                                      | 15                                                  | 14 | 13 | 12 | 11                                                       | 10 | 9 | - |  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

| Bit  | Name        | Attribute | Description                                                            |
|------|-------------|-----------|------------------------------------------------------------------------|
| 15-0 | TDSA[31:16] | RW        | TX Descriptor Start Address bit [31:16] that are currently being sent. |

Note: This register is initialized only when XMTEN=0.

#### 12.17 MRDSA0: MAC RX Descriptor Start Address 0 (34h)

| -             | Register Offset:<br>Register Name: |    |      | SA0: M | AC RX | Descrip | otor Sta | rt Addre | ess 0 |   |   |   |   |   |   |   |
|---------------|------------------------------------|----|------|--------|-------|---------|----------|----------|-------|---|---|---|---|---|---|---|
| Reset Value : |                                    |    | 0000 |        |       |         |          |          |       |   |   |   |   |   |   |   |
| 15            | 14                                 | 13 | 12   | 11     | 10    | 9       | 8        | 7        | 6     | 5 | 4 | 3 | 2 | 1 | 0 | _ |
|               |                                    |    |      |        |       | R       | DSA[15:  | 1]       |       |   |   |   |   |   | 0 |   |

|   | Bit  | Name       | Attribute | Description                             |
|---|------|------------|-----------|-----------------------------------------|
|   | 15-1 | RDSA[15:1] | R/W       | RX Descriptor Start Address bit [15:1]. |
| ſ | 0    | 0          | RO        | This bit must be 0.                     |

#### Notes:

- 1. This register is initialized only when RCVEN=0.
- 2. The first RX descriptor start address RDSA[31:0] = {MRDSA1[15:0], MRDSA0[15:0]} must be double-word alignment. The MAC will update the RX descriptor start address after the previous RX is finished.

#### 12.18 MRDSA1: MAC RX Descriptor Start Address 1 (38h)

| Regis | Register Offset: |     |      |                                           |    |   |   |   |   |   |   |   |   |   |   |  |
|-------|------------------|-----|------|-------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|
| Regis | ster Na          | me: | MRD  | MRDSA1: MAC RX Descriptor Start Address 1 |    |   |   |   |   |   |   |   |   |   |   |  |
| Rese  | t Value          | :   | 0000 |                                           |    |   |   |   |   |   |   |   |   |   |   |  |
|       |                  |     |      |                                           |    |   |   |   |   |   |   |   |   |   |   |  |
| 15    | 14               | 13  | 12   | 11                                        | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|       | RDSA[31:16]      |     |      |                                           |    |   |   |   |   |   |   |   |   |   |   |  |
|       |                  |     |      |                                           |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name        | Attribute | Description                                        |
|------|-------------|-----------|----------------------------------------------------|
| 15-0 | RDSA[31:16] | RW        | The first RX Descriptor Start Address bit [31:16]. |

Note: This register is initialized only when RCVEN=0.

### 12.19 MISR: MAC INT Status Register (3Ch)

| Regis | ster Off                         | set: | 3Ch   |    |    |         |        |      |      |      |       |      |      |       |       |
|-------|----------------------------------|------|-------|----|----|---------|--------|------|------|------|-------|------|------|-------|-------|
| Regis | Register Name: MISR: MAC INT Sta |      |       |    |    | tus Reg | jister |      |      |      |       |      |      |       |       |
| Rese  | t Value                          | :    | 0000  | h  |    |         |        |      |      |      |       |      |      |       |       |
| 15    | 14                               | 13   | 12    | 11 | 10 | 9       | 8      | 7    | 6    | 5    | 4     | 3    | 2    | 1     | 0     |
|       |                                  | Res  | erved |    |    | PCHG    | ECNTO  | TXEI | Rese | rved | TXEND | RXEI | RXFF | RXDUA | RXEND |

| Bit   | Name  | Attribute | Description                                 |
|-------|-------|-----------|---------------------------------------------|
| 15-10 | Rsvd  | RO        | Reserved.                                   |
| 9     | PCHG  | RC        | PHY Media Changed Interrupt status.         |
| 8     | ECNTO | RC        | Event Counter Overflow Interrupt status.    |
| 7     | TXEI  | RC        | TX Early Interrupt status.                  |
| 6-5   | Rsvd  | RO        | Reserved.                                   |
| 4     | TXEND | RC        | Transmit Packet Finish Interrupt status.    |
| 3     | RXEI  | RC        | RX Early Interrupt status.                  |
| 2     | RXFF  | RC        | RX FIFO Full Interrupt status.              |
| 1     | RXDUA | RC        | RX Descriptor Unavailable Interrupt status. |
| 0     | RXEND | RC        | Receive Packet Finish Interrupt status.     |

Note: RC = Read/Clear

#### 12.20 MIER: MAC INT Enable Register (40h)

| Regis                          | ster Offs | set: | 40h   |    |    |          |            |        |      |      |        |       |       |            |            |
|--------------------------------|-----------|------|-------|----|----|----------|------------|--------|------|------|--------|-------|-------|------------|------------|
| Register Name: MIER: MAC INT E |           |      |       |    |    | able Reg | gister     |        |      |      |        |       |       |            |            |
| Reset                          | t Value   | :    | 0000h |    |    |          |            |        |      |      |        |       |       |            |            |
| 15                             | 14        | 13   | 12    | 11 | 10 | 9        | 8          | 7      | 6    |      | 4      | 3     | 2     | 1          | 0          |
|                                |           | Rese | rved  |    |    | MCHGE    | ECNTO<br>E | TXEIEN | Rese | rved | TXENDE | RXEIE | RXFFE | RXDNA<br>E | RXEND<br>E |

| Bit   | Name   | Attribute | Description                                                                                          |
|-------|--------|-----------|------------------------------------------------------------------------------------------------------|
| 15-10 | Rsvd   | RO        | Reserved.                                                                                            |
| 9     | MCHGE  | RW        | PHY Link Changed Interrupt Enable<br>Set 1: Enable the MAC to generate interrupts to the CPU.        |
| 8     | ECNTOE | R/W       | Event Counter Overflow Interrupt Enable.<br>Set 1: Enable the MAC to generate interrupts to the CPU. |
| 7     | TXEIEN | R/W       | TX Early Interrupt Enable.<br>Set 1: Enable the MAC to generate interrupts to the CPU.               |
| 6-5   | Rsvd   | RO        | Reserved.                                                                                            |



| 4 | TXENDE | R/W | Transmit Packet Finish Interrupt Enable.<br>Set 1: Enable the MAC to generate interrupts to the CPU.    |
|---|--------|-----|---------------------------------------------------------------------------------------------------------|
| 3 | RXEIE  | R/W | RX Early Interrupt Enable.<br>Set 1: Enable the MAC to generate interrupts to the CPU.                  |
| 2 | RXFFE  | R/W | RX FIFO Full Interrupt Enable.<br>Set 1: Enable the MAC to generate interrupts to the CPU.              |
| 1 | RXDNAE | R/W | RX Descriptor Unavailable Interrupt Enable.<br>Set 1: Enable the MAC to generate interrupts to the CPU. |
| 0 | RXENDE | R/W | Receive Packet Finish Interrupt Enable.<br>Set 1: Enable the MAC to generate interrupts to the CPU.     |

#### 12.21 MECISR: MAC Event Counter INT Status Register (44h)

| R | egist          | ter Offs | set: | 44h  |                                               |      |       |       |       |      |        |        |        |      |      |       |  |
|---|----------------|----------|------|------|-----------------------------------------------|------|-------|-------|-------|------|--------|--------|--------|------|------|-------|--|
| R | Register Name: |          |      |      | MECISR: MAC Event Counter INT Status Register |      |       |       |       |      |        |        |        |      |      |       |  |
| R | Reset Value :  |          |      | 0000 | n                                             |      |       |       |       |      |        |        |        |      |      |       |  |
| 1 | 15             | 14       | 13   | 12   | 11                                            | 10   | 9     | 8     | 7     | 6    | 5      | 4      | 3      | 2    | 1    | 0     |  |
|   |                | Reser    | ved  |      | TDPCI                                         | LCCI | STPCI | RFFCI | RDUCI | Rsvd | LONGCI | RUNTCI | CRCECI | BCCI | MCCI | SRPCI |  |

The correspond bit in the Event Counter INT Status Register will be set when the MSB bit in the related Event Counter register is set to 1. Reading the Event Counter register will clear the corresponding bits. Those event counters will keep increasing until reaching 255 or 65535.

| Bit   | Name   | Attribute | Description                                                        |
|-------|--------|-----------|--------------------------------------------------------------------|
| 15-12 | Rsvd   | RO        | Reserved.                                                          |
| 11    | TDPCI  | RO        | TX FIFO under-run Dropped Packet Counter Interrupt status.         |
| 10    | LCCI   | RO        | TX Late Collision Counter Interrupt status.                        |
| 9     | STPCI  | RO        | TX Successfully Package Counter Interrupt status.                  |
| 8     | RFFCI  | RO        | RX FIFO Full Counter Interrupt status.                             |
| 7     | RDUCI  | RO        | RX Descriptor Unavailable Dropped Packet Counter Interrupt status. |
| 6     | Rsvd   | RO        | Reserved.                                                          |
| 5     | LONGCI | RO        | RX Long Packet Counter Interrupt status.                           |
| 4     | RUNTCI | RO        | RX Runt Packet Counter Interrupt status.                           |
| 3     | CRCECI | RO        | RX CRC Error Packet Counter Interrupt status.                      |
| 2     | BCCI   | RO        | RX Broadcast Packet Counter Interrupt status.                      |
| 1     | MCCI   | RO        | RX Multicast Packet Counter Interrupt status.                      |
| 0     | SRPCI  | RO        | RX Successfully Packet Counter Interrupt status.                   |

#### 12.22 MECIER: MAC Event Counter INT Enable Register (48h)

| Regi | ster Off | set:  | 48h  | 48h                                           |       |        |        |        |      |         |         |         |       |       |        |  |
|------|----------|-------|------|-----------------------------------------------|-------|--------|--------|--------|------|---------|---------|---------|-------|-------|--------|--|
| Regi | ster Na  | me:   | MECI | MECIER: MAC Event Counter INT Enable Register |       |        |        |        |      |         |         |         |       |       |        |  |
| Rese | et Value | :     | 0000 | ו                                             |       |        |        |        |      |         |         |         |       |       |        |  |
| 15   | 14       | 13    | 12   | 11                                            | 10    | 9      | 8      | 7      | 6    | 5       | 4       | 3       | 2     | 1     | 0      |  |
|      | Rese     | erved |      | TDPCIE                                        | LCCIE | STPCIE | RFFCIE | RDUCIE | Rsvd | LONGCIE | RUNTCIE | CRCECIE | BCCIE | MCCIE | SRPCIE |  |

| Bit   | Name    | Attribute | Description                                                        |
|-------|---------|-----------|--------------------------------------------------------------------|
| 15-12 | Rsvd    | RO        | Reserved.                                                          |
| 11    | TDPCIE  | RW        | TX FIFO under-run Dropped Packet Counter Interrupt Enable          |
| 10    | LCCIE   | R/W       | TX Late Collision Counter Interrupt Enable.                        |
| 9     | STPCIE  | R/W       | TX Successfully Packet Counter Interrupt Enable.                   |
| 8     | RFFCIE  | R/W       | RX FIFO Full Counter Interrupt Enable.                             |
| 7     | RDUCIE  | R/W       | RX Descriptor Unavailable Dropped Packet Counter Interrupt Enable. |
| 6     | Rsvd    | RO        | Reserved.                                                          |
| 5     | LONGCIE | R/W       | RX Long Packet Counter Interrupt Enable.                           |
| 4     | RUNTCIE | R/W       | RX Runt Packet Counter Interrupt Enable.                           |
| 3     | CRCECIE | R/W       | RX CRC Error Packet Counter Interrupt Enable.                      |
| 2     | BCCIE   | R/W       | RX Broadcast Packet Counter Interrupt Enable.                      |
| 1     | MCCIE   | R/W       | RX Multicast Packet Counter Interrupt Enable.                      |
| 0     | SRPCIE  | R/W       | RX Successfully Packet Counter Interrupt Enable.                   |

Note: Reading any one of all the following event counter registers will clear its value to 0.

# 12.23 MRCNT: MAC Successfully Received Packet Counter Register (50h)

| Regis | ster Off<br>ster Nar<br>t Value | ne: |    | 50h<br>MRCNT: MAC Successfully Received Packet Counter Register<br>0000h |    |   |       |          |   |   |   |   |   |   |          |  |
|-------|---------------------------------|-----|----|--------------------------------------------------------------------------|----|---|-------|----------|---|---|---|---|---|---|----------|--|
| 15    | 14                              | 13  | 12 | 11                                                                       | 10 | 9 | 8     | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0        |  |
|       |                                 |     |    |                                                                          |    |   | SRPCN | NT[15:0] |   |   |   |   |   |   |          |  |
|       |                                 |     |    |                                                                          |    |   |       |          |   |   |   |   |   |   | <b>_</b> |  |

| Bit  | Name         | Attribute | Description                          |
|------|--------------|-----------|--------------------------------------|
| 15-0 | SRPCNT[15:0] | RC        | Successfully Received Packet Counter |

# 12.24 MECNT0: MAC Event Counter 0 Register (52h)

| Regis | ster Off | set: | 52h   |         |        |         |          |         |   |   |      |         |   |   |   |
|-------|----------|------|-------|---------|--------|---------|----------|---------|---|---|------|---------|---|---|---|
| Regis | ster Na  | me:  | MEC   | NT0: M  | AC Eve | nt Cour | nter 0 R | egister |   |   |      |         |   |   |   |
| Rese  | t Value  | :    | 0000ł | n       |        |         |          |         |   |   |      |         |   |   |   |
| 15    | 14       | 13   | 12    | 11      | 10     | 9       | 8        | 7       | 6 | 5 | 4    | 3       | 2 | 1 | 0 |
|       |          |      | BCCN  | IT[7:0] |        |         |          |         |   |   | MCCN | IT[7:0] |   |   |   |

| Bit  | Name       | Attribute | Description                       |
|------|------------|-----------|-----------------------------------|
| 15-8 | BCCNT[7:0] | RC        | Receive Broadcast Packet Counter. |
| 7-0  | MCCNT[7:0] | RC        | Receive Multicast Packet Counter. |

Note: RC = Read/Clear

#### 12.25 MECNT1: MAC Event Counter 1 Register (54h)

| Regis | ster Off<br>ster Na<br>t Value | me: |      | 54h<br>MECNT1: MAC Event Counter 1 Register<br>0000h |    |   |   |   |   |   |      |          |   |   |   |
|-------|--------------------------------|-----|------|------------------------------------------------------|----|---|---|---|---|---|------|----------|---|---|---|
| 15    | 14                             | 13  | 12   | 11                                                   | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3        | 2 | 1 | 0 |
|       |                                |     | RUNC | NT[7:0]                                              |    |   |   |   |   |   | CRCE | CNT[7:0] |   |   |   |

| Bit  | Name         | Attribute | Description                       |
|------|--------------|-----------|-----------------------------------|
| 15-8 | RUNCNT[7:0]  | RC        | Receive Run Packet Counter.       |
| 7-0  | CRCECNT[7:0] | RC        | Receive CRC Error Packet Counter. |



#### 12.26 MECNT2: MAC Event Counter 2 Register (56h)

| Regi | ster Off | set: | 56h  |                                      |    |   |   |              |   |   |   |   |   |   |   |  |  |
|------|----------|------|------|--------------------------------------|----|---|---|--------------|---|---|---|---|---|---|---|--|--|
| Regi | ster Na  | me:  | MEC  | MECNT2: MAC Event Counter 2 Register |    |   |   |              |   |   |   |   |   |   |   |  |  |
| Rese | et Value | :    | 0000 | h                                    |    |   |   |              |   |   |   |   |   |   |   |  |  |
| 15   | 14       | 13   | 12   | 11                                   | 10 | 9 | 8 | 7            | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|      |          |      | Rese | erved                                |    |   |   | LONGCNT[7:0] |   |   |   |   |   |   |   |  |  |

| Bit  | Name         | Attribute | Description                  |
|------|--------------|-----------|------------------------------|
| 15-8 | Rsvd         | RC        | Reserved                     |
| 7-0  | LONGCNT[7:0] | RC        | Receive Long Packet Counter. |

*Note: RC* = *Read/Clear* 

#### 12.27 MCENT3: MAC Event Counter 3 Register (58h)

| Register Offset: 58h |         |     |                                      |         |    |   |   |   |   |   |       |         |   |   |   |  |
|----------------------|---------|-----|--------------------------------------|---------|----|---|---|---|---|---|-------|---------|---|---|---|--|
| Regis                | ter Na  | me: | MECNT3: MAC Event Counter 3 Register |         |    |   |   |   |   |   |       |         |   |   |   |  |
| Reset                | t Value | :   | 0000                                 | ſ       |    |   |   |   |   |   |       |         |   |   |   |  |
| 15                   | 14      | 13  | 12                                   | 11      | 10 | 9 | 8 | 7 | 6 | 5 | 4     | 3       | 2 | 1 | 0 |  |
|                      |         |     | RFFC                                 | NT[7:0] |    |   |   |   |   |   | RDUVC | NT[7:0] |   |   |   |  |

| Bit  | Name         | Attribute | Description                                    |
|------|--------------|-----------|------------------------------------------------|
| 15-8 | RFFCNT[7:0]  | RC        | RX FIFO Full Packet Counter.                   |
| 7-0  | RDUVCNT[7:0] | RC        | RX Descriptor Unavailable Packet lost Counter. |

# 12.28 MTCNT: MAC Successfully Transmit Packet Counter Register (5Ah)

| Regis | ster Off | set: | 5Ah  |        |         |          |        |          |        |          |        |   |   |   |   |
|-------|----------|------|------|--------|---------|----------|--------|----------|--------|----------|--------|---|---|---|---|
| Regis | ster Na  | me:  | MTC  | NT: MA | C Succe | essfully | Transn | nit Pack | et Cou | nter Reg | gister |   |   |   |   |
| Rese  | t Value  | :    | 0000 | ٦      |         |          |        |          |        |          |        |   |   |   |   |
|       |          |      |      |        |         |          |        |          |        |          |        |   |   |   |   |
| 15    | 14       | 13   | 12   | 11     | 10      | 9        | 8      | 7        | 6      | 5        | 4      | 3 | 2 | 1 | 0 |
|       |          |      |      |        |         |          | STPCN  | NT[15:0] |        |          |        |   |   |   |   |

| Bit  | Name         | Attribute | Description                              |
|------|--------------|-----------|------------------------------------------|
| 15-0 | STPCNT[15:0] | RC        | Successfully Transmitted Packet Counter. |

*Note: RC* = *Read/Clear* 

#### 12.29 MCENT4: MAC Event Counter 4 Register (5Ch)

| Regis | ster Off<br>ster Na<br>t Value | me: | 5Ch<br>MECI<br>00001 |         | AC Eve | nt Cour | nter 4 R | egister |   |   |      |         |   |   |   |
|-------|--------------------------------|-----|----------------------|---------|--------|---------|----------|---------|---|---|------|---------|---|---|---|
| 15    | 14                             | 13  | 12                   | 11      | 10     | 9       | 8        | 7       | 6 | 5 | 4    | 3       | 2 | 1 | 0 |
|       |                                |     | TDPCI                | NT[7:0] |        |         |          |         |   |   | LCCN | IT[7:0] |   |   |   |

| Bit  | Name        | Attribute | Description                                     |
|------|-------------|-----------|-------------------------------------------------|
| 15-8 | TDPCNT[7:0] | RC        | TX Dropped Packet Counter by TX FIFO under-run. |
| 7-0  | LCCNT[7:0]  | RC        | TX Late Collision Packet Counter.               |



#### 12.30 MPCNT: MAC Pause Frame Counter Register (5Eh)

| Regi | ster Off | set: | 5Eh   |         |         |         |         |         |      |   |       |         |   |   |   |
|------|----------|------|-------|---------|---------|---------|---------|---------|------|---|-------|---------|---|---|---|
| Regi | ster Na  | me:  | MPC   | NT: MA  | C Pause | e Frame | e Count | er Regi | ster |   |       |         |   |   |   |
| Rese | t Value  | :    | 0000  | n       |         |         |         |         |      |   |       |         |   |   |   |
| 15   | 14       | 13   | 12    | 11      | 10      | 9       | 8       | 7       | 6    | 5 | 4     | 3       | 2 | 1 | 0 |
|      |          |      | TXPFC | NT[7:0] |         |         |         |         |      |   | RXPFC | NT[7:0] |   |   |   |

| Bit  | Name         | Attribute | Description                      |
|------|--------------|-----------|----------------------------------|
| 15-8 | TXPFCNT[7:0] | RC        | Transmitted Pause Frame Counter. |
| 7-0  | RXPFCNT[7:0] | RC        | Received Pause Frame Counter.    |

Note: RC = Read/Clear

#### 12.31 MAR0 ~3: MAC Hash Table Word 0 ~3 (60h, 62h, 64h, 66h)

| Regis | ster Off | set: | 60h  |        |        |        |       |          |   |   |   |   |   |   |   |
|-------|----------|------|------|--------|--------|--------|-------|----------|---|---|---|---|---|---|---|
| Regis | ster Na  | me:  | MAR  | 0: MAC | Hash T | able W | ord 0 |          |   |   |   |   |   |   |   |
| Reset | t Value  | :    | 0000 | h      |        |        |       |          |   |   |   |   |   |   |   |
|       |          |      | 10   |        | 10     |        |       | _        |   | _ |   |   |   |   |   |
| 15    | 14       | 13   | 12   | 11     | 10     | 9      | 8     | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |          |      |      |        |        |        | MHMAR | R0[15:0] |   |   |   |   |   |   |   |

| Bi  | Name           | Attribute | Description        |
|-----|----------------|-----------|--------------------|
| 15- | 0 MHMAR0[15:0] | R/W       | Hash Table Word 0. |

| Regis | ter Off | set: | 62h  |        |        |        |       |          |   |   |   |   |   |   |   |
|-------|---------|------|------|--------|--------|--------|-------|----------|---|---|---|---|---|---|---|
| Regis | ter Na  | me:  | MAR  | 1: MAC | Hash T | able W | ord 1 |          |   |   |   |   |   |   |   |
| Reset | t Value | :    | 0000 | n      |        |        |       |          |   |   |   |   |   |   |   |
| 15    | 14      | 10   | 10   | 11     | 10     | 9      | 0     | 7        | c | 5 | 4 | 2 | 2 | 1 | 0 |
| 15    | 14      | 13   | 12   | 11     | 10     | 9      | 0     | 1        | 0 | Э | 4 | 3 | 2 | I | 0 |
|       |         |      |      |        |        |        | MHMA  | R1[15:0] |   |   |   |   |   |   |   |
|       |         |      |      |        |        |        |       |          |   |   |   |   |   |   |   |

| Bit  | Name         | Attribute | Description        |
|------|--------------|-----------|--------------------|
| 15-0 | MHMAR1[15:0] | R/W       | Hash Table Word 1. |

# **RDC**<sup>®</sup> RISC DSP Communication

| Regis | ster Off<br>ster Na<br>t Value | me: | 64h<br>MAR:<br>0000 | -  | Hash T | able W | ord 2 |          |   |   |   |   |   |   |   |   |
|-------|--------------------------------|-----|---------------------|----|--------|--------|-------|----------|---|---|---|---|---|---|---|---|
| 15    | 14                             | 13  | 12                  | 11 | 10     | 9      | 8     | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ |
|       |                                |     |                     |    |        |        | MHMAI | R2[15:0] |   |   |   |   |   |   |   |   |

| Bit  | Name         | Attribute | Description        |
|------|--------------|-----------|--------------------|
| 15-0 | MHMAR2[15:0] | R/W       | Hash Table Word 2. |

| Register Name:<br>Reset Value : | MAR3<br>0000h | -  | Hash T | able W | ord 3 |          |   |   |   |   |   |   |   |
|---------------------------------|---------------|----|--------|--------|-------|----------|---|---|---|---|---|---|---|
| 15 14 13                        | 12            | 11 | 10     | 9      | 8     | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                 |               |    |        |        | MHMA  | R3[15:0] |   |   |   |   |   |   |   |

| Bit  | Name         | Attribute | Description        |
|------|--------------|-----------|--------------------|
| 15-0 | MHMAR3[15:0] | R/W       | Hash Table Word 3. |

#### 12.32 MID0 (68h, 6Ah, 6Ch)

| Register Offset: | 68h                          |
|------------------|------------------------------|
| Register Name:   | MID0                         |
| Reset Value :    | 0000h                        |
| 15 14 13         | 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|                  | MID0L[15:0]                  |
| Register Offset: | 6Ah                          |
| Register Name:   | MID0                         |
| Reset Value :    |                              |
| 15 14 13         | 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|                  | MID0M[15:0]                  |
| Register Offset: | 6Ch                          |
| Register Name:   | MID0                         |
| Reset Value :    | 0000h                        |
| 15 14 13         | 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|                  | MID0H[15:0]                  |

The MAC/Multicast address MID0[47:0] = {MID0H[15:0], MID0M[15:0], MID0L[15:0]};

For example: The MAC address is 01:02:03:04:05:06; the contents for MID are:

MID0L[15:0] = 0201h

MID0M[15:0] = 0403h

MID0H[15:0] = 0605h

Bit 15-0: MID0L[15:0], the two bytes in the first line of the MAC/Multicast address.

Bit 15-0: MID0M[15:0], the two bytes in the second line of the MAC/Multicast address.

Bit 15-0: MID0H[15:0], the two bytes in the last line of the MAC/Multicast address.

#### 12.33 MID1 (70h, 72h, 74h)

| Regis | ster Offs<br>ster Nan<br>t Value |      | 70h<br>MID1<br>0000h |    |    |   |       |         |   |   |   |   |   |   |   |
|-------|----------------------------------|------|----------------------|----|----|---|-------|---------|---|---|---|---|---|---|---|
| 15    | 14                               | 13   | 12                   | 11 | 10 | 9 | 8     | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                                  |      |                      |    |    |   | MID1L | [15:0]  |   |   |   |   |   |   |   |
| Regis | ster Offs                        | set: | 72h                  |    |    |   |       |         |   |   |   |   |   |   |   |
| Regis | ster Nan                         | ne:  | MID1                 |    |    |   |       |         |   |   |   |   |   |   |   |
| Rese  | t Value                          | :    | 0000h                |    |    |   |       |         |   |   |   |   |   |   |   |
| 15    | 14                               | 13   | 12                   | 11 | 10 | 9 | 8     | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                                  |      |                      |    |    |   | MID1N | 1[15:0] |   |   |   |   |   |   |   |
| Regis | ster Offs                        | set: | 74h                  |    |    |   |       |         |   |   |   |   |   |   |   |
| Regis | ster Nar                         | ne:  | MID1                 |    |    |   |       |         |   |   |   |   |   |   |   |
| Rese  | t Value                          | :    | 0000h                |    |    |   |       |         |   |   |   |   |   |   |   |
| 15    | 14                               | 13   | 12                   | 11 | 10 | 9 | 8     | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                                  |      |                      |    |    |   | MID1F | I[15:0] |   |   |   |   |   |   |   |

The MAC/Multicast address MID1[47:0] = {MID1H[15:0], MID1M[15:0], MID1L[15:0]};

Bit 15-0: MID1L[15:0], the two bytes in the first line of the MAC/Multicast address.

Bit 15-0: MID1M[15:0], the two bytes in the second line of the MAC/Multicast address.

Bit 15-0: MID1H[15:0], the two bytes in the last line of the MAC/Multicast address.

# 12.34 MID2 (78h, 7Ah, 7Ch)

| Register Offset: | 78h    |      |         |      |   |   |   |   |   |   |
|------------------|--------|------|---------|------|---|---|---|---|---|---|
| Register Name:   | MID2   |      |         |      |   |   |   |   |   |   |
| Reset Value :    | 0000h  |      |         |      |   |   |   |   |   |   |
| 15 14 13         | 12 11  | 10 9 | 8       | 7 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|                  |        |      | MID2L[1 | 5:0] |   |   |   |   |   |   |
| Register Offset: | 7Ah    |      |         |      |   |   |   |   |   |   |
| Register Name:   | MID2   |      |         |      |   |   |   |   |   |   |
| Reset Value :    | 0000h  |      |         |      |   |   |   |   |   |   |
| Reset value .    | 000011 |      |         |      |   |   |   |   |   |   |
| 15 14 13         | 12 11  | 10 9 | 8       | 7 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|                  |        |      | MID2M[1 | 5:0] |   |   |   |   |   |   |
|                  |        |      |         |      |   |   |   |   |   |   |
| Register Offset: | 7Ch    |      |         |      |   |   |   |   |   |   |
| Register Name:   | MID2   |      |         |      |   |   |   |   |   |   |
| Reset Value :    | 0000h  |      |         |      |   |   |   |   |   |   |
| 15 14 13         | 12 11  | 10 9 | 8       | 7 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|                  |        |      | MID2H[1 | 5:0] |   |   |   |   |   |   |

The MAC/Multicast address MID2[47:0] = {MID2H[15:0], MID2M[15:0], MID2L[15:0]};

Bit 15-0: MID2L[15:0], the two bytes in the first line of the MAC/Multicast address.

Bit 15-0: MID2M[15:0], the two bytes in the second line of the MAC/Multicast address.

Bit 15-0: MID2H[15:0], the two bytes in the last line of the MAC/Multicast address.

#### 12.35 MID3 (80h, 82h, 84h)

| Regis | ster Offs<br>ster Nar<br>t Value |      | 80h<br>MID3<br>0000h |    |    |   |       |         |   |   |   |   |   |   |   |
|-------|----------------------------------|------|----------------------|----|----|---|-------|---------|---|---|---|---|---|---|---|
| 15    | 14                               | 13   | 12                   | 11 | 10 | 9 | 8     | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                                  |      |                      |    |    |   | MID3L | .[15:0] |   |   |   |   |   |   |   |
| Regis | ster Off                         | set: | 82h                  |    |    |   |       |         |   |   |   |   |   |   |   |
| Regis | ster Nar                         | ne:  | MID3                 |    |    |   |       |         |   |   |   |   |   |   |   |
| Rese  | t Value                          | :    | 0000h                |    |    |   |       |         |   |   |   |   |   |   |   |
| 15    | 14                               | 13   | 12                   | 11 | 10 | 9 | 8     | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                                  |      |                      |    |    |   | MID3N | 1[15:0] |   |   |   |   |   |   |   |
| Regis | ster Off                         | set: | 84h                  |    |    |   |       |         |   |   |   |   |   |   |   |
|       | ster Nar                         |      | MID3                 |    |    |   |       |         |   |   |   |   |   |   |   |
|       | t Value                          | :    | 0000h                |    |    |   |       |         |   |   |   |   |   |   |   |
| 15    | 14                               | 13   | 12                   | 11 | 10 | 9 | 8     | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                                  |      |                      |    |    |   | MID3F | I[15:0] |   |   |   |   |   |   |   |

The MAC/Multicast address MID3[47:0] = {MID3H[15:0], MID3M[15:0], MID3L[15:0]};

Bit 15-0: MID3L[15:0], the two bytes in the first line of the MAC/Multicast address.

Bit 15-0: MID3M[15:0], the two bytes in the second line of the MAC/Multicast address.

Bit 15-0: MID3H[15:0], the two bytes in the last line of the MAC/Multicast address.

# 12.36 MPSCCR: MAC PHY Status Change Configuration Register (88h)

| Regis | ter Off | set:  | 88h   |        |          |        |       |          |         |         |     |   |    |         |      |
|-------|---------|-------|-------|--------|----------|--------|-------|----------|---------|---------|-----|---|----|---------|------|
| Regis | ter Nar | ne:   | MPSC  | CCR: M | AC PH    | Status | Chang | je Confi | guratio | n Regis | ter |   |    |         |      |
| Reset | Value   | :     | 10000 | I      |          |        |       |          |         |         |     |   |    |         |      |
| 15    | 14      | 13    | 12    | 11     | 10       | 9      | 8     | 7        | 6       | 5       | 4   | 3 | 2  | 1       | 0    |
| EN    | Rese    | erved |       | Pł     | HYAD[4:0 | )]     |       |          | R       | eserved |     |   | ΤN | IRDIV[2 | ::0] |

| Bit  | Name        | Attribute | Description                                                                                                                                                                                                                            |
|------|-------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | EN          | R/W       | PHY Status Change Enable                                                                                                                                                                                                               |
| 12-8 | PHYAD[4:0]  | R/W       | PHY Address                                                                                                                                                                                                                            |
| 7-3  | Rsvd        | RO        | Reserved                                                                                                                                                                                                                               |
| 2-0  | TMRDIV[2:0] | R/W       | Timer Divider<br>The timer will time-out every host-clock*160*2 <sup>(16-TMRDIV)</sup> . If both PHY status change<br>functions in MAC0 and MAC1 are enabled, the value of TMRDIV[2:0] belonged to<br>MAC0 and MAC1 must be set alike. |

#### 12.37 MPSR: MAC PHY Status Register (8Ah)

| Regis | ter Off | set: | 8Ah  | 8Ah        |       |         |         |   |   |   |   |   |   |   |   |  |
|-------|---------|------|------|------------|-------|---------|---------|---|---|---|---|---|---|---|---|--|
| Regis | ter Nar | ne:  | MPSF | R: MAC     | PHY S | tatus R | egister |   |   |   |   |   |   |   |   |  |
| Reset | Value   | :    | 0000 | h          |       |         |         |   |   |   |   |   |   |   |   |  |
| 15    | 14      | 13   | 12   | 11         | 10    | 9       | 8       | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|       |         |      |      | MPSR[15:0] |       |         |         |   |   |   |   |   |   |   |   |  |
|       |         |      |      |            |       |         |         |   |   |   |   |   |   |   |   |  |

| Bit  | Name | Attribute | Description         |
|------|------|-----------|---------------------|
| 15-0 | MPSR | RO        | PHY Status Register |

# 12.38 MACID: MAC Identifier Register

| Regis | ster Off | set: | BEh  |        |           |         |       |     |   |   |   |   |   |   |   |
|-------|----------|------|------|--------|-----------|---------|-------|-----|---|---|---|---|---|---|---|
| Regis | ster Na  | me:  | MAC  | D: MAC | C Identif | ier Reg | ister |     |   |   |   |   |   |   |   |
| Rese  | t Value  | :    | 6040 | า      |           |         |       |     |   |   |   |   |   |   |   |
| 15    | 14       | 13   | 12   | 11     | 10        | 9       | 8     | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |          |      |      |        |           |         | MAG   | CID |   |   |   |   |   |   |   |

| Bit  | Name   | Attribute | Description                                                      |
|------|--------|-----------|------------------------------------------------------------------|
| 15-0 | MAC ID | RO        | This register contains a 16-bit value assigned to the R8610 MAC. |

# 13. USB2.0 Host Controller

#### 13.1 Features

The USB2.0 Host Controller is a two-port host controller which contains one OHCI host controller compliant with OpenHCI standard developed by Compaq, Microsoft and National Semiconductor and one EHCI host controller compliant with EHCI1.0 specification developed by Intel. Features of the USB2.0 host controller are described as below:

#### 13.1.1 USB1.1 Host Controller

- Supports all full-speed (12MHz) and low-speed (1.5MHz) devices compliant with the "USB Specification" version1.0.
- Supports four transfers: control, bulk, interrupt and isochronous transfers.
- Supports up to 127 devices at the same time.
- Contains one 64-byte FIFO.

#### 13.1.2 USB2.0 Host Controller

- Supports all high-speed (480MHz) devices compliant with the "USB Specification" version2.0.
- Supports four transfers: control, bulk, interrupt and isochronous transfers.
- Supports split transaction for USB2.0 Hub plugged with USB1.1 devices.
- Supports up to 127 devices at the same time.
- Contains two 1K-byte FIFO, one for TX and one for RX.

#### 13.2 General Descriptions

The USB 2.0 Host Controller includes one high-speed mode host controller and one USB 1.1 host controller (OHCI). The high-speed host controller implements an EHCI interface. It is used for all high-speed communications to high-speed-mode devices connected to the root ports of the USB 2.0 host controller. It allows communications to full- and low-speed devices connected to the root ports of the USB 2.0 host controller to be provided by the USB 1.1 host controller.

This architecture allows the USB 2.0 host controller to provide USB functionality as long as there is at least USB 1.1 software support in the resident operating system. Full USB 2.0 functionality is delivered when both USB 1.1 and EHCI software is available in the operating system. The port transceiver routing logic is key to delivering this flexible operating environment. The state of the routing logic initially depends on whether software has configured the EHCI controller. Once the EHCD driver has configured the EHCI controller, it can specifically release the transceiver to the companion host controller port register if the attached device is not a high-speed device. When the operating system does not include support for the EHCI controller, the ports are default-routed to the USB1.1 host controllers and the existing USB support for Full- and Low-speed devices remains. The USB1.1 host controllers always manage Full- and Low-speed USB devices connected to the root ports.

High-speed devices are always routed to and controlled by the EHCI host controller (eHC). When running and configured, the eHC is the default *owner* of all the root ports. The eHC and its driver initially detect all devices attached. It has additional control bits visible in each port register to manage the routing logic. For example: if the attached device is not a high-speed device, the eHC driver releases ownership of the port (and thus control the device) to a companion host controller. For that port, enumeration starts over from the initial attached detect point and the device is enumerated under the USB1.1 host controller. Otherwise, the eHC retains ownership of the port and the device completes enumeration under the eHC.



#### 13.3 Functional Block Diagram



#### 13.4 Functional Block Descriptions

#### 13.4.1 DMA/Master Unit

The Bus Master Controller provides the PCI Interface (PCI IF) with the signals necessary to perform PCI cycles on behalf of the Data Buffer Engine (not shown in the block diagram) or List Processor. These signals include the address of the first byte in the transfer, the size of the transfer in bytes, the direction of the transfer, and the data for write cycles. The PCI IF will carry out the appropriate PCI cycle based on the provided information. In addition, there are three control signals across the interface: a request signal from the Bus Master Controller, a cycle active and a data ready signal from the PCI Controller. The Bus Master Controller requests access when it is necessary to transfer a cycle on the PCI Bus. When access is granted, the PCI IF asserts the cycle active signal which remains asserted until the cycle completes. The PCI IF asserts the data ready signal for one PCI period for each Dword transfer across the interface. On a write, the data ready signal indicates that the PCI IF has consumed the Dword presented by the Bus Master Controller. On a read, the data ready signal indicates that a valid Dword is present on the PCI read data bus.

The Bus Master Controller maintains the address of the next PCI cycle to be requested. The address is initialized with a value from the List Processor when it initiates a request. The address is updated after each burst transfer completes. This is necessary for data transfers that require more than a single burst cycle.

#### 13.4.2 List Processor

The List Processor manages the data structures from the Host Controller Driver and coordinates all activities within the Host Controller. The List Processor has three main control sections that operate in a hierarchical fashion.

- List Control -- This is at the highest level of the control hierarchy. It schedules which type of list (Isochronous, Interrupt, Bulk or Control) is processed.
- Endpoint Descriptor (Queue Head Descriptor) Control -- This is at the middle level of the control hierarchy. Once the List Control detected a valid list to process, this controls the loading, processing of the Transfer Descriptor, and write-back of the Endpoint Descriptor for the current list.
- Transfer Descriptor (Queue Head Transfer Descriptor, iTD Descriptor, SiTD Descriptor) Control -- This is at the lowest level of the control hierarchy. Once the Endpoint Descriptor (QH) Control loaded a valid ED (QH), this controls the loading, processing of the data transfer, and write-back of the Transfer Descriptor (qTD, ...) for the current ED (QH).

#### 13.4.3 Host Parallel Interface Engine (HPIE) or Host Serial Interface Engine (HSIE)

The HPIE is for USB2.0 and the HSIE is for USB1.1.

The HPIE (HSIE) is responsible for managing all transactions to the USB. It controls the bus protocol, packet generation/extraction, data parallel-to-serial conversion, CRC coding, bit stuffing, and NRZI encoding. All transactions on the USB are requested by the List Processor and Frame Manager (not shown in the block diagram). After the List Processor retrieves all information necessary to initiate communication to a USB device, it generates a request to the HPIE (HSIE) accompanied by endpoint specific control information required to generate proper protocol and packet formats to establish the desired communication pipe. The data buffer provides a data path for the data packets and controls the number of bytes transferred.

#### 13.4.4 Port Router

The USB 2.0 host controller is comprised of one high-speed host controller which implements the EHCI programming interface and one OHCI host controllers. This configuration is used to deliver the required full USB 2.0-defined port capability; e.g. low-, full-, and high-speed capability for every port. The figure shown below illustrates a simple block diagram of the port routing logic and its relationship to the high-speed and OHCI host controllers within a USB 2.0 host controller.



There exists one transceiver per physical port and each host controller module has its own port status and control registers. The EHCI controller has port status and control registers for every port. The OHCI host controller has only the port control and status registers it is required to operate. Each transceiver can be controlled by either the EHCI host controller or the OHCI host controlled. Routing logic lies between the transceiver and the port status and control registers. The port routing logic is controlled from signals originating in the EHCI host controller. The EHCI host controller has a *global* routing policy control field and per-port *ownership* control fields. The *Configured Flag* (*CF*) bit (defined in OP register of EHCI) is the global routing policy control. At power-on or reset, the default routing policy is to the companion controllers (if they exist). In general, when the EHCI owns the ports, the companion host controllers' port registers do not see a connect indication from the transceiver. Similarly, when the OHCI host controller owns a port, the EHCI controller's port registers do not see a connect indication from the transceiver.

#### 13.4.5 <u>UTMI</u>

This block handles the low-level USB protocol and signaling. This includes features such as data serialization and de-serialization, bit stuffing and clock recovery and synchronization. The primary focus of this block is to shift the clock domain of the data from the USB 2.0 rate to one that is compatible with the general logic in the ASIC.

#### 13.5 Register Definition

#### 13.5.1 USB1.1 Configuration Space

| Regi | ster Off<br>ster Na<br>t Value | me: | 01h -<br>Vend<br>17F3 | or ID R | egister |   |   |    |   |   |   |   |   |   |   |
|------|--------------------------------|-----|-----------------------|---------|---------|---|---|----|---|---|---|---|---|---|---|
| 15   | 14                             | 13  | 12                    | 11      | 10      | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|      |                                |     |                       |         |         |   | V | ID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description |
|------|------|-----------|-------------|
| 15-0 | VID  | RO        | Vendor ID   |

| Register Offset:<br>Register Name:<br>Reset Value : | 03h – 02h<br>Device ID Register<br>6060h |    |    |   |   |    |   |   |   |   |   |   |   |
|-----------------------------------------------------|------------------------------------------|----|----|---|---|----|---|---|---|---|---|---|---|
| 15 14 13                                            | 12                                       | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                                     |                                          |    |    |   | D | ID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description |
|------|------|-----------|-------------|
| 15-0 | DID  | RO        | Device ID   |



|          | Regis | ster Offs | set:  | 05h –   | 04h    |         |   |     |   |          |   |      |     |     |    |     |  |
|----------|-------|-----------|-------|---------|--------|---------|---|-----|---|----------|---|------|-----|-----|----|-----|--|
|          | Regis | ster Nar  | ne:   | Comr    | mand R | egister |   |     |   |          |   |      |     |     |    |     |  |
|          | Reset | t Value   | :     | 0000ł   | า      |         |   |     |   |          |   |      |     |     |    |     |  |
|          | Reco  | mmend     | Value | : 00071 | ı      |         |   |     |   |          |   |      |     |     |    |     |  |
|          | 15    | 14        | 13    | 12      | 11     | 10      | 9 | 8   | 7 | 6        | 5 | 4    | 3   | 2   | 1  | 0   |  |
| Reserved |       |           |       |         |        |         |   | SDE |   | Reserved | d | MWIC | SCE | PME | ME | IOE |  |

| Bit   | Name | Attribute | Description                                                                                                                                                                                                                                                                                                               |
|-------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-10 | Rsvd | R/W       | Reserved bits.<br>These bits are always 0.<br>Power on Value: 0.<br>Recommend Setting: 0.                                                                                                                                                                                                                                 |
| 9     | BBE  | R/W       | Back to Back Enable<br>USB HC only acts as a master to a single device, so this functionality is not needed. This bit<br>is always 0.<br>Power on Value: 0b.<br>Recommend Setting: 0b.                                                                                                                                    |
| 8     | SDE  | R/W       | SERR_n (Response) Detection Enable bit<br>If set to 1, USB HC asserts SERR_n when it detects an address parity error. SERR_n is not<br>asserted if this bit is 0.<br>Power on Value: 0b.<br>Recommend Setting: 0b.                                                                                                        |
| 7-5   | Rsvd | R/W       | Reserved bits.<br>These bits are always 0.<br>Power on Value: 0b.<br>Recommend Setting: 0b.                                                                                                                                                                                                                               |
| 4     | MWIC | R/W       | Memory Write and Invalidate Command<br>If set to 1, USB HC is enabled to run Memory Write and Invalidate commands. The Memory<br>Write and Invalidate Command will only occur if the cacheline size is set to 32 bytes and the<br>memory write is exactly one cacheline.<br>Power on Value: 0b.<br>Recommend Setting: 0b. |
| 3     | SCE  | R/W       | Special Cycle Enable<br>USB HC does not run special cycles on PCI. This bit is always 0.<br>Power on Value: 0b.<br>Recommend Setting: 0b.                                                                                                                                                                                 |
| 2     | PME  | R/W       | PCI Master Enable<br>If set to 1, USB HC is enabled to run PCI master cycles.<br>Power on Value: 0b.<br>Recommend Setting: 1b.                                                                                                                                                                                            |
| 1     | ME   | R/W       | Memory Enable<br>If set to 1, USB HC is enabled to respond as a target to memory cycles.<br>Power on Value: 0b.<br>Recommend Setting: 1b.                                                                                                                                                                                 |
| 0     | IOE  | R/W       | I/O Enable<br>If set to 1, USB HC is enabled to respond as a target to I/O cycles.<br>Power on Value: 0b.<br>Recommend Setting: 1b.                                                                                                                                                                                       |



| Regis | ster Of | fset: | 07h – 06h       |      |     |      |      |      |   |          |   |      |   |          |   |
|-------|---------|-------|-----------------|------|-----|------|------|------|---|----------|---|------|---|----------|---|
| Regis | ster Na | me:   | Status Register |      |     |      |      |      |   |          |   |      |   |          |   |
| Rese  | t Value | :     | 0280ł           | า    |     |      |      |      |   |          |   |      |   |          |   |
| 15    | 14      | 13    | 12              | 11   | 10  | 9    | 8    | 7    | 6 | 5        | 4 | 3    | 2 | 1        | 0 |
| DPE   | SS      | RMAS  | RTAS            | STAS | DEV | SELT | DPRP | FBBC |   | Reserved |   | INTS | I | Reserved |   |

| Bit  | Name    | Attribute | Description                                                                                                                                                                                  |
|------|---------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | DPE     | R/W       | Detected Parity Error<br>This bit is set to 1 whenever USB HC detects a parity error, even if the Parity Error<br>(Response) Detection Enable bit is disabled. Cleared by writing a 1 to it. |
| 14   | SS      | R/W       | SERR_n Status<br>This bit is set to 1 whenever the USB HC detects a PCI address parity error. Cleared by<br>writing a 1 to it.                                                               |
| 13   | RMAS    | R/W       | Received Master Abort Status<br>Set to 1 when USB HC, acting as a PCI master, aborts a PCI bus memory cycle. Cleared by<br>writing a 1 to it.                                                |
| 12   | RTAS    | R/W       | Received Target Abort Status<br>This bit is set to 1 when a USB HC generated PCI cycle (USB HC is the PCI master) is<br>aborted by a PCI target. Cleared by writing a 1 to it.               |
| 11   | STAS    | R/W       | Signaled Target Abort Status<br>This bit is set to 1 when USB HC signals target aborts. Cleared by writing a 1 to it.                                                                        |
| 10-9 | DEVSELT | R/W       | DEVSEL_n timing<br>Read only bits indicating DEVSEL_n timing when a positive decode is performed. Since<br>DEVSEL_n is asserted to meet the medium timing, these bits are encoded as 01b.    |
| 8    | DPRP    | R/W       | Data Parity Reported<br>Set to 1 if the Parity Error Response bit is set, and USB HC detects PERR_n asserted while<br>acting as PCI master (whether PERR_n was driven by USB HC or not).     |
| 7    | FBBC    | R/W       | Fast Back-to-Back Capable<br>USB HC does support fast back-to-back transactions when the transactions are not to the<br>same agent. This bit is always 1.                                    |
| 6-4  | Rsvd    | R/W       | Reserved Bits These bits are always 0.                                                                                                                                                       |
| 3    | INTS    | RO        | Interrupt Status<br>This bit reflects the state of interrupts in the device.                                                                                                                 |
| 2-0  | Rsvd    | R/W       | Reserved Bits<br>These bits are always 0.                                                                                                                                                    |

# RDC<sup>®</sup> RISC DSP Communication

| Regist          | er Offse         | et:     | 08h             |            |          |          |             |
|-----------------|------------------|---------|-----------------|------------|----------|----------|-------------|
| Regist<br>Reset | er Name<br>Value | e:<br>: | Revision<br>07h | ID Registe | r        |          |             |
| 7               | 6                | 5       | 4 3             | 3 2        | 1        | 0        |             |
|                 |                  |         | FTRVL           |            |          |          |             |
| Bit             | Nam              | e       | Attribute       |            |          |          | Description |
| 7-0             | FTRV             | Ľ       | RO              | Functiona  | I Revisi | on Level |             |

| Re | giste  | r Offs | et: | 0B  | 0Bh – 09h           |    |    |    |    |    |     |     |    |   |   |   |   |   |    |     |   |   |   |
|----|--------|--------|-----|-----|---------------------|----|----|----|----|----|-----|-----|----|---|---|---|---|---|----|-----|---|---|---|
| Re | giste  | r Nam  | ne: | Cla | Class Code Register |    |    |    |    |    |     |     |    |   |   |   |   |   |    |     |   |   |   |
| Re | set Va | alue   | :   | 0C  | 0310                | h  |    |    |    |    |     |     |    |   |   |   |   |   |    |     |   |   |   |
| 23 | 22     | 21     | 20  | 19  | 18                  | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3   | 2 | 1 | 0 |
|    | BCLS   |        |     |     |                     |    |    |    |    |    | SUB | CLS |    |   |   |   |   |   | PR | GIF |   |   |   |

| Bit   | Name   | Attribute | Description                                                          |
|-------|--------|-----------|----------------------------------------------------------------------|
| 23-16 | BCLS   | RO        | Base Class                                                           |
| 25-10 | DOLO   | RU        | The Base Class is 0Ch (Serial Bus Controller).                       |
| 15-8  | SUBCLS | RO        | Sub Class                                                            |
| 10-0  | SOBCLS | RU        | The Sub Class is 03h (Universal Serial Bus).                         |
| 7-0   | PRGIF  | RO        | Programming Interface<br>The Programming Interface is 10h (OpenHCI). |

| Register Offset: | 0Ch                      |
|------------------|--------------------------|
| Register Name:   | Cache Line Size Register |
| Reset Value :    | 00h                      |
| Recommend Value: | 08h                      |
|                  |                          |

#### 7 6 5 4 3 2 1 0 CCHLSZ

| Bit | Name   | Attribute | Description                                                                                                                                                                                                                                                                                                                        |
|-----|--------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | CCHLSZ |           | Cache Line Size<br>This register identifies the system cache line size in units of 32-bit words. USB HC will only<br>store the value of bit 3 in this register since the cache line size of 32 bytes is the only value<br>applicable to the design. Any value other than 08h written to this register will be read back as<br>00h. |

# RDC<sup>®</sup> RISC DSP Communication

| Register Offset: | 0Dh                    |
|------------------|------------------------|
| Register Name:   | Latency Timer Register |
| Reset Value :    | 00h                    |
| Recommend Value: | 20h                    |

#### 7 6 5 4 3 2 1 0

LTCTimer

| Bit | Name     | Attribute | Description                                                                                                       |
|-----|----------|-----------|-------------------------------------------------------------------------------------------------------------------|
| 7-0 | LTCTimer |           | Latency Timer<br>This register identifies the value of the latency timer in PCI clocks for PCI bus master cycles. |

| Regis | ster Off | set: | 0Eh   | 0Eh                             |   |   |   |  |  |  |  |  |  |
|-------|----------|------|-------|---------------------------------|---|---|---|--|--|--|--|--|--|
| Regis | ster Na  | ne:  | Head  | Header Type Register            |   |   |   |  |  |  |  |  |  |
| Rese  | t Value  | :    | 80h/( | 80h/00h (function0/function1-3) |   |   |   |  |  |  |  |  |  |
| 7     | 76       |      | 4     | 3                               | 2 | 1 | 0 |  |  |  |  |  |  |
|       |          |      |       |                                 |   |   |   |  |  |  |  |  |  |

ΗT

| Bit | Name | Attribute | Description                                                                                                                                                                                                                                                                                                  |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | HT   | RO        | Header Type Register<br>This register identifies the type of the predefined header in the configuration space. HC0 bit7<br>of this register is used to identify a multifunction device. When more than one USB HC is<br>enabled, the read out value for HC0 is 80h, and those for HC1, HC2 and EHCI are 00h. |

| Register Offset: | 13h – 10h             |
|------------------|-----------------------|
| Register Name:   | Base Address Register |
| Reset Value :    | 00h                   |
|                  |                       |

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

|       |      |           | BAD                                                         | Reserved                 |  |  |  |  |  |  |  |
|-------|------|-----------|-------------------------------------------------------------|--------------------------|--|--|--|--|--|--|--|
|       |      |           |                                                             |                          |  |  |  |  |  |  |  |
| Bit   | Name | Attribute | Desc                                                        | ription                  |  |  |  |  |  |  |  |
| 31-12 | BAD  |           | Base Address<br>POST writes the value of the memory base ad | ldress to this register. |  |  |  |  |  |  |  |
| 11-0  | Rsvd | RO        | Always 0. Indicates a 4K-byte address range i               | s requested.             |  |  |  |  |  |  |  |

# **R8610** 32-Bit RISC MicroController



| Regist | ter Offse | et: | 2Dh – 2Ch |                              |    |   |    |    |   |   |   |   |   |   |   |  |  |  |
|--------|-----------|-----|-----------|------------------------------|----|---|----|----|---|---|---|---|---|---|---|--|--|--|
| Regist | ter Name  | e:  | Subsyste  | Subsystem Vendor ID Register |    |   |    |    |   |   |   |   |   |   |   |  |  |  |
| Reset  | Value:    |     | 0000h     |                              |    |   |    |    |   |   |   |   |   |   |   |  |  |  |
| 15     | 14        | 13  | 12        | 11                           | 10 | 9 | 8  | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|        |           |     |           |                              |    |   | SV | ΊD |   |   |   |   |   |   |   |  |  |  |

| E  | Bit | Name | Attribute | Description                                     |
|----|-----|------|-----------|-------------------------------------------------|
| 15 | 5-0 | SVID | R/WL      | This register contains the subsystem Vendor ID. |

| Register Offset:<br>Register Name:<br>Reset Value: |      |    |    | 2Fh – 2Eh<br>Subsystem Device ID Register<br>0000h |    |   |   |   |   |   |   |   |   |   |   |
|----------------------------------------------------|------|----|----|----------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| 15                                                 | 14   | 13 | 12 | 11                                                 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                                    | SDID |    |    |                                                    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                     |
|------|------|-----------|-------------------------------------------------|
| 15-0 | SDID | R/WL      | This register contains the subsystem Device ID. |

| Regis | ter Offs<br>ter Nam<br>Value: |    | 3Dh – 3<br>Interrupi<br>01XXh |    | l Registe | er |   |   |   |      |   |   |   |   |   |  |  |
|-------|-------------------------------|----|-------------------------------|----|-----------|----|---|---|---|------|---|---|---|---|---|--|--|
| 15    | 14                            | 13 | 12                            | 11 | 10        | 9  | 8 | 7 | 6 | 5    | 4 | 3 | 2 | 1 | 0 |  |  |
|       | INTP                          |    |                               |    |           |    |   |   |   | INTL |   |   |   |   |   |  |  |

| Bit  | Name | Attribute | Description                             |
|------|------|-----------|-----------------------------------------|
| 15-8 | INTP | R         | Interrupt Pin. Use INT_A.               |
| 7-0  | INTL | R/W       | Interrupt Line. Index Interrupt Vector. |

| Register Offset: | 3Eh                    |
|------------------|------------------------|
| Register Name:   | Minimum Grant Register |
| Reset Value :    | 00h                    |
|                  |                        |

## 7 6 5 4 3 2 1 0

MINGNT

| Bit | Name   | Attribute | Description    |
|-----|--------|-----------|----------------|
| 7-0 | MINGNT | RO        | Minimum Grant. |

| Register Offset: | 3Fh                  |
|------------------|----------------------|
| Register Name:   | Max Latency Register |
| Reset Value :    | 50h                  |
| 765              | 4 3 2 1              |

MAXLAT

| Bit | Name   | Attribute | Description      |
|-----|--------|-----------|------------------|
| 7-0 | MAXLAT | RO        | Maximum Latency. |

| 44h                                |
|------------------------------------|
| Operational Mode Enable Register I |
| 2ah                                |
| 5ch                                |
|                                    |

| 7    | 6   | 5     | 4     | 3 | 2                   | 1 | 0     |
|------|-----|-------|-------|---|---------------------|---|-------|
| Rsvd | BUO | NR3HS | H910E |   | BUFUN<br>DEREO<br>F |   | DBR16 |

| Bit | Name  | Attribute | Description                                                                                                                                                                                       |
|-----|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | Rsvd  | R/W       | Reserved.<br>Power on Value: 0b.<br>Recommend Setting: 0b.                                                                                                                                        |
| 6   | BUO   | R/W       | Buffer Under Orphan.<br>When set, it will fix the problem happened in DB module. The buffer point will reset while<br>data underrun is occurred.<br>Power on Value: 0b.<br>Recommend Setting: 1b. |
| 5   | NR3HS | R/W       | NoResp3HS.<br>The bit is low active. When cleared, the Error interrupt is reported after three consecutive<br>USB bus transfer error.<br>Power on Value: 1b.<br>Recommend Setting: 0b.            |



| 4 | H910E           | R/W                                                                                                                              | HcControl bit 9 and bit10 Function Enable.<br>When this bit is set, the function of RemoteWakeupConnected and RemoteWakeupEnable<br>in OHCI will be enabled. Otherwise, these two bits are always cleared.<br>Power on Value: 0b.<br>Recommend Setting: 1b. |
|---|-----------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | PES             | R/W PCI EDB Select.<br>When this bit is set, USB HC selects EDB as DMA channel.<br>Power on Value: 1b.<br>Recommend Setting: 1b. |                                                                                                                                                                                                                                                             |
| 2 | BUFUNDE<br>REOF | R/W                                                                                                                              | Buffer Under End of Frame.<br>Setting this bit will stop the Data Buffer Module function until next access.<br>Power on Value: 0b.<br>Recommend Setting: 1b.                                                                                                |
| 1 | S3WU            | R/W                                                                                                                              | S3 Wakeup.<br>The HC will accept wait-state write command after leaving suspend mode if there are no<br>device attached.<br>Power on Value: 1b.<br>Recommend Setting: 0b.                                                                                   |
| 0 | DBR16           | R/W                                                                                                                              | Data Buffer Region 16.<br>When the size of the region set for the data buffer is 16 bytes. Otherwise, the size is 32<br>bytes.<br>Power on Value: 0b.<br>Recommend Setting: 0b.                                                                             |

| Register Offset: | 45h                                 |
|------------------|-------------------------------------|
| Register Name:   | Operational Mode Enable Register II |
| Reset Value :    | 00h                                 |
| Recommend Value: | ach/aeh (P4 system/K8 system)       |
|                  |                                     |

| 7    | 6    | 5    | 4  | 3   | 2   | 1  | 0   |
|------|------|------|----|-----|-----|----|-----|
| DSCE | Rsvd | SUPO | MP | DRE | RFE | Rs | svd |

| Bit | Name | Attribute | Description                                                                                                                                                                                                        |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | DSCE | R/W       | Delay Suspend Clock Enable.<br>When this bit is set, the HC generates 4T 12M clock before entering USB suspend state.<br>Power on Value: 0b.<br>Recommend Setting: 1b.                                             |
| 6   | Rsvd | R/W       | Reserved.<br>Power on Value: 0b.<br>Recommend Setting: 0b.                                                                                                                                                         |
| 5   | SUPO | R/W       | Set USB Power OK.<br>This bit enables USB IO port to drive bus. When this bit is 0, the HC cannot drive any signals<br>to USB bus.<br>Power on Value: 0b.<br>Recommend Setting: 1b.                                |
| 4   | MP   | R/W       | Mask PMCS.<br>OpenHCI host controllers optional support power management capability function. When this<br>bit is set, the HC is PCI2.2 compliant. PMCS is masked<br>Power on Value: 0b.<br>Recommend Setting: 0b. |
| 3   | DRE  | R/W       | Drive Resume Enable.<br>When this bit is set, the HC will drive resume signal to downstream port that sent remote<br>wakeup signal in S3 or S4.<br>Power on Value: 0b.<br>Recommend Setting: 1b.                   |



| 2   | RFE  | R/W | Restore Function Enable.<br>Setting this bit can automatically restore all OHCI OP register after resuming from S3 or S4.<br>Power on Value: 0b.<br>Recommend Setting: 1b. |
|-----|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-0 | Rsvd | R/W | Reserved.<br>Power on Value: 0b.<br>Recommend Setting: 0b.                                                                                                                 |

| Register Offset: | 46h                                  |
|------------------|--------------------------------------|
| Register Name:   | Operational Mode Enable Register III |
| Reset Value :    | 00h                                  |
| Recommend Value  | : 01h                                |

7 6 5 4 3 2 1 0 Reserved RDRST

| Bit | Name  | Attribute | Description                                                                                                                                                     |
|-----|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-1 | Rsvd  | R/W       | Reserved                                                                                                                                                        |
| 0   | RDRST | R/W       | Ready for Restore.<br>When this bit is set, the HC automatically restores OP registers after resuming from S3.<br>Power on Value: 0b.<br>Recommend Setting: 1b. |

| Register  | 49h –      | 48h      |          |         |          |          |         |         |       |   |   |   |   |   |
|-----------|------------|----------|----------|---------|----------|----------|---------|---------|-------|---|---|---|---|---|
| Register  | Opera      | tional M | lode Ena | able Re | gister I | V (For F | Power N | /lanage | ment) |   |   |   |   |   |
| Reset Val | 00h        |          |          |         |          |          |         |         |       |   |   |   |   |   |
| Recomm    | end Value: | 00h      |          |         |          |          |         |         |       |   |   |   |   |   |
| 15 14     | 4 13       | 12       | 11       | 10      | 9        | 8        | 7       | 6       | 5     | 4 | 3 | 2 | 1 | 0 |
|           |            |          |          |         |          | Reser    | ved     |         |       |   |   |   |   |   |

| Bit  | Name | Attribute | Description                                                                                  |
|------|------|-----------|----------------------------------------------------------------------------------------------|
| 15-0 | Rsvd | R/W       | Reserved for Power Management & Debug port.<br>Power on Value: 0b.<br>Recommend Setting: 0b. |

### 13.5.2 USB1.1 Operational Registers

The base address of these registers is programmable by the memory base address register (USB PCI configuration register offset 10h - 13h). These registers should be written as Dword. Bytes write to these registers may have unpredictable effects.

The OpenHCI Host Controller (HC) contains a set of on-chip operational registers that are mapped into a non-cacheable portion of the system addressable space. These registers are used by the Host Controller Driver (HCD). According to the functions 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 Dwords.

Reserved bits may be allocated in future releases of this specification. To ensure interoperability, the Host Controller Driver that does not use a reserved field should not assume that the reserved field contains 0. Furthermore, the Host Controller Driver should always preserve the value(s) of the reserved field. When a R/W register is modified, the Host Controller Driver should first read the register, modify the bits desired, then write the register with the reserved bits still containing the read value. Alternatively, the Host Controller Driver can maintain an in-memory copy of previously written values that can be modified and then written to the Host Controller register. When a write to set/clear register is written, bits written to reserved fields should be 0.



### 13.5.2.1 Open Host Controller Interface Operational Registers

| Offset    | Register Name         |
|-----------|-----------------------|
| 00h       | HC Revision           |
| 04h       | HC Control            |
| 08h       | HC Command Status     |
| 0Ch       | HC Interrupt Status   |
| 10h       | HC Interrupt Enable   |
| 14h       | HC Interrupt Disable  |
| 18h       | HC HCCA               |
| 1Ch       | HC Period Current ED  |
| 20h       | HC Control Head ED    |
| 24h       | HC Control Current ED |
| 28h       | HC Bulk Head ED       |
| 2Ch       | HC Bulk Current ED    |
| 30h       | HC Done Head          |
| 34h       | HC Fm Interval        |
| 38h       | HC Fm Remaining       |
| 3Ch       | HC Fm Number          |
| 40h       | HC Periodic Start     |
| 44h       | HC LS Threshold       |
| 48h       | HC Rh Descriptor A    |
| 4Ch       | HC Rh Descriptor B    |
| 50h       | HC Rh Status          |
| 54h       | HC Rh Port Status [1] |
| 58h       | HC Rh Port Status [2] |
| 5Ch – FFh | Reserved              |
| 100h      | HC eControl           |
| 104h      | HC eInput             |
| 108h      | HC eOutput            |
| 10Ch      | HC eStatus            |



#### 13.5.2.2 Control and Status Partition

| Register Offset: | 00h                  |
|------------------|----------------------|
| Register Name:   | HC Revision Register |
| Reset Value :    | 00000110h            |

| 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 | eserv | red |    |    |    |    |    |    |    |    |    |   | IG |   |   |   | R | v |   |   |   |

| Name | Attribute | Description |    |    |
|------|-----------|-------------|----|----|
|      |           |             |    |    |
|      |           | Reserved    | LG | RV |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                  |
|------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-9 | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                    |
| 8    | LG   | RO        | Legacy.<br>This read-only field is 1 to indicate that the legacy support registers are present in this HC.                                                                                                                                                                                                                   |
| 7-0  | RV   |           | Revision.<br>This read-only field contains the BCD representation of the version of the HCI specification<br>that is implemented by this HC. For example, a value of 11h corresponds to version 1.1. All of<br>the HC implementations that are compliant with current OpenHCI 1.0 specification will have a<br>value of 10h. |

| Register Offset: | 04h                 |
|------------------|---------------------|
| Register Name:   | HC Control Register |
| Reset Value :    | 00000000h           |

#### 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

|--|

The HC Control Register defines the operating modes for the Host Controller. Only the Host Controller Driver, except Host

Controller Functional State and Remote Wakeup Connected, modifies most of the fields in this register.

| Bit   | Name   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-11 | Rsvd   | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 10    | RMWUEn | RO        | Remote Wakeup Enable.<br>This bit is used by the HCD to enable or disable the remote wakeup feature upon the<br>detection of upstream resume signaling. When this bit is set and the Resume Detected bit in<br>HC Interrupt Status is set, a remote wakeup is signaled to the host system. Setting this bit<br>has no impact on the generation of hardware interrupt.                                                                                           |
| 9     | RMWUC  | RO        | Remote Wakeup Connected.<br>This bit indicates whether the HC supports remote wakeup signaling or not. If remote<br>wakeup is supported and used by the system, it is the responsibility of system firmware to<br>set this bit during POST. The HC clears the bit upon a hardware reset but does not alter it<br>upon a software reset.                                                                                                                         |
| 8     | INTRT  | R/W       | Interrupt Routing.<br>This bit determines the routing of interrupts generated by events registered in HC Interrupt<br>Status. If cleared, all interrupts are routed to the normal host bus interrupt mechanism. If set,<br>interrupts are routed to the System Management Interrupt. The HCD clears this bit upon a<br>hardware reset, but it does not alter this bit upon a software reset. The HCD uses this bit as<br>a tag to indicate the ownership of HC. |



| 97-6 | HCFSUSB | R/W | Host Controller Functional State for USB.<br>00b: USB Reset<br>01b: USB Resume<br>10b: USB Operational<br>11b: USB Suspend<br>A transition to UsbOperational from another state causes SOF generation to begin 1 ms<br>later. The HCD may determine whether the HC has begun sending SOFs by reading the<br>Start of Frame field of HC Interrupt Status.<br>This field may be changed by the HC only in the UsbSuspend state. The HC may move from<br>the USB Suspend state to the USB Resume state after the resume signal from a<br>downstream port is detected.<br>The HC enters USB Suspend after a software reset, whereas it enters USB Reset after a<br>hardware reset. The latter also resets the Root Hub and asserts subsequent reset signal to<br>downstream ports. |
|------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | BLEn    | R/W | Bulk List Enable.<br>This bit is set to enable the processing of the Bulk list in the next Frame. If cleared by the HCD, processing of the Bulk list does not occur after the next SOF. The HC checks this bit whenever it determines to process the list. When disabled, the HCD may modify the list. If HC Bulk Current ED is pointing to an ED to be removed, the HCD must advance the pointer by updating HC Bulk Current ED before the processing of the list is re-enabled.                                                                                                                                                                                                                                                                                              |
| 4    | CTLEn   | R/W | Control List Enable.<br>This bit is set to enable the processing of the Control list in the next Frame. If cleared by the HCD, the processing of the Control list does not occur after the next SOF. The HC must check this bit whenever it determines to process the list. When disabled, the HCD may modify the list. If HC Control Current ED is pointing to an ED to be removed, the HCD must advance the pointer by updating HC Control Current ED before re-enabling the processing of the list.                                                                                                                                                                                                                                                                         |
| 3    | lEn     | R/W | Isochronous Enable.<br>This bit is used by the HCD to enable/disable the processing of isochronous EDs. While<br>processing the periodic list in a Frame, the HC checks the status of this bit when it finds an<br>Isochronous ED (F=1). If set (enabled), the HC continues processing the EDs. If cleared<br>(disabled), the HC halts processing of the periodic list (which now contains only isochronous<br>EDs) and begins processing the Bulk/Control lists. Setting this bit is guaranteed to take effect<br>in the next Frame (not the current Frame).                                                                                                                                                                                                                  |
| 2    | PLEn    | R/W | Periodic List Enable.<br>This bit is set to enable the processing of the periodic list in the next Frame. If cleared by the HCD, the processing of the periodic list does not occur after the next SOF. The HC must check this bit before it starts processing the list.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1-0  | CTBSRT  | R/W | Control Bulk Service Ratio.         This specifies the service ratio between Control and Bulk EDs. Before processing any of the non-periodic lists, the HC must compare the ratio specified with its internal count on how many non-empty Control EDs have been processed, in determining whether to continue serving another Control ED or switching to Bulk EDs. The internal count will be retained when crossing the frame boundary. In case of reset, the HCD is responsible for restoring this value.         CBSR No. of Control EDs Over Bulk EDs Served         0       1:1         1       2:1         2       3:1         3       4:1                                                                                                                               |

| R  | egis                                  | ter | Offs | set: |    | 08h  |       |    |      |     |    |    |    |     |     |    |    |    |    |    |      |      |   |   |   |   |   |          |     |   |               |
|----|---------------------------------------|-----|------|------|----|------|-------|----|------|-----|----|----|----|-----|-----|----|----|----|----|----|------|------|---|---|---|---|---|----------|-----|---|---------------|
| R  | Register Name: HC Command Status Regi |     |      |      |    |      |       |    | egis | ter |    |    |    |     |     |    |    |    |    |    |      |      |   |   |   |   |   |          |     |   |               |
| R  | Reset Value : 00000000h               |     |      |      |    |      |       |    |      |     |    |    |    |     |     |    |    |    |    |    |      |      |   |   |   |   |   |          |     |   |               |
| 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             |
|    |                                       |     |      |      |    | Rese | erved | 1  |      |     |    |    |    | SDO | ORC |    |    |    |    |    | Rese | rvec |   |   |   |   |   | ON<br>CR | BLF |   | HC<br>TR<br>S |

The HC Command Status Register is used by the Host Controller to receive commands issued by the Host Controller Driver, as well as reflecting the current status of the Host Controller. To the Host Controller Driver, it appears to be a "write to set" register. The Host Controller must ensure those "written as '1" bits become set in the register while those "written as '0" bits remain unchanged in the register. The Host Controller Driver may issue multiple distinct commands to the Host Controller without concern for corrupting previously issued commands. The Host Controller Driver has normal read access to all bits.

The Scheduling Overrun Count field indicates the number of frames with which the Host Controller has detected the scheduling overrun error. This occurs when the Periodic list does not complete before EOF. When a scheduling overrun error is detected, the Host Controller increments the counter and sets the Scheduling Overrun field in the HC Interrupt Status Register.

| Bit   | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-18 | Rsvd  | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 17-16 | SDORC | RO        | Scheduling Overrun Count.<br>These bits are incremented on each scheduling overrun error. It is initialized to 00b and<br>wraps around at 11b. This will be incremented when a scheduling overrun is detected even if<br>Scheduling Overrun in HC Interrupt Status has already been set. This is used by the HCD to<br>monitor any persistent scheduling problems.                                                                                                                                                                                                                                                                                                                                                                  |
| 15-4  | Rsvd  | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3     | ONCR  | R/W       | Ownership Change Request.<br>This bit is set by an OS HCD to request a change of control of the HC. When set, the HC will<br>set the Ownership Change field in HC Interrupt Status. After the changeover, this bit is<br>cleared and remains so until the next request from OS HCD.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2     | BLF   | R/W       | Bulk List Filled.<br>This bit is used to indicate whether there are any TDs on the Bulk list. It is set by the HCD<br>whenever it adds a TD to an ED in the Bulk list.<br>When the HC begins to process the head of the Bulk list, it checks BF. As long as BLF is 0,<br>the HC will not start processing the Bulk list. If BLF is 1, the HC will start processing the Bulk<br>list and will set BF to 0. If the HC finds a TD on the list, then the HC will set BLF to 1,<br>causing the Bulk list processing to continue. If no TD is found on the Bulk list, and if the HCD<br>does not set BLF, then BLF will still be 0 when the HC completes processing the Bulk list and<br>Bulk list processing will stop.                  |
| 1     | CTLF  | R/W       | Control List Filled.<br>This bit is used to indicate whether there are any TDs on the Control list. It is set by the HCD whenever it adds a TD to an ED in the Control list.<br>When the HC begins to process the head of the Control list, it checks CTLF. As long as CTLF is 0, the HC will not start processing the Control list. If CF is 1, the HC will start processing the Control list and will set CLF to 0. If the HC finds a TD on the list, then the HC will set CTLF to 1, causing the Control list processing to continue. If no TD is found on the Control list, and if the HCD does not set CTLF, then CTLF will still be 0 when the HC completes processing the Control list and Control list processing will stop |
| 0     | HCTRS | R/W       | Host Controller Reset.<br>This bit is set by the HCD to initiate a software reset of the HC. Regardless of the functional state of the HC, it moves to the USB Suspend state in which most of the operational registers are reset except those stated otherwise; e.g., the Interrupt Routing field of HC Control, and no Host bus accesses are allowed. This bit is cleared by the HC upon the completion of the reset operation. The reset operation must be completed within 10 $\mu$ s. This bit, when set, should not cause a reset to the Root Hub and no subsequent reset signal should be asserted to its downstream ports.                                                                                                  |

| Register Offset: | 0Ch                          |
|------------------|------------------------------|
| Register Name:   | HC Interrupt Status Register |
| Reset Value :    | 0000000h                     |

|   | 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 |    |    | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RH | FN | Dov | БС | eг | WB | SD |  |

This register provides status on various events that cause hardware interrupts. When an event occurs, the Host Controller sets the corresponding bit in this register. When a bit is set, a hardware interrupt is generated if the interrupt is enabled in the HC Interrupt Enable Register and the Master Interrupt Enable bit is set. The Host Controller Driver may clear specific bits in this register by writing '1' to bit positions to be cleared. The Host Controller Driver may not set any of these bits. The Host Controller will never clear the bit.

| Bit  | Name  | Attribute | Description                                                                                                                                                                                                                                                                                            |
|------|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | Rsvd  | RO        | Reserved.                                                                                                                                                                                                                                                                                              |
| 30   | ONCS  | R/W       | Ownership Change Status.<br>This bit is set by the HC when the HCD sets the Ownership Change Request field in HC<br>Command Status. This event, when unmasked, will always generate a System Management<br>Interrupt (SMI_n) immediately.                                                              |
| 29-7 | Rsvd  | RO        | Reserved.                                                                                                                                                                                                                                                                                              |
| 6    | RHSCS | R/W       | Root Hub Status Change Status.<br>This bit is set when the contents of HC Rh Status or the contents of any of HC Rh Port<br>Status [Number of Downstream Port] have changed.                                                                                                                           |
| 5    | FNOFS | R/W       | Frame Number Overflow Status.<br>This bit is set when the MSb of HC Fm Number (bit 15) changes values, from 0 to 1 or from<br>1 to 0, and after HCCA Frame Number has been updated.                                                                                                                    |
| 4    | Rsvd  | RO        | Reserved.                                                                                                                                                                                                                                                                                              |
| 3    | RSDS  | R/W       | Resume Detected Status.<br>This bit is set when the HC detects that a device on the USB is asserting resume signaling.<br>It is the transition from no resume signaling to resume signaling causing this bit to be set.<br>This bit is not set when the HCD sets the USB Resume state.                 |
| 2    | SFS   | R/W       | Start of Frame Status.<br>This bit is set by the HC at each start of a frame and after the update of HCCA Frame<br>Number. The HC also generates an SOF token at the same time.                                                                                                                        |
| 1    | WBDHS | R/W       | Write Back Done Head Status.<br>This bit is set immediately after the HC has written HC Done Head to HCCA Done Head.<br>Further updates of the HCCA Done Head will not occur until this bit has been cleared. The<br>HCD should only clear this bit after it has saved the contents of HCCA Done Head. |
| 0    | SDORS | R/W       | Scheduling Overrun Status.<br>This bit is set when the USB schedule for the current Frame overruns and after the update of<br>HCCA Frame Number. A scheduling overrun will also cause the Scheduling Overrun Count of<br>HC Command Status to be incremented.                                          |



| Register Offset: | 10h                          |
|------------------|------------------------------|
| Register Name:   | HC Interrupt Enable Register |
| Reset Value :    | 0000000h                     |

| 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 |
|------------|---------------|----|----|----|----|----|----|----|----|----|----|----|-------|-----|----|----|----|----|----|----|----|---|---|---|---|----------------|----------|---------------|----------|----------------|---|
| MIN<br>TEn | ON<br>CE<br>n |    |    |    |    |    |    |    |    |    |    | Re | eserv | ved |    |    |    |    |    |    |    |   |   |   |   | FN<br>OF<br>En | Rsv<br>d | RS<br>DE<br>n | SF<br>En | WB<br>DH<br>En | - |

Each enabled bit in the HcInterruptEnable register corresponds to an associated interrupt bit in the HC Interrupt Status Register. The HC Interrupt Enable Register is used to control those events to generate a hardware interrupt. When a bit is set in the HC Interrupt Status Register and the corresponding bit in the HC Interrupt Enable Register is set and the Master Interrupt Enable bit is set, a hardware interrupt is requested on the host bus.

Writing a '1' to a bit in this register sets the corresponding bit, whereas writing a '0' to a bit in this register leaves the corresponding bit unchanged. On read, the current value of this register is returned.

| Bit  | Name   | Attribute | Description                                                                                                                                                                                                                                                    |
|------|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | MINTEn | R/W       | Master Interrupt Enable.<br>A '0' written to this field is ignored by the HC. A '1' written to this field enables interrupt<br>generation due to events specified in the other bits of this register. This is used by the HCD<br>as a Master Interrupt Enable. |
| 30   | ONCEn  | R/W       | Ownership Change Enable.<br>0: Ignore.<br>1: Enable interrupt generation due to Ownership Change.                                                                                                                                                              |
| 29-7 | Rsvd   | RO        | Reserved.                                                                                                                                                                                                                                                      |
| 6    | RHSCEn | R/W       | Root Hub Status Change Enable.<br>0: Ignore.<br>1: Enable interrupt generation due to Root Hub Status Change.                                                                                                                                                  |
| 5    | FNOFEn | R/W       | Frame Number Overflow Enable.<br>0: Ignore.<br>1: Enable interrupt generation due to Frame Number Overflow.                                                                                                                                                    |
| 4    | Rsvd   | RO        | Reserved.                                                                                                                                                                                                                                                      |
| 3    | RSDEn  | R/W       | Resume Detected Enable.<br>0: Ignore.<br>1: Enable interrupt generation due to Resume Detect.                                                                                                                                                                  |
| 2    | SFEn   | R/W       | Start of Frame Enable.<br>0: Ignore.<br>1: Enable interrupt generation due to Start of Frame.                                                                                                                                                                  |
| 1    | WBDHEn | R/W       | Write Back Done Head Enable.<br>0: Ignore.<br>1: Enable interrupt generation due to HC Done Head Writeback,                                                                                                                                                    |
| 0    | SDOREn | R/W       | Scheduling Overrun Enable.<br>0: Ignore.<br>1: Enable interrupt generation due to Scheduling Overrun.                                                                                                                                                          |



| Register Offset: | 14h                           |
|------------------|-------------------------------|
| Register Name:   | HC Interrupt Disable Register |
| Reset Value :    | 0000000h                      |

| MII<br>TC |   | кн  | FN<br>OF | RC | nni | S⊦ | WB<br>DH | SD<br>OR |  |
|-----------|---|-----|----------|----|-----|----|----------|----------|--|
| s         | s | Dis | Dis      | S  | s   | -  | Dis      | Dis      |  |

Each disabled bit in the HC Interrupt Disable Register corresponds to an associated interrupt bit in the HC Interrupt Status Register. The HC Interrupt Disable Register is coupled with the HC Interrupt Enable Register. Thus, writing a '1' to a bit in this register clears the corresponding bit in the HC Interrupt Enable Register, whereas writing a '0' to a bit in this register leaves the corresponding bit in the HC Interrupt Enable Register unchanged. On read, the current value of the HCInterruptEnable register is returned.

| Bit  | Name     | Attribute | Description                                                                                                                                                                                                                                                      |
|------|----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | MINTDis  | R/W       | Master Interrupt Disable.<br>A '0' written to this field is ignored by the HC. A '1' written to this field disables interrupt<br>generation due to events specified in the other bits of this register. This field is set after a<br>hardware or software reset. |
| 30   | ONCDis   | R/W       | Ownership Change Disable.<br>0: Ignore.<br>1: Disable interrupt generation due to Ownership Change.                                                                                                                                                              |
| 29-7 | Rsvd     | RO        | Reserved.                                                                                                                                                                                                                                                        |
| 6    | RHSCDis  | R/W       | Root Hub Status Change Disable.<br>0: Ignore.<br>1: Disable interrupt generation due to Root Hub Status Change.                                                                                                                                                  |
| 5    | FNOFDis  | R/W       | Frame Number Overflow Disable.<br>0: Ignore.<br>1: Disable interrupt generation due to Frame Number Overflow.                                                                                                                                                    |
| 4    | UNRCEDis | R/W       | Unrecoverable Error Disable.<br>This event is not implemented. All writes to this bit will be ignored.                                                                                                                                                           |
| 3    | RSDDis   | R/W       | Resume Detected Disable.<br>0: Ignore.<br>1: Disable interrupt generation due to Resume Detect.                                                                                                                                                                  |
| 2    | SFDis    | R/W       | Start of Frame Disable.<br>0: Ignore.<br>1: Disable interrupt generation due to Start of Frame.                                                                                                                                                                  |
| 1    | WBDHDis  | R/W       | Write Back Done Head Disable.<br>0: Ignore.<br>1: Disable interrupt generation due to HcDoneHead Writeback.                                                                                                                                                      |
| 0    | SDORDis  | R/W       | Scheduling Overrun Disable.<br>0: Ignore.<br>1: Disable interrupt generation due to Scheduling Overrun.                                                                                                                                                          |



#### 13.5.2.3 Memory Pointer Partition

| Register Offset: | 18h              |
|------------------|------------------|
| Register Name:   | HC HCCA Register |
| Reset Value :    | 00000000h        |

#### 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

| BAHCTC Reserved |
|-----------------|
|-----------------|

The HC HCCA register contains the physical address of the Host Controller Communication Area. The Host Controller Driver determines the alignment restrictions by writing all 1s to HC HCCA and reading the contents of HC HCCA. The alignment is evaluated by examining the number of zeroes in the lower order bits. The minimum alignment is 256 bytes; therefore, bits 0 through 7 must always return '0' when read. This area is used to hold the control structures and the Interrupt table that are accessed by both the Host Controller and the Host Controller Driver.

| Bit  | Name   | Attribute | Description                                                         |
|------|--------|-----------|---------------------------------------------------------------------|
| 31-8 | BAHCTC | R/W       | This is the base address of the Host Controller Communication Area. |
| 7-0  | Rsvd   | RO        | Reserved.                                                           |

| Register Offset: | 1Ch                                                                    |
|------------------|------------------------------------------------------------------------|
| Register Name:   | HC Period Current ED Register                                          |
| Reset Value :    | 0000000h                                                               |
| 31 30 29 28 27 2 | 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 |

| PRCRED | Reserved |
|--------|----------|
|        |          |

The HC Period Current ED Register contains the physical address of the current Isochronous or Interrupt Endpoint Descriptor.

| Bit  | Name   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                 |
|------|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | PRCRED |           | Period Current ED.<br>This is used by the HC to point to the head of one of the Periodic lists that will be processed<br>in the current Frame. The contents of this register are updated by the HC after a periodic ED<br>has been processed. The HCD may read the contents in determining which ED is currently<br>being processed at the time of reading. |
| 3-0  | Rsvd   | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                   |



| Register Offset: | 20h                         |
|------------------|-----------------------------|
| Register Name:   | HC Control Head ED Register |
| Reset Value :    | 0000000h                    |

| CTHED Reserved | CTHED | Reserved |  |
|----------------|-------|----------|--|
|----------------|-------|----------|--|

The HC Control Head ED Register contains the physical address of the first Endpoint Descriptor of the Control list.

| ſ | Bit  | Name  | Attribute | Description                                                                                                                                                                   |
|---|------|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | 31-4 | CTHED | R/W       | Control Head ED.<br>The HC traverses the Control list starting with the HC Control Head ED pointer. The contents<br>are loaded from HCCA during the initialization of the HC. |
| ſ | 3-0  | Rsvd  | RO        | Reserved.                                                                                                                                                                     |

| Register Offset: | 24h                            |
|------------------|--------------------------------|
| Register Name:   | HC Control Current ED Register |
| Reset Value :    | 00000000h                      |

### 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

CTCRED

The HC Control Current ED Register contains the physical address of the current Endpoint Descriptor of the Control

| Bit  | Name   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | CTCRED | R/W       | Control Current ED.<br>This pointer is advanced to the next ED after the present one is served. The HC will continue<br>processing the list from where it left off in the last Frame. When it reaches the end of the<br>Control list, the HC checks CTLF in the HC Command Status Regster. If set, it copies the<br>contents of HC Control Head ED to HC Control Current ED and clears the bit. If not set, it<br>does nothing. The HCD is allowed to modify this register only when CTLEn in the HC Control<br>Register is cleared. When set, the HCD only reads the instantaneous value of this register.<br>Initially, this is set to zero to indicate the end of the Control list. |
| 3-0  | Rsvd   | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

list.



| Register Offset: | 28h                      |
|------------------|--------------------------|
| Register Name:   | HC Bulk Head ED Register |
| Reset Value :    | 00000000h                |

|--|

The HC Bulk Head ED Register contains the physical address of the first Endpoint Descriptor of the Bulk list.

| ſ | Bit  | Name | Attribute | Description                                                                                                                                                          |
|---|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | 31-4 | BHED | R/W       | Bulk Head ED.<br>The HC traverses the Bulk list starting with the HC Bulk Head ED pointer. The contents are<br>loaded from HCCA during the initialization of the HC. |
|   | 3-0  | Rsvd | RO        | Reserved.                                                                                                                                                            |

| F  | Register Offset: 2Ch                       |    |    |    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|--------------------------------------------|----|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| F  | Register Name: HC Bulk Current ED Register |    |    |    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| F  | Reset Value : 0000000h                     |    |    |    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
|    | BHCRD                                      |    |    |    |    |    |    |    |    | Rese | ervec | ł  |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

The HC Bulk Current ED Register contains the physical address of the current endpoint of the Bulk list. As the Bulk list will be served in a round-robin fashion, the endpoints will be ordered according to their insertion to the list.

| Bit  | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | BCRED | R/W       | Bulk Current ED.<br>This is advanced to the next ED after the HC has served the present one. The HC continues<br>processing the list from where it left off in the last Frame. When it reaches the end of the Bulk<br>list, the HC checks the ControlListFilled of HcControl. If set, it copies the contents of HC Bulk<br>Head ED to HC Bulk Current ED and clears the bit. If it is not set, it does nothing. The HCD is<br>only allowed to modify this register when BLEn in the HC Control Register is cleared. When<br>set, the HCD only reads the instantaneous value of this register. This is initially set to zero to<br>indicate the end of the Bulk list. |
| 3-0  | Rsvd  | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



| Register Offset: | 30h                      |
|------------------|--------------------------|
| Register Name:   | HC Done Head ED Register |
| Reset Value :    | 00000000h                |

| DH Rese | erved |  |
|---------|-------|--|
|---------|-------|--|

The HC Done Head Register contains the physical address of the last completed Transfer Descriptor that was added to the Done queue. In normal operation, the Host Controller Driver should not need to read this register as its contents are periodically written to the HCCA.

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                        |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | DH   |           | Done Head.<br>When a TD is completed, the HC writes the contents of HC Done Head to the Next TD field<br>of the TD. The HC then overwrites the contents of HcDoneHead with the address of this TD.<br>This is set to zero whenever the HC writes the contents of this register to HCCA. It also sets<br>WBDHS in the HC Interrupt Status Register. |
| 3-0  | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                          |

#### 13.5.2.4 Frame Counter Partition

| Register Offset: | 34h                     |  |  |  |  |
|------------------|-------------------------|--|--|--|--|
| Register Name:   | HC Fm Interval Register |  |  |  |  |
| Reset Value :    | 00002EDFh               |  |  |  |  |

#### 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

| FIN |       |      |       |
|-----|-------|------|-------|
| TVT | FSLDP | Rsvd | FINTV |
| G   |       |      |       |

The HC Fm Interval Register contains a 14-bit value which indicates the bit time interval in a Frame, (i.e., between two consecutive SOFs), and a 15-bit value indicating the Full Speed maximum packet size that the Host Controller may transmit or receive without causing scheduling overrun. The Host Controller Driver may carry out minor adjustments on the FrameInterval by writing a new value over the present one at each SOF. This provides the programmability necessary for the Host Controller to synchronize with an external clocking resource and to adjust any unknown local clock offset.

| Bit   | Name    | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|---------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | FINTVTG | R/W       | Frame Interval Toggle.<br>The HCD toggles this bit whenever it loads a new value to FrameInterval.                                                                                                                                                                                                                                                                                                                                                       |
| 30-16 | FSLDP   | R/W       | FS Largest Data Packet.<br>This field specifies a value that is loaded into the Largest Data Packet Counter at the<br>beginning of each frame. The counter value represents the largest amount of data in bits<br>which can be sent or received by the HC in a single transaction at any given time without<br>causing scheduling overrun. The field value is calculated by the HCD.                                                                     |
| 15-14 | Rsvd    | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 13-0  | FINTV   | R/W       | Frame Interval.<br>This specifies the interval between two consecutive SOFs in bit times. The nominal value is<br>set to be 11,999.<br>The HCD should store the current value of this field before resetting the HC. By setting the<br>HCTRS field in the HC Command Status Register as this will cause the HC to reset this field<br>to its nominal value. The HCD may choose to restore the stored value upon the completion<br>of the Reset sequence. |



FNB

| Register Offset: | 38h                      |
|------------------|--------------------------|
| Register Name:   | HC Fm Remaining Register |
| Reset Value :    | 0000000h                 |

#### 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

| FR |          |     |
|----|----------|-----|
| MT | Reserved | FRM |
| G  |          |     |

The HC Fm Remaining Register is a 14-bit down counter showing the bit time remaining in the current Frame.

| Bit   | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                        |  |
|-------|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31    | FRMTG | RO        | Frame Remaining Toggle.<br>This bit is loaded from the Frame Interval Toggle field in the HC Fm Interval Register<br>whenever Frame Remaining reaches 0. This bit is used by the HCD for the synchronization<br>between Frame Interval and Frame Remaining.                                                                                                                                        |  |
| 30-14 | Rsvd  | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 13-0  | FRM   | RO        | Frame Remaining.<br>This counter is decremented at each bit time. When it reaches zero, it is reset by loading the<br>Frame Interval value specified in the HC Fm Interval Register at the next bit time boundary.<br>When entering the USB Operational state, the HC re-loads the content with the Frame<br>Interval in the HC Fm Interval Register and uses the updated value from the next SOF. |  |

| Register Offset:  | 3Ch                                                                   |
|-------------------|-----------------------------------------------------------------------|
| Register Name:    | HC Fm Number Register                                                 |
| Reset Value :     | 0000000h                                                              |
| 31 30 29 28 27 26 | 6 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

The HC Fm Number Register is a 16-bit counter. It provides a timing reference among events occurring in the Host Controller and the Host Controller Driver. The Host Controller Driver may use the 16-bit value specified in this register and generate a 32-bit frame number without requiring frequent access to the register.

| Bit                                                                                                                                                                                                  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-16                                                                                                                                                                                                | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 15-0FNBROFrame Number.<br>This is incremented when HcFmRemainin<br>When the USB Operational state is enter<br>contents will be written to HCCA after the<br>frame boundary and sent a SOF but before |      | RO        | Frame Number.<br>This is incremented when HcFmRemaining is re-loaded. It will be rolled over to 0h after ffffh.<br>When the USB Operational state is entered, this will be incremented automatically. The<br>contents will be written to HCCA after the HC has incremented the Frame Number at each<br>frame boundary and sent a SOF but before the HC reads the first ED in that Frame. After<br>writing to HCCA, the HC will set the Start of Frame in HC Interrupt Status. |  |



| Register Offset: | 40h                        |
|------------------|----------------------------|
| Register Name:   | HC Periodic Start Register |
| Reset Value :    | 0000000h                   |

|--|

The Hc Periodic Start Register has a 14-bit programmable value that determines the earliest time the HC should start processing the periodic list.

| Bit   | Name                                                                                                                                                                                                                                                                                                    | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-14 | Rsvd                                                                                                                                                                                                                                                                                                    | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 13-0  | 13-0       PRS       R/W       Periodic Start<br>After a hardware reset, this field is cleared.<br>initialization. The value is calculated roughly<br>typical value will be 3E67h. When HC Fm Re<br>processing of the periodic lists will have prio<br>therefore start processing the Interrupt list at |           | Periodic Start<br>After a hardware reset, this field is cleared. This is then set by the HCD during the HC<br>initialization. The value is calculated roughly as 10% off from the HC Fm Interval Register. A<br>typical value will be 3E67h. When HC Fm Remaining reaches the value specified,<br>processing of the periodic lists will have priority over Control/Bulk processing. The HC will<br>therefore start processing the Interrupt list after completing the current Control or Bulk<br>transaction that is in progress. |

| Register Offset:  | 44h                                                                   |
|-------------------|-----------------------------------------------------------------------|
| Register Name:    | HC LS Threshold Register                                              |
| Reset Value :     | 0000000h                                                              |
| 31 30 29 28 27 26 | 3 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 | LSTSH |
|----------|-------|

The HC LS Threshold register contains an 11-bit value used by the Host Controller to determine whether it is necessary to commit to the transfer of a maximum of 8-byte LS packets before EOF. Neither the Host Controller nor the Host Controller Driver is allowed to change this value.

| Bit   | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                        |  |
|-------|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-12 | Rsvd  | RO        | Reserved.                                                                                                                                                                                                                                                                                                          |  |
| 11-0  | LSTSH | R/W       | LS Threshold.<br>This field contains a value that is compared to the Frame Remaining field prior to initiating a<br>Low Speed transaction. The transaction is started only if Frame Remaining $\geq$ this field. The<br>value is calculated by the HCD with the consideration of transmission and set-up overhead. |  |

### 13.5.2.5 Root Hub Partition

All registers included in this partition are dedicated to the USB Root Hub which is an integral part of the Host Controller though still a functionally separate entity. The HCD emulates USBD accesses to the Root Hub via a register interface. The HCD maintains many USB-defined hub features that are not required to be supported in hardware. For example, the Hub's Device, Configuration, Interface, and Endpoint Descriptors are maintained only in the HCD as well as some static fields of the Class Descriptor. The HCD also maintains and decodes the Root Hub's device address as well as other trivial operations that are better suited to software than hardware.

The Root Hub register interface is otherwise developed to maintain similarity of bit organization and operation to typical hubs that are found in the system. Below are four register definitions: HC Rh Descriptor A, HC Rh Descriptor B, HC Rh Status, and HC Rh Port Status [5:1]. Each register is read and written as a Dword. These registers are only written during initialization to correspond with the system implementation. The HC Rh Descriptor A and HC Rh Descriptor B registers should be implemented such that they are writable regardless of the HC USB state. HC Rh Status and HC Rh Port Status must be writable during the USB Operational state.

| Register Offset: | 48h                                                                    |
|------------------|------------------------------------------------------------------------|
| Register Name:   | HC Rh Discriptor A Register                                            |
| Reset Value :    | 01001102h                                                              |
| 31 30 29 28 27 2 | 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 |

| POPGT | Reserved | NO OC<br>CR RP DV NP PS<br>PT TM T SW WM | NBDSTP |
|-------|----------|------------------------------------------|--------|

The HC Rh Descriptor A Register is the first register of two describing characteristics of the Root Hub. Reset values are implementation-specific. All other fields are located in the HC Rh Descriptor A and HC Rh Descriptor B registers.

| Bit   | Name   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24 | POPGT  | R/W       | Power On to Power Good Time.<br>This byte specifies the duration the HCD has to wait before a powered-on port of the Root<br>Hub is accessed. It is implementation-specific. The unit of time is 2 ms. The duration is<br>calculated as POTPGT * 2 ms.                                                                                                                                                                    |
| 23-13 | Rsvd   | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12    | NOCRPT | R/W       | No Over Current Protection.<br>This bit describes how the over-current status for the Root Hub ports is reported. When this bit is cleared, the Over Current Protection Mode field specifies global or per-port reporting.<br>0: Over-current status is reported collectively for all downstream ports.<br>1: No over-current protection supported.                                                                       |
| 11    | OCRPTM | R/W       | Over Current Protection Mode.<br>This bit describes how the over-current status for the Root Hub ports is reported. At reset,<br>this field should reflect the same mode as Power Switching Mode. This field is valid only if<br>the No Over Current Protection field is cleared.<br>0: Over-current status is reported collectively for all downstream ports.<br>1: Over-current status is reported on a per-port basis. |
| 10    | DVT    | RO        | Device Type<br>This bit specifies that the Root Hub is not a compound device. The Root Hub is not permitted<br>to be a compound device. This field should always read/write 0.                                                                                                                                                                                                                                            |
| 9     | NPSW   | R/W       | No Power Switching.<br>These bits are used to specify whether power switching is supported or ports are always<br>powered. USB HC supports global power switching mode. When this bit is cleared, the<br>Power Switching Mode specifies global or per-port switching.<br>0: Ports are power switched.<br>1: Ports are always powered on when the HC is powered on.                                                        |
| 8     | PSWM   | R/W       | Power Switching Mode.<br>This bit is used to specify how the power switching of the Root Hub ports is controlled. USB                                                                                                                                                                                                                                                                                                     |



|     |        |    | field is cleared.<br>0: all ports are powered at the s<br>1: Each port is powered individ<br>the global switch or per-port sw<br>If the Port Power Control Mask | ually. This mode allows port pov<br>vitching.<br>bit is set, the port responds only<br>ort mask is cleared, the port is o | ver to be controlled by either<br>y to port power commands |
|-----|--------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
| 7-0 | NBDSTP | RO | Both of the HCs support three of In A version it can be program                                                                                                 |                                                                                                                           | olled by SB CFG 6C bit 0                                   |
|     |        |    | NDP's value                                                                                                                                                     | SB CFG 6C bit0 or bit2                                                                                                    | SB CFG 6C bit1 or bit3                                     |
|     |        |    | 01h                                                                                                                                                             | 1                                                                                                                         | Х                                                          |
|     |        |    | 02h                                                                                                                                                             | 0                                                                                                                         | 1                                                          |
|     |        |    | 03h                                                                                                                                                             | 0                                                                                                                         | 0                                                          |

| Register Offse<br>Register Name<br>Reset Value | scrip<br>)h | tor E | 8 Re  | giste | er |    |    |    |    |    |    |    |    |    |    |    |   |    |    |   |   |   |   |   |   |   |
|------------------------------------------------|-------------|-------|-------|-------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|---|---|---|---|---|---|
| 31 30 29 28                                    | 27 26       | 25    | 24 2; | 3 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                                |             | Р     | PWCT  | М     |    |    |    |    |    |    |    |    |    |    |    |    |   | DV | RM |   |   |   |   |   |   |   |

The HC Rh Descriptor B Register is the second register of two describing the characteristics of the Root Hub. These fields are written during initialization to configure the Root Hub.

| Bit   | Name   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|--------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | PPWCTM | R/W       | Port Power Control Mask.<br>Each bit indicates if a port is affected by a global power control command when Power<br>Switching Mode is set. When set, the port's power state is only affected by per-port power<br>control (Set/Clear Port Power). When cleared, the port is controlled by the global power<br>switch (Set/Clear Global Power). If the device is configured to global switching mode (Power<br>Switching Mode=0), this field is not valid.<br>USB HC implements global power switching.<br>bit 0: Reserved<br>bit 1: Ganged-power mask on Port #1<br>bit 2: Ganged-power mask on Port #2<br><br>bit15: Ganged-power mask on Port #15 |
| 15-0  | DVRM   | R/W       | Device Removable.<br>Each bit is dedicated to a port of the Root Hub. When cleared, the attached device is<br>removable. When set, the attached device is not removable.<br>bit 0: Reserved<br>bit 1: Device attached to Port #1<br>bit 2: Device attached to Port #2<br><br>bit15: Device attached to Port #15                                                                                                                                                                                                                                                                                                                                      |



| Register Offset: | 50h                   |
|------------------|-----------------------|
| Register Name:   | HC Rh Status Register |
| Reset Value :    | 00000000h             |

| 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       |
|--------------------|----|----|----|----|----|----|-------|-----|----|----|----|----|----|----------------|----------|----------|----|----|----|----|----|----|-------|-----|---|---|---|---|---|-----------|---------|
| CR<br>M<br>WE<br>n |    |    |    |    |    | Re | eserv | ved |    |    |    |    |    | OC<br>RID<br>C | LP<br>SC | DR<br>WE |    |    |    |    |    | Re | eserv | ved |   |   |   |   |   | OC<br>RID | LP<br>S |

The HC Rh Status Register is divided into two parts. The lower word of a Dword represents the Hub Status field and the upper word represents the Hub Status Change field. Reserved bits should always be written '0'.

| Bit   | Name   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | CRMWEn | WO        | Clear Remote Wakeup Enable <b>(Write).</b><br>Writing a '1' clears Device Remove Wakeup Enable. Writing a '0' has no effect.                                                                                                                                                                                                                                                                                                                                                               |
| 31-18 | Rsvd   | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 17    | OCRIDC | R/W       | Over Current Indicator Change.<br>This bit is set by hardware when a change has occurred to the OCI field of this register.<br>The HCD clears this bit by writing a '1'.Writing a '0' has no effect.                                                                                                                                                                                                                                                                                       |
| 16    | LPSC   | R/W       | Local Power Status Change ( <b>Read</b> ).<br>The Root Hub does not support the local power status feature; thus, this bit is always read<br>as '0'.<br>Set Global Power ( <b>Write</b> ).<br>In global power mode (Power Switching Mode=0), this bit is written to '1' to turn on power to<br>all ports (clear Port Power Status). In per-port power mode, it sets Port Power Status only on<br>ports whose Port Power Control Mask bit is not set. Writing a '0' has no effect.          |
| 15    | DRWE   | RO        | <ul> <li>Device Remote Wakeup Enable (Read).</li> <li>This bit enables a Connect Status Change bit as a resume event, causing an USB Suspend to USB Resume state transition and setting Resume Detected interrupt.</li> <li>0: Connect Status Change is not a remote wakeup event.</li> <li>1: Connect Status Change is a remote wakeup event.</li> <li>Set Remote Wakeup Enable (Write).</li> <li>Writing a '1' sets Device Remove Wakeup Enable. Writing a '0' has no effect.</li> </ul> |
| 14-2  | Rsvd   | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1     | OCRID  | RO        | Over Current Indicator.<br>This bit reports over-current conditions when the global reporting is implemented. When set,<br>an over-current condition exists. When cleared, all power operations are normal. If per-port<br>over-current protection is implemented, this bit is always '0'                                                                                                                                                                                                  |
| 0     | LPS    | R/W       | Local Power Status ( <b>Read</b> ).<br>The Root Hub does not support the local power status feature; thus, this bit is always read<br>as '0'.<br>Clear Global Power ( <b>Write</b> ).<br>In global power mode (Power Switching Mode=0), This bit is written to '1' to turn off power to<br>all ports (clear Port Power Status). In per-port power mode, it clears Port Power Status only<br>on ports whose Port Power Control Mask bit is not set. Writing a '0' has no effect.            |

| Register Offset: | 54h/58h                          |
|------------------|----------------------------------|
| Register Name:   | HC Rh Port Status [2:1] Register |
| Reset Value :    | 0000000h                         |

## 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 PR PR CRI PS PEN CN Reserve | ed $\begin{array}{c} LS \\ DV \\ A \end{array} \begin{array}{c} PP \\ S \end{array} \begin{array}{c} Reserved \\ S \end{array} \begin{array}{c} PR \\ S \end{array} \begin{array}{c} PO \\ S \end{array} \begin{array}{c} PS \\ PS \end{array} \begin{array}{c} PE \\ S \end{array} \begin{array}{c} CC \\ S \end{array} \begin{array}{c} CC \\ S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} PE \\ S \end{array} \begin{array}{c} CC \\ S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} PE \\ S \end{array} \begin{array}{c} CC \\ S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} PE \\ S \end{array} \begin{array}{c} CC \\ S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} PE \\ S \end{array} \begin{array}{c} S \end{array} \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \end{array} \begin{array}{c} S \end{array} \begin{array}{c} S \end{array} \end{array} \end{array} \begin{array}{c} S \end{array} \end{array} \begin{array}{c} S \end{array} \end{array} \end{array} \begin{array}{c} S \end{array} \end{array} \end{array} \begin{array}{c} S \end{array} \end{array} \end{array} \end{array} \begin{array}{c} S \end{array} \end{array} \end{array} \end{array} \begin{array}{c} S \end{array} $ |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

The HC Rh Port Status [2:1] registers are used to control and report port events on a per-port basis. Two HC Rh Port Status registers are implemented in this HC, respectively. The lower word is used to reflect the port status, whereas the upper word reflects the status change bits. Some status bits are implemented with special write behaviour (see below). If a transaction (token through handshake) is in progress when a write to change port status occurs, the resulting port status change must be postponed until the transaction is completed. Reserved bits should always be written as '0'. While the NDP of register 48h is 01h, the register 58 and register 5C will be read as 0000000h. While the NDP of register 48h is 02h, only register 5C is read as 0000000h.

| Bit   | Name    | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-21 | Rsvd    | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 20    | PRSC    | R/W       | Port Reset Status Change.<br>This bit is set at the end of the 10-ms port reset signal.<br>The HCD writes a '1' to clear this bit. Writing a '0' has no effect.<br>0: port reset is not complete<br>1: port reset is complete                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 19    | POCRIDC | R/W       | Port Over Current Indicator Change.<br>This bit is valid only if over-current conditions are reported on a per-port basis. This bit is set<br>when Root Hub changes the Port Over Current Indicator bit. The HCD writes a '1' to clear<br>this bit. Writing a '0' has no effect.<br>0: no change in Port Over Current Indicator<br>1: Port Over Current Indicator has changed                                                                                                                                                                                                                                                                                                                          |
| 18    | PSPSC   | R/W       | Port Suspend Status Change.<br>This bit is set when the full resume sequence has been completed. This sequence includes<br>the 20-s resume pulse, LS EOP, and 3-ms resynchronization delay. The HCD writes a '1' to<br>clear this bit. Writing a '0' has no effect. This bit is also cleared when Reset Status Change is<br>set.<br>0: resume is not completed<br>1: resume completed                                                                                                                                                                                                                                                                                                                  |
| 17    | PEnSC   | R/W       | Port Enable Status Change.<br>This bit is set when hardware events cause the Port Enable Status bit to be cleared.<br>Changes from the HCD writes do not set this bit. The HCD writes a '1' to clear this bit.<br>Writing a '0' has no effect.<br>0: no change in Port Enable Status<br>1: change in Port Enable Status                                                                                                                                                                                                                                                                                                                                                                                |
| 16    | CNSC    | R/W       | <ul> <li>Connect Status Change.</li> <li>This bit is set whenever a connect or disconnect event occurs. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. If Current Connect Status is cleared when a Set Port Reset, Set Port Enable, or Set Port Suspend write occurs, this bit is set to force the driver to re-evaluate the connection status since these writes should not occur if the port is disconnected.</li> <li>0: no change in Current Connect Status.</li> <li>1: change in Current Connect Status.</li> <li>Note: If the Device Removable [NDP] bit is set, this bit is set only after a Root Hub reset to inform the system that the device is attached.</li> </ul> |
| 15-10 | Rsvd    | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



| 9   | LSDVA | R/W | Low Speed Device Attached ( <b>Read</b> ).<br>This bit indicates the speed of the device attached to this port. When set, a Low-Speed<br>device is attached to this port. When cleared, a Full Speed device is attached to this port.<br>This field is valid only when the Current Connect Status is set.<br>0: full-speed device attached<br>1: low-speed device attached                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | PPS   | R/W | Port Power Status ( <b>Read</b> ).<br>This bit reflects the port's power status, regardless of the type of power switching<br>implemented. This bit is cleared if an over-current condition is detected. The HCD sets this<br>bit by writing Set Port Power or Set Global Power. The HCD clears this bit by writing Clear<br>Port Power or Clear Global Power. Which power control switches will be enabled is<br>determined by Power Switching Mode and Port Power Control Mask [NDP]. In global<br>switching mode (Power Switching Mode=0), only Set/Clear Global Power controls this bit.<br>In per-port power switching (Power Switching Mode=1), if the Port Power Control Mask<br>[NDP] bit for the port is set, only Set/ClearPortPower commands are enabled. If the mask is<br>not set, only Set/ Clear Global Power commands are enabled. When port power is disabled,<br>Current Connect Status, Port Enable Status, Port Suspend Status, and Port Reset Status<br>should be reset.<br>0: port power is off<br>1: port power is on<br>Set Port Power (Write)<br>The HCD writes a '1' to set the Port Power Status bit. Writing a '0' has no effect.<br><i>Note: This bit is always reads '1b' if power switching is not supported.</i> |
| 7-5 | Rsvd  | RO  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4   | PRS   | R/W | Port Reset Status ( <b>Read</b> ).<br>When this bit is set by a write to Set Port Reset, port reset signaling is asserted. When reset<br>is completed, this bit is cleared when Port Reset Status Change is set. This bit cannot be set<br>if Current Connect Status is cleared.<br>0: port reset signal is not active<br>1: port reset signal is active<br>Set Port Reset ( <b>Write</b> ).<br>The HCD sets the port reset signaling by writing a '1' to this bit. Writing a '0' has no effect. If<br>Current Connect Status is cleared, this write does not set Port Reset Status, but instead sets<br>Connect Status Change. This informs the driver that it attempted to reset a disconnected<br>port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3   | POCI  | R/W | Port Over Current Indicator ( <b>Read</b> ).<br>This bit is only valid when the Root Hub is configured in such a way that over-current<br>conditions are reported on a per-port basis. If per-port over-current reporting is not<br>supported, this bit is set to 0. If cleared, all power operations are normal for this port. If set,<br>an over-current condition exists on this port. This bit always reflects the over-current input<br>signal<br>0: no over-current condition.<br>1: over-current condition detected.<br>Clear Suspend Status ( <b>Write</b> ).<br>The HCD writes a '1' to initiate a resume. Writing a '0' has no effect. A resume is initiated<br>only if Port Suspend Status is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2   | PSS   | R/W | Port Suspend Status ( <b>Read</b> ).<br>This bit indicates the port is suspended or in the resume sequence. It is set by a Set<br>Suspend State write and cleared when Port Suspend Status Change is set at the end of the<br>resume interval. This bit cannot be set if Current Connect Status is cleared. This bit is also<br>cleared when Port Reset Status Change is set at the end of the port reset or when the HC is<br>placed in the USB Resume state. If an upstream resume is in progress, it should propagate<br>to the HC.<br>0: port is not suspended.<br>1: port is suspended.<br>Set Port Suspend ( <b>Write</b> ).<br>The HCD sets the Port Suspend Status bit by writing a '1' to this bit. Writing a '0' has no<br>effect. If Current Connect Status is cleared, this write does not set Port Suspend Status;<br>instead it sets Connect Status Change. This informs the driver that it attempts to suspend a<br>disconnected port.                                                                                                                                                                                                                                                                                            |



| 1 | PES | R/W | Port Enable Status ( <b>Read</b> ).<br>This bit indicates whether the port is enabled or disabled. The Root Hub may clear this bit<br>when an over-current condition, disconnect event, switched-off power, or operational bus<br>error such as babble is detected. This change also causes Port Enabled Status Change to<br>be set. The HCD sets this bit by writing Set Port Enable and clears it by writing Clear Port<br>Enable. This bit cannot be set when Current Connect Status is cleared. This bit is also set, if<br>not already, at the completion of a port reset when Reset Status Change is set or a port<br>suspend when Suspend Status Change is set.<br>0: port is disabled.<br>1: port is enabled.<br>Set Port Enable ( <b>Write</b> ).<br>The HCD sets Port Enable Status by writing a '1'. Writing a '0' has no effect. If Current<br>Connect Status is cleared, this write does not set Port Enable Status, but instead sets<br>Connect Status Change. This informs the driver that it attempts to enable a disconnected<br>port. |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | CCS | R/W | Current Connect Status ( <b>Read</b> ).<br>This bit reflects the current state of the downstream port.<br>0: no device connected.<br>1: device connected.<br>Clear Port Enable ( <b>Write</b> ).<br>The HCD writes a '1' to this bit to clear the Port Enable Status bit. Writing a '0' has no effect.<br>Current Connect Status is not affected by any write.<br><b>Note:</b> This bit is always read as '1b' when the attached device is non-removable (Device<br>Removeable [NDP]).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

### 13.5.2.6 Legacy Support Registers

Four operational registers are used to provide the legacy support. Each of these registers is located on a 32-bit boundary. The offset of these registers is relative to the base address of the Host Controller operational registers with HceControl located at offset 100h.

| Offset | Register     | Description                                                                                                |
|--------|--------------|------------------------------------------------------------------------------------------------------------|
| 100h   | H(:e(:ontrol | Used to enable and control the emulation hardware and report various status informations.                  |
| 104h   | HC eInput    | Emulation side of the legacy Input Buffer register.                                                        |
| 108h   |              | Emulation side of the legacy Output Buffer register where keyboard and mouse data are written by software. |
| 10Ch   | HC eStatus   | Emulation side of the legacy Status register.                                                              |

Table 13.1: Legacy Support Registers

Three of the operational registers (HC eStatus, HC eInput and HC eOutput) are accessible at I/O address 60h and 64h when emulation is enabled. Reads and writes to the registers using I/O addresses have side effects as outlined in the Table 13.1.

| I/O Address | Cycle Type | Register Contents<br>Accessed/Modified | Side Effects                                                                   |
|-------------|------------|----------------------------------------|--------------------------------------------------------------------------------|
| 60h         | IN         | HC eOutput                             | IN from port 60h will set OutputFull in<br>HceStatus to 0                      |
| 60h         | OUT        | HC eInput                              | OUT to port 60h will set InputFull to 1 and CmdData to 0 in HceStatus.         |
| 64h         | IN         | HC eStatus                             | IN from port 64h returns current value of HceStatus with no other side effect. |
| 64h         | OUT        | HC eInput                              | OUT to port 64h will set InputFull to 0<br>and CmdData in HceStatus to 1.      |

### Table 13.2: Emulated Registers

| Register Offset: | 100h                 |
|------------------|----------------------|
| Register Name:   | HC eControl Register |
| Reset Value :    | 00000000h            |

#### 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 A20 RQ RQ GA RQ RQ GA RQ FTI RQ CT EM EM S 12A 1A 20S En PD T EN T                                                                                                                                                                                                                     |
|------|---------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit  | Name    | Attribute | Description                                                                                                                                                                                                                                                                                     |
| 31-9 | Rsvd    | RO        | Reserved.                                                                                                                                                                                                                                                                                       |
| 8    | A20S    | R/W       | A20 State.<br>Indicates current state of Gate A20 on keyboard controller. Used to compare value to 60h<br>when Gate A20 Sequence is active.                                                                                                                                                     |
| 7    | IRQ12A  | R/W       | IRQ12 Active<br>Indicates that a positive transition on IRQ12 from keyboard controller has occurred. SW may<br>write a 1 to this bit to clear it (set it to 0). SW write of a 0 to this bit has no effect.                                                                                      |
| 6    | IRQ1A   | R/W       | IRQ1 Active.<br>Indicates that a positive transition on IRQ1 from keyboard controller has occurred. SW may<br>write a 1 to this bit to clear it (set it to 0). SW write of a 0 to this bit has no effect.                                                                                       |
| 5    | GA20S   | R/W       | Gate A20 Sequence.<br>Set by the HC when a data value of D1h is written to I/O port 64h; cleared by the HC on<br>writes to I/O port 64h of any value other than D1h.                                                                                                                            |
| 4    | ETIRQEn | R/W       | External IRQ Enable.<br>When set to 1, IRQ1 and IRQ12 from the keyboard controller cause an emulation interrupt.<br>The function controlled by this bit is independent of the setting of the Emulation Enable bit in<br>this register.                                                          |
| 3    | IRQEn   | R/W       | IRQ Enable.<br>When set, the HC generates IRQ1 or IRQ12 as long as the Output Full bit in HC eStatus is<br>set to 1. If the Aux Output Full bit of HC eStatus is 0, then IRQ1 is generated; if it is 1, then<br>an IRQ12 is generated.                                                          |
| 2    | CTPD    | R/W       | Character Pending.<br>When set, an emulation interrupt is generated when the Output Full bit in the HC eStatus<br>Register is set to 0.                                                                                                                                                         |
| 1    | EMLINT  | RO        | Emulation Interrupt.<br>This bit is a static decode of the emulation interrupt condition                                                                                                                                                                                                        |
| 0    | EMLEn   | R/W       | Emulation Enable.<br>When set to 1, the HC is enabled for legacy emulation. The HC decodes accesses to I/O registers 60h and 64h and generates IRQ1 and/or IRQ12 when appropriate. Additionally, the HC generates an emulation interrupt at appropriate times to invoke the emulation software. |



| Register Offset: | 104h               |
|------------------|--------------------|
| Register Name:   | HC eInput Register |
| Reset Value :    | 00000000h          |

Reserved

OPD

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7-0  | IPD  | R/W       | Input Data<br>This register holds data that is written to I/O ports 60h and 64h.<br>I/O data that is written to ports 60h and 64h is captured in this register when emulation is<br>enabled. This register may be read or written directly by accessing it with its memory address<br>in the Host Controller's operational register space. When accessed directly with a memory<br>cycle, reads and writes of this register have no side effects. |

| Register Offset:  | 108h                                                                |
|-------------------|---------------------------------------------------------------------|
| Register Name:    | HC eOutnput Register                                                |
| Reset Value :     | 0000000h                                                            |
|                   |                                                                     |
| 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 |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                                                                                                                                |
|------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | Rsvd | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                  |
| 7-0  | OPD  | R/W       | Output Data<br>This register hosts data that is returned when an I/O read of port 60h is performed by<br>application software.<br>The data placed in this register by the emulation software is returned when I/O port 60h is<br>read and emulation is enabled. On a read of this location, the Output Full bit in the HC<br>eStatus Register is set to 0. |



IPF OP F



| Register Offset: | 10Ch                |
|------------------|---------------------|
| Register Name:   | HC eStatus Register |
| Reset Value :    | 00000000h           |

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



| Bit  | Name  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | Rsvd  | RO        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | PRT   | R/W       | Parity.<br>Indicates parity error on keyboard/mouse data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6    | TOUT  | R/W       | Time-out.<br>Used to indicate a time-out                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5    | AOF   | R/W       | Aux Output Full.<br>IRQ12 is asserted whenever this bit is set to 1 and Output Full is set to 1 and the IRQEn bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4    | IHBSW | R/W       | Inhibit Switch.<br>This bit reflects the state of the keyboard inhibit switch and is set if the keyboard is NOT<br>inhibited.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3    | CD    | R/W       | Cmd Data.<br>The HC sets this bit to 0 on an I/O write to port 60h and to 1 on an I/O write to port 64h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2    | F     | R/W       | Flag.<br>Nominally used as a system flag by software to indicate a warm or cold boot.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1    | IPF   | R/W       | Input Full.<br>Except for the case of a Gate A20 sequence, this bit is set to 1 on an I/O write to address<br>60h or 64h. While this bit is set to 1 and emulation is enabled, an emulation interrupt<br>condition exists.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0    | OPF   | R/W       | Output Full.<br>The HC sets this bit to 0 on a read of I/O port 60h. If IRQEn is set and Aux Output Full is set<br>to 0, then an IRQ1 is generated as long as this bit is set to 1. If IRQEn is set and Aux Output<br>Full is set to 1, then an IRQ12 is generated as long as this bit is set to 1. While this bit is 0<br>and Character Pending in the HC eControl Register is set to 1, an emulation interrupt<br>condition exists.<br>The contents of the HC eStatus Register are returned on an I/O Read of port 64h when<br>emulation is enabled. Reads and writes of port 60h and writes to port 64h can cause changes<br>in this register. Emulation software can directly access this register through its memory<br>address in the Host Controller's operational register space. Accessing this register through its<br>memory address produces no side effects. |

### 13.5.3 EHCI Configuration Space

| 13.5.3.1 USB2.0 Configuration Space |
|-------------------------------------|
|-------------------------------------|

| Regis | ster Off<br>ster Na<br>t Value | me: | 01h –<br>Vend<br>17F3 | or ID Re | egister |   |   |    |   |   |   |   |   |   |   |
|-------|--------------------------------|-----|-----------------------|----------|---------|---|---|----|---|---|---|---|---|---|---|
| 15    | 14                             | 13  | 12                    | 11       | 10      | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |                                |     |                       |          |         |   | V | ID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description |
|------|------|-----------|-------------|
| 15-0 | VID  | RO        | Vendor ID.  |

| Register Offset:<br>Register Name:<br>Reset Value : |    |    | Devic | 03h – 02h<br>Device ID Register<br>6061h |    |   |   |    |   |   |   |   |   |   |   |
|-----------------------------------------------------|----|----|-------|------------------------------------------|----|---|---|----|---|---|---|---|---|---|---|
| 15                                                  | 14 | 13 | 12    | 11                                       | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                                     |    |    |       |                                          |    |   | D | ID |   |   |   |   |   |   |   |

| Bit  | Name | Attribute | Description |
|------|------|-----------|-------------|
| 15-0 | DID  | RO        | Device ID.  |

| -  | Register Offset:05h – 04hRegister Name:Command Register |    |         |    |    |   |       |   |   |         |   |   |            |     |      |  |
|----|---------------------------------------------------------|----|---------|----|----|---|-------|---|---|---------|---|---|------------|-----|------|--|
| -  | t Value                                                 |    | 0000    |    | 5  |   |       |   |   |         |   |   |            |     |      |  |
| 15 | 14                                                      | 13 | 12      | 11 | 10 | 9 | 8     | 7 | 6 | 5       | 4 | 3 | 2          | 1   | 0    |  |
|    |                                                         |    | Reserve | d  |    |   | SDTEn |   | F | Reserve | d |   | PCIME<br>n | MEn | IOEn |  |

| Bit  | Name   | Attribute | Description                                                                                                                                                        |
|------|--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-9 | Rsvd   | RO        | Reserved bits.<br>These bits are always 0.                                                                                                                         |
| 8    | SDTEn  |           | SERR_n (Response) Detection Enable bit<br>If set to 1, the EHC asserts SERR_n when it detects an address parity error. SERR_n is not<br>asserted if this bit is 0. |
| 7-3  | Rsvd   | RO        | Reserved bits<br>These bits are always 0.                                                                                                                          |
| 2    | PCIMEn |           | PCI Master Enable<br>If set to 1, the EHC is enabled to run PCI master cycles.                                                                                     |



| 1 | MEn  | R/W | Memory Enable.<br>If set to 1, the EHC is enabled to respond as a target to memory cycles. |
|---|------|-----|--------------------------------------------------------------------------------------------|
| 0 | IOEn | RO  | I/O Enable.<br>This bit is always 0.                                                       |

| Regis | ster Off | set: | 07h –  | 06h             |    |    |      |   |      |       |   |      |   |          |   |
|-------|----------|------|--------|-----------------|----|----|------|---|------|-------|---|------|---|----------|---|
| Regis | ster Na  | me:  | Status | Status Register |    |    |      |   |      |       |   |      |   |          |   |
| Rese  | t Value  | :    | 0280ł  | n               |    |    |      |   |      |       |   |      |   |          |   |
| 15    | 14       | 13   | 12     | 11              | 10 | 9  | 8    | 7 | 6    | 5     | 4 | 3    | 2 | 1        | 0 |
| DTPRE | SERRS    | RMAS | RTAS   | SNTAS           | DV | ST | DPRP |   | Rese | erved |   | INTS | F | Reserved | Ł |

| Bit  | Name  | Attribute | Description                                                                                                                                                                              |
|------|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | DTPRE | RO        | Detected Parity Error.<br>This bit is always 0.                                                                                                                                          |
| 14   | SERRS | R/W       | SERR_n Status.<br>This bit is set to 1 whenever the EHC detects a PCI address parity error. Cleared by writing a<br>1 to it.                                                             |
| 13   | RMAS  | R/W       | Received Master Abort Status.<br>This bit is set to 1 when the EHC receives a master-abort status on a PCI bus memory cycle.<br>Cleared by writing a 1 to it.                            |
| 12   | RTAS  | R/W       | Received Target Abort Status.<br>This bit is set to 1 when the EHC receives a target-abort status on a PCI bus memory cycle.<br>Cleared by writing a 1 to it.                            |
| 11   | SNTAS | R/W       | Signaled Target Abort Status.<br>This bit is set to 1 when the EHC responds to a memory cycle with a target abort. Cleared by<br>writing a 1 to it.                                      |
| 10-9 | DVST  | RO        | DEVSEL_n timing.<br>Read-only bits indicating DEVSEL_n timing when performing a positive decode. Since<br>DEVSEL_n is asserted to meet the medium timing, these bits are encoded as 01b. |
| 8    | DPRP  | R/W       | Data Parity Reported.<br>Set to 1 if the Parity Error Response bit is set, and the EHC detects PERR_n asserted while acting as PCI master (whether PERR_n was driven by the EHC or not). |
| 7-4  | Rsvd  | RO        | Reserved bits<br>These bits are always 0.                                                                                                                                                |
| 3    | INTS  | R/O       | Interrupt Status.<br>This bit reflects the state of the interrupt in the device.                                                                                                         |
| 2-0  | Rsvd  | RO        | Reserved bits.<br>These bits are always 0                                                                                                                                                |

1

0

| Register Offset: | 08h                  |
|------------------|----------------------|
| Register Name:   | Revision ID Register |
| Reset Value :    | 00h                  |
|                  |                      |

### 7 6 5 4 3 2 1 0

FTRVL

| Bit | Name  | Attribute | Description                |
|-----|-------|-----------|----------------------------|
| 7-0 | FTRVL | RO        | Functional Revision Level. |

| Register Offset: | 0Bh – 09h                                     |
|------------------|-----------------------------------------------|
| Register Name:   | Class Code Register                           |
| Reset Value :    | 0C0320h                                       |
| 23 22 21 20      | 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 |

| BCLS | SUBCLS | PRGINTE |
|------|--------|---------|
| 2020 | 002010 |         |
|      |        |         |

| Bit   | Name                  | Attribute | Description                                                   |  |  |  |  |  |  |  |
|-------|-----------------------|-----------|---------------------------------------------------------------|--|--|--|--|--|--|--|
| 23-16 | BCLS                  | RO        | Base Class.<br>The Base Class is 0Ch (Serial Bus Controller). |  |  |  |  |  |  |  |
| 15-8  | SUBCLS                | Sub Class |                                                               |  |  |  |  |  |  |  |
| 7-0   | Programming Interface |           |                                                               |  |  |  |  |  |  |  |

| Regis | ster Off | set: | 0Ch                      |   |   |   |  |  |  |  |  |
|-------|----------|------|--------------------------|---|---|---|--|--|--|--|--|
| Regis | ster Na  | me:  | Cache Line Size Register |   |   |   |  |  |  |  |  |
| Rese  | t Value  | :    | 00h                      |   |   |   |  |  |  |  |  |
| 7     | 6        | 5    | 4                        | 3 | 2 | 1 |  |  |  |  |  |

CCHLSZ

 
 Bit
 Name
 Attribute
 Description

 7-0
 CCHLSZ
 R/W
 Cache Line Size. This register identifies the system cache line size in units of 32-bit words. The ECH will only store the value of bit 3 in this register since the cache line size of 32 bytes is the only value applicable to the design. Any value other than 08h written to this register will be read back as 00h.

| Regi | Register Offset:<br>Register Name:<br>Reset Value :<br>7 6 5 |     | 0Dh                    |       |   |   |  |  |  |
|------|--------------------------------------------------------------|-----|------------------------|-------|---|---|--|--|--|
| Regi | ster Na                                                      | me: | Latency Timer Register |       |   |   |  |  |  |
| Rese | t Value                                                      | :   | 00h                    |       |   |   |  |  |  |
| 7    | 6                                                            | 5   | 4                      | 3     | 2 | 1 |  |  |  |
|      |                                                              |     | LTCI                   | Timer |   |   |  |  |  |

| Bit | Name     | Attribute | Description                                                                                                        |
|-----|----------|-----------|--------------------------------------------------------------------------------------------------------------------|
| 7-0 | LTCTimer | R/W       | Latency Timer.<br>This register identifies the value of the latency timer in PCI clocks for PCI bus master cycles. |

| Regi | ster Off<br>ster Na<br>et Value | me: | 0Eh<br>Head<br>00h | ler Type | e Regist | er |   |
|------|---------------------------------|-----|--------------------|----------|----------|----|---|
| 7    | 7 6                             |     | 4                  | 3        | 2        | 1  | 0 |
|      |                                 |     | F                  | IT       |          |    |   |

| Bit | Name | Attribute | Description                                                                                                                                                                                                               |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | HT   |           | Header Type Register.<br>This register identifies the type of the predefined header in the configuration space. Since the<br>EHC is a single function device and not a PCI-to-PCI bridge, the byte should be read as 00h. |

| Register Offset:                | 13h – 10h                                   |                           |
|---------------------------------|---------------------------------------------|---------------------------|
| Register Name:<br>Reset Value : | Base Address Register<br>00000000h          |                           |
| 31 30 29 28 27 2                | 6 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 |
|                                 | BAD                                         | Reserved                  |

| Bit   | Name | Attribute | Description                                                                         |
|-------|------|-----------|-------------------------------------------------------------------------------------|
| 31-12 | BAD  | RVW       | Base Address.<br>POST writes the value of the memory base address to this register. |
| 11-0  | Rsvd | RO        | Always 0.                                                                           |

| Register Offset: |         | 2Dh - | 2Dh – 2Ch |         |          |        |      |   |   |   |   |   |   |   |  |
|------------------|---------|-------|-----------|---------|----------|--------|------|---|---|---|---|---|---|---|--|
| Regis            | ster Na | me:   | Subs      | ystem \ | /endor I | D Regi | ster |   |   |   |   |   |   |   |  |
| Reset Value :    |         | 17F3  | h         |         |          |        |      |   |   |   |   |   |   |   |  |
| 15               | 14      | 13    | 12        | 11      | 10       | 9      | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 |  |
|                  | SSVDID  |       |           |         |          |        |      |   |   |   |   |   |   |   |  |

| Bit | Name   | Attribute | Description                                                                                                                                                                         |
|-----|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | SSVDID | R/WS      | Subsystem Vendor ID.<br>Set the value in this field to identify the subsystem vendor ID. Before writing to this field, write-protect bits in register 40h bit 1:0 must be disabled. |

| Register Offset:<br>Register Name:<br>Reset Value : |    | 2Fh -<br>Subs<br>6061 | ystem I | D Regis | ster |   |   |   |   |   |   |   |   |   |   |
|-----------------------------------------------------|----|-----------------------|---------|---------|------|---|---|---|---|---|---|---|---|---|---|
| 15                                                  | 14 | 13                    | 12      | 11      | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SSID                                                |    |                       |         |         |      |   |   |   |   |   |   |   |   |   |   |

| Bit | Name | Attribute | Description                                                                                                                                                               |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | SSID | R/WS      | Subsystem ID.<br>Set the value in this field to identify the subsystem ID. Before writing to this field, write-protect<br>bits in register 40h bit[1:0] must be disabled. |

| Register Offset:<br>Register Name:<br>Reset Value: |      | 3Dh – 3<br>Interrupt<br>01XXh |    |    |    |   |   |   |   |   |    |    |   |   |   |
|----------------------------------------------------|------|-------------------------------|----|----|----|---|---|---|---|---|----|----|---|---|---|
| 15                                                 | 14   | 13                            | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|                                                    | INTP |                               |    |    |    |   |   |   |   |   | IN | TL |   |   |   |

| Bit  | Name | Attribute | Description                             |  |  |  |  |
|------|------|-----------|-----------------------------------------|--|--|--|--|
| 15-8 | INTP | R         | Interrupt Pin. Use INT_A.               |  |  |  |  |
| 7-0  | INTL | R/W       | Interrupt Line. Index Interrupt Vector. |  |  |  |  |

| Regi | ster Off | set: | 3Eh   |         |          |       |
|------|----------|------|-------|---------|----------|-------|
| Regi | ster Na  | me:  | Minim | nun Gra | int Regi | ister |
| Rese | t Value  | :    | 00h   |         |          |       |
| 7    | 6        | 5    | 4     | 3       | 2        | 1     |
|      |          |      |       |         |          |       |

I

MINGNT

| Bit | Name   | Attribute Description |                                                                                                                                                                                                     |  |  |  |
|-----|--------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7-0 | MINGNT | RO                    | Minimum Grant.<br>This register specifies the desired settings for how long of a burst EHC needs assuming a clock rate of 33 MHz. The value specifies a period of time in units of 1/4 microsecond. |  |  |  |

| Regis | ster Offs | et: | 3Fh                  |   |   |   |   |  |
|-------|-----------|-----|----------------------|---|---|---|---|--|
| Regis | ster Nam  | ie: | Max Latency Register |   |   |   |   |  |
| Rese  | t Value   | :   | 00h                  |   |   |   |   |  |
| 7     | 0         | -   | 4                    | 2 | 0 | 4 | 0 |  |
| 1     | 6         | 5   | 4                    | 3 | 2 | Ĩ | 0 |  |
|       | MAXLAT    |     |                      |   |   |   |   |  |

| Bit | Name   | Attribute | Description                                                                                                                                                                                                                |  |  |  |  |  |
|-----|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7-0 | MAXLAT | RO        | Maximum Latency.<br>This register specifies the desired setting for how often the EHC needs access to the PCI bus<br>assuming a clock rate of 33 MHz. The value specifies a period of time in units of 1/4<br>microsecond. |  |  |  |  |  |



| ter |
|-----|
|     |
|     |
|     |

| Bit  | Name        | Attribute | Description                                                                                  |
|------|-------------|-----------|----------------------------------------------------------------------------------------------|
| 31-8 | -8 Rsvd R/W |           | Reserved.                                                                                    |
|      |             |           | These bits are only used for test-mode. Changes to these bits will cause undefined behavior. |
|      |             |           | PCIFIFO Threshold Control.                                                                   |
|      |             |           | These bits are used to control the PCIFIFO threshold level. When PCIFIFO threshold is        |
|      |             |           | reached, OUT cycle will be driven by the EHC.                                                |
|      |             |           | 000 : PCIFIFO threshold is set to 128 bytes                                                  |
|      |             |           | 001 : PCIFIFO threshold is set to 256 bytes                                                  |
| 7-5  | PTC         | R/W       | 010 : PCIFIFO threshold is set to 384 bytes                                                  |
|      |             |           | 011 : PCIFIFO threshold is set to 512 bytes                                                  |
|      |             |           | 100 : PCIFIFO threshold is set to 640 bytes                                                  |
|      |             |           | 101 : PCIFIFO threshold is set to 768 bytes                                                  |
|      |             |           | 110 : PCIFIFO threshold is set to 896 bytes                                                  |
|      |             |           | 111 : PCIFIFO threshold is set to 1024 bytes                                                 |
| 4-2  | Rsvd        | R/W       | Reserved.                                                                                    |
| 4-2  | 4-2 RSVU R  |           | These bits are only used for test-mode. Changes to these bits will cause undefined behavior. |
|      |             |           | Write Special Registers Protect.                                                             |
| 1-0  | 1-0 WSRP    | R/W       | These registers protect write-special registers.                                             |
| 1-0  | WORF        | FX/ V V   | 10: Registers can be written                                                                 |
|      |             |           | Others: Register cannot be written                                                           |

| Regi | ster Off | set: | 60h                         |   |   |   |   |  |
|------|----------|------|-----------------------------|---|---|---|---|--|
| Regi | ster Nar | ne:  | USB Release Number Register |   |   |   |   |  |
| Rese | t Value  | :    | 20h                         |   |   |   |   |  |
| _    |          | _    |                             | _ | _ |   | _ |  |
| 7    | 6        | 5    | 4                           | 3 | 2 | 1 | 0 |  |
|      | USBRN    |      |                             |   |   |   |   |  |

| Bit | Name  | Attribute | Description                                                                                        |
|-----|-------|-----------|----------------------------------------------------------------------------------------------------|
| 7-0 | USBRN | RO        | USB Release Number.<br>This register is hardwired to 20h to indicate the EHC follows USB 2.0 Spec. |

| Regis | ster Offs | et: | 61h   |        |          |         |          |
|-------|-----------|-----|-------|--------|----------|---------|----------|
| Regis | ster Nam  | ne: | Frame | e Leng | th Adjus | tment I | Register |
| Rese  | t Value   | :   | 20h   |        |          |         |          |
| 7     | 6         | 5   | 4     | 3      | 2        | 1       | 0        |

Reserved FLTV

| Bit | Name | Attribute | Description                                                                                                              |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------|
| 7-6 | Rsvd | RO        | Reserved.<br>These registers are always 0.                                                                               |
| 5-0 | FLTV | R/W       | Frame Length Timing Value.<br>Each decimal value change to this register corresponds to 16-bit times for high-speed bus. |

| Regis | ster Off<br>ster Na<br>t Value | me: | 63h -<br>Port \<br>007F | Wake C | apabilit | y Regis | ter |   |   |   |      |   |   |   |     |
|-------|--------------------------------|-----|-------------------------|--------|----------|---------|-----|---|---|---|------|---|---|---|-----|
| 15    | 14                             | 13  | 12                      | 11     | 10       | 9       | 8   | 7 | 6 | 5 | 4    | 3 | 2 | 1 | 0   |
|       |                                |     | Rese                    | erved  |          |         |     |   |   |   | PWCM |   |   |   | PWI |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                      |
|------|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Rsvd | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                                                       |
| 7-1  | PWCM | R/W       | Port Wake Up Capability Mask.<br>Bit positions 1 through 6 correspond to a physical port implemented on this host controller. A<br>one in a bit position indicates that a device connected below the port can be enabled as a<br>wake-up device. |
| 0    | PWI  | R/W       | Port Wake Implemented.<br>A one in this bit indicates whether the register is implemented.                                                                                                                                                       |

| Regis | ster Offs | set: | 65h – | - 64h    |         |         |      |   |   |   |      |   |   |   |     |
|-------|-----------|------|-------|----------|---------|---------|------|---|---|---|------|---|---|---|-----|
| Regis | ster Nan  | ne:  | USB1  | I.1 Port | Overrio | le Regi | ster |   |   |   |      |   |   |   |     |
| Rese  | t Value   | :    | 0000  | h        |         |         |      |   |   |   |      |   |   |   |     |
| 15    | 14        | 13   | 12    | 11       | 10      | 9       | 8    | 7 | 6 | 5 | 4    | 3 | 2 | 1 | 0   |
|       |           |      | Rese  | erved    |         |         |      |   |   |   | PWCM |   |   |   | PWI |

| Bit  | Name | Attribute | Description                                                                                                                                                                                                                                           |
|------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Rsvd | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                                                            |
| 7-1  | PWCM |           | USB1.1 Port7-1 Owner.<br>Bit positions 1 through 5 correspond to a physical port implemented on this host controller. A<br>one in a bit position indicates that a device connected below the port will always be routed to<br>USB1.1 host controller. |
| 0    | PWI  | RO        | USB1.1 Port 0 Owner.<br>Port 0 for the EHC must never be programmed to the USB1.1 because this port is used as debug port.                                                                                                                            |

| Register Offset: | 73h – 70h                                       |
|------------------|-------------------------------------------------|
| Register Name:   | USB Legacy Support Extended Capability Register |
| Reset Value :    | 0000000h                                        |
|                  |                                                 |

| 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 | eserv | ved |    |    | HC<br>OS |    |    | Re | eserv | red |    |    | HC<br>OS |    |    | N  | IEHC | CIEC | P  |   |   |   |   |   | C | ID |   |   |   |

| Bit   | Name     | Attribute | Description                                                                                                                                                                                                |
|-------|----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-25 | Rsvd     | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                 |
| 24    | HCOS     | R/W       | HC Owned Semaphore.<br>System software sets this bit to request ownership of the EHCI controller. Ownership is<br>obtained when this bit is read as one and the HC Owned Semaphore bit read as zero.       |
| 23-17 | Rsvd     | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                 |
| 16    | HCOS     | R/W       | HC Owned Semaphore.<br>Set this bit to establish ownership of the EHCI controller. System will set this bit to a zero in<br>response to a request for ownership of the EHCI controller by system software. |
| 15-8  | NEHCIECP | RO        | Next EHCI Extended Capability Pointer.<br>A value of 00h indicates the end of the extended capability list.                                                                                                |
| 7-0   | CID      | RO        | Capability ID.<br>A value of 01h identifies the capability as Legacy Support.                                                                                                                              |



| Register Offset: | 77h – 74h                                  |
|------------------|--------------------------------------------|
| Register Name:   | USB Legacy Support Control/Status Register |
| Reset Value :    | 0000000h                                   |

| 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                     |
|----------------|-----|-----------------|----|----|----|-------|-----|----|----|-----------|----------------|----|----|----|----|----------------------|-----------------------|-----------------------|----|----|----|------|-----|---|---|---|----|------------------|----------------------|----------|-----------------------|
| SMI<br>BA<br>R | PCI | SMI<br>OS<br>OC |    |    | Re | eserv | red |    |    | SMI<br>AA | SMI<br>HS<br>E |    | PC | US | US | SMI<br>BA<br>RE<br>n | SMI<br>PCI<br>CE<br>n | SMI<br>OS<br>OC<br>En |    |    | Re | serv | ved |   |   | - | HS | SMI<br>FLR<br>En | SMI<br>PC<br>DE<br>n | US<br>BE | SMI<br>US<br>BC<br>En |

| Bit   | Name      | Attribute | Description                                                                                                                              |
|-------|-----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | SMIBAR    | R/WC      | SMI on BAR.                                                                                                                              |
|       |           | 10000     | This bit is set to one whenever the Base Address Register (BAR) is written.                                                              |
| 30    | SMIPCIC   | R/WC      | SMI on PCI Command.                                                                                                                      |
|       |           |           | This bit is set to one whenever the PCI Command Register is written.<br>SMI on OS Ownership Change.                                      |
| 29    | SMIOSOC   | R/WC      | This bit is set to one whenever the HC OS Owned Semaphore bit in the USBLEGSUP                                                           |
| 29    | 31110300  | R/WC      | register is changed.                                                                                                                     |
|       |           |           | Reserved.                                                                                                                                |
| 28-22 | Rsvd      | RO        | These registers are always 0.                                                                                                            |
|       |           |           | SMI on Async Advance.                                                                                                                    |
| 21    | SMIAA     | RO        | Shadow bit of the Interrupt on the Async Advance bit in the USBSTS register. Software must                                               |
|       |           |           | write 1 to the corresponding bit in USBSTS to clear this bit.                                                                            |
|       |           |           | SMI on Host System Error.                                                                                                                |
| 20    | SMIHSE    | RO        | Shadow bit of Host System Error bit in the USBSTS register. Software must write 1 to the                                                 |
|       |           |           | corresponding bit in USBSTS to clear this bit.                                                                                           |
|       |           |           | SMI on Frame List Rollover.                                                                                                              |
| 19    | SMIFLR    | RO        | Shadow bit of Frame List Rollover bit in the USBSTS register. Software must write 1 to the                                               |
|       |           |           | corresponding bit in USBSTS to clear this bit.                                                                                           |
| 10    |           | DO        | SMI on Port Change Detect.                                                                                                               |
| 18    | SMIPCD    | RO        | Shadow bit of Port Chance Detect bit in the USBSTS register. Software must write 1 to the corresponding bit in USBSTS to clear this bit. |
| -     |           |           | SMI on USB Error.                                                                                                                        |
| 17    | SMIUSBE   | RO        | Shadow bit of USB Error Interrupt (USBERRINT) bit in the USBSTS register. Software must                                                  |
|       | OWNOODE   |           | write 1 to the corresponding bit in USBSTS to clear this bit.                                                                            |
|       |           |           | SMI on USB Complete.                                                                                                                     |
| 16    | SMIUSBC   | RO        | Shadow bit of USB Interrupt (USBINT) bit in the USBSTS register. Software must write 1 to                                                |
| -     |           | _         | the corresponding bit in USBSTS to clear this bit.                                                                                       |
| 15    | SMIBAREn  | R/W       | SMI on BAR Enable.                                                                                                                       |
|       | -         |           |                                                                                                                                          |
| 14    | SMIPCICEn | R/W       | SMI on PCI Command Enable.                                                                                                               |
| 13    | SMIOSOCEn | R/W       | SMI on OS Ownership Change Enable.                                                                                                       |
| 12-6  | Rsvd      | RO        | Reserved.                                                                                                                                |
| 12-0  | RSVU      | RU        | These registers are always 0.                                                                                                            |
| 5     | SMIAAEn   | R/W       | SMI on Async Advance Enable.                                                                                                             |
| 4     | SMIHSEEn  | R/W       | SMI on Host System Error Enable.                                                                                                         |
| 3     | SMIFLREn  | R/W       | SMI on Frame List Rollover Enable.                                                                                                       |
|       |           | -         |                                                                                                                                          |
| 2     | SMIPCDEn  | R/W       | SMI on Port Change Detect Enable.                                                                                                        |
| 1     | SMIUSBEEn | R/W       | SMI on USB Error Enable.                                                                                                                 |
| 0     | SMIUSBCEn | R/W       | SMI on USB Complete Enable.                                                                                                              |
| •     | -         |           |                                                                                                                                          |

# RDC<sup>®</sup> RISC DSP Communication

| Register Offset: | 7Bh – 78h                                 |
|------------------|-------------------------------------------|
| Register Name:   | USB Legacy Support Enable/Status Register |
| Reset Value :    | 0000000h                                  |

| 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 |
|-------|----|----|----|------|------|----|----|----|---------------|----|---------------|----|----|----------|----|----|----|----|----|------|-----|----|---|---|----|----|----|---------------|---|---|
| Rsvd  |    |    |    | LP8- | -100 | )  |    |    | PM<br>CS<br>C | 70 | PS<br>En<br>C | -  | -  | HC<br>RC |    | vd |    |    | L  | P7-0 | OCE | În |   |   | CS | En | En | CF<br>CE<br>n |   |   |

| Bit   | Name          | Attribute | Description                                                                                                                                                                          |
|-------|---------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | Rsvd          | RO        | Reserved.<br>These registers are always 0.                                                                                                                                           |
| 29-22 | LP8-1OC       | R/WC      | Legacy port 8-1 owner Change.<br>Bit positions 22 through 29 correspond to a physical port on this host controller. A one in a bit position indicates that a device owner is changed |
| 21    | PMCSC         | R/WC      | PMCS Change.<br>This bit is set to one whenever the PMCS is changed.                                                                                                                 |
| 20    | ASEnC         | R/WC      | Asynchronous Schedule Enable Change.<br>This bit is set to one whenever the Asynchronous Schedule Enable bit is changed.                                                             |
| 19    | PSEnC         | R/WC      | Periodic Schedule Enable Change.<br>This bit is set to one whenever the Peridic Schedule Enable bit is changed.                                                                      |
| 18    | CFC           | R/WC      | Configure Flag Change.<br>This bit is set to one whenever the Configure Flag bit is changed.                                                                                         |
| 17    | нснс          | R/WC      | HCHalted Change.<br>This bit goes to one whenever the HCHalted register makes a 0b to 1b transition.                                                                                 |
| 16    | HCRC          | R/WC      | HCRESET Change.<br>This bit goes to one whenever the HCRESET register makes a 0b to 1b transition.                                                                                   |
| 15-14 | Rsvd          | RO        | Reserved.<br>These registers are always 0.                                                                                                                                           |
| 13-6  | LP7-0OCE<br>n | R/W       | Legacy Port 7-0 Owner Change Enable.                                                                                                                                                 |
| 5     | PMCSCEn       | R/W       | PMCS Change Enable.                                                                                                                                                                  |
| 4     | ASEnCEn       | R/W       | Asynchronous Schedule Enable Change Enable.                                                                                                                                          |
| 3     | PSEnCEn       | R/W       | Periodic Schedule Enable Change Enable.                                                                                                                                              |
| 2     | CFCEn         | R/W       | Configure Flag Change Enable.                                                                                                                                                        |
| 1     | HCHCEn        | R/W       | HCHalted Change Enable.                                                                                                                                                              |
| 0     | HCSCEn        | R/W       | HCRESET Change Enable.                                                                                                                                                               |

#### 13.5.4 EHCI Operational Registers

The base address of these registers is programmable by the memory base address register (EHC PCI configuration register offset 10h - 13h). These registers should be written as DWORD. Bytes access to these registers may have unpredictable effects.

#### 13.5.4.1 Host Controller Capability Register

| Regis | ster Offs | et: | 00h   | 00h                                 |   |   |   |  |  |  |  |  |
|-------|-----------|-----|-------|-------------------------------------|---|---|---|--|--|--|--|--|
| Regis | ster Nam  | ne: | Capal | Capability Register Length Register |   |   |   |  |  |  |  |  |
| Rese  | t Value   | :   | 20h   |                                     |   |   |   |  |  |  |  |  |
| 7     | 6         | 5   | 4     | 3                                   | 2 | 1 | 0 |  |  |  |  |  |
|       |           |     | CF    | RL                                  |   |   |   |  |  |  |  |  |

| Bit | Name | Attribute | Description                                                                                                      |
|-----|------|-----------|------------------------------------------------------------------------------------------------------------------|
| 7-0 | CRL  |           | Capability Register Length.<br>This register indicates to the length of the host controller capability register. |

| Regis | ster Off<br>ster Na<br>t Value | me: | 03h -<br>USB1<br>0100 | I.1 Port | : Overric | le Regi | ster |   |   |   |   |   |   |   |   |
|-------|--------------------------------|-----|-----------------------|----------|-----------|---------|------|---|---|---|---|---|---|---|---|
| 15    | 14                             | 13  | 12                    | 11       | 10        | 9       | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| HCIVN |                                |     |                       |          |           |         |      |   |   |   |   |   |   |   |   |

| Bit  | Name  | Attribute | Description                                                                                                       |
|------|-------|-----------|-------------------------------------------------------------------------------------------------------------------|
| 15-0 | HCIVN | RO        | Host Controller Interface Version Number.<br>This register indicates the EHC supports the EHCI Spec Revision 1.0. |

# RDC<sup>®</sup> RISC DSP Communication

| Register Offset: | 07h – 04h                     |
|------------------|-------------------------------|
| Register Name:   | Structure Parameters Register |
| Reset Value :    | 00103308h                     |

| 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 | DPN | Reserved | N_CC | N_PCC | Reserved | N_PORTS |
|----------|-----|----------|------|-------|----------|---------|

| Bit   | Name    | Attribute | Description                                                                                                                                     |
|-------|---------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24 | Rsvd    | RO        | Reserved. These registers are always 0.                                                                                                         |
| 23-20 | DPN     | RO        | Debug Port Number.<br>This register identifies the first port as the debug port.                                                                |
| 19-16 | Rsvd    | RO        | Reserved. These registers are always 0.                                                                                                         |
| 15-12 | N_CC    | RO        | Number of Companion Controller (N_CC).<br>This field indicates the number of companion controllers associated with this USB2.0 host controller. |
| 11-8  | N_PCC   | RO        | Number of Ports per Companion Controller (N_PCC).<br>This field indicates the number of ports supported per companion host controller.          |
| 7-4   | Rsvd    | RO        | Reserved. These registers are always 0.                                                                                                         |
| 3-0   | N_PORTS | RO        | Number of Ports (N_PORTS).<br>This field indicates the number of ports supported on this host controller.                                       |

| Register Offset: | 0Bh – 08h                      |
|------------------|--------------------------------|
| Register Name:   | Capability Parameters Register |
| Reset Value :    | 00800070h                      |

| 31 30 29 28 27 26 25 | 5 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 | EECP | IST | Rsv AS<br>d OC Rsvd |
|----------|------|-----|---------------------|
|----------|------|-----|---------------------|

| Bit   | Name | Attribute | Description                                                                                                                                                                                   |
|-------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Rsvd | RO        | Reserved. These registers are always 0.                                                                                                                                                       |
| 15-8  | EECP | RO        | EHCI Extend Capabilities Pointer (EECP).<br>This field indicates the existence of a capability list.                                                                                          |
| 7-4   | IST  | R/WS      | Isochronous Scheduling Threshold.<br>This field indicates, relative to the current position of the executing host controller, where<br>software can reliably update the isochronous schedule. |
| 3     | Rsvd | RO        | Reserved. This register is always 0.                                                                                                                                                          |
| 2     | ASOC | R/WS      | Asynchronous Schedule Park Capability.<br>If this bit is set to a one, then the host controller supports the park feature for high-speed<br>queue heads in the Asynchronous Schedule.         |
| 1-0   | Rsvd | RO        | Reserved. These registers are always 0.                                                                                                                                                       |



#### 13.5.4.2 Host Controller Operational Register

| Register Offset: | 23h – 20h               |
|------------------|-------------------------|
| Register Name:   | USB2.0 Command Register |
| Reset Value :    | 00080000h               |

| 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  |
|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---------------|----------|----------|---------|----------|-----------------|----------|----------|----|-----|---------------------|----|
|    |    |    | Rese | erveo | ł  |    |    |    |    |    | IT | Ċ  |    |    |    |    | Rs | svd |    | AS<br>PM<br>C | Rsv<br>d | ASF<br>r | ME<br>ז | LH<br>CR | INT<br>_AA<br>D | AS<br>En | PS<br>En | Rs | svd | HC<br>RE<br>SE<br>T | RS |

| Bit   | Name    | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24 | Rsvd    | RO        | Reserved. These registers are always 0.                                                                                                                                                                                                                                                                                                                                                                      |
| 23-16 | ITC     | R/W       | Interrupt Threshold Control.<br>This field is used by system software to select the maximum rate at which the host controller<br>will issue interrupts.                                                                                                                                                                                                                                                      |
| 15-12 | Rsvd    | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                                                                                                                                                                                                                   |
| 11    | ASPMEn  | R/W       | Asynchronous Schedule Park Mode Enable.<br>If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this bit<br>defaults to a 1h and is R/W. Software uses this bit to enable or disable Park mode.                                                                                                                                                                                  |
| 10    | Rsvd    | RO        | Reserved.<br>This register is always 0.                                                                                                                                                                                                                                                                                                                                                                      |
| 9-8   | ASPMC   | R/W       | Asynchronous Schedule Park Mode Count.<br>If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this bit<br>defaults to a 3h and is R/W. This field contains a count to the number of successive<br>transactions the host controller is allowed to execute from a high-speed queue head on the<br>asynchronous schedule before continuing traversal of the asynchronous schedule. |
| 7     | LHCR    | R/W       | Light Host Controller Reset.<br>It allows the driver to reset the EHCI controller without affecting the state of the ports or the relationship to the companion host controllers.                                                                                                                                                                                                                            |
| 6     | INT_AAD | R/W       | Interrupt on Async Advance Doorbell.<br>This bit is used as a doorbell by software to tell the host controller to issue an interrupt the<br>next time it advances asynchronous schedule.                                                                                                                                                                                                                     |
| 5     | ASEn    | R/W       | Asynchronous Schedule Enable.<br>This bit controls whether the host controller skips processing the Asynchronous Schedule.                                                                                                                                                                                                                                                                                   |
| 4     | PSEn    | R/W       | Periodic Schedule Enable.<br>This bit controls whether the host controller skips processing the Periodic Schedule.                                                                                                                                                                                                                                                                                           |
| 3-2   | Rsvd    | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                                                                                                                                                                                                                   |
| 1     | HCRESET | R/W       | Host Controller Reset (HCRESET).<br>This control bit is used by software to reset the host controller.                                                                                                                                                                                                                                                                                                       |
| 0     | RS      | R/W       | Run/Stop (RS)<br>When set to a 1, the host controller proceeds with execution of the schedule.                                                                                                                                                                                                                                                                                                               |

# **RDC**<sup>®</sup> RISC DSP Communication

| Register Offset: | 27h – 24h              |
|------------------|------------------------|
| Register Name:   | USB2.0 Status Register |
| Reset Value :    | 00001000h              |

# 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 | AS<br>S |  | RC<br>I M | HC<br>Halt<br>ed | Reserved | INT<br>_AA | HS<br>ER<br>R |  | DF | BE BIN<br>RRI T<br>NT |  |
|----------|---------|--|-----------|------------------|----------|------------|---------------|--|----|-----------------------|--|
|----------|---------|--|-----------|------------------|----------|------------|---------------|--|----|-----------------------|--|

| Bit   | Name          | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|---------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Rsvd          | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15    | ASS           | RO        | Asynchronous Schedule Status.<br>This bit reports the current real status of the Asynchronous Schedule. If this bit is a zero then<br>the status of the Asynchronous Schedule is disabled.                                                                                                                                                                                                                                                                                                                                    |
| 14    | PSS           | RO        | Periodic Schedule Status.<br>This bit reports the current real status of the Periodic Schedule. If this bit is a zero then the status of the Periodic Schedule is disabled.                                                                                                                                                                                                                                                                                                                                                   |
| 13    | RCLM          | RO        | Reclamation.<br>This bit is used to detect an empty asynchronous schedule.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12    | HCHalted      | RO        | Host Controller Halted (HCHalted).<br>This bit is a zero whenever the Run/Stop bit is a one. The Host Controller sets this bit to one<br>after it has stopped executing as a result of the Run/Stop bit being set to 0, either by<br>software or by the Host Controller hardware.                                                                                                                                                                                                                                             |
| 11-6  | Rsvd          | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5     | INT_AA        | R/WC      | Interrupt on Async Advance.<br>System software can force the host controller to issue an interrupt the next time the host<br>controller advances the asynchronous schedule by writing a one to the Interrupt on Async<br>Advance Doorbell bit in the USB2CMD register.                                                                                                                                                                                                                                                        |
| 4     | HSERR         | R/WC      | Host System Error.<br>The Host Controller sets this bit to 1 when a serious error occurs during a host system<br>access involving the Host Controller module.                                                                                                                                                                                                                                                                                                                                                                 |
| 3     | FLRL          | R/WC      | Frame List Rollover.<br>The Host Controller sets this bit to a one when the Frame List Index rolls over from its maximum value to zero.                                                                                                                                                                                                                                                                                                                                                                                       |
| 2     | PCD           | R/WC      | Port Change Detect.<br>The Host Controller sets this bit to a one when any port for which the Port Owner bit is set to<br>zero has a change bit transition from a zero to a one or a Force Port Resume bit transition<br>from a zero to a one as a result of a J-K transaction detected on a suspended port. This bit<br>will also be set as a result of the Connect Status Change being set to a one after system<br>software has relinquished ownership of a connected port by writing a one to a port's Port<br>Owner bit. |
| 1     | USBERRI<br>NT | R/WC      | USB Error Interrupt (USBERRINT).<br>The Host Controller sets this bit to 1 when completion of a USB transaction results in an<br>error condition.                                                                                                                                                                                                                                                                                                                                                                             |
| 0     | USBINT        | R/WC      | USB Interrupt (USBINT).<br>The Host Controller sets this bit to 1 one the completion of a USB transaction, which result in<br>the retirement of a Transfer Descriptor that had its IOC bit set.                                                                                                                                                                                                                                                                                                                               |



| Register Offset: | 2Bh – 28h                        |
|------------------|----------------------------------|
| Register Name:   | USB2.0 Interrupt Enable Register |
| Reset Value :    | 0000000h                         |

# 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 INT HS AA ER FLR DE US EN LEN DE RRI BIN n NT TEN En

| Bit   | Name            | Attribute | Description                                                                                       |
|-------|-----------------|-----------|---------------------------------------------------------------------------------------------------|
| 31-16 | Rsvd            | RO        | Reserved.                                                                                         |
| 01 10 | 11370           | NO        | These registers are always 0.                                                                     |
|       |                 |           | Interrupt on Async Advance Enable.                                                                |
| 5     | INT AAEn        | R/W       | When this bit is a one and the Interrupt on the Async Advance bit in the USBSTS register is       |
| Ū.    |                 |           | a one, the host controller will issue an interrupt at the next interrupt threshold. The interrupt |
|       |                 |           | is acknowledged by software clearing the Interrupt on the Async Advance bit.                      |
|       |                 |           | Host System Error Enable.                                                                         |
| 4     | HSERREn         | R/W       | When this bit is a one and the Host System Error Status bit in the USBSTS register is a one,      |
| -     |                 |           | the host controller will issue an interrupt. The interrupt is acknowledged by software clearing   |
|       |                 |           | the Host System Error bit.                                                                        |
| _     |                 |           | Frame List Rollover Enable.                                                                       |
| 3     | FLRLEn          | R/W       | When the Rollover bit in the USBSTS register is a one, the host controller will issue an          |
|       |                 |           | interrupt. The interrupt is acknowledged by software clearing the Frame List Rollover bit         |
|       |                 |           | Port Change Detect Enable.                                                                        |
| 2     | PCDEn           | R/W       | When this bit is a one and the Port Chang Detect bit in the USBSTS register is a one, the         |
|       |                 |           | host controller will issue an interrupt. The interrupt is acknowledged by software clearing the   |
|       |                 |           | Port Change Detect bit.                                                                           |
|       |                 |           | USB Error Interrupt Enable.                                                                       |
| 1     | USBERRI<br>NTFn | R/W       | When this bit is a one, and the USBERRINT bit in the USBSTS register is a one, the host           |
|       | NIEN            |           | controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged |
|       |                 |           | by software clearing the USBERRINT bit.                                                           |
|       |                 |           | USB Interrupt Enable.                                                                             |
| 0     | USBINTEn        | R/W       | When this bit is a one and the USBINT bit in the USBSTS register is a one, the host controller    |
|       |                 |           | will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by         |
|       |                 |           | software clearing the USBINT bit.                                                                 |



| Register Offset: | 2Fh – 2Ch                   |
|------------------|-----------------------------|
| Register Name:   | USB2.0 Frame Index Register |
| Reset Value :    | 0000000h                    |

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

| Bit   | Name | Attribute | Description                                                                              |
|-------|------|-----------|------------------------------------------------------------------------------------------|
| 31-14 | Rsvd |           | Reserved.<br>These registers are always 0.                                               |
| 13-0  | FI   |           | Frame Index.<br>The value in this register is incremented at the end of each time frame. |

| Register Offset: | 37h – 34h                                                              |
|------------------|------------------------------------------------------------------------|
| Register Name:   | Periodic Frame List Base Address Register                              |
| Reset Value :    | undefined                                                              |
| 31 30 29 28 27 2 | 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 |
|----|----------|
|    |          |

| Bit   | Name | Attribute | Description                                                       |
|-------|------|-----------|-------------------------------------------------------------------|
| 31-12 | BA   | R/W       | Base Address.<br>These bits correspond to memory address [31:12]. |
| 11-0  | Rsvd | RO        | Reserved.<br>These registers are always 0.                        |

| Register Offset: | 3Bh – 38h                                  |
|------------------|--------------------------------------------|
| Register Name:   | Current Asynchronous List Address Register |
| Reset Value :    | undefined                                  |

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

| LP | Reserved |
|----|----------|
|    |          |

| Bit  | Name | Attribute | Description                                                      |
|------|------|-----------|------------------------------------------------------------------|
| 31-5 | LP   |           | Link Pointer.<br>These bits correspond to memory address [31:5]. |
| 4-0  | Rsvd | RO        | Reserved.<br>These registers are always 0.                       |



CF

| 63h – 60h                |
|--------------------------|
| Configured Flag Register |
| undefined                |
|                          |

#### 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

| Bit  | Name | Attribute | Description                                                                                                                                                                                               |
|------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1 | Rsvd | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                |
| 0    | CF   | R/W       | Configure Flag (CF).<br>Host software sets this bit as the last action in its process of configuring the Host Controller.<br>Writing a one to this register will route all ports to this host controller. |

| - 64h                         |
|-------------------------------|
| ) Status and Control Register |
| Bh                            |
| Status and Control Register   |
| 2000h                         |
|                               |

| 31 | 30 2 | 29 28 | 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 |
|----|------|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |      |       |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Reserved | WK<br>OC | WK WK<br>DS CC<br>CN NT_<br>E | PTC | Rsvd | PO | PP | LS | Rsv<br>d |  | SS<br>PN<br>D |  | OC<br>RC | 00 | P_E<br>DC | ᄃ | SC 1 | CR<br>CN<br>NT<br>S |
|----------|----------|-------------------------------|-----|------|----|----|----|----------|--|---------------|--|----------|----|-----------|---|------|---------------------|
|----------|----------|-------------------------------|-----|------|----|----|----|----------|--|---------------|--|----------|----|-----------|---|------|---------------------|

| Bit   | Name           | Attribute | Description                                                                                                                                                                                                                                                                                                   |
|-------|----------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-23 | Rsvd           | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                                                                                                                    |
| 22    | WKOC_E         | R/W       | Wake on Over-current Enable (WKOC_E).<br>Writing this bit to a one enables the port to be sensitive to over-current conditions as<br>wake-up events.                                                                                                                                                          |
| 21    | WKDSCN<br>NT_E | R/W       | Wake on Disconnect Enable (WKDSCNNT_E).<br>Writing this bit to a one enables the port to be sensitive to device disconnects as wake-up events.                                                                                                                                                                |
| 20    | WKCNNT_<br>E   | R/W       | Wake on Connect Enable (WKCNNT_E).<br>Writing this bit to a one enables the port to be sensitive to device connects as wake-up events.                                                                                                                                                                        |
| 19-16 | PTC            | R/W       | Port Test Control.<br>When this field is zero, the port does NOT come into operation in test mode.                                                                                                                                                                                                            |
| 15-14 | Rsvd           | RO        | Reserved.<br>These registers are always 0.                                                                                                                                                                                                                                                                    |
| 13    | PO             | R/W       | Port Owner.<br>This bit unconditionally goes to a 0b when the Configured bit in the CONFIGFLAG register<br>makes a 0b to 1b transition. This bit unconditionally goes to 1b whenever the Configured bit<br>is zero. Software writes a one to this bit when the attached device is not a high-speed<br>device. |
| 12    | PP             | RO        | Port Power (PP).<br>The Host Controller does not have port power control switches. Each port is hard-wired to<br>power.                                                                                                                                                                                       |



| 11-10 | LS      | RO             | Line Status.                                                                                       |
|-------|---------|----------------|----------------------------------------------------------------------------------------------------|
| 11 10 | 20      | i to           | These bits reflect the current logical levels of the D+ (bit 11) and D- (bit 10) signal lines.     |
| 9     | Rsvd    | RO             | Reserved.                                                                                          |
| Ŭ     | Hora    | 110            | This bit is always 0.                                                                              |
|       |         |                | Port Reset.                                                                                        |
| 8     | PRESET  | R/W            | When software writes a one to this bit, the bus reset sequence as defined in the USB Spec          |
| Ŭ     |         |                | Revision 2.0 is started. Software writes a zero to this bit to terminate the bus reset             |
|       |         |                | sequence.                                                                                          |
|       |         |                | Suspend.                                                                                           |
| 7     | SSPND   | R/W            | Software writes a one to this bit to suspend the downstream port. A write of zero to this bit is   |
| -     |         |                | ignored by the host controller. The host controller will unconditionally set this bit to a zero    |
|       |         |                | when software sets the Force Port Resume from 1 to 0 or sets the Port Reset bit to 1.              |
|       |         |                | Force Port Resume.                                                                                 |
|       | 5550    |                | Software sets this bit to a 1 to drive resume signaling. The Host Controller sets this bit to a 1  |
| 6     | FPRS    | R/W            | if a J-to-K transition is detected while the port is in the Suspend state. A write of zero to this |
|       |         |                | bit will force the downstream port to follow the resume sequence defined in the sequence           |
|       |         |                | documented in the USB Spec Revision 2.0.                                                           |
| 5     | OCRC    | R/WC           | Over-current Change.                                                                               |
|       |         |                | This bit gets set to a one when there is a change to Over-current Active. Over-current Active.     |
| 4     | OCRA    | RO             | 0: This port does not have an over-current condition.                                              |
| 4     | UCRA    | RU             | 1: This port has an over-current condition.                                                        |
| -     |         |                | Port Enable/Disable Change.                                                                        |
| 3     | P EDC   | R/WC           | For the root hub, this bit gets set to a one only when a port is disabled due to the appropriate   |
| 5     | F_EDC   | R/WC           | conditions existing at the EOF2 pointer.                                                           |
|       |         |                | Port Enable/Disabled.                                                                              |
|       |         |                | Ports can only be enabled by the host controller as a part of the reset and enable. Software       |
| 2     | P_ED    | R/W            | cannot enable a port by writing a one to this field. Ports can be disabled by either a fault       |
|       |         |                | condition or by host software.                                                                     |
|       |         |                | Connect Status Change.                                                                             |
| 1     | CNNTSC  | R/WC           | 1: Change in Current Connect Status.                                                               |
|       |         | 10110          | 0: No change.                                                                                      |
|       |         | <b>5</b> 4 4 4 | Current Connect Status.                                                                            |
| 0     | CRCNNTS | R/W            | This value reflects the current connect status of the port.                                        |
| L     | 1 1     |                |                                                                                                    |



# 14. DC Electrical Characteristics

## 14.1 Absolute Maximum Ratings (25)

| Symbol     | Parameter                        | Min. | Max. | Unit | Conditions |
|------------|----------------------------------|------|------|------|------------|
| VCC_CORE   | Core Supply Voltage              | 1.71 | 1.89 | V    |            |
| VCC18A     | PLL Supply Voltage               | 1.71 | 1.89 | V    |            |
| VCC_IO     | I/O Supply Voltage               | 3.0  | 3.6  | V    |            |
| AVDD [0:1] | Analog Suply Voltage             | 1.71 | 1.89 | V    |            |
| AVDD33     | I/O Supply Voltage               | 3.0  | 3.6  | V    |            |
| AVDDPLL    | USB PLL Supply Voltage           | 1.71 | 1.89 | V    |            |
| Vil        | Input Low Voltage                |      | 0.8  | V    |            |
| Vih        | Input High Voltage               | 2.0  |      | V    |            |
| Vol        | Output Low Voltage               |      | 0.4  | V    |            |
| Voh        | Output High Voltage              | 2.4  | -    | V    |            |
| lin        | Input leakage current            | -10  | 10   | uA   |            |
| loz        | Tri-State output leakage current | -10  | 10   | uA   |            |

#### 14.2 Temperature

| Symbol           | Parameter                                        | Тур.    | Unit | Conditions                                                                                |
|------------------|--------------------------------------------------|---------|------|-------------------------------------------------------------------------------------------|
| T <sub>cop</sub> | Case Surface Operating<br>Temperature (case top) | 43~49   |      | <ol> <li>Ambient Temperature = 25</li> <li>Open case testing.</li> <li>Note 2.</li> </ol> |
| T <sub>A</sub>   | Ambient Temperature                              | 0~70    |      | Temperature of the surrounding medium                                                     |
| T <sub>stg</sub> | Storage Temperature                              | -65~125 |      | Dry Pack.                                                                                 |

#### Notes:

 The IC should be mounted on PCB within 7 days after the dry pack is opened. If the IC is out of dry pack more than 7 days, it should be burned in oven (+125℃, > 12 hours) before mounted on PCB.

2. *T<sub>cop</sub>* depends on the number of PCB layers, PCB size, system loading, working voltage and running pattern. The condition is for 4-layer A4-size PCB at typical working voltage.

# 15. AC Electrical Characteristics

### 15.1 System Reset

| Symbol | Parameter                                     | Min. | Max. | Unit | Notes |
|--------|-----------------------------------------------|------|------|------|-------|
| T1     | PWRGOOD active to SDRAMCLK output<br>stable   | 1    |      | ms   |       |
| T2     | PWRGOOD active to PCIRST_n ready              | 1    |      | ms   |       |
| Т3     | PWRGOOD active to first code fetch<br>command | 2    |      | ms   |       |





## 15.2 SDRAM Interface

### • Read Cycle (66MHz)

| Symbol | Parameter                     | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|-------------------------------|--------------|--------------|--------------|-------|
| tSCK   | SDRAM clock cycle time        | 15.16        |              |              |       |
| tSCH   | SDRAM clock high-level width  |              | 7.58         |              |       |
| tSCL   | SDRAM clock low-level width   |              | 7.58         |              |       |
| tCEV   | CKE valid delay time          |              |              | 6            |       |
| tCEH   | CKE hold time                 | 4            |              |              |       |
| tCSV   | CS_n valid delay time         |              |              | 6            |       |
| tCSH   | CS_n hold time                | 4            |              |              |       |
| tRV    | RAS_n valid delay time        |              |              | 6            |       |
| tRH    | RAS_n hold time               | 4            |              |              |       |
| tCV    | CAS_n valid delay time        |              |              | 6            |       |
| tCH    | CAS_n hold time               | 4            |              |              |       |
| tWV    | WE_n valid delay time         |              |              | 6            |       |
| tWH    | WE_n hold time                | 4            |              |              |       |
| tDMV   | DQM valid delay time          |              |              | 6            |       |
| tDMH   | DQM hold time                 | 4            |              |              |       |
| tAV    | Address valid delay time      |              |              | 5            |       |
| tAH    | Address hold time             | 4            |              |              |       |
| tBAV   | Bank address valid delay time |              |              | 5            |       |
| tBAH   | Bank address hold time        | 4            |              |              |       |
| tDIS   | Data input setup time         | 2            |              |              |       |
| tDIH   | Data input hold time          | 1            |              |              |       |



#### • Read Cycle Waveforms (I)



16-Bit Data Bus Burst Read Cycle



#### • Write Cycle (66MHz)

| Symbol | Parameter                     | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|-------------------------------|--------------|--------------|--------------|-------|
| tSCK   | SDRAM clock cycle time        | 15.16        |              |              |       |
| tSCH   | SDRAM clock high-level width  |              | 7.58         |              |       |
| tSCL   | SDRAM clock low-level width   |              | 7.58         |              |       |
| tCEV   | CKE valid delay time          |              |              | 6            |       |
| tCEH   | CKE hold time                 | 4            |              | -            |       |
| tCSV   | CS_n valid delay time         |              |              | 6            |       |
| tCSH   | CS_n hold time                | 4            |              | -            |       |
| tRV    | RAS_n valid delay time        |              |              | 6            |       |
| tRH    | RAS_n hold time               | 4            |              |              |       |
| tCV    | CAS_n valid delay time        |              |              | 6            |       |
| tCH    | CAS_n hold time               | 4            |              |              |       |
| tWV    | WE_n valid delay time         |              |              | 6            |       |
| tWH    | WE_n hold time                | 4            |              |              |       |
| tDMV   | DQM valid delay time          |              |              | 6            |       |
| tDMH   | DQM hold time                 | 4            |              | -            |       |
| tAV    | Address valid delay time      |              |              | 5            |       |
| tAH    | Address hold time             | 4            |              | -            |       |
| tBAV   | Bank address valid delay time |              |              | 5            |       |
| tBAH   | Bank address hold time        | 4            |              |              |       |
| tDOV   | Data output valid delay time  |              |              | 8            |       |
| tDOH   | Data output hold time         | 2            |              |              |       |



#### • Write Cycle Waveforms (I)



16-Bit Data Bus Write with Terminate



#### • Write Cycle Waveforms (II)



16-Bit Data Bus Burst Write Cycle

# 15.3 PCI Interface

### 15.3.1 R8610 as a PCI Master

#### Read Cycle

| Symbol | Parameter                           | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|-------------------------------------|--------------|--------------|--------------|-------|
| tPCK   | PCI clock cycle time                | 30           |              |              |       |
| tPCH   | PCI clock high-level width          |              | 15           |              |       |
| tPCL   | PCI clock low-level width           |              | 15           |              |       |
| tAOV   | Address output valid delay time     | 2            |              | 11           |       |
| tAOH   | Address output hold time            | 1            |              |              |       |
| tDOS   | Data input setup time               | 7            |              |              |       |
| tDOH   | Data input hold time                | 1            |              |              |       |
| tCOV   | Command output valid delay time     | 2            |              | 11           |       |
| tCOH   | Command output hold time            | 1            |              |              |       |
| tBOV   | Byte Enable output valid delay time | 2            |              | 11           |       |
| tBOH   | Byte Enable output hold time        | 1            |              |              |       |
| tFOV   | FRAME_n output valid delay time     | 2            |              | 11           |       |
| tFOH   | FRAME_n output hold time            | 1            |              |              |       |
| tIOV   | IRDY_n output valid delay time      | 2            |              | 11           |       |
| tIOH   | IRDY_n output hold time             | 1            |              |              |       |
| tTIS   | TRDY_n input setup time             | 7            |              |              |       |
| tTIH   | TRDY_n input hold time              | 1            |              |              |       |
| tSIS   | STOP_n input setup time             | 7            |              |              |       |
| tSIH   | STOP_n input hold time              | 1            |              |              |       |
| tDEIS  | DEVSEL_n input setup time           | 7            |              |              |       |
| tDEIH  | DEVSEL_n input hold time            | 1            |              |              |       |



#### • Memory Read Cycle Waveforms



#### • Write Cycle

| Symbol | Parameter                           | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|-------------------------------------|--------------|--------------|--------------|-------|
| tPCK   | PCI clock cycle time                | 30           |              |              |       |
| tPCH   | PCI clock high-level width          |              | 15           |              |       |
| tPCL   | PCI clock low-level width           |              | 15           |              |       |
| tAOV   | Address output valid delay time     | 2            |              | 11           |       |
| tAOH   | Address output hold time            | 1            |              |              |       |
| tDOV   | Data output valid delay time        | 2            |              | 11           |       |
| tDOH   | Data output hold time               | 1            |              |              |       |
| tCOV   | Command output valid delay time     | 2            |              | 11           |       |
| tCOH   | Command output hold time            | 1            |              |              |       |
| tBOV   | Byte Enable output valid delay time | 2            |              | 11           |       |
| tBOH   | Byte Enable output hold time        | 1            |              |              |       |
| tFOV   | FRAME_n output valid delay time     | 2            |              | 11           |       |
| tFOH   | FRAME_n output hold time            | 1            |              |              |       |
| tIOV   | IRDY_n output valid delay time      | 2            |              | 11           |       |
| tIOH   | IRDY_n output hold time             | 1            |              |              |       |
| tTIS   | TRDY_n input setup time             | 7            |              |              |       |
| tTIH   | TRDY_n input hold time              | 1            |              |              |       |
| tSIS   | STOP_n input setup time             | 7            |              |              |       |
| tSIH   | STOP_n input hold time              | 1            |              |              |       |
| tDEIS  | DEVSEL_n input setup time           | 7            |              |              |       |
| tDEIH  | DEVSEL_n input hold time            | 1            |              |              |       |

#### Memory Write Cycle Waveforms



#### 15.3.2 R8610 as a PCI Target

#### Read Cycle

| Symbol | Parameter                        | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|----------------------------------|--------------|--------------|--------------|-------|
| tPCK   | PCI clock cycle time             | 30           |              |              |       |
| tPCH   | PCI clock high-level width       |              | 15           |              |       |
| tPCL   | PCI clock low-level width        |              | 15           |              |       |
| tAIS   | Address input setup time         | 7            |              |              |       |
| tAIH   | Address output hold time         | 1            |              |              |       |
| tDOV   | Data output valid delay time     | 2            |              | 11           |       |
| tDOH   | Data output hold time            | 1            |              |              |       |
| tCIS   | Command input setup time         | 7            |              |              |       |
| tCIH   | Command input hold time          | 1            |              |              |       |
| tBIS   | Byte Enable input setup time     | 7            |              |              |       |
| tBIH   | Byte Enable input hold time      | 1            |              |              |       |
| tFIS   | FRAME_n input setup time         | 7            |              |              |       |
| tFIH   | FRAME_n input hold time          | 1            |              |              |       |
| tIIS   | IRDY_n input setup time          | 7            |              |              |       |
| tIIH   | IRDY_n input hold time           | 1            |              |              |       |
| tTOV   | TRDY_n output valid delay time   | 2            |              | 11           |       |
| tTOH   | TRDY_n output hold time          | 1            |              |              |       |
| tSOV   | STOP_n output valid delay time   | 2            |              | 11           |       |
| tSOH   | STOP_n output hold time          | 1            |              |              |       |
| tDEOV  | DEVSEL_n output valid delay time | 2            |              | 11           |       |
| tDEOH  | DEVSEL_n output hold time        | 1            |              |              |       |

#### Burst Read Cycle Waveforms



#### • Write Cycle

| Symbol | Parameter                        | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|----------------------------------|--------------|--------------|--------------|-------|
| tPCK   | PCI clock cycle time             |              |              |              |       |
| tPCH   | PCI clock high-level width       |              | 15           |              |       |
| tPCL   | PCI clock low-level width        |              | 15           |              |       |
| tAIS   | Address input setup time         | 7            |              |              |       |
| tAIH   | Address output hold time         | 1            |              |              |       |
| tDIV   | Data input setup time            | 7            |              |              |       |
| tDIH   | Data input hold time             | 1            |              |              |       |
| tCIS   | Command input setup time         | 7            |              |              |       |
| tCIH   | Command input hold time          | 1            |              |              |       |
| tBIS   | Byte Enable input setup time     | 7            |              |              |       |
| tBIH   | Byte Enable input hold time      | 1            |              |              |       |
| tFIS   | FRAME_n input setup time         | 7            |              |              |       |
| tFIH   | FRAME_n input hold time          | 1            |              |              |       |
| tIIS   | IRDY_n input setup time          | 7            |              |              |       |
| tIIH   | IRDY_n input hold time           | 1            |              |              |       |
| tTOV   | TRDY_n output valid delay time   | 2 11         |              |              |       |
| tTOH   | TRDY_n output hold time          | 1            |              |              |       |
| tSOV   | STOP_n output valid delay time   | ne 2 11      |              |              |       |
| tSOH   | STOP_n output hold time          | time 1       |              |              |       |
| tDEOV  | DEVSEL_n output valid delay time | e 2 11       |              |              |       |
| tDEOH  | DEVSEL_n output hold time        | 1            |              |              |       |

#### • Burst Write with Disconnect without Data



### 15.4 LPC Interface

#### • Memory Read Cycle

| Symbol | Parameter                | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|--------------------------|--------------|--------------|--------------|-------|
| tPCK   | PCI clock cycle time     | 30           |              | -            |       |
| tLFV   | LFRAM_n valid delay time |              |              | 23           |       |
| tLFH   | LFRAM_n hold time        | 2            |              |              |       |
| tLAV   | Address valid delay time |              |              | 23           |       |
| tLAH   | Address hold time        | 2            |              |              |       |
| tDIS   | Data input setup time    | 7            |              |              |       |
| tDIH   | Data input hold time     | 2            |              |              |       |



#### • Memory Write Cycle

| Symbol | Parameter                    | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|------------------------------|--------------|--------------|--------------|-------|
| tPCK   | PCI clock cycle time         | 30           |              |              |       |
| tLFV   | LFRAM_n valid delay time     |              |              | 23           |       |
| tLFH   | LFRAM_n hold time            | 2            |              |              |       |
| tLAV   | Address valid delay time     |              |              | 23           |       |
| tLAH   | Address hold time            | 2            |              |              |       |
| tDOV   | Data output valid delay time |              |              | 23           |       |
| tDOH   | Data output hold time        | 2            |              |              |       |



# 15.5 Bus Interface

### Read Cycle

| Symbol | Parameter          | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|--------------------|--------------|--------------|--------------|-------|
| tRC    | Read cycle time    |              | 500          |              |       |
| tOEH   | MEMR_n hold time   |              | 500          |              |       |
| tRP    | MEMR_n pulse width |              | 240          |              |       |
| tDS    | Data setup time    |              | 10           |              |       |
| tDH    | Data hold time     |              | 0            |              |       |

#### • Read Cycle Waveforms



#### • Write Cycle

| Symbol | Parameter                   | Min.<br>(ns) | Type<br>(ns) | Max.<br>(ns) | Notes |
|--------|-----------------------------|--------------|--------------|--------------|-------|
| tAS    | Address setup time          | 208          |              |              |       |
| tAH    | Address hold time           |              | 360          |              |       |
| tCS    | MEMW_n & ROMCS_n setup time |              | 178          |              |       |
| tCH    | MEMW_n & ROMCS_n hold time  |              | 62           |              |       |
| tWP    | MEMW_n pulse width          |              | 240          |              |       |
| tWPH   | MEMW_n high width           |              | 240          |              |       |
| tDV    | Data valid time             |              | 180          |              |       |
| tDH    | Data hold time              |              | 120          |              |       |

#### • Write Cycle Waveforms



# 16. Package Information

# LQFP: 216 pins



| Symbol         | Dimension in mm |       |       |  |  |  |
|----------------|-----------------|-------|-------|--|--|--|
| Symbol         | Min.            | Nom.  | Max.  |  |  |  |
| A              |                 |       | 1.60  |  |  |  |
| A <sub>1</sub> | 0.05            |       | 0.15  |  |  |  |
| A <sub>2</sub> | 1.35            | 1.40  | 1.45  |  |  |  |
| b              | 0.13            | 0.18  | 0.23  |  |  |  |
| D              | 25.85           | 26.00 | 26.15 |  |  |  |
| D <sub>1</sub> | 23.90           | 24.00 | 24.10 |  |  |  |
| E              | 25.85           | 26.00 | 26.15 |  |  |  |
| E <sub>1</sub> | 23.90 24.00     |       | 24.10 |  |  |  |
| е              | 0.40 BSC        |       |       |  |  |  |
| L              | 0.45 0.60       |       | 0.75  |  |  |  |
| L <sub>1</sub> | 1.00 REF        |       |       |  |  |  |
| R <sub>1</sub> | 0.08            |       |       |  |  |  |
| R <sub>2</sub> | 0.08            |       |       |  |  |  |
| S              | 0.20            |       |       |  |  |  |
|                | 0°              | 3.5°  | 7°    |  |  |  |
| 1              | 0°              |       |       |  |  |  |
| 2              | <b>11</b> °     | 12°   | 13°   |  |  |  |
| 3              | 11°             | 12°   | 13°   |  |  |  |



# 17. Revision History

| Rev. | Date       | History           |
|------|------------|-------------------|
| D01  | 2005/02/22 | Draft Version 0.1 |
| D02  | 2005/04/18 | Draft Version 0.2 |
| D03  | 2005/05/03 | Draft Version 0.3 |
| D04  | 2005/05/18 | Draft Version 0.4 |
| D05  | 2005/07/13 | Draft Version 0.5 |
| D06  | 2005/10/03 | Draft Version 0.6 |

RDC reserves the right to make changes without further notice to any products or data herein to improve reliability, function, or design. Information furnished by RDC is believed to be accurate and reliable. However, RDC does not assure any liability arising out of the application or use of this information, nor the application or use of any product or circuit described herein, neither does it convey any license under its patent rights nor the rights of others.