

# GT-96100A

Datasheet Revision 1.0 3 October. 2000

#### **Advanced Communication Controller**

Please contact Galileo Technology for possible updates before finalizing a design.

### **FEATURES**

- Integrated communication controller and system controller with PCI interface for highperformance embedded control applications.
- Eight Multi-Protocol Serial Controllers (MPSCs):
  - Support HDLC, BISYNC, UART and Transparent protocols.
  - Bit rate of up to 55Mbit/s on multiple channels simultaneously.
  - Can drive dedicated pins or use TDMs.
  - Dedicated DPLL for clock recovery and data encoding/decoding.
  - Supports NRZ, NRZI, FM0, FM1, Manchester and Differential Manchester.
  - Hardware support for HDLC over asynchronous channel in UART mode.
- Four FlexTDM channels:
  - Time slot assigner for serial and control channels.
  - Supports up to four Basic Rate ISDN interfaces (2B+D) in GCI mode.
  - Fully programmable via dual-port memory.
- Two 10/100Mbps Fast Ethernet MAC controllers:
  - MII/RMII interface.
  - Full duplex and flow-control support.
  - Programmable perfect filtering of 1/2K or 8K MAC addresses (both physical and multicast).
  - 2 Queues for Tx Priority queueing
  - 4 Queues for Priority queuing based on IP DSCP field or 802.1q tag or MAC address.
  - IGMP and BPDU packet trapping.

- Twenty Serial DMA (SDMA) channels to support the communications and Ethernet controllers.
  - Moves data between communications controllers and SDRAM/PCI.
  - Buffer chaining via a linked list of descriptors.
- Eight baud rate generators with multiple clock sources.
- 64-bit CPU bus interface:
  - Supports all 64-bit bus MIPS CPUs: RM5260, RM5270/1 and RM7000 from QED, RV4600 through RV5000 from IDT and R5000 compatibles from various vendors.
  - 100MHz bus frequency.
  - 3.3V bus interface.
  - Support for multiple GT-96100A devices on the same SysAD bus (up to 4).
  - 8x64-bit (64 byte) CPU write posting buffer accepts CPU writes with zero wait-states.
  - CPU address remapping to resources.
  - Zero wait state secondary cache support (L2 of R4xxx and R5000, L3 of R7000).
  - Backward Software Compatibility with GT-64010A, GT-64011 and GT-64120.



- SDRAM controller:
  - 3.3V (5V tolerant).
  - 4GB address space.
  - Supports 16/64/128/256/512Mbit SDRAM devices.
  - Supports 64-bit registered SDRAM.
  - Supports 2-way & 4-way SDRAM bank interleaving.
  - Up to 4GB bank address space, 1MB granularity.
  - 1 to 4 banks supported.
  - 64-bit data width.
  - ECC support for 64-bit SDRAM.
  - Zero wait-state interleaved burst accesses at 100MHz.
  - Supports the VESA Unified Memory Architecture (VUMA) Standard allows for external masters access to SDRAM directly.
- · Device controller:
  - 5 chip selects.
  - Programmable timing for each chip select.
  - Supports many types of standard memory and I/O devices.
  - Up to 4GB address space.
  - Optional external wait-state support.
  - 8-,16-,32- and 64-bit width device support.
  - Support for boot ROMs.

- Four Independent DMA (IDMA) channels:
  - Chaining via linked-lists of records.
  - Byte address boundary for source and destination.
  - Moves data between PCI, memory, and devices.
  - Two 64-byte internal FIFOs.
  - Alignment of source and destination addresses.
  - DMAs can be initiated by the CPU writing to a register, external request via DMAReq\* pin, or an internal timer/ counter.
  - Termination of DMA transfer on each channel.
  - Descriptor ownership transfer to CPU.
  - Fly-By support for local data bus.
  - Override capability of source/ destination/record address mapping.



- Two 32-bit or one 64-bit high-performance PCI 2.1 compliant devices:
  - Dual mode PCI interface can be used as two independent 32-bit interfaces (synchronous or asynchronous to each other) or as a single 64-bit interface.
  - 192-bytes of posted write and read prefetch buffers for each PCI interface.
  - 32/64-bit PCI master and target operations.
  - PCI bus speed of up to 66MHz with zero wait states.
  - Universal PCI buffers (each 32-bit PCI use a different voltage).
  - Operates either synchronous or asynchronous to the CPU clock.
  - Burst transfers used for efficient data movement.
  - Doorbell interrupts provided between CPU and PCI.
  - Supports flexible byte swapping through PCI interface.
  - Synchronization barrier support for PCI side.
  - PCI address remapping to resources.
- Host to PCI bridge:
  - Translates CPU cycles into PCI I/O or Memory cycles.
  - Generates PCI Configuration, Interrupt Acknowledge, and Special cycles on PCI bus.
- PCI to Main Memory bridge:
  - Supports fast back-to-back transactions.
  - Supports memory and I/O transactions to internal configuration registers.
  - Supports locked operations.

- I<sub>2</sub>O and Plug and Play Support:
  - Industry Standard I<sub>2</sub>O messaging unit on primary 32-bit PCI interface (also available in 64-bit mode).
  - Plug and Play compatible configuration registers.
  - PCI configuration header can be loaded from boot PROM.
  - PCI configuration registers are accessible from both CPU and PCI bus.
  - Expansion ROM support.
- PCI Hot-Plug and CompactPCI Hot-Swap capable compliant.
- Two programmable PCI Arbiter functions:
  - Supports up to 9 external agents in addition to PCI\_0 and PCI\_1 internal devices.
  - Two level priority arbitration capability
     each request can be assigned either high or low priority.
- Two-stage watchdog timer (NMI, Reset).
- One 32-bit wide timer/counter, Three 24-bit wide timer/counters.
- Eighty-eight pins dedicated for peripheral functions and general purpose I/Os.
  - Each pin can be configured independently as peripheral or General Purpose I/O.
  - Supports simple I/O and LED control.
  - Inputs can generate a maskable interrupt.
- 2.5V Core Supply Voltage, 3.3V I/O Supply Voltage (PCI and Peripherals).
  - All inputs are 5V tolerant.
- JTAG Boundary Scan.
- 492 pin PBGA package.
- Advanced 0.25 micron CMOS process.



Part Number: GT-96100A Publication Revision: 1.0

©Galileo Technology, Inc.

No part of this datasheet may be reproduced or transmitted in any form or by any means, electronic or mechanical, including photocopying and recording, for any purpose without the express written permission of Galileo Technology, Inc.

Galileo Technology, Inc. retains the right to make changes to these specifications at any time, without notice.

Galileo Technology, Inc. makes no warranty of any kind, expressed or implied, with regard to this material, including, but not limited to, the implied warranties of merchantability or fitness for any particular purpose. Galileo Technology, Inc. further does not warrant the accuracy or completeness of the information, text, graphics, or other items contained within these materials. Galileo Technology, Inc. makes no commitment to update nor to keep current the information contained in this document.

Galileo Technology, Inc. assumes no responsibility for the use of any circuitry other than circuitry embodied in Galileo Technology, Inc. products. No other circuit patent licenses are implied.

Galileo Technology, Inc. products are not designed for use in life support equipment or applications in which if the product failed it would cause a life threatening situation. Do not use Galileo Technology, Inc. products in these types of equipment or applications.

Contact your local sales office to obtain the latest specifications before finalizing your product.

Galileo Technology, Inc. 142 Charcot Avenue San Jose, California 95131 Phone: 1 408 367-1400 Fax: 1 (408) 367-1401 E-mail: info@galileot.com www.galileoT.com



Other brands and names are the property of their respective owners.

## TABLE OF CONTENTS

| 1. | Over        | view                                                      | 19 |
|----|-------------|-----------------------------------------------------------|----|
|    | 1.1         | Communication Unit Description                            | 19 |
|    | 1.2         | CPU Interface                                             | 21 |
|    | 1.3         | SDRAM and Device Interface                                | 21 |
|    | 1.4         | PCI Interface                                             | 21 |
|    | 1.5         | Independent DMA (IDMA) Engines                            | 22 |
|    | 1.6         | Peripheral Configurations                                 |    |
| 2. | Pin I       | nformation                                                | 25 |
| 3. | ۸dd         | ress Space Decoding                                       | 56 |
| J. | 3.1         | Two Stage Decoding Process                                |    |
|    | 3.1         | Disabling Address Decoders                                |    |
|    | 3.2<br>3.3  | DMA Unit Address Decoding                                 |    |
|    | 3.3<br>3.4  |                                                           |    |
|    |             | Address Space Decoding Errors                             |    |
|    | 3.5         | Default Memory Map                                        |    |
|    | 3.6         | Address Remapping                                         |    |
|    | 3.7         | Using the CPU PCI Override.                               |    |
|    | 3.8         | Using the DMA to PCI Bypass.                              | 71 |
| 4. | CPU         | Interface Description                                     |    |
|    | 4.1         | CPU Interface Signals                                     | 72 |
|    | 4.2         | SysAD, SysADC, and SysCmd Buses                           |    |
|    | 4.3         | Operation of WrRdy* and the Internal Write Posting Queues | 79 |
|    | 4.4         | CPU Write Modes and Write Patterns Supported              | 79 |
|    | 4.5         | CPU Interface Endianess                                   | 80 |
|    | 4.6         | Burst Order                                               | 80 |
|    | 4.7         | MIPS L2 Cache Support                                     | 80 |
|    | 4.8         | Multiple GT-96100A Support.                               | 81 |
|    | 4.9         | CPU Interface Restrictions                                | 84 |
|    | 4.10        | CPU Interface Control Registers                           | 84 |
| 5. | Mem         | ory Controller                                            | 95 |
| •  | 5.1         | SDRAM Controller                                          |    |
|    | 5.2         | Connecting the Address Bus to the SDRAM.                  |    |
|    | 5.3         | Programmable SDRAM Parameters                             |    |
|    | 5.4         | SDRAM Performance                                         |    |
|    | 5.5         | SDRAM Bank Interleaving.                                  |    |
|    | 5.6         | Unified Memory Architecture (UMA) Support                 |    |
|    | 5.7         | Device Controller                                         |    |
|    | 5.8         | Programming the ADP lines for other Functions             |    |
|    | 5.8<br>5.9  | Memory Controller Restrictions                            |    |
|    | 5.9<br>5.10 | Registered SDRAM Interface Restrictions                   |    |
|    | 5.10        | Memory Interface Control Registers                        |    |
|    |             |                                                           |    |
| 6. |             | Integrity 1                                               |    |
|    | 6.1         | SDRAM ECC                                                 |    |
|    | 6.2         | PCI Parity Support                                        | 47 |



|     | <ul> <li>6.3 Parity Support for Devices</li> <li>6.4 CPU Parity Support</li> <li>6.5 Data Integrity Flow</li> <li>6.6 Register Information</li> <li>6.7 CPU Errors Report Registers</li> </ul>                                                                                                                                                                                                                                                                                                                                     | 147<br>148<br>150                                                                                                  |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| 7.  | PCI Interfaces                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 152<br>157<br>161<br>162<br>163<br>166<br>167<br>167<br>167<br>168<br>168<br>169                                   |
| 8.  | Intelligent I/O (I2O) Standard Support       2         8.1       Overview         8.2       I2O Registers         8.3       Enabling I2O Support         8.4       Register Map Compatibility with the i960Rx Family         8.5       Message Registers         8.6       Doorbell Registers         8.7       Circular Queues         8.8       I2O Support Registers                                                                                                                                                            | 201<br>203<br>203<br>203<br>203<br>204<br>204                                                                      |
| 9.  | Independent DMA Controllers (IDMA Controllers)       2         9.1       DMA Channel Registers.         9.2       DMA Channel Control Register (0x840 - 0x84c)         9.3       Restarting a Disabled Channel.         9.4       Reprogramming an Active Channel         9.5       Arbitration.         9.6       Current Descriptor Pointer Registers         9.7       Design Information         9.8       Initiating a DMA from a Timer/Counter.         9.9       DMA Restrictions         9.10       DMA Control Registers. | <ul> <li>219</li> <li>221</li> <li>224</li> <li>225</li> <li>225</li> <li>225</li> <li>230</li> <li>230</li> </ul> |
| 10. | PCI Arbiter       10.1         10.1       Interface         10.2       Arbitration Scheme         10.3       Arbitration Parking         10.4       PCI Arbiter Configuration Register                                                                                                                                                                                                                                                                                                                                             | 241<br>242<br>243                                                                                                  |



|     | Communication Interface Unit (CIU)                     | 246                                                                       |
|-----|--------------------------------------------------------|---------------------------------------------------------------------------|
|     | 11.1 CIU Connectivity                                  |                                                                           |
|     | 11.2 Address Decoding and PCI Override (MASTER)        |                                                                           |
|     | 11.3 Arbitration Scheme                                |                                                                           |
|     | 11.4 CIU Arbiter Configuration Register                | 201                                                                       |
| 12. | 10/100Mb Ethernet Unit                                 |                                                                           |
|     | 12.1 Functional Overview                               |                                                                           |
|     | 12.2 Port Features                                     |                                                                           |
|     | 12.3 Operational Description                           |                                                                           |
|     | 12.4 Ethernet Port    12.5 Internal Control Registers  |                                                                           |
|     | 12.6 Ethernet MIB Counters                             |                                                                           |
|     |                                                        |                                                                           |
| 13. | Serial DMA (SDMA)                                      |                                                                           |
|     | 13.1 Overview                                          |                                                                           |
|     | <ul><li>13.2 SDMA Descriptors</li></ul>                |                                                                           |
|     | 13.4 SDMA Command Register (SDC)                       |                                                                           |
|     | 13.5 SDMA Group Configuration Register                 |                                                                           |
|     | 13.6 SDMA Descriptor Pointer Registers                 |                                                                           |
|     | 13.7 Transmit SDMA                                     |                                                                           |
|     | 13.8 Receive SDMA                                      |                                                                           |
|     | 13.9 SDMA Interrupt and Mask register (SDI and SDM)    |                                                                           |
|     | 13.10 SDMA in Auto Mode                                | 319                                                                       |
|     | 13.11 SDMA Registers                                   | 320                                                                       |
| 14. | Multi Protocol Serial Controller (MPSC)                | 326                                                                       |
|     | 14.1 DPLL                                              |                                                                           |
|     | 14.2 MPSCx Main Configuration Register (MMCRx)         | 328                                                                       |
|     | 14.3 MPSCx Protocol Configuration Registers (MPCRx)    |                                                                           |
|     | 14.4 Channel Registers (CHxRx)                         |                                                                           |
|     | 14.5 HDLC Mode                                         |                                                                           |
|     | 14.6 BISYNC Mode                                       |                                                                           |
|     | 14.7 UART Mode                                         |                                                                           |
|     | 14.9 Transport Drotocol                                |                                                                           |
|     | 14.8 Transparent Protocol                              |                                                                           |
| 15. | FlexTDM Units (FTDM)                                   | 372<br><b>379</b>                                                         |
| 15. | FlexTDM Units (FTDM)                                   | 372<br><b>379</b><br>380                                                  |
| 15. | FlexTDM Units (FTDM)         15.1 FlexTDM Architecture | 372<br><b>379</b><br>380<br>380                                           |
| 15. | FlexTDM Units (FTDM)         15.1 FlexTDM Architecture | 372<br>379<br>380<br>380<br>383                                           |
| 15. | FlexTDM Units (FTDM)                                   | 372<br>379<br>380<br>380<br>383<br>383                                    |
| 15. | FlexTDM Units (FTDM)                                   | 372<br>379<br>380<br>380<br>383<br>384<br>386                             |
| 15. | FlexTDM Units (FTDM)                                   | 372<br>380<br>380<br>383<br>383<br>384<br>386<br>387                      |
| 15. | FlexTDM Units (FTDM)                                   | 372<br>380<br>380<br>383<br>384<br>386<br>387<br>388                      |
| 15. | FlexTDM Units (FTDM)                                   | 372<br>380<br>380<br>383<br>384<br>386<br>387<br>388<br>388               |
| 15. | FlexTDM Units (FTDM)                                   | 372<br>380<br>380<br>383<br>384<br>386<br>387<br>388<br>388<br>388<br>388 |



| 16.               | Baud Rate Generators (BRGs)         16.1 BRG Inputs and Outputs         16.2 BRG Baud Tuning         16.3 BRG Registers                                                                                                                                                                                                                                                                                                                   | . 397<br>. 397                                                                                               |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| 17.               | Watchdog Timer         17.1 Watchdog Registers         17.2 Watchdog Operation                                                                                                                                                                                                                                                                                                                                                            | 401                                                                                                          |
| 18.               | Timers/Counters         18.1 Timer / Counter Registers                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                              |
| 19.               | General Purpose Ports         19.1 Overview         19.2 General Purpose Control Registers                                                                                                                                                                                                                                                                                                                                                | 405                                                                                                          |
| 20.               | Physical Signal Routing         20.1 Signal Routing         20.2 Clock Routing                                                                                                                                                                                                                                                                                                                                                            | 414                                                                                                          |
| 21.               | Interrupt Controller         21.1       Interrupt Cause Registers         21.2       Interrupt Mask Registers         21.3       Interrupt Summaries         21.4       Interrupt Select Registers         21.5       Interrupt Registers Tables                                                                                                                                                                                          | 424<br>425<br>426<br>426                                                                                     |
| 22.               | Reset Configuration                                                                                                                                                                                                                                                                                                                                                                                                                       | 452                                                                                                          |
| <b>LL</b> .       |                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                              |
| 23.               | Connecting the Memory Controller to SDRAM and Devices                                                                                                                                                                                                                                                                                                                                                                                     | <b>455</b><br>455                                                                                            |
|                   | Connecting the Memory Controller to SDRAM and Devices                                                                                                                                                                                                                                                                                                                                                                                     | <b>455</b><br>455<br>456<br><b>460</b><br>460<br>461<br>461<br>461                                           |
| 23.               | Connecting the Memory Controller to SDRAM and Devices                                                                                                                                                                                                                                                                                                                                                                                     | <b>455</b><br>456<br><b>460</b><br>460<br>461<br>461<br>461<br>461<br>462<br><b>463</b>                      |
| 23.<br>24.        | Connecting the Memory Controller to SDRAM and Devices                                                                                                                                                                                                                                                                                                                                                                                     | <b>455</b><br>456<br><b>460</b><br>460<br>461<br>461<br>461<br>461<br>462<br><b>463</b><br>463<br>465        |
| 23.<br>24.<br>25. | Connecting the Memory Controller to SDRAM and Devices.         23.1 SDRAM         23.2 Devices.         JTAG Interface.         24.1 IEEE Standard 1149.1         24.2 TAP Controller         24.3 Instruction Register (IR).         24.4 Bypass Register (BR).         24.5 JTAG Scan Chain.         24.6 ID Register         Big and Little Endian         25.1 Background         25.2 Configuring a System for Big and Little Endian | <b>455</b><br>456<br>460<br>460<br>461<br>461<br>461<br>461<br>462<br><b>463</b><br>463<br>465<br><b>466</b> |



| 29. | System Configurations                                      | 475   |
|-----|------------------------------------------------------------|-------|
|     | 29.1 Minimal System Configuration                          |       |
|     | 29.2 Typical System Configuration                          |       |
|     | 29.3 High Performance System.                              | . 477 |
| 30. | Register Tables                                            | 478   |
|     | 30.1 Access to On-Chip PCI Configuration Space Registers   | . 478 |
|     | 30.2 Register Maps                                         | . 479 |
| 31. | DC Characteristics                                         | 508   |
|     | 31.1 DC Electrical Characteristics Over Operating Range    | . 509 |
|     | 31.2 Thermal Data                                          | 512   |
| 32. | AC Timing                                                  | 513   |
|     | 32.1 TClk/PClk Restrictions                                |       |
|     | 32.2 Serial (Communication) Clock Domain AC Characteristic | . 518 |
|     | 32.3 MPSC Waveforms                                        |       |
|     | 32.4 MII Waveforms                                         |       |
|     | 32.5 JTAG AC Characteristics.                              |       |
|     | 32.6 Additional Delay Due to Capacitive Loading            | . 531 |
| 33. | Pinout Table, 492 Pin BGA                                  | 533   |
| 34. | 492 BGA Package Mechanical Information                     | 542   |
| 35. | GT–96100A Part Numbering                                   | 543   |
|     | 35.1 Standard Part Number                                  |       |
|     | 35.2 Valid Part Numbers                                    | . 543 |
| 36. | Abbreviations                                              | 544   |
| 37. | Revision History                                           | 515   |
| 57. |                                                            | J+J   |



## List of Tables

| 1. | Overview               |                                                                                | 19   |
|----|------------------------|--------------------------------------------------------------------------------|------|
|    | Table 1:               | GT–96100A Serial Performance                                                   | . 20 |
|    | Table 2:               | GT–96100A Port Configurations                                                  | . 23 |
|    | Table 3:               | GT–96100A Peripheral Configurations                                            | . 24 |
| 2. | Pin Information        | on                                                                             | 25   |
|    | Table 4:               | CPU Interface Pin Assignments                                                  |      |
|    | Table 5:               | Secondary Cache Interface Pin Assignments                                      | . 26 |
|    | Table 6:               | PCI Bus 0 Pin Assignments.                                                     | . 27 |
|    | Table 7:               | PCI Bus 1 Pin Assignments.                                                     | . 29 |
|    | Table 8:               | SDRAM and Devices Pin Assignments                                              | . 31 |
|    | Table 9:               | Local Address and Data Bus Pin Assignments                                     | . 32 |
|    | Table 10:              | DMA Pin Assignments                                                            | . 35 |
|    | Table 11:              | WAN Pin Assignments                                                            | . 36 |
|    | Table 12:              | LAN Pin Assignments                                                            |      |
|    | Table 13:              | GPP Pin Assignments                                                            |      |
|    | Table 14:              | Interrupt Interface Pin Assignments                                            |      |
|    | Table 15:              | Watchdog Interface Pin Assignments                                             |      |
|    | Table 16:              | Test Interface Pin Assignments.                                                |      |
|    | Table 17:              | Clock/Control Interface Pin Assignments                                        |      |
| 3. | Address Spa            | ce Decoding                                                                    | 56   |
|    | Table 18:              | CPU and Device Decoder Mappings.                                               | . 57 |
|    |                        | PCI_0 Base Address Register and Device Decoder Mappings                        |      |
|    |                        | PCI_1 Base Address Register and Device Decoder Mappings                        |      |
|    | Table 21:              | CPU and Device Decoder Default Address Mapping                                 |      |
|    | Table 22:              | PCI Function 0 and Device Decoder Default Address Mapping                      | . 65 |
|    | Table 23:              | PCI Function 1 (Byte Order Swap) and<br>Device Decoder Default Address Mapping | 66   |
|    | Table 24 <sup>.</sup>  | PCI Address Remapping Example                                                  |      |
|    |                        |                                                                                |      |
| 4. |                        | Description                                                                    |      |
|    | Table 25.<br>Table 26: | CPU Interface Signals                                                          |      |
|    |                        | Address Phase SysCmd[8:0] Encodings (driven by CPU)                            |      |
|    |                        | Read Response SysCmd[8:0] Encodings (driven by the GT-96100A)                  |      |
|    | Table 28.              | CPU Write SysCmd[8:0] Encodings (driven by local master)                       |      |
|    | Table 30:              | SysAD Read Phases                                                              |      |
|    | Table 31:              | SysAD Write Phases                                                             |      |
|    | Table 31:              | Pin Strapping the GT-96100A ID.                                                |      |
|    | Table 33:              | WrRdy*, ValidIn*, and ScDOE* Signal Multiple GT-96100A Functionality           |      |
|    | Table 34:              | Initializing a Multiple GT-96100A System                                       |      |
|    | Table 35:              | CPU Interface Register Map                                                     |      |
| F  |                        |                                                                                |      |
| 5. |                        | roller<br>DMAReq*, Ready* and BypsOE* Functionality                            |      |
|    |                        | Divinited, ready and bypoor rundlinding                                        | 101  |



|                  | Table 72:<br>Table 73:<br>Table 74:<br>Table 75:<br>Table 76:                                                                                                                                                                                                                                    | SysAD/PCI Address Decoding for 32-bit SDRAM, 16 Mbit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | . 104<br>. 105<br>. 105<br>. 106                                                                                                                                                 |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | Table 77:<br>Table 78:                                                                                                                                                                                                                                                                           | Programmable SDRAM Parameters                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                  |
|                  | Table 70:                                                                                                                                                                                                                                                                                        | Events Determining PCI Read Performance from SDRAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
|                  | Table 80:                                                                                                                                                                                                                                                                                        | GT–96100A Sync. Modes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                  |
|                  | Table 81:                                                                                                                                                                                                                                                                                        | SDRAM Performance Summary PCI Read Accesses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                  |
|                  | Table 82:                                                                                                                                                                                                                                                                                        | UMA AC Timing Parameters                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                  |
|                  | Table 83:                                                                                                                                                                                                                                                                                        | ADP[7:0] Pin Functionality                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | . 125                                                                                                                                                                            |
|                  | Table 84:                                                                                                                                                                                                                                                                                        | 32-bit Device Limitations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | . 127                                                                                                                                                                            |
|                  | Table 85:                                                                                                                                                                                                                                                                                        | Memory Interface Register Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | . 128                                                                                                                                                                            |
| 6.               | Data Integrity                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 143                                                                                                                                                                              |
|                  |                                                                                                                                                                                                                                                                                                  | ECC Code Matrix                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                  |
|                  | Table 124:                                                                                                                                                                                                                                                                                       | Registers for Implementing Parity and ECC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | . 150                                                                                                                                                                            |
| 7.               | PCI Interfaces                                                                                                                                                                                                                                                                                   | \$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 152                                                                                                                                                                              |
|                  |                                                                                                                                                                                                                                                                                                  | DevNum to IdSel Mapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                  |
|                  | Table 131:                                                                                                                                                                                                                                                                                       | PCI_0 Registers Loaded at RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 165                                                                                                                                                                            |
|                  | Table 132:                                                                                                                                                                                                                                                                                       | PCI_1 Registers Loaded at RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 165                                                                                                                                                                            |
|                  | Table 133:                                                                                                                                                                                                                                                                                       | PCI Control and Configuration Register Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | . 169                                                                                                                                                                            |
|                  |                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                  |
| 8.               | Intelligent I/O                                                                                                                                                                                                                                                                                  | (I2O) Standard Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                  |
| 8.               | Intelligent I/O<br>Table 209:                                                                                                                                                                                                                                                                    | I2O PCI and CPU Offsets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . 202                                                                                                                                                                            |
| 8.               | Intelligent I/O<br>Table 209:<br>Table 210:                                                                                                                                                                                                                                                      | I2O PCI and CPU Offsets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . 202<br>. 203                                                                                                                                                                   |
| 8.               | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:                                                                                                                                                                                                                                        | I2O PCI and CPU Offsets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . 202<br>. 203<br>. 205                                                                                                                                                          |
| 8.               | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:                                                                                                                                                                                                                          | I2O PCI and CPU Offsets       Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses       I2O Circular Queue Functional Summary.                                                                                                                                                                                                                                                                                                                                                                                    | . 202<br>. 203<br>. 205<br>. 209                                                                                                                                                 |
|                  | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:                                                                                                                                                                                                            | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map                                                                                                                                                                                                                                                                                                                                               | . 202<br>. 203<br>. 205<br>. 209<br>. 210                                                                                                                                        |
| 8.<br>9.         | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent                                                                                                                                                                                             | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).                                                                                                                                                                                                                                                                                                   | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. <b>219</b>                                                                                                                        |
|                  | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 237:                                                                                                                                                                             | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.                                                                                                                                                                                                                                                          | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br><b>. 219</b><br>. 223                                                                                                               |
|                  | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 237:<br>Table 238:                                                                                                                                                               | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP                                                                                                                                                                                                             | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br><b>. 219</b><br>. 223<br>. 223                                                                                                      |
|                  | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 237:<br>Table 238:<br>Table 239:                                                                                                                                                 | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP                                                                                                                                                                     | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. 219<br>. 223<br>. 223<br>. 223<br>. 223                                                                                           |
|                  | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 237:<br>Table 238:<br>Table 239:<br>Table 240:                                                                                                                                   | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP         IDMA Controller Design Information Terms and Definitions                                                                                                    | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. 219<br>. 223<br>. 223<br>. 223<br>. 223<br>. 225                                                                                  |
|                  | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 237:<br>Table 238:<br>Table 239:<br>Table 240:<br>Table 241:                                                                                                                     | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP         IDMA Controller Design Information Terms and Definitions         Source and Data Transfer Examples                                                          | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. 210<br>. 223<br>. 223<br>. 223<br>. 225<br>. 227                                                                                  |
|                  | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 237:<br>Table 238:<br>Table 239:<br>Table 240:<br>Table 241:<br>Table 242:                                                                                                       | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP         IDMA Controller Design Information Terms and Definitions         Source and Data Transfer Examples         Fly-By Bits.                                     | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. 210<br>. 223<br>. 223<br>. 223<br>. 223<br>. 225<br>. 227<br>. 229                                                                |
| 9.               | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 237:<br>Table 238:<br>Table 239:<br>Table 240:<br>Table 241:<br>Table 242:<br>Table 243:                                                                                         | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP         IDMA Controller Design Information Terms and Definitions         Source and Data Transfer Examples         Fly-By Bits.         DMA Control Register Map    | 202<br>203<br>205<br>209<br>210<br>223<br>223<br>223<br>225<br>225<br>227<br>229<br>231                                                                                          |
|                  | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 237:<br>Table 238:<br>Table 239:<br>Table 240:<br>Table 240:<br>Table 241:<br>Table 242:<br>Table 243:<br>PCI Arbiter                                                            | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP         IDMA Controller Design Information Terms and Definitions         Source and Data Transfer Examples         Fly-By Bits.                                     | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. 210<br>. 223<br>. 223<br>. 223<br>. 225<br>. 227<br>. 229<br>. 231<br>. 231<br>. 241                                              |
| 9.               | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 239:<br>Table 239:<br>Table 240:<br>Table 241:<br>Table 242:<br>Table 243:<br>PCI Arbiter<br>Table 269:                                                                          | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP         IDMA Controller Design Information Terms and Definitions         Source and Data Transfer Examples         Fly-By Bits.         DMA Control Register Map    | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. 210<br>. 223<br>. 223<br>. 223<br>. 225<br>. 227<br>. 229<br>. 231<br>. 221<br>. 241                                              |
| 9.<br>10.<br>11. | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 239:<br>Table 239:<br>Table 240:<br>Table 240:<br>Table 241:<br>Table 242:<br>Table 243:<br>PCI Arbiter<br>Table 269:                                                            | I2O PCI and CPU Offsets.         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP         IDMA Controller Design Information Terms and Definitions.         Source and Data Transfer Examples         Fly-By Bits.         DMA Control Register Map. | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. 210<br>. 223<br>. 223<br>. 223<br>. 225<br>. 227<br>. 229<br>. 231<br>. 229<br>. 231<br>. 241<br>. 241<br>. 246                   |
| 9.<br>10.        | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 237:<br>Table 238:<br>Table 239:<br>Table 240:<br>Table 241:<br>Table 241:<br>Table 242:<br>Table 243:<br>PCI Arbiter<br>Table 269:<br>Communicati<br>10/100Mb Eth               | I2O PCI and CPU Offsets         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP         IDMA Controller Design Information Terms and Definitions         Source and Data Transfer Examples         Fly-By Bits.         DMA Control Register Map.   | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. 210<br>. 223<br>. 223<br>. 223<br>. 223<br>. 225<br>. 227<br>. 229<br>. 231<br>. 241<br>. 241<br>. 241<br>. 241<br>. 246<br>. 253 |
| 9.<br>10.<br>11. | Intelligent I/O<br>Table 209:<br>Table 210:<br>Table 211:<br>Table 212:<br>Table 213:<br>Independent I<br>Table 238:<br>Table 239:<br>Table 239:<br>Table 240:<br>Table 240:<br>Table 241:<br>Table 242:<br>Table 243:<br>PCI Arbiter<br>Table 269:<br>Communicati<br>10/100Mb Eth<br>Table 273: | I2O PCI and CPU Offsets.         Register Differences Between the GT–96100A and i960Rx.         Circular Queue Starting Addresses         I2O Circular Queue Functional Summary.         I2O Support Register Map         DMA Controllers (IDMA Controllers).         Location of Source Address, SLP.         Location of Destination Address, DLP         Location of Record Address, RLP         IDMA Controller Design Information Terms and Definitions.         Source and Data Transfer Examples         Fly-By Bits.         DMA Control Register Map. | . 202<br>. 203<br>. 205<br>. 209<br>. 210<br>. 219<br>. 223<br>. 223<br>. 223<br>. 223<br>. 225<br>. 227<br>. 229<br>. 231<br>. 241<br>. 241<br>. 241<br>. 246<br>. 253<br>. 260 |



|     | Table 275: Ethernet TX Descriptor - Buffer Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | er                                                                                                                                                                     | 261                                                                                                                                                                                              |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | Table 276: Ethernet TX Descriptor - Next Descri                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ptor Pointer                                                                                                                                                           | 261                                                                                                                                                                                              |
|     | Table 277: Ethernet RX Descriptor - Command/S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                        |                                                                                                                                                                                                  |
|     | Table 278: Ethernet RX Descriptor - Buffer Size                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | / Byte Count                                                                                                                                                           | 266                                                                                                                                                                                              |
|     | Table 279: Ethernet RX Descriptor - Buffer Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ter                                                                                                                                                                    | 266                                                                                                                                                                                              |
|     | Table 280: Ethernet RX Descriptor - Next Descri                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | iptor Pointer                                                                                                                                                          | 266                                                                                                                                                                                              |
|     | Table 281: Hash Table Entry Fields                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                        | 270                                                                                                                                                                                              |
|     | Table 282: Packet Filtering Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                        | 275                                                                                                                                                                                              |
|     | Table 283: MII Management Frame Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                        | 281                                                                                                                                                                                              |
|     | Table 284: Bit Transmission Parts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                        | 281                                                                                                                                                                                              |
|     | Table 285: Ethernet Unit Register Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                        | 283                                                                                                                                                                                              |
|     | Table 300: IP Differentiated Services CodePoint                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | to Priority0 low (DSCP2P0L)                                                                                                                                            | 299                                                                                                                                                                                              |
|     | Table 301: IP Differentiated Services CodePoint                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | to Priority0 high (DSCP2P0H)                                                                                                                                           | 299                                                                                                                                                                                              |
|     | Table 302: IP Differentiated Services CodePoint                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | to Priority1 low (DSCP2P1L)                                                                                                                                            | 299                                                                                                                                                                                              |
|     | Table 303: IP Differentiated Services CodePoint                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | to Priority1 high (DSCP2P1H)                                                                                                                                           | 299                                                                                                                                                                                              |
|     | Table 304: VLAN Priority Tag to Priority (VPT2P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | )                                                                                                                                                                      | 299                                                                                                                                                                                              |
|     | Table 305: Writing IP DSCP Priority Example.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                        | 300                                                                                                                                                                                              |
|     | Table 306: Writing VLAN Priority Example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                        | 300                                                                                                                                                                                              |
|     | Table 307: Writing IP DSCP and VLAN Priority E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Example                                                                                                                                                                | 301                                                                                                                                                                                              |
|     | Table 308: Writing IP DSCP and VLAN Priority F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Register mapping Example                                                                                                                                               | 301                                                                                                                                                                                              |
|     | Table 309: Terms Used in MIB Counters Descrip                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | otions                                                                                                                                                                 | 301                                                                                                                                                                                              |
| 13. | Serial DMA (SDMA)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                        | 307                                                                                                                                                                                              |
|     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                        |                                                                                                                                                                                                  |
| 10. | Table 311: SDMA Descriptor - Command/Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | word                                                                                                                                                                   | 309                                                                                                                                                                                              |
| 10. | Table 311: SDMA Descriptor - Command/Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | word                                                                                                                                                                   | 309                                                                                                                                                                                              |
| 10. | Table 311: SDMA Descriptor - Command/Status<br>Table 312: SDMA Descriptor - Buffer Size, Byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | word                                                                                                                                                                   | 309<br>310                                                                                                                                                                                       |
| 10. | Table 311: SDMA Descriptor - Command/Status<br>Table 312: SDMA Descriptor - Buffer Size, Byte<br>Table 313: SDMA Descriptor - Byte Count, Shac                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | word                                                                                                                                                                   | 309<br>310<br>310                                                                                                                                                                                |
| 10. | Table 311: SDMA Descriptor - Command/Status<br>Table 312: SDMA Descriptor - Buffer Size, Byte<br>Table 313: SDMA Descriptor - Byte Count, Shac<br>Table 314: SDMA Descriptor - Buffer Pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | word                                                                                                                                                                   | 309<br>310<br>310<br>310                                                                                                                                                                         |
| 10. | Table 311: SDMA Descriptor - Command/Status<br>Table 312: SDMA Descriptor - Buffer Size, Byte<br>Table 313: SDMA Descriptor - Byte Count, Shac<br>Table 314: SDMA Descriptor - Buffer Pointer<br>Table 315: SDMA Descriptor - Next Descriptor F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | s word                                                                                                                                                                 | 309<br>310<br>310<br>310<br>311                                                                                                                                                                  |
| 10. | Table 311: SDMA Descriptor - Command/StatusTable 312: SDMA Descriptor - Buffer Size, ByteTable 313: SDMA Descriptor - Byte Count, ShacTable 314: SDMA Descriptor - Buffer PointerTable 315: SDMA Descriptor - Next Descriptor FTable 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s word                                                                                                                                                                 |                                                                                                                                                                                                  |
| 10. | Table 311: SDMA Descriptor - Command/StatusTable 312: SDMA Descriptor - Buffer Size, ByteTable 313: SDMA Descriptor - Byte Count, ShacTable 314: SDMA Descriptor - Buffer PointerTable 315: SDMA Descriptor - Next Descriptor FTable 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | word                                                                                                                                                                   | 309<br>310<br>310<br>310<br>311<br>318<br>320                                                                                                                                                    |
|     | Table 311: SDMA Descriptor - Command/StatusTable 312: SDMA Descriptor - Buffer Size, ByteTable 313: SDMA Descriptor - Byte Count, ShacTable 314: SDMA Descriptor - Buffer PointerTable 315: SDMA Descriptor - Next Descriptor FTable 315: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s word                                                                                                                                                                 | 309<br>310<br>310<br>311<br>311<br>318<br>320<br>323                                                                                                                                             |
| 14. | Table 311: SDMA Descriptor - Command/StatusTable 312: SDMA Descriptor - Buffer Size, ByteTable 313: SDMA Descriptor - Byte Count, ShacTable 314: SDMA Descriptor - Buffer PointerTable 315: SDMA Descriptor - Next Descriptor FTable 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s word                                                                                                                                                                 | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>326                                                                                                                                             |
|     | Table 311: SDMA Descriptor - Command/StatusTable 312: SDMA Descriptor - Buffer Size, ByteTable 313: SDMA Descriptor - Byte Count, ShacTable 314: SDMA Descriptor - Buffer PointerTable 315: SDMA Descriptor - Next Descriptor FTable 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s word                                                                                                                                                                 | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>326<br>333                                                                                                                                      |
|     | Table 311: SDMA Descriptor - Command/Status         Table 312: SDMA Descriptor - Buffer Size, Byte         Table 313: SDMA Descriptor - Byte Count, Shac         Table 314: SDMA Descriptor - Buffer Pointer         Table 315: SDMA Descriptor - Buffer Pointer         Table 315: SDMA Descriptor - Next Descriptor F         Table 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                            | s word                                                                                                                                                                 | 309<br>310<br>310<br>311<br>318<br>320<br>323<br><b>326</b><br>333<br>338                                                                                                                        |
|     | Table 311: SDMA Descriptor - Command/Status         Table 312: SDMA Descriptor - Buffer Size, Byte         Table 313: SDMA Descriptor - Byte Count, Shac         Table 314: SDMA Descriptor - Buffer Pointer         Table 315: SDMA Descriptor - Next Descriptor F         Table 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | s word                                                                                                                                                                 | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>323<br>338<br>338<br>348                                                                                                                        |
|     | Table 311: SDMA Descriptor - Command/Status         Table 312: SDMA Descriptor - Buffer Size, Byte         Table 313: SDMA Descriptor - Byte Count, Shac         Table 314: SDMA Descriptor - Buffer Pointer         Table 315: SDMA Descriptor - Next Descriptor F         Table 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | s word                                                                                                                                                                 | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>326<br>333<br>338<br>338<br>348<br>350                                                                                                          |
|     | Table 311: SDMA Descriptor - Command/Status         Table 312: SDMA Descriptor - Buffer Size, Byte         Table 313: SDMA Descriptor - Byte Count, Shac         Table 314: SDMA Descriptor - Buffer Pointer         Table 315: SDMA Descriptor - Next Descriptor F         Table 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | s word<br>Count (Rx Descriptor)<br>dow Byte Count (Tx Descriptor)<br>Pointer<br>DLC Mode<br>ISYNC Mode<br>Format.                                                      | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>326<br>333<br>338<br>348<br>350<br>358                                                                                                          |
|     | Table 311: SDMA Descriptor - Command/Status         Table 312: SDMA Descriptor - Buffer Size, Byte         Table 313: SDMA Descriptor - Byte Count, Shac         Table 314: SDMA Descriptor - Buffer Pointer         Table 315: SDMA Descriptor - Next Descriptor F         Table 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | word<br>Count (Rx Descriptor)<br>dow Byte Count (Tx Descriptor)<br>Pointer<br>DLC Mode<br>ISYNC Mode<br>Format.                                                        | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>323<br>338<br>338<br>338<br>350<br>358<br>359                                                                                                   |
|     | Table 311: SDMA Descriptor - Command/Status         Table 312: SDMA Descriptor - Buffer Size, Byte         Table 313: SDMA Descriptor - Byte Count, Shac         Table 314: SDMA Descriptor - Buffer Pointer         Table 315: SDMA Descriptor - Next Descriptor F         Table 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | word<br>Count (Rx Descriptor)<br>low Byte Count (Tx Descriptor)<br>Pointer<br>DLC Mode<br>ISYNC Mode<br>Format                                                         | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>323<br>326<br>338<br>338<br>348<br>350<br>359<br>359<br>359                                                                                     |
|     | Table 311: SDMA Descriptor - Command/Status         Table 312: SDMA Descriptor - Buffer Size, Byte         Table 313: SDMA Descriptor - Byte Count, Shac         Table 314: SDMA Descriptor - Buffer Pointer         Table 315: SDMA Descriptor - Next Descriptor F         Table 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | s word<br>Count (Rx Descriptor)<br>dow Byte Count (Tx Descriptor)<br>Pointer<br>DLC Mode<br>ISYNC Mode<br>Format                                                       | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>328<br>326<br>333<br>338<br>348<br>350<br>359<br>359<br>359<br>359<br>362                                                                       |
|     | Table 311: SDMA Descriptor - Command/Status         Table 312: SDMA Descriptor - Buffer Size, Byte         Table 313: SDMA Descriptor - Byte Count, Shac         Table 314: SDMA Descriptor - Buffer Pointer         Table 315: SDMA Descriptor - Next Descriptor F         Table 319: SDMA Definitions         Table 320: SDMA Group 0 Register Map         Table 321: SDMA Group 1 Register Map         Table 323: TIDL/RTSM Relationship.         Table 337: BISYNC Receiver Operating Modes         Table 338: SDMAx Command/Status Field for H         Table 341: BISYNC Control Character Register         Table 342: Auto Transparent Programming         Table 345: SDMAx Command/Status Field for U         Table 345: SDMAx Command/Status Field for U         Table 347: UART Stop Bit Reception and Framin | s word<br>Count (Rx Descriptor)<br>dow Byte Count (Tx Descriptor)<br>Pointer<br>DLC Mode<br>ISYNC Mode<br>Format<br>ART Mode<br>ng Error                               | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>326<br>323<br>326<br>333<br>338<br>348<br>350<br>359<br>359<br>359<br>359<br>362<br>365                                                         |
|     | Table 311: SDMA Descriptor - Command/StatusTable 312: SDMA Descriptor - Buffer Size, ByteTable 313: SDMA Descriptor - Byte Count, ShacTable 314: SDMA Descriptor - Buffer PointerTable 315: SDMA Descriptor - Next Descriptor FTable 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s word<br>Count (Rx Descriptor)<br>dow Byte Count (Tx Descriptor)<br>Pointer<br>Pointer<br>DLC Mode<br>ISYNC Mode<br>Format<br>ART Mode<br>mg Error<br>rmat            | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>323<br>323<br>326<br>338<br>338<br>348<br>350<br>359<br>359<br>359<br>365<br>371                                                                |
|     | Table 311: SDMA Descriptor - Command/StatusTable 312: SDMA Descriptor - Buffer Size, ByteTable 313: SDMA Descriptor - Byte Count, ShacTable 314: SDMA Descriptor - Buffer PointerTable 315: SDMA Descriptor - Next Descriptor FTable 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s word<br>Count (Rx Descriptor)<br>dow Byte Count (Tx Descriptor)<br>Pointer<br>Pointer<br>DLC Mode<br>ISYNC Mode<br>Format<br>ART Mode<br>ng Error<br>ransparent Mode | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>323<br>326<br>338<br>338<br>348<br>350<br>359<br>359<br>359<br>359<br>365<br>371<br>374                                                         |
|     | Table 311: SDMA Descriptor - Command/StatusTable 312: SDMA Descriptor - Buffer Size, ByteTable 313: SDMA Descriptor - Byte Count, ShacTable 314: SDMA Descriptor - Buffer PointerTable 315: SDMA Descriptor - Next Descriptor FTable 319: SDMA Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s word<br>Count (Rx Descriptor)<br>dow Byte Count (Tx Descriptor)<br>Pointer<br>Pointer<br>DLC Mode<br>ISYNC Mode<br>Format<br>ART Mode<br>ransparent Mode<br>Options  | 309<br>310<br>310<br>311<br>318<br>320<br>323<br>323<br>326<br>333<br>338<br>348<br>350<br>359<br>359<br>359<br>359<br>359<br>359<br>359<br>359<br>359<br>359<br>359<br>359<br>374<br>374<br>374 |



| 15. | FlexTDM Units (FTDM)                                                                               |     |
|-----|----------------------------------------------------------------------------------------------------|-----|
|     | Table 356: Flex TDM DPRAM Entry.                                                                   |     |
|     | Table 358: Monitor Channel Handshaking Process                                                     |     |
|     | Table 359: IOM-1 Programming                                                                       |     |
|     | Table 360: IOM2-TE Programming.       Table 264: IOM2 + C (compared to showned 2) CCI              |     |
|     | Table 361: IOM2-LC (connected to channel 3) GCI         Table 362: FlexTDM Register Map            |     |
|     |                                                                                                    |     |
| 16. | Baud Rate Generators (BRGs)                                                                        |     |
|     | Table 363:       BRG Registers Map         Table 364:       DBC:// Configuration Deviator (DCD)    |     |
|     | Table 364: BRGx Configuration Register (BCR)         Table 365: BRGx Baud Tuning register (BTR)    |     |
| 47  |                                                                                                    |     |
| 17. | Watchdog Timer                                                                                     | 401 |
| 18. | Timers/Counters                                                                                    | 403 |
| 19. | General Purpose Ports                                                                              | 405 |
|     | Table 373: Control Registers                                                                       |     |
|     | Table 374: GPP Registers Map                                                                       | 406 |
| 20. | Physical Signal Routing                                                                            | 414 |
| 21. | Interrupt Controller                                                                               | 424 |
|     | Table 390: Interrupt Registers Map                                                                 |     |
| 22. | Reset Configuration                                                                                | 452 |
|     | Table 420: Reset Configuration                                                                     |     |
| 23. | Connecting the Memory Controller to SDRAM and Devices                                              | 455 |
|     | Table 421: 64-bit SDRAM.                                                                           |     |
|     | Table 422: 32-bit SDRAM.                                                                           | 456 |
|     | Table 423: 64-bit Devices                                                                          | 456 |
|     | Table 424: 32-bit Devices                                                                          |     |
|     | Table 425: 16-bit Devices.                                                                         |     |
|     | Table 426: 8-bit Devices                                                                           | 459 |
| 24. |                                                                                                    |     |
|     | Table 427: Supported JTAG Instructions                                                             |     |
|     | Table 428: IDCODE Register Map                                                                     | 462 |
| 25. | Big and Little Endian                                                                              |     |
|     | Table 429: Nomenclature                                                                            |     |
|     | Table 430: Configuring for Big and Little Endian                                                   | 465 |
| 26. | Using the GT-96100A Without the CPU Interface                                                      |     |
|     | Table 431: CPU-less Pin Strapping                                                                  | 466 |
| 27. | Using the GT–96100A in Different PCI Configurations                                                |     |
|     | Table 432: No PCI Interface         Table 432: DCI 0 or 22 bit DCI 0 or 12                         |     |
|     | Table 433: PCI_0 as 32-bit PCI Only         Table 434: PCI_0 as 32 bit PCI and PCI_1 as 32 bit PCI |     |
|     | Table 434: PCI_0 as 32-bit PCI and PCI_1 as 32-bit PCI                                             | 470 |



|            | Table 435: PCI_0 as 64-bit PCI Only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 471                                                                                            |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| 28.        | Phased Locked Loop (PLL) Application Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 473                                                                                            |
| 29.        | System Configurations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 475                                                                                            |
| 30.        | Register TablesTable 436: CPU Registers Map.Table 437: SDRAM Registers Map.Table 438: DMA Registers MapTable 439: Timer/Counter Registers Map.Table 440: PCI Registers MapTable 441: Interrupts Registers Map.Table 442: I2O Support Registers Map.Table 443: Communication Unit Register Map                                                                                                                                                                                                                                           | 479<br>480<br>482<br>483<br>483<br>486<br>488                                                  |
| 31.        | DC Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 508<br>508<br>508<br>509<br>510<br>512                                                         |
| 32.        | AC Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 513                                                                                            |
|            | Table 452: TClk/PClk Restrictions.Table 453: Flex-TDM Receive Timing - Normal ClockTable 454: Flex-TDM Transmit Timing - Normal Speed ClockTable 455: Flex-TDM Receive Timing - Double Speed ClockTable 456: Flex-TDM Transmit Timing - Double Speed ClockTable 456: Flex-TDM Transmit Timing - Double Speed ClockTable 457: MPSC Receive TimingTable 458: MPSC Transmit TimingTable 459: MII Transmit TimingTable 459: MII Transmit TimingTable 460: MII Receive TimingTable 461: JTAG AC Characteristics.Table 462: Btyp Values       | 518<br>519<br>520<br>521<br>523<br>524<br>529<br>529<br>530                                    |
| 33.        | Table 453: Flex-TDM Receive Timing - Normal ClockTable 454: Flex-TDM Transmit Timing - Normal Speed ClockTable 455: Flex-TDM Receive Timing - Double Speed ClockTable 456: Flex-TDM Transmit Timing - Double Speed ClockTable 457: MPSC Receive TimingTable 458: MPSC Transmit TimingTable 459: MII Transmit TimingTable 459: MII Receive TimingTable 460: MII Receive TimingTable 461: JTAG AC Characteristics                                                                                                                         | 518<br>519<br>520<br>521<br>523<br>524<br>529<br>529<br>530<br>532<br><b>533</b>               |
| 33.<br>34. | Table 453: Flex-TDM Receive Timing - Normal ClockTable 454: Flex-TDM Transmit Timing - Normal Speed ClockTable 455: Flex-TDM Receive Timing - Double Speed ClockTable 456: Flex-TDM Transmit Timing - Double Speed ClockTable 457: MPSC Receive TimingTable 458: MPSC Transmit TimingTable 459: MII Transmit TimingTable 459: MII Transmit TimingTable 460: MII Receive TimingTable 461: JTAG AC CharacteristicsTable 462: Btyp Values                                                                                                  | 518<br>519<br>520<br>521<br>523<br>524<br>529<br>529<br>530<br>532<br><b>533</b><br>533        |
|            | Table 453: Flex-TDM Receive Timing - Normal ClockTable 454: Flex-TDM Transmit Timing - Normal Speed ClockTable 455: Flex-TDM Receive Timing - Double Speed ClockTable 456: Flex-TDM Transmit Timing - Double Speed ClockTable 457: MPSC Receive TimingTable 458: MPSC Transmit TimingTable 459: MII Transmit TimingTable 459: MII Transmit TimingTable 460: MII Receive TimingTable 461: JTAG AC CharacteristicsTable 462: Btyp ValuesPinout Table, 492 Pin BGATable 463: GT-96100A Pinout Table                                        | 518<br>520<br>521<br>523<br>524<br>529<br>529<br>530<br>532<br><b>533</b><br>533<br><b>542</b> |
| 34.        | Table 453: Flex-TDM Receive Timing - Normal ClockTable 454: Flex-TDM Transmit Timing - Normal Speed ClockTable 455: Flex-TDM Receive Timing - Double Speed ClockTable 456: Flex-TDM Transmit Timing - Double Speed ClockTable 457: MPSC Receive TimingTable 458: MPSC Transmit TimingTable 458: MPSC Transmit TimingTable 459: MII Transmit TimingTable 460: MII Receive TimingTable 461: JTAG AC CharacteristicsTable 462: Btyp ValuesPinout Table, 492 Pin BGATable 463: GT-96100A Pinout Table492 BGA Package Mechanical Information | 518<br>520<br>521<br>523<br>524<br>529<br>529<br>530<br>532<br>533<br>533<br>533<br>542<br>543 |



## List of Figures

| Figure 1:  | Pin List                                                            |
|------------|---------------------------------------------------------------------|
| Figure 2:  | Two Stage Address Decoding- Conceptual View                         |
| Figure 3:  | CPU-Side Resource Group Decode Function and Example 60              |
| Figure 4:  | Device Sub-Decode Function and Example                              |
| Figure 5:  | Bank Size Register Function Example (16Meg Decode) 62               |
| Figure 6:  | CPU Address Remapping To Resources                                  |
| Figure 7:  | Double Word (8 bytes) Read by CPU With Parity Check Bits            |
| Figure 8:  | Four Word (16 bytes) Burst Read by CPU                              |
| Figure 9:  | CPU Four Word Burst Write                                           |
| Figure 10: | R5000 L2 Read Miss Example                                          |
| Figure 11: | Memory Controller Default Arbitration                               |
| Figure 12: | Memory Controller Modified Arbitration                              |
| Figure 13: | Non-Staggered Refresh Waveform                                      |
| Figure 14: | Staggered Refresh Waveform                                          |
| Figure 15: | Read Modify Write Transaction by the SDRAM Controller 100           |
| Figure 16: | 512 Mbit/64-bit SDRAM Connection to Memory Bus Using x8 Devices 108 |
| Figure 17: | VUMA Device and The GT-96100A sharing SDRAM 114                     |
| -          | Handing the Bus Over 115                                            |
| Figure 19: | MREQ* Requests from the VUMA Device                                 |
| Figure 20: | Waveform Showing Device Read Parameters                             |
| Figure 21: | Waveform Showing Device Write Parameters                            |
| Figure 22: | Ready* Extending AccToFirst on Read Cycle 122                       |
| Figure 23: | Ready* Extending AccToNext on Read Cycle 123                        |
| Figure 24: | Extending WrActive Parameter on Write Cycle 124                     |
| Figure 25: | PCI Master FIFOs in Single 64-bit Mode 154                          |
| Figure 26: | PCI Master FIFOs in Dual 32-bit Mode 155                            |
| Figure 27: | PCI Target Interface "Ping-Pong" FIFOs 158                          |
| Figure 28: | PCI Target Interface FIFOs Operational Example 159                  |
| Figure 29: | PCI Configuration Header                                            |
| Figure 30: | Power Management Registers 168                                      |
| Figure 31: | I2O Circular Queue Operation                                        |
| Figure 32: | Chained Mode DMA                                                    |
| Figure 33: | PCI Arbiter's Interface Diagram                                     |
| Figure 34: | PCI Arbitration Flow                                                |
| Figure 35: | CIU Connection Diagram                                              |
| Figure 36: | Arbiter Connectivity                                                |
| Figure 37: | MASTER Arbitration Flow                                             |



| Figure 38: | Ethernet Descriptors and Buffers                            | 255 |
|------------|-------------------------------------------------------------|-----|
| Figure 39: | Ethernet Packet Transmission Example                        | 257 |
| Figure 40: | Ethernet TX Descriptor                                      | 259 |
| Figure 41: | Ethernet TX Buffer Alignment Restrictions (5 byte payload)  | 259 |
| Figure 42: | Ethernet RX DMA Descriptor.                                 | 264 |
| Figure 43: | Type of Service Queueing Algorithm.                         | 268 |
| Figure 44: | Ethernet Hash Table Entry                                   | 270 |
| Figure 45: | Address Chain                                               | 272 |
| Figure 46: | Address Filtering Process                                   | 274 |
| Figure 47: | RMII Di-Bit Stream.                                         | 279 |
| Figure 48: | MII Transmit Signal Timing                                  | 279 |
| Figure 49: | MII Receive Signal Timing                                   | 280 |
| Figure 50: | MDIO Output Delay                                           | 282 |
| Figure 51: | MDIO Setup and Hold Time                                    | 282 |
| Figure 52: | SDMA Descriptor Format                                      | 308 |
| Figure 53: | SDMAx Configuration Register (SDCx)                         | 311 |
| Figure 54: | SDMA Command Register (SDCMx)                               | 313 |
| Figure 55: | SDMA Descriptor Pointer Registers                           | 316 |
| Figure 56: | Using Auto Mode to Create Idle Loop                         | 320 |
| Figure 57: | MPSC DPLL Encoding/Decoding Schemes                         | 327 |
| Figure 58: | MPSC Main Configuration Register (MMCRx)                    | 328 |
| Figure 59: | Typical HDLC Frame                                          | 337 |
| Figure 60: | Typical LocalTalk Frame                                     | 337 |
| Figure 61: | MPSCx Protocol Configuration Register (MPCRx) for HDLC      | 339 |
| Figure 62: | Channel Registers (CHxRx) for HDLC                          | 341 |
| Figure 63: | Typical BISYNC/MonoSYNC Frames                              | 347 |
| Figure 64: | MPSCx Protocol Configuration Register (MPCRx) for BISYNC    | 351 |
| Figure 65: | Channel Registers (CHxRx) for BISYNC.                       | 353 |
| Figure 66: | BISYNC Control Character Register Format.                   | 357 |
| -          | Typical UART Frame                                          |     |
| Figure 68: | MPSCx Protocol Configuration Register (MPCRx) for UART Mode | 363 |
| Figure 69: | Channel Registers (CHxRx) for UART Mode                     | 367 |
| Figure 70: | UART Control Character Register Format.                     | 370 |
| Figure 71: | Channel Registers (CHxRx) for Transparent Mode.             | 375 |
| Figure 72: | FlexTDM Architecture                                        | 379 |
| Figure 73: | Typical IOM Structures                                      | 387 |
| Figure 74: | Auxiliary Channel A Control Registers                       | 389 |
| Figure 75: | Channel B Control Register                                  | 390 |
| Figure 76: | Baud Rate Generator Block Diagram                           | 397 |

| Figure 77: Watchdog Register Map 401                                                           |
|------------------------------------------------------------------------------------------------|
| Figure 78: Filtering Circuit                                                                   |
| Figure 79: Resistor and Capacitor Values for VccPLL and VssPLL                                 |
| Figure 80: Minimal System Configuration 475                                                    |
| Figure 81: Typical System Configuration                                                        |
| Figure 82: High Performance System 477                                                         |
| Figure 83: Power vs. Operating Frequency 511                                                   |
| Figure 84: TClk = PClk, in Sync Mode = 1, Skew Requirement                                     |
| Figure 85: Flex-TDM Receive Timing - Normal Clock Waveform                                     |
| Figure 86: Flex-TDM Transmit Timing - Normal Speed Clock Waveform                              |
| Figure 87: Flex-TDM Receive Timing - Double Speed Clock Waveform                               |
| Figure 88: Flex-TDM Receive Timing - Double Speed Clock Waveform                               |
| Figure 89: Flex-TDM Transmit Timing - Double Speed Clock Waveform                              |
| Figure 90: Flex-TDM Transmit Timing - Double Speed Clock Waveform                              |
| Figure 91: MPSC Receive Timing 523                                                             |
| Figure 92: MPSC Transmit Timing 524                                                            |
| Figure 93: Output Delay From RTS*, Asynchronous CTS*<br>(CTSS=0 in MMCRLx) Waveform            |
| Figure 94: Output Delay From RTS*, Synchronous CTS*<br>(CTSS=1 in MMCRLx) Waveform             |
| Figure 95: Output Delay From CTS*, Asynchronous CTS*<br>(CTSS=0 in MMCRLx) Waveform            |
| Figure 96: Output Delay From CTS*, Synchronous CTS*<br>(CTSS=1 in MMCRLx) Waveform             |
| Figure 97: CTS* Loss In Synchronous Protocol:<br>Start of Frame Waveform With CTS Lost         |
| Figure 98: CTS* Loss In Synchronous Protocol:                                                  |
| Start of Frame Waveform Without CTS Lost                                                       |
| Figure 99: CTS* Loss In Synchronous Protocol, Synchronous<br>CTS* (CTSS=1 in MMCRLx) Waveform  |
| Figure 100:CTS* Loss In Synchronous Protocol, Asynchronous<br>CTS* (CTSS=0 in MMCRLx) Waveform |
| Figure 101:Reception Control Using CD* Waveform                                                |
| Figure 101:Reception Control Cang CD Wavelorm                                                  |
| Figure 103:Transmit Synchronize to Receive (TSYN=1 in MMCRLx),                                 |
| External Sync (RSYL=0 in MMCRHx) Waveform                                                      |
| External Sync (RSYL=0 in MMCRHx), CD* and                                                      |
| CTS* Pulse Mode (CTSM=1 and CDM=1 in MMCRLx),                                                  |
| Synchronous CTS* (CTSS=1 in MMCRLx) Waveform                                                   |
| Figure 105:MII Port Transmit Signals Timing    529                                             |

| Figure 106:MII Port Receive Signals Timing             | 530 |
|--------------------------------------------------------|-----|
| Figure 107:JTAG AC Timing                              | 530 |
| Figure 108:GT–96100A Pinout Map (top view, left side)  | 540 |
| Figure 109:GT–96100A Pinout Map (top view, right side) | 541 |
| Figure 110:492 BGA Package Mechanical Information      | 542 |
| Figure 111:Sample Part Number                          | 543 |



### 1. OVERVIEW

The GT-96100A offers a single-chip solution for designers building communication systems using any high performance 64-bit MIPS CPUs.

CPUs compatible with the GT-96100A include:

- The RM5260, RM5270/1 and RM7000 from QED.
- The RV4600 through RV5000 from IDT.
- Other R5000 compatibles from various vendors.

The GT-96100A integrates a system controller with a communication unit that handles a wide range of serial communication protocols, such as Ethernet, Fast Ethernet, and HDLC. Its architecture supports several system implementations for different applications and cost/performance points. Also, it is possible to design a powerful system with minimal glue logic, or add commodity logic (controlled by the GT-96100A) for differentiated system architectures that attain higher performance.

The GT-96100A has a three or four bus architecture:

- A 64-bit interface to the CPU bus (SysAD bus)
- A 64-bit interface to the memory and device subsystem
- Two independent 32-bit PCI interfaces or one 64-bit PCI interface

The three/four buses are de-coupled from each other in most accesses, enabling concurrent operation of the CPU bus, PCI devices, and accesses to memory. For example, the GT-96100A can simultaneously support a CPU bus writing to the on-chip write buffer, an IDMA agent moving data from SDRAM to its own buffers, and a PCI device writing into an on-chip FIFO.

## 1.1 Communication Unit Description

The heart of the GT-96100A device is a high-performance WAN communications unit.

This unit includes:

- Eight multi-protocol serial controllers.
- Four FlexTDM time slot assigners.
- Two perfect filtering 10/100 Ethernet controllers.
- Twenty SDMA channels.

The GT-96100A can directly support several WAN interfaces including Basic Rate ISDN (two channels), frame relay, non channelized T1/E1/T3, xDSL (HDSL, VDSL etc.), HSSI, and others.

### 1.1.1 Multi-protocol Serial Controllers

The eight multi-protocol serial controllers (MPSCs) integrated onto the GT-96100A support UART, HDLC, BISYNC, and transparent protocols. The MPSCs are implemented in the hardware. Hardware implementation allows for superior performance when compared to microcoded implementations.



In HDLC mode, the MPSCs perform all framing operations such as bit stuffing/stripping and flag generation, and part of the data link operations (e.g. address recognition functions). The MPSCs directly support common HDLC protocols including those used by ISDN and frame relay. Each MPSC can communicate over dedicated package pins or through one of four FlexTDM time slot assigners.

### 1.1.2 FlexTDM Time Slot Assigners

There are four FlexTDM (time slot assigners) in the GT-96100A.

The FlexTDMs support PCM Highway, IOM1, and IOM2 (GCI) formats to allow connections to most WAN framer and PHY devices. The FlexTDMs are fully programmable and can be configured to support almost any proprietary TDM bus. They can also be programed to interface voice CODECs and MVIP bus peripherals.

The FlexTDM unit includes two auxiliary channels that can be multiplexed onto the TDM highway with data from the eight MPSCs. They are optimized for supporting GCI bus Monitor and C/I channels.

### 1.1.3 10/100 Ethernet Controllers

There are two 10/100-Mbps full duplex Ethernet ports in GT-96100A. Each port is fully compliant with the IEEE 802.3 and 802.3u standards and integrates MAC function and a dual speed MII interface.

The ports' speed (10 or 100Mb/s) and duplex mode (half or full duplex) is auto-negotiated through the PHY and does not require user intervention. The ports' logic also supports 802.3x flow-control mode for full-duplex and back-pressure mode for half-duplex.

The GT-96100A's Ethernet ports includes Galileo's advanced address filtering capability and can be programmed to accept or reject packets based on MAC addresses, thus providing hardware acceleration to complicated tasks such as bridging, routing, and firewall. The ports' can also filter up to 8,000 individual MAC addresses.

### 1.1.4 SDMA Channels

The GT-96100A offers 20 SDMA channels to support the eight MPSCs and two Fast Ethernet controllers. The SDMA channels are used to transfer data from the various serial ports to the SDRAM (and vice versa) or over the PCI. The SDMA channels use linked chain of descriptors and buffers to reduce CPU overhead.

Table 1 summarizes guaranteed throughput of the MPSCs in HDLC mode when the two Fast-Ethernet ports run at 100Mbit/s full wire speed in full duplex mode.

Table 1: GT-96100A Serial Performance

| No. | Operational Mode                        | Aggregate Bandwidth |           |           |
|-----|-----------------------------------------|---------------------|-----------|-----------|
|     |                                         | Serial              | Ethernet  | Total     |
| 1   | 4 ports @55 Mbps simultaneously         | 440Mbit/s           | 400Mbit/s | 840Mbit/s |
| 2   | 6 ports @45 Mbps simultaneously         | 540Mbit/s           | 400Mbit/s | 940Mbit/s |
| 3   | All the 8 ports @30 Mbps simultaneously | 480Mbit/s           | 400Mbit/s | 880Mbit/s |



## 1.2 CPU Interface

The GT-96100A's SysAD bus allows the CPU and other local bus masters to access the PCI and memory/device buses.

The SysAD bus protocol supports byte, sub-word, 32-bit word, and 64-bit word operations with burst lengths of up to eight words (sub-word, two word, and four word burst length are also supported). With a maximum frequency of 100MHz, the CPU can transfer in excess of 800 Mbytes/sec.

The GT-96100A allows up to four GT-96100A devices, or GT-64120 system controllers, to share the same CPU interface. This significantly increases the address space, number of communication channels, and flexibility of system design.<sup>1</sup>

The GT-96100A supports CPU address remapping to resources and can operate in little or big endian mode.

## 1.3 SDRAM and Device Interface

The GT-96100A integrates a SDRAM controller with a 64-bit interface.

The SDRAM controller supports 16, 64, 128, 256 and 512Mbit SDRAMs. It is 3.3V and 5V tolerant, operates at frequencies of up to 100MHz, and can address up to 4GBytes. Up to four SDRAM banks can be connected to the controller and it supports 2 bank interleaving for 16 Mbit SDRAMs and 2 or 4 bank interleaving for 64/128/256/ 512 Mbit SDRAMs.

The SDRAM controller also supports a UMA feature that enables external masters to arbitrate for direct access to SDRAM. This feature enhances system performance and gives flexibility when designing shared memory systems.

The GT-96100A device controller supports different types of memory and I/O devices. It has the control signals and timing programmability to support devices such as Flash, EPROMs, FIFOs, and I/O controllers. Device widths from 8-bits to 64-bits are also supported.

ECC generation and checking is supported both internally and externally and is optional for each bank of SDRAM.

## 1.4 PCI Interface

The GT-96100A interfaces directly to the PCI bus. The PCI interface can be configured to function as either:

- Two 32-bit PCI devices (PCI\_0 and PCI\_1)
- A single 64-bit PCI device (PCI\_0) operating at a maximum frequency of 66MHz.

Each of the GT-96100A's PCI interface can either be a master initiating PCI bus transaction or a target responding to a PCI bus operation.

The GT-96100A incorporates 192-bytes of posted write and read prefetch buffers per PCI device for efficient data transfer between the CPU bus/DMA to PCI and PCI to main memory.

<sup>1.</sup> The increased loading will only have a small effect on the system's maximum operating frequency.



The GT-96100A becomes a PCI bus master when the CPU interface unit or the internal DMA engine initiates a bus cycle to a PCI device. The following PCI bus cycles are supported:

- Memory Read/Write
- Interrupt Acknowledge
- Special
- I/O Read/Write
- Configuration Read/Write
- Locked Reads/Writes (only for PCI\_0 slave).

The GT-96100A acts as a target when a PCI device initiates a memory access (or an I/O access in the case of internal registers). It responds to all memory read/write accesses, as well as to all configuration and I/O cycles in the case of internal registers. It is possible to program the PCI slave function to retry all PCI transactions targeted to the GT-96100A. The PCI slave performs PCI address remapping to resources.

The GT-96100A includes all required PCI configuration registers. All internal registers, including PCI configuration registers, are accessible from both the CPU bus and the PCI bus. GT-96100A configuration register set is PC Plug-and-Play compatible, with industry standard I<sub>2</sub>O support.

The GT-96100A supports PCI Hot-Plug and CompactPCI Hot Swap Capable requirements.

The GT-96100A can also act as a PCI to Memory bridge and PCI communication peripheral, even without the presence of a CPU.

## 1.5 Independent DMA (IDMA) Engines

The GT-96100A incorporates four high performance IDMA engines.

Each IDMA engine has the capability to transfer data between PCI devices, between PCI devices and main memory, or between devices residing on the 64-bit device/memory bus. The IDMA uses two internal 64-byte FIFOs for temporary storage of IDMA data. These pair of FIFOs allows two IDMA channels to be working concurrently with each channel utilizing one FIFO. For example, while channel 0 is reading data from SDRAM into one FIFO, channel 2 can write data from the other FIFO to the PCI bus.

Source and destination addresses can be nonaligned on any byte address boundary. The IDMA channels can be controlled from the CPU or PCI interfaces or via a linked list of records without CPU bus intervention. This linked list is loaded by the IDMA controller into the channel's working set when a IDMA transaction ends. The IDMA supports increment/decrement/hold on source and destination addresses independently and alignment of addresses towards source and destination. In addition, the GT-96100A provides an override capability of source/ destination/record address mapping to force access to PCI 0 or PCI 1.

IDMA can be initiated by the CPU writing to a register, an external request via IDMAReq\* pin, or an internal timer/counter. Four End-of-Transfer pins, which act as inputs to the GT-96100A, allow ending a IDMA transfer on a certain channel. In case of chained mode, it is possible to transfer the descriptor to CPU ownership after the transfer has ended. The CPU then calculates the number of remaining bytes in the buffer associated with the closed descriptor.

Fly-by is also supported. This mode allows data to be transferred directly between two residents on the device/ memory bus without having to go into an IDMA FIFO.



## **1.6** Peripheral Configurations

The GT-96100A provides 88 pins to configure either as peripheral function pins or as general purpose I/Os. These pins consist of the following ports:

- Six WAN ports (A, B, C, D, E, F) with seven pins allocated per port (total of 42 pins).
- Two LAN port (MII0 and MII1) with 15 pins allocated per port (total of 30 pins).
- One GPP port with 16 pins allocated to it.

Each of the ports listed above supports multiple internal functions. Table 2 shows the configuration options supported for each port.

Table 2: GT-96100A Port Configurations

| Port | Port Configuration Options                                                                                                             |
|------|----------------------------------------------------------------------------------------------------------------------------------------|
| A    | <ol> <li>Physical interface for MPSC0</li> <li>PCI_0 arbiter signals</li> <li>General Purpose Port</li> </ol>                          |
| В    | <ol> <li>Physical interface for MPSC1</li> <li>PCI_1 arbiter signals</li> <li>General Purpose Port</li> </ol>                          |
| С    | <ol> <li>Physical interface for MPSC2</li> <li>Physical interface for FlexTDM0</li> <li>General Purpose Port</li> </ol>                |
| D    | <ol> <li>Physical interface for MPSC3</li> <li>Physical interface for FlexTDM1</li> <li>General Purpose Port</li> </ol>                |
| E    | <ol> <li>Physical interface for MPSC4</li> <li>Physical interface for FlexTDM2</li> <li>General Purpose Port</li> </ol>                |
| F    | <ol> <li>Physical interface for MPSC5</li> <li>Physical interface for FlexTDM3</li> <li>General Purpose Port</li> </ol>                |
| MIIO | <ol> <li>MII interface for Ethernet0</li> <li>Physical interface for MPSC6, MPSC7</li> <li>General Purpose Port</li> </ol>             |
| MII1 | <ol> <li>MII interface for Ethernet1</li> <li>RMII interface for both Ethernet0 and Ethernet1</li> <li>General Purpose Port</li> </ol> |

Table 3 shows typical peripheral configurations supported by the GT-96100A.

| Co          | eripheral<br>onfiguration<br>otion                                           | Port<br>A        | Port<br>B        | Port<br>C | Port<br>D | Port<br>E | Port<br>F | Port<br>MII0          | Port<br>MII1            |
|-------------|------------------------------------------------------------------------------|------------------|------------------|-----------|-----------|-----------|-----------|-----------------------|-------------------------|
| •           | Two serial ports<br>Two TDM ports<br>One Ethernet port                       | Mpsc0            | Mpsc1            | TDM0      | TDM1      | GPP       | GPP       | Ether0                | GPP                     |
| •           | Six serial ports<br>Two Ethernet ports                                       | Mpsc0            | Mpsc1            | Mpsc2     | Mpsc3     | Mpsc4     | Mpsc5     | Ether0                | Ether1                  |
| •<br>•<br>• | Two PCI arbiters<br>Two serial port<br>Two TDM ports<br>Two Ethernet ports   | PCI_0<br>arbiter | PCI_1<br>arbiter | Mpsc2     | Mpsc3     | TDM2      | TDM3      | Ether0                | Ether1                  |
| • • •       | One PCI arbiter<br>Three serial ports<br>Four TDM ports<br>One Ethernet port | PCI_0<br>arbiter | Mpsc1            | TDM0      | TDM1      | TDM2      | TDM3      | Mpsc6<br>and<br>Mpsc7 | Ether1                  |
| •           | Eight Serial ports<br>Two Ethernet ports                                     | Mpsc0            | Mpsc1            | Mpsc2     | Mpsc3     | Mpsc4     | Mpsc5     | Mpsc6<br>and<br>Mpsc7 | Ether0<br>and<br>Ether1 |

 Table 3:
 GT-96100A Peripheral Configurations





### 2. **PIN INFORMATION**

#### Figure 1: Pin List



| Pin Name                | Туре | Full Name                                  | Description                                                                                                                                |  |
|-------------------------|------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|
| ValidOut*               | Ι    | Valid Output                               | Driven by the CPU to signal a valid address or data on the SysAD bus and a valid command or data identifier on the SysCmd bus.             |  |
| ValidIn*                | 0    | Valid Input                                | Driven by the GT-96100A to signal that it is driving valid data on the SysAD bus and a valid data identifier on the SysCmd bus.            |  |
| WrRdy*                  | 0    | Write Ready                                | Driven by the GT-96100A to signal that it can accept a CPU write request from the CPU (i.e. there is room in the write post-<br>ing FIFO). |  |
| Release*                | I    | Release                                    | Driven by the CPU to signal that it has released the SysAD and SysCmd buses for completion of a read request.                              |  |
| SysCmd[8:0]             | I/O  | System Com-<br>mand/Data<br>Identifier Bus | 9-bit bus used for command and data identifier transmission between the CPU and GT-96100A.                                                 |  |
| SysAD[63:0]             | I/O  | System<br>Address/Data<br>Bus              | 64-bit bus used as multiplexed address and data bus for com-<br>munication between the CPU, the GT-96100A, and the L2<br>cache.            |  |
| SysADC[7:0]             | I/O  | System<br>Address/Data<br>Check            | 8-bit bus used as parity for the SysAD bus. SysADC is valid on data cycles only.                                                           |  |
| CPU Interface Total: 85 |      |                                            |                                                                                                                                            |  |

| Table 4: | CPU Interface Pin Assignments |
|----------|-------------------------------|
|----------|-------------------------------|

#### Table 5: Secondary Cache Interface Pin Assignments

| Pin Name | Туре | Full Name                                       | Description                                                                                                                                                                                                                                                                                                     |
|----------|------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ScDOE*   | 0    | Secondary<br>Cache Data<br>RAM Output<br>Enable | Asserted by the GT-96100A to cause the data RAM to drive<br>data onto their I/O pins. This signal is monitored by the proces-<br>sor to determine when to drive the data RAM write enable in a<br>secondary cache miss refill sequence.<br>This pin must be left unconnected if secondary cache is not<br>used. |
| ScMatch  | I    | Secondary<br>Cache Tag<br>Match                 | Asserted by the cache Tag RAM when a match occurs between<br>the value on its data inputs and the contents of its RAM at the<br>value of its address inputs.<br>This pin must be pulled <b>LOW</b> through a 4.7KOhm resistor if<br>secondary cache is not used.                                                |



| Pin Name                 | Туре | Full Name                                    | Description                                                                                                                                                |
|--------------------------|------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ScTCE*                   | I    | Secondary<br>Cache Tag<br>RAM Chip<br>Enable | Indicates that a secondary cache access is occurring.<br>This pin must be pulled <b>HIGH</b> through a 4.7KOhm resistor if<br>secondary cache is not used. |
| ScWord[1:0]              | 0    | Secondary<br>Cache Double<br>Word Index      | Driven by the GT-96100A on cache miss refills.<br>These pins must be left unconnected if secondary cache is not<br>used.                                   |
| Secondary Cache Total: 5 |      |                                              |                                                                                                                                                            |

 Table 5:
 Secondary Cache Interface Pin Assignments (Continued)

| Table 6: PCI Bus 0 Pin Assignme | nts |
|---------------------------------|-----|
|---------------------------------|-----|

| Pin Name   | Туре | Full Name                         | Description                                                                                                                                                                                                                                                                                                                                                                       |
|------------|------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VREF0      | I    | PCI_0 Voltage<br>Reference        | Must be connected directly to the 3.3V or the 5V power plane,<br>depending on which voltage level PCI_0 supports.<br><b>NOTE:</b> VREF0 and VREF1 can be completely independent<br>voltage levels.                                                                                                                                                                                |
| PClk0      | I    | PCI_0 Clock                       | Provides the timing for the PCI_0 transactions. The PCI_0<br>clock range is between 0 and 66MHz.<br><b>NOTE:</b> The PCIk0 cycle must be higher than the TCIk cycle by<br>at least 1ns. See Section 32.1 "TCIk/PCIk Restric-<br>tions" on page 516.                                                                                                                               |
| PAD0[31:0] | I/O  | PCI_0<br>Address/Data             | 32-bit multiplexed PCI_0 address and data lines.<br>During the first clock of the transaction, PAD0[31:0] contains a<br>physical byte address (32 bits). During subsequent clock<br>cycles, this contains data.                                                                                                                                                                   |
| CBE0[3:0]* | I/O  | PCI_0 Com-<br>mand/Byte<br>Enable | During the address phase of the transaction, CBE0[3:0]* pro-<br>vides the PCI_0 bus command.<br>During the data phase, these lines provide the byte enables.                                                                                                                                                                                                                      |
| Par0       | I/O  | PCI_0 Parity                      | Calculated by the GT-96100A as an even parity bit for the PAD0[31:0] and CBE0[3:0]* lines.                                                                                                                                                                                                                                                                                        |
| Frame0*    | I/O  | PCI_0 Frame                       | Asserted by the GT-96100A to indicate the beginning and dura-<br>tion of a master transaction.<br>Frame0* asserts to indicate the beginning of the cycle. While<br>asserted, data transfer continues.<br>Frame0* deasserts to indicate that the next data phase is the<br>final data phase transaction.<br>Frame0* is monitored by the GT-96100A when it acts as a PCI<br>target. |
| IRdy0*     | I/O  | PCI_0 Initiator<br>Ready          | Asserted to indicate the bus master's ability to complete the current data phase of the transaction. A data phase is completed on any clock when both IRdy0* and TRdy0* are asserted. Wait cycles are inserted until TRdy0* and IRdy0* are asserted together.                                                                                                                     |

| Pin Name             | Туре | Full Name                                  | Description                                                                                                                                                                                                                                                                                                                           |
|----------------------|------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRdy0*               | I/O  | PCI_0 Target<br>Ready                      | Asserted to indicate the target agent's ability to complete the current data phase of the transaction. A data phase is completed on any clock when both TRdy0* and IRdy0* are asserted. Wait cycles are inserted until TRdy0* and IRdy0* are asserted together.                                                                       |
| Stop0*               | I/O  | PCI_0 Stop                                 | Asserted to indicate that current target is requesting the bus master to stop the current transaction.                                                                                                                                                                                                                                |
|                      |      |                                            | As a master, the GT-96100A responds to the assertion of Stop0* by disconnecting, retrying, or aborting.                                                                                                                                                                                                                               |
|                      |      |                                            | As a target, the GT-96100A asserts Stop0* to retry or discon-<br>nect.                                                                                                                                                                                                                                                                |
| Lock0*               | I    | PCI_0 Lock                                 | Asserted to indicate an automatic operation that may require multiple transactions to complete.                                                                                                                                                                                                                                       |
|                      |      |                                            | When the GT-96100A is a PCI_0 target, Lock0* is sampled on<br>the rising edge of PCIk0 when Frame0* is asserted. If Lock0* is<br>sampled asserted, the GT-96100A enters a locked state and<br>remains in this state until Lock0* is sampled deasserted on the<br>following rising edge of PCIk0, when Frame0* is sampled<br>asserted. |
| IDSel0               | I    | PCI_0 Initial-<br>ization Device<br>Select | Asserted to indicate a chip select during PCI_0 configuration read and write transactions.                                                                                                                                                                                                                                            |
| DevSel0*             | I/O  | PCI_0 Device<br>Select                     | Asserted by the target of the current access.<br>When the GT-96100A is bus master, it expects the target to<br>assert DevSel0* within five bus cycles, confirming the access. If<br>the target does not assert DevSel0* within this time window, the<br>GT-96100A aborts the cycle.                                                   |
|                      |      |                                            | As a target, when the GT-96100A recognizes that it is the target of a transaction, it asserts DevSel0* at medium speed (two cycles after assertion of Frame0*).                                                                                                                                                                       |
| Req0*/<br>PARB0_GNT1 | 0    | PCI_0 Bus<br>Request                       | If the internal arbiter for PCI_0 is disabled, this signal is asserted by the GT-96100A to indicate to the PCI_0 bus arbiter that it requires use of the PCI_0 bus.                                                                                                                                                                   |
|                      |      | PCI_0 arbiter<br>output grant 1            | If the internal arbiter for PCI_0 is enabled, this pin functions as the arbiter's grant 1 output signal.                                                                                                                                                                                                                              |
| Gnt0*/<br>PARB0_REQ1 | I    | PCI_0 Bus<br>Grant                         | If the internal arbiter for PCI_0 is disabled, this signal is asserted by the external PCI_0 bus arbiter to Indicate that access to the PCI_0 bus is granted to the GT-96100A.                                                                                                                                                        |
|                      |      | PCI_0 arbiter<br>input request 1           | If the internal arbiter for PCI_0 is enabled, this pin functions as the arbiter's request 1 input signal.                                                                                                                                                                                                                             |

| Table 6: | PCI Bus 0 Pin Assignments (Continued) |
|----------|---------------------------------------|
|----------|---------------------------------------|



| Pin Name            | Туре       | Full Name             | Description                                                                                                                                                                                                               |
|---------------------|------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PErr0*              | I/O<br>STS | PCI_0 Parity<br>Error | Asserted when a data parity error is detected.<br>This pin features a sustained tristate output.                                                                                                                          |
| SErr0*              | OD         | PCI_0 System<br>Error | Asserted when a serious system error (not necessarily a PCI_0<br>error) is detected. SErr0* behavior in the GT-96100A is pro-<br>grammable (refer to PCI section for details).<br>This pin features an open-drain output. |
| PCI Bus 0 Total: 50 |            |                       |                                                                                                                                                                                                                           |

Table 6: PCI Bus 0 Pin Assignments (Continued)

| T                          | I    | -                                 |                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------|------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Name                   | Туре | Full Name                         | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
| VREF1                      | I    | PCI_1 Voltage<br>Reference        | Must be connected directly to the 3.3V or the 5V power plane depending on which voltage level PCI_1 supports.<br><b>NOTE:</b> VREF0 and VREF1 can be completely independent voltage levels.                                                                                                                                                                                                                      |
| PClk1                      | Ι    | PCI_1 Clock                       | <ul> <li>Provides the timing for PCI_1 transactions. The PCI_1 clock range is between 0 and 66MHz.</li> <li>Runs independently of PClk0.</li> <li>Active only when PCI_1 is enabled.</li> <li><b>NOTE:</b> The PClk0 cycle must be higher than the TClk cycle by at least 1ns. This clock frequency can be independent of both TClk and PClk0. See Section 32.1 "TClk/PClk Restrictions" on page 516.</li> </ul> |
| PAD1[31:0]/<br>PAD0[63:32] | I/O  | PCI_1<br>Address/Data             | During the first clock of the transaction, PAD1[31:0] contains a physical byte address (32 bits). During subsequent clock cycles, PAD1[31:0] contains data.                                                                                                                                                                                                                                                      |
|                            |      | PCI_0 (64 bit)<br>Address/Data    | If PCI_0 is configured for 64 bit, these pins function as PAD0[63:32] and carry the most significant 32 bits of data for PCI_0 transactions.                                                                                                                                                                                                                                                                     |
| CBE1[3:0]*/<br>CBE0[7:4]*  | I/O  | PCI_1 Com-<br>mand/Byte<br>Enable | During the address phase of the transaction, CBE1[3:0]* pro-<br>vide the PCI_1 bus command. During the data phase, these<br>lines provide the byte enables.                                                                                                                                                                                                                                                      |
|                            |      | PCI_0 (64 bit)<br>Byte Enable     | If PCI_0 is configured for 64 bit, these pins function as CBE0[7:4]* and carry byte enables for the most significant 32 bits of PCI_0 data.                                                                                                                                                                                                                                                                      |
| Par1/Par64                 | I/O  | PCI_1 Parity                      | Calculated by the GT-96100A as an even parity bit for PAD1[31:0] and CBE1[3:0]* lines.                                                                                                                                                                                                                                                                                                                           |
|                            |      | PCI_0 (64 bit)<br>Parity          | If PCI_0 is configured for 64 bit, this pin functions as Par64 and carries even parity bit for PAD0[63:32] and CBE0[7:4]*.                                                                                                                                                                                                                                                                                       |

| Pin Name            | Туре | Full Name                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Frame1*/<br>Req64*  | I/O  | PCI_1 Frame                                | Asserted by the GT-96100A to indicate the beginning and dura-<br>tion of a master transaction. Frame1* asserts to indicate the<br>beginning of the cycle.<br>While asserted, data transfer continues.<br>Deasserts to indicate that the next data phase is the final data<br>phase transaction. Frame1* is monitored by the GT-96100A<br>when it acts as a target.                                                                                      |
|                     |      | PCI_0 (64 bit)<br>Request 64               | If PCI_0 is configured for 64 bit, this pin functions as Req64*<br>and functions as a request for a 64-bit transaction. Req64* has<br>the same timing as Frame0*.                                                                                                                                                                                                                                                                                       |
|                     | SoR  |                                            | SET to configure the GT-96100A prior to boot-up. See Section 22. ation" on page 452 for more information.                                                                                                                                                                                                                                                                                                                                               |
| IRdy1*              | I/O  | PCI_1 Initiator<br>Ready                   | Asserted to indicate the bus master's ability to complete the current data phase of the transaction. A data phase is completed on any clock when both IRdy1* and TRdy1* are asserted. Wait cycles are inserted until TRdy1* and IRdy1* are asserted together.                                                                                                                                                                                           |
| TRdy1*              | I/O  | PCI_1 Target<br>Ready                      | Asserted to indicate the target agent's ability to complete the current data phase of the transaction. A data phase is completed on any clock when both TRdy1* and IRdy1* are asserted. Wait cycles are inserted until TRdy1* and IRdy1* are asserted together.                                                                                                                                                                                         |
| Stop1*              | I/O  | PCI_1 Stop                                 | Asserted to indicate the current target is requesting the bus<br>master to stop the current transaction. As a master, the GT-<br>96100A responds to the assertion of Stop1* by disconnecting,<br>retrying or aborting. As a target, the GT-96100A asserts Stop1*<br>to retry or disconnect.                                                                                                                                                             |
| IDSel1              | I    | PCI_1 Initial-<br>ization Device<br>Select | Asserted to indicate a chip select during PCI_1 configuration read and write transactions.                                                                                                                                                                                                                                                                                                                                                              |
| DevSel1*/<br>Ack64* | I/O  | PCI_1 Device<br>Select                     | Asserted by the target of the current access. When the GT-<br>96100A is bus master, it expects the target to assert DevSel1*<br>within 5 bus cycles, confirming the access. If the target does<br>not assert DevSel1* within this time window, the GT-96100A<br>aborts the cycle. As a target, when the GT-96100A recognizes<br>that it is the target of a transaction, it asserts DevSel1* at<br>medium speed (two cycles after assertion of Frame1*). |
|                     |      | PCI_1 (64 bit)<br>Acknowledge<br>64        | If PCI_0 is configured for 64 bit, this signal functions as Ack64*.<br>When actively driven by the PCI target, it indicates that the tar-<br>get is willing to accept 64 bit data. Ack64* has the same timing<br>as DevSel0*.                                                                                                                                                                                                                           |

#### Table 7: PCI Bus 1 Pin Assignments (Continued)



| Pin Name             | Туре       | Full Name                        | Description                                                                                                                                                                    |  |
|----------------------|------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Req1*/<br>PARB1_GNT1 | 0          | PCI_1 Bus<br>Request             | If the internal arbiter for PCI_1 is disabled, this signal is asserted by the GT-96100A to indicate to the PCI_1 bus arbiter that it requires use of the PCI_1 bus.            |  |
|                      |            | PCI_1 arbiter<br>output grant 1  | If the internal arbiter for PCI_1 is enabled, this pin functions as the PCI_1 arbiter's grant 1 output signal.                                                                 |  |
| Gnt1*/<br>PARB1_REQ1 | I          | PCI_1 Bus<br>Grant               | If the internal arbiter for PCI_1 is disabled, this signal is asserted by the external PCI_1 bus arbiter to Indicate that access to the PCI_1 bus is granted to the GT-96100A. |  |
|                      |            | PCI_1 arbiter<br>input request 1 | If the internal arbiter for PCI_1 is enabled, this pin functions as the PCI_1 arbiter's request 1 input signal.                                                                |  |
| PErr1*               | I/O<br>STS | PCI_1 Parity<br>Error            | Asserted when a data parity error is detected. This pin features a sustained tristate output.                                                                                  |  |
| SErr1*               | OD         | PCI_1 System<br>Error            | Asserted when a serious system error (not necessarily a PCI_1 error) is detected. SErr1* behavior in the GT-96100A is pro-<br>grammable (refer to PCI section for details).    |  |
|                      |            |                                  | This pin features an open-drain output.                                                                                                                                        |  |
| PCI Bus 1 Total: 49  |            |                                  |                                                                                                                                                                                |  |

 Table 7:
 PCI Bus 1 Pin Assignments (Continued)

| Pin Name                | Туре | Full Name                                                                                                                                          | Description                                                                                                                                                                                                                    |
|-------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DWr*                    | 0    | SDRAM Write                                                                                                                                        | Asserted low when the GT-96100A performs a write transaction to the SDRAM.                                                                                                                                                     |
| DAdr[2:0]/<br>BAdr[2:0] | 0    | SDRAM<br>Address [2:0]                                                                                                                             | When accessing a SDRAM bank, these pins function as SDRAM address bits [2:0].                                                                                                                                                  |
|                         |      | Burst Address<br>[2:0]                                                                                                                             | In write and read accesses from devices these pins function as<br>burst address bits [2:0]. See Section 23.2 "Devices" on page<br>456 for more information on how to connect these address bits<br>to various devices.         |
|                         | SoR  | <b>NOTE:</b> Sampled on RESET to configure the GT-96100A prior to boot-up. See Section 22. "Reset Configuration" on page 452 for more information. |                                                                                                                                                                                                                                |
| DAdr[10:3]/<br>Wr[7:0]* | 0    | SDRAM<br>Address [10:3]                                                                                                                            | When accessing a SDRAM bank, these pins function as SDRAM address bits.                                                                                                                                                        |
|                         |      | Byte Write<br>[7:0]                                                                                                                                | In write and accesses to devices these pins function as byte write enable indications for bytes [7:0]. See Section 23.2<br>"Devices" on page 456 for more information on how to connect these address bits to various devices. |
|                         | SoR  | <b>NOTE:</b> Sampled on RESET to configure the GT-96100A prior to boot-up. See Section 22. "Reset Configuration" on page 452 for more information. |                                                                                                                                                                                                                                |

| Pin Name                | Туре | Full Name                                                                                                                                                        | Description                                                                                                             |
|-------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| BankSel[0]              | 0    | SDRAM Bank<br>Select [0]                                                                                                                                         | In SDRAM accesses, this pin functions as bank select bit [0].                                                           |
|                         | SoR  |                                                                                                                                                                  | d on RESET to configure the GT-96100A prior to boot-up. See 22. "Reset Configuration" on page 452 for more information. |
| SRAS*                   | 0    | SDRAM Row<br>Address<br>Strobe                                                                                                                                   | Asserted to indicate that an active ROW address is driven on DAdr lines.                                                |
| SCAS*                   | 0    | SDRAM Col-<br>umn Address<br>Strobe                                                                                                                              | Asserted to indicate that an active COLUMN address is driven on DAdr lines.                                             |
| SCS[3:0]*               | 0    | SDRAM Chip<br>Selects                                                                                                                                            | SDRAM chip selects for up to 4 banks.                                                                                   |
| SDQM[7:0]*              | 0    | SDRAM Byte<br>Enables                                                                                                                                            | In SDRAM write transaction these pins function as byte enable signals.                                                  |
|                         | SoR  | <b>NOTE:</b> SDQM[3:0] are sampled on RESET to configure the GT-96100A prior to boot-up. See Section 22. "Reset Configuration" on page 452 for more information. |                                                                                                                         |
| SDRAM/Devices Total: 27 |      |                                                                                                                                                                  |                                                                                                                         |

 Table 8:
 SDRAM and Devices Pin Assignments (Continued)

| Table 9: | Local Address and Data Bus Pin Assignments |
|----------|--------------------------------------------|
|----------|--------------------------------------------|

| Pin Name               | Туре | Full Name               | Description                                                                                                                                                                                                    |
|------------------------|------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AD[63:42]              | I/O  | Address/Data<br>[63:42] | In SDRAM accesses, these pins function as part of the data to be read/written from/to the SDRAMs. In Device accesses, these pins function as data during the data phase.                                       |
| AD[41]/<br>DevRW*      | I/O  | Address/Data<br>[41]    | In SDRAM/Device data phase, this pin functions as data bit [41].                                                                                                                                               |
|                        |      | Device Read-<br>Write   | In Device address phase, this pin indicates if an access to a device is read ('1') or write ('0'). Latching is done via ALE.                                                                                   |
| AD[40]/<br>BootCS*     | I/O  | Address/Data<br>[40]    | In SDRAM/Device data phase, this pin functions as data bit [40].                                                                                                                                               |
|                        |      | Boot Chip<br>Select     | In Device address phase, this pin functions as the boot device chip select. Latching is done via ALE.                                                                                                          |
| AD[39:36]/<br>CS[3:0]* | I/O  | Address/Data<br>[39:36] | In SDRAM/Device data phase, these pins function as data bits [39:36].                                                                                                                                          |
|                        |      | Chip Select<br>[3:0]    | In Device address phase, these pins function as Device Chip<br>Selects and are valid (and should be latched). The Chip Selects<br>need to be qualified with the CSTiming* signal. Latching is done<br>via ALE. |



| Pin Name                        | Туре | Full Name                           | Description                                                                                                                                                                                                                                          |
|---------------------------------|------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AD[35:32]/<br>DMAAck            | I/O  | Address/Data<br>[35:32]             | In SDRAM/Device data phase, these pins function as data bits [35:32].                                                                                                                                                                                |
| [3:0]*                          |      | DMA Acknowl-<br>edge[3:0]           | In Device address phase, these pins function as DMA Acknowl-<br>edges and are valid (and should be latched). They need to be<br>qualified with the CSTiming* signal. Latching is done via ALE.                                                       |
| AD[31:0]                        | I/O  | Address/<br>Data[31:0]              | Multiplexed address and data bus to the SDRAM (data only) and Devices (address and data).                                                                                                                                                            |
| ADP[7:6]/<br>SRAS*/<br>SCAS*    | I/O  | SDRAM data<br>ECC [7:6]             | If the GT-96100A is configured for ECC mode, then in SDRAM accesses, these pins serve as bits [7:6] of the ECC for data bits [63:0]. ECC is generated by the GT-96100A for 64-bit SDRAM writes, and read from SDRAM ECC bank for 64-bit SDRAM reads. |
|                                 |      | SDRAM Row<br>Address<br>Strobe      | ADP[7:6] can be configured to function as SRAS* on RESET.<br>See Section 22. "Reset Configuration" on page 452.                                                                                                                                      |
|                                 |      | SDRAM Col-<br>umn Address<br>Strobe | ADP[7:6] can be configured to function as SCAS* on RESET.<br>See Section 22. "Reset Configuration" on page 452.                                                                                                                                      |
| ADP[5]/<br>DAdr[11]             | I/O  | SDRAM data<br>ECC [5]               | If the GT-96100A is configured for ECC mode, then in SDRAM accesses this pin serve as bit [5] of the ECC for data bits [63:0]. ECC is generated by the GT-96100A for 64 bit SDRAM writes, and read from SDRAM ECC bank for 64 bit SDRAM reads.       |
|                                 |      | SDRAM<br>Address [11]               | If the GT-96100A is configured to non-ECC mode, then in SDRAM accesses this pin functions as SDRAM address bit[11].                                                                                                                                  |
| ADP[4]/Bank<br>Sel[1]           | I/O  | SDRAM data<br>ECC [4]               | If the GT-96100A is configured for ECC mode, then in SDRAM accesses this pin serve as bit [4] of the ECC for data bits [63:0]. ECC is generated by the GT-96100A for 64 bit SDRAM writes, and read from SDRAM ECC bank for 64 bit SDRAM reads.       |
|                                 |      | SDRAM Bank<br>Select [1]            | If the GT-96100A is configured to non-ECC mode, then in SDRAM accesses, this pin functions as bank select bit[1].                                                                                                                                    |
| ADP[3:1]/<br>EOT[3:1]*/<br>DWr* | I/O  | SDRAM data<br>ECC [3:1]             | If the GT-96100A is configured for ECC mode, then in SDRAM accesses, these pins serve as bits [3:1] of the ECC for data bits [63:0]. ECC is generated by the GT-96100A for 64 bit SDRAM writes, and read from SDRAM ECC bank for 64 bit SDRAM reads. |
|                                 |      | End of DMA<br>Transfer [3:1]        | If the GT-96100A is configured to non-ECC mode, then in SDRAM accesses, these pins serve as End Of Transfer indications for the DMA channels.                                                                                                        |
|                                 |      | SDRAM Write                         | ADP[3] can be configured to function as DWr* on RESET. See Section 22. "Reset Configuration" on page 452.                                                                                                                                            |

 Table 9:
 Local Address and Data Bus Pin Assignments (Continued)

| Pin Name                        | Туре | Full Name                                                                                                                                          | Description                                                                                                                                                                                                                                                             |  |  |
|---------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| ADP[0]/<br>EOT[0]*/<br>DAdr[12] | I/O  | SDRAM data<br>ECC[0]                                                                                                                               | If the GT-96100A is configured for ECC mode, then in SDRAM accesses, this pin serves as bit [0] of the ECC for data bits [63:0]. ECC is generated by the GT-96100A for 64 bit SDRAM writes, and read from SDRAM ECC bank for 64 bit SDRAM reads.                        |  |  |
|                                 |      | End of DMA<br>Transfer [0]                                                                                                                         | If the GT-96100A is configured to non-ECC mode, then in SDRAM accesses, this pin serves as End Of Transfer indication for DMA channel 0.                                                                                                                                |  |  |
|                                 |      | SDRAM<br>Address [12]                                                                                                                              | ADP[0] can be configured to function as SDRAM Address [12] on RESET. See Section 22. "Reset Configuration" on page 452.                                                                                                                                                 |  |  |
| CSTiming*                       | 0    | Chip Select<br>Timing                                                                                                                              | This signal is active (asserted low) for the number of cycles that the device currently being accessed is programmed to. Used to qualify CS[3:0]*, BootCS and DMAAck[3:0]* signals.                                                                                     |  |  |
|                                 | SoR  | <b>NOTE:</b> Sampled on RESET to configure the GT-96100A prior to boot-up. See Section 22. "Reset Configuration" on page 452 for more information. |                                                                                                                                                                                                                                                                         |  |  |
| ALE                             | 0    | Address Latch<br>Enable                                                                                                                            | This signal is asserted in the Device address phase and must<br>be used to latch the Address, BootCS*, CS[3:0]*, DevRW* and<br>DMAAck[3:0]* pins from the AD bus.                                                                                                       |  |  |
| Ready*/                         | I    | Ready                                                                                                                                              | This input signal is used as a cycle extender                                                                                                                                                                                                                           |  |  |
| EOT[1]*                         |      |                                                                                                                                                    | <b>NOTE:</b> When inactive during device access, the access is extended until Ready* is asserted.                                                                                                                                                                       |  |  |
|                                 |      | End Of Trans-<br>fer [1]                                                                                                                           | Ready* can be programmed to function as EOT[1]*. See Section 5.1.2.3 "DMA End of Transfer Pins Functionality" on page 101.                                                                                                                                              |  |  |
|                                 | SoR  | <b>NOTE:</b> Sampled on RESET to configure the GT-96100A prior to boot-up. See Section 22. "Reset Configuration" on page 452 for more information. |                                                                                                                                                                                                                                                                         |  |  |
| BypsOE*/<br>MGNT*/DWr*          | 0    | Bypass Out-<br>put Enable                                                                                                                          | If bypass mode is enabled, this signal controls the output<br>enable for bypass latches/buffers/switches. The bypass can be<br>used when a 64-bit read transaction is executed from the CPU.<br>Read data will be transferred directly to the CPU bus. See Table<br>77. |  |  |
|                                 |      | Memory (AD)<br>bus Grant                                                                                                                           | If the GT-96100A is configured (at RESET) for UMA support, this pin functions as Memory Grant. It is asserted in response to MREQ*.                                                                                                                                     |  |  |
|                                 |      | SDRAM Write                                                                                                                                        | This pin can be programmed to function as DWr*. See Section 5.1.2.1 "Duplicating SDRAM Control Lines" on page 100.                                                                                                                                                      |  |  |
| Local Address Total: 76         |      |                                                                                                                                                    |                                                                                                                                                                                                                                                                         |  |  |

#### Table 9: Local Address and Data Bus Pin Assignments (Continued)



| Pin Name                                            | Туре | Full Name                                                                                                                                          | Description                                                                                                                                                                                                                           |
|-----------------------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMAReq[3]*/<br>DAdr[12]/<br>EOT[0]*/<br>SCAS*/TREQ* | I/O  | DMA<br>Request[3]                                                                                                                                  | DMA request by external devices to IDMA channel 3.                                                                                                                                                                                    |
|                                                     |      | SDRAM<br>Address [12]                                                                                                                              | This pin can be configured to function as DAdr[12]. See Section 5.1.2.4 "Multiplexing DAdr[12]" on page 102.                                                                                                                          |
|                                                     |      | UMA Internal<br>Request                                                                                                                            | For UMA operation, DMAReq[3]* can be programed to indicate that there is a pending internal request in SDRAM and Device interface that requires the GT-96100A ownership of the AD bus. See Section 5.6.6 "Total Request" on page 117. |
|                                                     |      | End of DMA<br>Transfer[0]                                                                                                                          | DMAReq[3]* can be programmed to function as EOT[0]*. See<br>Section Section 5.1.2.3 "DMA End of Transfer Pins Functional-<br>ity" on page 101.                                                                                        |
|                                                     |      | SDRAM Col-<br>umn Address<br>Strobe                                                                                                                | DMAReq[3]* can be programmed to function as SCAS*. See<br>Section 5.1.2.1 "Duplicating SDRAM Control Lines" on page<br>100.                                                                                                           |
|                                                     | SoR  | <b>NOTE:</b> Sampled on RESET to configure the GT-96100A prior to boot-up. See Section 22. "Reset Configuration" on page 452 for more information. |                                                                                                                                                                                                                                       |
| DMAReq[2]*/<br>DAdr[11]                             | I/O  | DMA<br>Request[2]                                                                                                                                  | DMA request by external devices to IDMA channel 2.                                                                                                                                                                                    |
|                                                     |      | SDRAM<br>Address [11]                                                                                                                              | This pin can be configured to function as SDRAM address bit[11]. See Section 5.1.2.2 "Duplicating DAdr[11] and Bank-Sel[1] on DMAReq[2:1]*" on page 101.                                                                              |
|                                                     | SoR  | <b>NOTE:</b> Sampled on RESET to configure the GT-96100A prior to boot-up. See Section 22. "Reset Configuration" on page 452 for more information. |                                                                                                                                                                                                                                       |
| DMAReq[1]*/<br>BankSel[1]                           | I/O  | DMA<br>Request[1]                                                                                                                                  | DMA request by external devices to IDMA channel 1.                                                                                                                                                                                    |
|                                                     |      | SDRAM Bank<br>Select [1]                                                                                                                           | This pin can be configured to function as BankSel[1]. See Sec-<br>tion 5.1.2.2 "Duplicating DAdr[11] and BankSel[1] on<br>DMAReq[2:1]*" on page 101.                                                                                  |
|                                                     | SoR  | <b>NOTE:</b> Sampled on RESET to configure the GT-96100A prior to boot-up. See Section 22. "Reset Configuration" on page 452 for more information. |                                                                                                                                                                                                                                       |
| DMAReq[0]*/<br>MREQ*/<br>SRAS*                      | I/O  | DMA Request<br>[0]                                                                                                                                 | DMA request by external devices to IDMA channel 0.                                                                                                                                                                                    |
|                                                     |      | Memory Bus<br>Request                                                                                                                              | If the GT-96100A is configured (at RESET) for UMA support, this pin functions as Memory Request.                                                                                                                                      |
|                                                     |      | SDRAM Row<br>Address Strobe                                                                                                                        | This pin can be programmed to function as SRAS*. See Sec-<br>tion 5.1.2.1 "Duplicating SDRAM Control Lines" on page 100.                                                                                                              |
| DMA Total: 4                                        |      |                                                                                                                                                    |                                                                                                                                                                                                                                       |

Table 10: DMA Pin Assignments



#### Table 11: WAN Pin Assignments

| Pin Name                           | Туре | Full Name              | Description                                                                                                                                                                                         |
|------------------------------------|------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port A<br>NOTE: Port A<br>details. |      | nected to MPSC0.       | See Section 20. "Physical Signal Routing" on page 414 for more                                                                                                                                      |
|                                    |      |                        | t A can be connected to the PCI Arbiter or used as GPP. See on page 405 for more details.                                                                                                           |
| PORTA[0]                           | I/O  | RXD0 (Input)           | Serial receive data input to MPSC0.                                                                                                                                                                 |
|                                    |      | PARB0_GNT2<br>(output) | PCI_0 arbiter output grant 2.                                                                                                                                                                       |
|                                    |      | GPP16 (I/O)            | General Purpose Pin 16.                                                                                                                                                                             |
| PORTA[1]                           | I/O  | PARB0_REQ2<br>(Input)  | PCI_0 arbiter input request 2.                                                                                                                                                                      |
|                                    |      | TXD0 (Output)          | Serial transmit data output from the MPSC0.                                                                                                                                                         |
|                                    |      | GPP17 (I/O)            | General Purpose Pin 17.                                                                                                                                                                             |
| PORTA[2]                           | I/O  | PARB0_REQ3<br>(Input)  | PCI_0 arbiter input request 3.                                                                                                                                                                      |
|                                    |      | RTS0* (Output)         | Request to Send output from MPSC0. Indicates that MPSC0 is ready to transmit data.                                                                                                                  |
|                                    |      | GPP18 (I/O)            | General Purpose Pin 18.                                                                                                                                                                             |
| PORTA[3]                           | I/O  | CTS0* (Input)          | Clear to Send input to MPSC0. Indicates to MPSC0 that data transmission may begin.                                                                                                                  |
|                                    |      | PARB0_GNT3<br>(Output) | PCI_0 arbiter output grant 3.                                                                                                                                                                       |
|                                    |      | GPP19 (I/O)            | General Purpose Pin 19.                                                                                                                                                                             |
| PORTA[4]                           | I/O  | CD0 (Input)            | Carrier Detect input to MPSC0. Indicates to MPSC0 that it can begin reception of data.                                                                                                              |
|                                    |      | PARB0_GNT4<br>(Output) | PCI_0 arbiter output grant 4.                                                                                                                                                                       |
|                                    |      | GPP20 (I/O)            | General Purpose Pin 20.                                                                                                                                                                             |
| PORTA[5]                           | I/O  | SCLK0 (Input)          | Input clock to MPSC0. Can be used as both transmit and receive clock.                                                                                                                               |
|                                    |      |                        | <b>NOTE:</b> This clock also serves as one of the input clocks to the Baud Rate Generators.                                                                                                         |
|                                    |      | PARB0_REQ4<br>(Input)  | PCI_0 arbiter input request 4.                                                                                                                                                                      |
|                                    |      | OSCLK0 (Out-<br>put)   | Output clock from MPSC0. Can be used when SCLK0 is not<br>needed (i.e. the MPSC is programmed to use one of the Baud<br>Rate Generators as its clock source or is connected to one of<br>the TDMs). |
|                                    |      | GPP21 (I/O)            | General Purpose Pin 21.                                                                                                                                                                             |



| Pin Name                                                                                                                                                                                                                                                                                                  | Туре  | Full Name                    | Description                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port A (Contin                                                                                                                                                                                                                                                                                            | nued) |                              |                                                                                                                                                                                                                                                              |
| PORTA[6]                                                                                                                                                                                                                                                                                                  | I/O   | TSCLK0<br>(Input)            | <ul><li>Input clock to MPSC0. Can be used by the MPSC transmitter when separate receive and transmit clocks are needed.</li><li>NOTE: This clock also serves as one of the input clocks to the Baud Rate Generators.</li></ul>                               |
|                                                                                                                                                                                                                                                                                                           |       | PARB0_REQ5<br>(Input)        | PCI_0 arbiter input request 5.                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                           |       | OTSCLK0<br>(Output)          | Output Tx clock from MPSC0. Can be used when TSCLK0 is<br>not needed (i.e. the MPSC is programmed to use one of the<br>Baud Rate Generators as its clock source or is connected to<br>one of the TDMs, or when there is no need for a separate Tx<br>clock). |
|                                                                                                                                                                                                                                                                                                           |       | GPP22 (I/O)                  | General Purpose Pin 22.                                                                                                                                                                                                                                      |
| <ul> <li>NOTE: Port B can be connected to MPSC1. See Section 20. "Physical Signal Routing" on page 414 for mor details.</li> <li>When not connected to MPSC1, Port B can be connected to the PCI Arbiter or used as GPP. See Section 19. "General Purpose Ports" on page 405 for more details.</li> </ul> |       |                              |                                                                                                                                                                                                                                                              |
| PORTB[0]                                                                                                                                                                                                                                                                                                  | I/O   | RXD1 (Input)                 | Serial receive data input to MPSC1.                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                           |       | PARB1_GNT2<br>(Output)       | PCI_1 arbiter output grant 2.                                                                                                                                                                                                                                |
| l .                                                                                                                                                                                                                                                                                                       |       | GPP24 (I/O)                  | General Purpose Pin 24.                                                                                                                                                                                                                                      |
| PORTB[1]                                                                                                                                                                                                                                                                                                  | I/O   | PARB1_REQ2<br>(Input)        | PCI_1 arbiter input request 2.                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                           |       | TXD1 (Output)                | Serial transmit data output from the MPSC1.                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                           |       | GPP25 (I/O)                  | General Purpose Pin 25.                                                                                                                                                                                                                                      |
| PORTB[2]                                                                                                                                                                                                                                                                                                  | I/O   | PARB1_REQ3(<br>Input)        | PCI_1 arbiter input request 3.                                                                                                                                                                                                                               |
| L                                                                                                                                                                                                                                                                                                         |       | RTS1* (Output)               | Request to Send output from MPSC1. Indicates that MPSC1 is ready to transmit data.                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                           |       |                              | , , , , , , , , , , , , , , , , , , ,                                                                                                                                                                                                                        |
| I                                                                                                                                                                                                                                                                                                         |       | GPP26 (I/O)                  | General Purpose Pin 26.                                                                                                                                                                                                                                      |
| PORTB[3]                                                                                                                                                                                                                                                                                                  | I/O   | GPP26 (I/O)<br>CTS1* (Input) |                                                                                                                                                                                                                                                              |
| PORTB[3]                                                                                                                                                                                                                                                                                                  | I/O   |                              | General Purpose Pin 26.<br>Clear to Send input to MPSC1. Indicates to MPSC1 that data                                                                                                                                                                        |

 Table 11:
 WAN Pin Assignments (Continued)

| Pin Name       | Туре | Full Name              | Description                                                                                                                                                                                                                                                  |
|----------------|------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port B (Contin | ued) |                        |                                                                                                                                                                                                                                                              |
| PORTB[4]       | I/O  | CD1 (Input)            | Carrier Detect input to MPSC1. Indicates to MPSC1 that it can begin reception of data.                                                                                                                                                                       |
|                |      | PARB0_GNT6<br>(Output) | PCI_0 arbiter output grant 6.                                                                                                                                                                                                                                |
|                |      | PARB1_GNT4<br>(Output) | PCI_1 arbiter output grant 4.                                                                                                                                                                                                                                |
|                |      | GPP28 (I/O)            | General Purpose Pin 28.                                                                                                                                                                                                                                      |
| PORTB[5]       | I/O  | SCLK1 (Input)          | Input clock to MPSC1. Can be used as both transmit and receive clock.<br><b>NOTE:</b> This clock also serves as one of the input clocks to                                                                                                                   |
|                |      |                        | the Baud Rate Generators.                                                                                                                                                                                                                                    |
|                |      | PARB0_REQ6<br>(Input)  | PCI_0 arbiter input request6.                                                                                                                                                                                                                                |
|                |      | PARB1_REQ4<br>(Input)  | PCI_1 arbiter input request 4.                                                                                                                                                                                                                               |
|                |      | OSCLK1 (Out-<br>put)   | Output clock from MPSC1. Can be used when SCLK1 is not needed (i.e. the MPSC is programmed to use one of the Baud Rate Generators as its clock source or is connected to one of the TDMs).                                                                   |
|                |      | GPP29 (I/O)            | General Purpose Pin 29.                                                                                                                                                                                                                                      |
| PORTB[6]       | I/O  | TSCLK1<br>(Input)      | Input clock to MPSC1. Can be used by the MPSC transmitter<br>when separate receive and transmit clocks are needed.<br><b>NOTE:</b> This clock also serves as one of the input clocks to<br>the Baud Rate Generators.                                         |
|                |      | OTSCLK1<br>(Output)    | Output Tx clock from MPSC1. Can be used when TSCLK1 is<br>not needed (i.e. the MPSC is programmed to use one of the<br>Baud Rate Generators as its clock source or is connected to<br>one of the TDMs, or when there is no need for a separate Tx<br>clock). |
|                |      | PARB0_GNT5<br>(Output) | PCI_0 arbiter output grant 5.                                                                                                                                                                                                                                |
|                |      | GPP30 (I/O)            | General Purpose Pin 30.                                                                                                                                                                                                                                      |



| Pin Name                                                                                                                                            | Туре                                                                                                                                                  | Full Name           | Description                                                                                                              |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------|--|--|
| <ul> <li>Port C</li> <li>NOTE: Port C can be connected to MPSC2. See Section 20. "Physical Signal Routing" on page 414 for more details.</li> </ul> |                                                                                                                                                       |                     |                                                                                                                          |  |  |
|                                                                                                                                                     | When not connected to MPSC2, Port C can be connected to TDM0 or used as GPP. See Section 19.<br>"General Purpose Ports" on page 405 for more details. |                     |                                                                                                                          |  |  |
| PORTC[0]                                                                                                                                            | I/O                                                                                                                                                   | RXD2 (Input)        | Serial receive data input to MPSC2.                                                                                      |  |  |
|                                                                                                                                                     |                                                                                                                                                       | TRXD0 (Input)       | Serial receive data input to TDM channel0.                                                                               |  |  |
|                                                                                                                                                     |                                                                                                                                                       | TTXD0 (Out-<br>put) | Serial transmit data from TDM channel0.                                                                                  |  |  |
|                                                                                                                                                     |                                                                                                                                                       | GPP32 (I/O)         | General Purpose Pin 32.                                                                                                  |  |  |
| PORTC[1]                                                                                                                                            | I/O                                                                                                                                                   | TXD2 (Output)       | Serial transmit data output from the MPSC2.                                                                              |  |  |
|                                                                                                                                                     |                                                                                                                                                       | TTXD0 (Out-<br>put) | Serial transmit data from TDM channel0.                                                                                  |  |  |
|                                                                                                                                                     |                                                                                                                                                       | TRXD0 (Input)       | Serial receive data input to TDM channel0.                                                                               |  |  |
|                                                                                                                                                     |                                                                                                                                                       | GPP33 (I/O)         | General Purpose Pin 33.                                                                                                  |  |  |
| PORTC[2]                                                                                                                                            | I/O                                                                                                                                                   | RTS2* (Output)      | Request to Send output from MPSC2. Indicates that MPSC2 is ready to transmit data.                                       |  |  |
|                                                                                                                                                     |                                                                                                                                                       | TDSTRB0<br>(Output) | TDM channel0 strobe output signal, which can be used to gate clocks to external devices that do not have a built in TDM. |  |  |
|                                                                                                                                                     |                                                                                                                                                       | GPP34 (I/O)         | General Purpose Pin 34.                                                                                                  |  |  |
| PORTC[3]                                                                                                                                            | I/O                                                                                                                                                   | CTS2* (Input)       | Clear to Send input to MPSC2. Indicates to MPSC2 that data transmission may begin.                                       |  |  |
|                                                                                                                                                     |                                                                                                                                                       | TTSYNC0<br>(Input)  | Transmit Frame Sync input to TDM channel0.                                                                               |  |  |
|                                                                                                                                                     |                                                                                                                                                       | GPP35 (I/O)         | General Purpose Pin 35.                                                                                                  |  |  |
| PORTC[4]                                                                                                                                            | I/O                                                                                                                                                   | CD2 (Input)         | Carrier Detect input to MPSC2. Indicates to MPSC2 that it can begin reception of data (input to MPSC2).                  |  |  |
|                                                                                                                                                     |                                                                                                                                                       | TRSYNC0<br>(Input)  | Receive Frame Sync input to TDM channel0.                                                                                |  |  |
|                                                                                                                                                     |                                                                                                                                                       | GPP36 (I/O)         | General Purpose Pin 36.                                                                                                  |  |  |

 Table 11:
 WAN Pin Assignments (Continued)

| Pin Name           | Туре       | Full Name            | Description                                                                                                                                                                                                                                                  |
|--------------------|------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port C (Contin     | nued)      |                      |                                                                                                                                                                                                                                                              |
| PORTC[5]           | I/O        | SCLK2 (Input)        | Input clock to MPSC2. Can be used as both transmit and receive clock.<br><b>NOTE:</b> This clock also serves as one of the input clocks to the Baud Rate Generators.                                                                                         |
|                    |            | OSCLK2 (Out-<br>put) | Output clock from MPSC2. Can be used when SCLK2 is not<br>needed (i.e. the MPSC is programmed to use one of the Baud<br>Rate Generators as its clock source or is connected to one of<br>the TDMs).                                                          |
|                    |            | TRCLK0<br>(Input)    | Receive input clock to TDM channel0.                                                                                                                                                                                                                         |
|                    |            | GPP37 (I/O)          | General Purpose Pin 37.                                                                                                                                                                                                                                      |
| PORTC[6]           | I/O        | TSCLK2<br>(Input)    | Input clock to MPSC2. Can be used by the MPSC transmitter<br>when separate receive and transmit clocks are needed.<br><b>NOTE:</b> This clock also serves as one of the input clocks to<br>the Baud Rate Generators.                                         |
|                    |            | OTSCLK2<br>(Output)  | Output Tx clock from MPSC2. Can be used when TSCLK2 is<br>not needed (i.e. the MPSC is programmed to use one of the<br>Baud Rate Generators as its clock source or is connected to<br>one of the TDMs, or when there is no need for a separate Tx<br>clock). |
|                    |            | TTCLK0<br>(Input)    | Transmit input clock to TDM channel0.                                                                                                                                                                                                                        |
|                    |            | GPP38 (I/O)          | General Purpose Pin 38.                                                                                                                                                                                                                                      |
| details.<br>When r | not connec |                      | See Section 20. "Physical Signal Routing" on page 414 for more<br>t D can be connected to TDM1 or used as GPP. See Section 19.<br>5 for more details.                                                                                                        |
| PORTD[0]           | I/O        | RXD3 (Input)         | Serial receive data input to MPSC3.                                                                                                                                                                                                                          |
|                    |            | TRXD1 (Input)        | Serial receive data input to TDM channel1.                                                                                                                                                                                                                   |
|                    |            | TTXD1 (Out-<br>put)  | Serial transmit data from TDM channel1.                                                                                                                                                                                                                      |
|                    |            | GPP40 (I/O)          | General Purpose Pin 40.                                                                                                                                                                                                                                      |
| PORTD[1]           | I/O        | TXD3 (Output)        | Serial transmit data output from the MPSC3.                                                                                                                                                                                                                  |
|                    |            | TTXD1 (Out-<br>put)  | Serial transmit data from TDM channel1.                                                                                                                                                                                                                      |
|                    |            | TRXD1 (Input)        | Serial receive data input to TDM channel1.                                                                                                                                                                                                                   |
|                    |            | GPP41 (I/O)          | General Purpose Pin 41.                                                                                                                                                                                                                                      |



| Pin Name       | Туре  | Full Name            | Description                                                                                                                                                                                                                                                  |
|----------------|-------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port D (Contin | nued) |                      |                                                                                                                                                                                                                                                              |
| PORTD[2]       | I/O   | RTS3* (Output)       | Request to Send output from MPSC3. Indicates that MPSC3 is ready to transmit data.                                                                                                                                                                           |
|                |       | TDSTRB1<br>(Output)  | TDM channel1 strobe output signal, which can be used to gate clocks to external devices that do not have a built in TDM.                                                                                                                                     |
|                |       | GPP42 (I/O)          | General Purpose Pin 42.                                                                                                                                                                                                                                      |
| PORTD[3]       | I/O   | CTS3* (Input)        | Clear to Send input to MPSC3. Indicates to MPSC3 that data transmission may begin.                                                                                                                                                                           |
|                |       | TTSYNC1<br>(Input)   | Transmit Frame Sync input to TDM channel1.                                                                                                                                                                                                                   |
|                |       | GPP43 (I/O)          | General Purpose Pin 43.                                                                                                                                                                                                                                      |
| PORTD[4]       | I/O   | CD3 (Input)          | Carrier Detect input to MPSC3. Indicates to MPSC3 that it can begin reception of data (input to MPSC3).                                                                                                                                                      |
|                |       | TRSYNC1<br>(Input)   | Receive Frame Sync input to TDM channel1.                                                                                                                                                                                                                    |
|                |       | GPP44 (I/O)          | General Purpose Pin 44.                                                                                                                                                                                                                                      |
| PORTD[5]       | I/O   | SCLK3 (Input)        | Input clock to MPSC3. Can be used as both transmit and receive clock.<br><b>NOTE:</b> This clock also serves as one of the input clocks to the Baud Rate Generators.                                                                                         |
|                |       | OSCLK3 (Out-<br>put) | Output clock from MPSC3. Can be used when SCLK3 is not<br>needed (i.e. the MPSC is programmed to use one of the Baud<br>Rate Generators as its clock source or is connected to one of<br>the TDMs).                                                          |
|                |       | TRCLK1<br>(Input)    | Receive input clock to TDM channel1.                                                                                                                                                                                                                         |
|                |       | GPP45 (I/O)          | General Purpose Pin 45.                                                                                                                                                                                                                                      |
| PORTD[6]       | I/O   | TSCLK3<br>(Input)    | Input clock to MPSC3. Can be used by the MPSC transmitter<br>when separate receive and transmit clocks are needed.<br><b>NOTE:</b> This clock also serves as one of the input clocks to<br>the Baud Rate Generators.                                         |
|                |       | OTSCLK3<br>(Output)  | Output Tx clock from MPSC3. Can be used when TSCLK3 is<br>not needed (i.e. the MPSC is programmed to use one of the<br>Baud Rate Generators as its clock source or is connected to<br>one of the TDMs, or when there is no need for a separate Tx<br>clock). |
|                |       | TTCLK1<br>(Input)    | Transmit input clock to TDM channel1.                                                                                                                                                                                                                        |
|                |       | GPP46 (I/O)          | General Purpose Pin 46.                                                                                                                                                                                                                                      |

 Table 11:
 WAN Pin Assignments (Continued)

| Pin Name                                                                                                                                            | Туре | Full Name                              | Description                                                                                                              |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--|
| <ul> <li>Port E</li> <li>NOTE: Port E can be connected to MPSC4. See Section 20. "Physical Signal Routing" on page 414 for more details.</li> </ul> |      |                                        |                                                                                                                          |  |
|                                                                                                                                                     |      | ed to MPSC4, Port<br>Ports" on page 40 | E can be connected to TDM2 or used as GPP. See Section 19.<br>5 for more details.                                        |  |
| PORTE[0]                                                                                                                                            | I/O  | RXD4 (Input)                           | Serial receive data input to MPSC4.                                                                                      |  |
|                                                                                                                                                     |      | TRXD2 (Input)                          | Serial receive data input to TDM channel2.                                                                               |  |
|                                                                                                                                                     |      | TTXD2 (Out-<br>put)                    | Serial transmit data from TDM channel2.                                                                                  |  |
|                                                                                                                                                     |      | GPP48 (I/O)                            | General Purpose Pin 48.                                                                                                  |  |
| PORTE[1]                                                                                                                                            | I/O  | TXD4 (Output)                          | Serial transmit data output from the MPSC4.                                                                              |  |
|                                                                                                                                                     |      | TTXD2 (Out-<br>put)                    | Serial transmit data from TDM channel2.                                                                                  |  |
|                                                                                                                                                     |      | TRXD2 (Input)                          | Serial receive data input to TDM channel2.                                                                               |  |
|                                                                                                                                                     |      | GPP49 (I/O)                            | General Purpose Pin 49.                                                                                                  |  |
| PORTE[2]                                                                                                                                            | I/O  | RTS4* (Output)                         | Request to Send output from MPSC4. Indicates that MPSC4 is ready to transmit data.                                       |  |
|                                                                                                                                                     |      | TDSTRB2<br>(Output)                    | TDM channel2 strobe output signal, which can be used to gate clocks to external devices that do not have a built in TDM. |  |
|                                                                                                                                                     |      | GPP50 (I/O)                            | General Purpose Pin 50.                                                                                                  |  |
| PORTE[3]                                                                                                                                            | I/O  | CTS4* (Input)                          | Clear to Send input to MPSC4. Indicates to MPSC4 that data transmission may begin.                                       |  |
|                                                                                                                                                     |      | TTSYNC2<br>(Input)                     | Transmit Frame Sync input to TDM channel2.                                                                               |  |
|                                                                                                                                                     |      | GPP51 (I/O)                            | General Purpose Pin 51.                                                                                                  |  |
| PORTE[4]                                                                                                                                            | I/O  | CD4 (Input)                            | Carrier Detect input to MPSC4. Indicates to MPSC4 that it can begin reception of data (input to MPSC4).                  |  |
|                                                                                                                                                     |      | TRCLK2<br>(Input)                      | Receive input clock to TDM channel2.                                                                                     |  |
|                                                                                                                                                     |      | GPP52 (I/O)                            | General Purpose Pin 52.                                                                                                  |  |



| Pin Name                                                                                                                                                                                                                                                                                                        | Туре  | Full Name            | Description                                                                                                                                                                                                                                                  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Port E (Contin                                                                                                                                                                                                                                                                                                  | nued) |                      |                                                                                                                                                                                                                                                              |  |
| PORTE[5]                                                                                                                                                                                                                                                                                                        | I/O   | SCLK4 (Input)        | Input clock to MPSC4. Can be used as both transmit and receive clock.<br><b>NOTE:</b> This clock also serves as one of the input clocks to the Baud Rate Generators.                                                                                         |  |
|                                                                                                                                                                                                                                                                                                                 |       | OSCLK4 (Out-<br>put) | Output clock from MPSC4. Can be used when SCLK4 is not needed (i.e. the MPSC is programmed to use one of the Baud Rate Generators as its clock source or is connected to one of the TDMs).                                                                   |  |
|                                                                                                                                                                                                                                                                                                                 |       | TRSYNC2<br>(Input)   | Receive Frame Sync input to TDM channel2.                                                                                                                                                                                                                    |  |
|                                                                                                                                                                                                                                                                                                                 |       | GPP53 (I/O)          | General Purpose Pin 53.                                                                                                                                                                                                                                      |  |
| PORTE[6]                                                                                                                                                                                                                                                                                                        | I/O   | TSCLK4<br>(Input)    | Input clock to MPSC4. Can be used by the MPSC transmitter<br>when separate receive and transmit clocks are needed.<br><b>NOTE:</b> This clock also serves as one of the input clocks to<br>the Baud Rate Generators.                                         |  |
|                                                                                                                                                                                                                                                                                                                 |       | OTSCLK4<br>(Output)  | Output Tx clock from MPSC4. Can be used when TSCLK4 is<br>not needed (i.e. the MPSC is programmed to use one of the<br>Baud Rate Generators as its clock source or is connected to<br>one of the TDMs, or when there is no need for a separate Tx<br>clock). |  |
|                                                                                                                                                                                                                                                                                                                 |       | TTCLK2<br>(Input)    | Transmit input clock to TDM channel2.                                                                                                                                                                                                                        |  |
|                                                                                                                                                                                                                                                                                                                 |       | GPP54 (I/O)          | General Purpose Pin 54.                                                                                                                                                                                                                                      |  |
| <ul> <li>Port F</li> <li>NOTE: Port F can be connected to MPSC5. See Section 20. "Physical Signal Routing" on page 414 for more details.</li> <li>When not connected to MPSC5, Port F can be connected to TDM3 or used as GPP. See Section 19. "General Purpose Ports" on page 405 for more details.</li> </ul> |       |                      |                                                                                                                                                                                                                                                              |  |
| PORTF[0]                                                                                                                                                                                                                                                                                                        | I/O   | RXD5 (Input)         | Serial receive data input to MPSC5.                                                                                                                                                                                                                          |  |
|                                                                                                                                                                                                                                                                                                                 |       | TRXD3 (Input)        | Serial receive data input to TDM channel3.                                                                                                                                                                                                                   |  |
|                                                                                                                                                                                                                                                                                                                 |       | TTXD3 (Out-<br>put)  | Serial transmit data from TDM channel3.                                                                                                                                                                                                                      |  |
|                                                                                                                                                                                                                                                                                                                 |       | GPP56 (I/O)          | General Purpose Pin 56.                                                                                                                                                                                                                                      |  |
| PORTF[1]                                                                                                                                                                                                                                                                                                        | I/O   | TXD5 (Output)        | Serial transmit data output from the MPSC5.                                                                                                                                                                                                                  |  |
|                                                                                                                                                                                                                                                                                                                 |       | TTXD3 (Out-<br>put)  | Serial transmit data from TDM channel3.                                                                                                                                                                                                                      |  |
|                                                                                                                                                                                                                                                                                                                 |       | TRXD3 (Input)        | Serial receive data input to TDM channel3.                                                                                                                                                                                                                   |  |
|                                                                                                                                                                                                                                                                                                                 |       | GPP57 (I/O)          | General Purpose Pin 57.                                                                                                                                                                                                                                      |  |

 Table 11:
 WAN Pin Assignments (Continued)

| Pin Name       | Туре  | Full Name            | Description                                                                                                                                                                                                                                                  |
|----------------|-------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port F (Contin | nued) |                      |                                                                                                                                                                                                                                                              |
| PORTF[2]       | I/O   | RTS5* (Output)       | Request to Send output from MPSC5. Indicates that MPSC5 is ready to transmit data.                                                                                                                                                                           |
|                |       | TDSTRB3<br>(Output)  | TDM channel3 strobe output signal, which can be used to gate clocks to external devices that do not have a built in TDM.                                                                                                                                     |
|                |       | GPP58 (I/O)          | General Purpose Pin 58.                                                                                                                                                                                                                                      |
| PORTF[3]       | I/O   | CTS5* (Input)        | Clear to Send input to MPSC5. Indicates to MPSC5 that data transmission may begin.                                                                                                                                                                           |
|                |       | TTSYNC3<br>(Input)   | Transmit Frame Sync input to TDM channel3.                                                                                                                                                                                                                   |
|                |       | GPP59 (I/O)          | General Purpose Pin 59.                                                                                                                                                                                                                                      |
| PORTF[4]       | I/O   | CD5 (Input)          | Carrier Detect input to MPSC5. Indicates to MPSC5 that it can begin reception of data (input to MPSC5).                                                                                                                                                      |
|                |       | TRCLK3<br>(Input)    | Receive input clock to TDM channel3.                                                                                                                                                                                                                         |
|                |       | GPP60 (I/O)          | General Purpose Pin 60.                                                                                                                                                                                                                                      |
| PORTF[5]       | I     | SCLK5 (Input)        | Input clock to MPSC5. Can be used as both transmit and receive clock.<br><b>NOTE:</b> This clock also serves as one of the input clocks to the Baud Rate Generators.                                                                                         |
|                |       | OSCLK5 (Out-<br>put) | Output clock from MPSC5. Can be used when SCLK5 is not needed (i.e. the MPSC is programmed to use one of the Baud Rate Generators as its clock source or is connected to one of the TDMs).                                                                   |
|                |       | TRSYNC3<br>(Input)   | Receive Frame Sync input to TDM channel3.                                                                                                                                                                                                                    |
|                |       | GPP61 (I/O)          | General Purpose Pin 61.                                                                                                                                                                                                                                      |
| PORTF[6]       | I/O   | TSCLK5<br>(Input)    | Input clock to MPSC5. Can be used by the MPSC transmitter<br>when separate receive and transmit clocks are needed.<br><b>NOTE:</b> This clock also serves as one of the input clocks to<br>the Baud Rate Generators.                                         |
|                |       | OTSCLK5<br>(Output)  | Output Tx clock from MPSC5. Can be used when TSCLK5 is<br>not needed (i.e. the MPSC is programmed to use one of the<br>Baud Rate Generators as its clock source or is connected to<br>one of the TDMs, or when there is no need for a separate Tx<br>clock). |
|                |       | TTCLK3<br>(Input)    | Transmit input clock to TDM channel3.                                                                                                                                                                                                                        |
|                |       | GPP62 (I/O)          | General Purpose Pin 62.                                                                                                                                                                                                                                      |



| Table 12: | LAN Pin Assignments |  |
|-----------|---------------------|--|
|-----------|---------------------|--|

| Pin Name                                                                                                                                        | Туре | Full Name                                               | Description                                                                                                                                                                                                                                                    |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Port MII0<br>NOTE: Port MII0 can be connected to MPSC6 and/or MPSC7. See Section 20. "Physical Signal Routing" on<br>page 414 for more details. |      |                                                         |                                                                                                                                                                                                                                                                |  |
|                                                                                                                                                 |      |                                                         | MPSC7, Port MII0 is connected to Ethernet 0 or used as GPP.<br>on page 405 for more details.                                                                                                                                                                   |  |
| MIIO[0]                                                                                                                                         | I/O  | MTXEN0 -<br>MII0 Transmit<br>Enable (Out-<br>put)       | Indicates that a packet is being transmitted to the PHY.<br>MTXEN0 is synchronous to MTXCLK0.                                                                                                                                                                  |  |
|                                                                                                                                                 |      | GPP64 (I/O)                                             | General Purpose Pin 64.                                                                                                                                                                                                                                        |  |
| MIIO[1]                                                                                                                                         | I/O  | MTXCLK0 -<br>MII0 Transmit<br>Clock (Input)             | Provides the timing reference for the transfer of the MTXEN0,<br>MTXD0 signals. It operates at either 25 MHz (100Mbps) or 2.5<br>MHz (10Mbps).                                                                                                                 |  |
|                                                                                                                                                 |      | TSCLK6<br>(Input)                                       | Input clock to MPSC6.<br>Can be used by the MPSC transmitter when separate receive<br>and transmit clocks are needed.<br><b>NOTE:</b> This clock also serves as one of the input clocks to the<br>Baud Rate Generators.                                        |  |
|                                                                                                                                                 |      | OTSCLK6<br>(Output)                                     | Output Tx clock from MPSC6.<br>Can be used when TSCLK6 is not needed (i.e. the MPSC is pro-<br>grammed to use one of the Baud Rate Generators as its clock<br>source or is connected to one of the TDMs, or when there is no<br>need for a separate Tx clock). |  |
|                                                                                                                                                 |      | GPP65 (I/O)                                             | General Purpose Pin 65.                                                                                                                                                                                                                                        |  |
| MII0[2]                                                                                                                                         | I/O  | MTXD0[3] -<br>MII0 Transmit<br>Data Bit [3]<br>(Output) | Data nibble bit [3] output to the external PHY device. Synchro-<br>nous to MTXCLK0.                                                                                                                                                                            |  |
|                                                                                                                                                 |      | RTS6* (Out-<br>put)                                     | Request to Send output from MPSC6. Indicates that MPSC6 is ready to transmit data.                                                                                                                                                                             |  |
|                                                                                                                                                 |      | GPP66 (I/O)                                             | General Purpose Pin 66.                                                                                                                                                                                                                                        |  |
| MII0[3]                                                                                                                                         | I/O  | MTXD0[2] -<br>MII0 Transmit<br>Data Bit [2]<br>(Output) | Data nibble bit [2] output to the external PHY device. Synchro-<br>nous to MTXCLK0.                                                                                                                                                                            |  |
|                                                                                                                                                 |      | TXD6 (Output)                                           | Serial transmit data output from the MPSC6.                                                                                                                                                                                                                    |  |
|                                                                                                                                                 |      | GPP67 (I/O)                                             | General Purpose Pin 67.                                                                                                                                                                                                                                        |  |

| Pin Name      | Туре     | Full Name                                               | Description                                                                                                                                                                                                                                                  |
|---------------|----------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port MII0 (Co | ntinued) |                                                         |                                                                                                                                                                                                                                                              |
| MII0[4]       | I/O      | MTXD0[1] -<br>MII0 Transmit<br>Data Bit [1]<br>(Output) | Data nibble bit [1] output to the external PHY device. Synchro-<br>nous to MTXCLK0.                                                                                                                                                                          |
|               |          | RTS7* (Out-<br>put)                                     | Request to Send output from MPSC7. Indicates that MPSC7 is ready to transmit data.                                                                                                                                                                           |
|               |          | GPP68 (I/O)                                             | General Purpose Pin 68.                                                                                                                                                                                                                                      |
| MII0[5]       | I/O      | MTXD0[0] -<br>MII0 Transmit<br>Data Bit [0]<br>(Output) | Data nibble bit [0] output to the external PHY device. Synchro-<br>nous to MTXCLK0.                                                                                                                                                                          |
|               |          | TXD7 (Output)                                           | Serial transmit data output from the MPSC7.                                                                                                                                                                                                                  |
|               |          | GPP69 (I/O)                                             | General Purpose Pin 69.                                                                                                                                                                                                                                      |
| MII0[6]       | I/O      | MCOL0 - MII0<br>Collision<br>detect (Input)             | Indicates that a collision has been detected on the wire.<br><b>NOTE:</b> This input is ignored in half - and full-duplex mode<br>mode when MTxEn0 is LOW. MCol0 is asynchronous.                                                                            |
|               |          | TSCLK7<br>(Input)                                       | Input clock to MPSC7.<br>Can be used by the MPSC transmitter when separate receive<br>and transmit clocks are needed.<br><b>NOTE:</b> This clock also serves as one of the input clocks to the<br>Baud Rate Generators.                                      |
|               |          | OTSCLK7<br>(Output)                                     | Output Tx clock from MPSC7. Can be used when TSCLK7 is<br>not needed (i.e. the MPSC is programmed to use one of the<br>Baud Rate Generators as its clock source or is connected to<br>one of the TDMs, or when there is no need for a separate Tx<br>clock). |
|               |          | GPP70 (I/O)                                             | General Purpose Pin 70.                                                                                                                                                                                                                                      |
| MII0[7]       | I/O      | MRXD0[3] -<br>MII0 Receive<br>Data Bit [3]<br>(Input)   | Data nibble bit [3] input from external PHY. Synchronous to MRXCLK0.                                                                                                                                                                                         |
|               |          | CTS6* (Input)                                           | Clear to Send input to MPSC6. Indicates to MPSC6 that data transmission may begin.                                                                                                                                                                           |
|               |          | GPP71 (I/O)                                             | General Purpose Pin 71.                                                                                                                                                                                                                                      |
| MII0[8]       | I/O      | MRXD0[2] -<br>MII0 Receive<br>Data Bit [2]<br>(Input)   | Data nibble bit [2] input from external PHY. Synchronous to MRXCLK0.                                                                                                                                                                                         |
|               |          | RXD6 (Input)                                            | Serial receive data input to MPSC6.                                                                                                                                                                                                                          |
|               |          | GPP72 (I/O)                                             | General Purpose Pin 72.                                                                                                                                                                                                                                      |



| Pin Name      | Туре     | Full Name                                             | Description                                                                                                                                                                                                                                                              |
|---------------|----------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port MII0 (Co | ntinued) |                                                       |                                                                                                                                                                                                                                                                          |
| MII0[9]       | I/O      | MRXD0[1] -<br>MII0 Receive<br>Data Bit [1]<br>(Input) | Data nibble bit [1] input from external PHY. Synchronous to MRXCLK0.                                                                                                                                                                                                     |
|               |          | CTS7* (Input)                                         | Clear to Send input to MPSC7. Indicates to MPSC7 that data transmission may begin.                                                                                                                                                                                       |
|               |          | GPP73 (I/O)                                           | General Purpose Pin 73.                                                                                                                                                                                                                                                  |
| MII0[10]      | I/O2     | MRXD0[0] -<br>MII0 Receive<br>Data Bit [0]<br>(Input) | Data nibble bit [0] input from external PHY. Synchronous to MRXCLK0.                                                                                                                                                                                                     |
|               |          | RXD7 (Input)                                          | Serial receive data input to MPSC7.                                                                                                                                                                                                                                      |
|               |          | GPP74 (I/O)                                           | General Purpose Pin 74.                                                                                                                                                                                                                                                  |
| MII0[11]      | I/O      | MRXER0 -<br>MII0 Receive<br>Error (Input)             | Indicates that an error was detected in the received frame. This input is ignored when MRXDV0 is inactive.                                                                                                                                                               |
|               |          | CD6 (Input)                                           | Carrier Detect input to MPSC6. Indicates to MPSC6 that it can begin reception of data.                                                                                                                                                                                   |
|               |          | GPP75 (I/O)                                           | General Purpose Pin 75.                                                                                                                                                                                                                                                  |
| MII0[12]      | I/O      | MRXCLKO<br>(Input)                                    | <ul> <li>Provides the timing reference for the transfer of the MRXDV0, MRXD0 and MRXER0 signals. Operates at either 25 MHz (100Mbps) or 2.5 MHz (10Mbps).</li> <li><b>NOTE:</b> The nominal frequency of MRXCLK0 must match the nominal frequency of MTXCLK0.</li> </ul> |
|               |          | SCLK6 (Input)                                         | Input clock to MPSC6.<br>Can be used as both transmit and receive clock.<br><b>NOTE:</b> This clock also serves as one of the input clocks to the<br>Baud Rate Generators.                                                                                               |
|               |          | OSCLK6 (Out-<br>put)                                  | Output clock from MPSC6.<br>Can be used when SCLK6 is not needed (i.e. the MPSC is pro-<br>grammed to use one of the Baud Rate Generators as its clock<br>source or is connected to one of the TDMs).                                                                    |
|               |          | GPP76 (I/O)                                           | General Purpose Pin 76.                                                                                                                                                                                                                                                  |

 Table 12:
 LAN Pin Assignments (Continued)

| Pin Name      | Туре     | Full Name                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|----------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port MII0 (Co | ntinued) |                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| MII0[13]      | I/O      | MRXDV0 -<br>MII0 Receive<br>Data Valid<br>(Input) | Indicates that valid data is present on RXD0 lines. Synchronous to MRXCLK0.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               |          | SCLK7 (Input)                                     | Input clock to MPSC7.<br>Can be used as both transmit and receive clock.<br><b>NOTE:</b> This clock also serves as one of the input clocks to the<br>Baud Rate Generators.                                                                                                                                                                                                                                                                                                                                                         |
|               |          | OSCLK7 (Out-<br>put)                              | Output clock from MPSC7. Can be used when SCLK7 is not needed (i.e. the MPSC is programmed to use one of the Baud Rate Generators as its clock source or is connected to one of the TDMs).                                                                                                                                                                                                                                                                                                                                         |
|               |          | GPP77 (I/O)                                       | General Purpose Pin 77.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| MII0[14]      | I/O      | MCRS0 - MII0<br>Carrier Sense<br>(Input)          | In half duplex mode, indicates that either the transmit or receive medium is non-idle.<br><b>NOTE:</b> MCRS0 is ignored in full-duplex.                                                                                                                                                                                                                                                                                                                                                                                            |
|               |          | CD7 (Input)                                       | Carrier Detect input to MPSC7. Indicates to MPSC7 that it can begin reception of data.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               |          | GPP78 (I/O)                                       | General Purpose Pin 78.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Port MII1     |          |                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| MII1[0]       | I/O      | MTXEN1 -<br>MII1 Transmit<br>Enable (Out-<br>put) | Indicates that a packet is being transmitted to the PHY.<br>MTXEN1 is synchronous to MTXCLK1.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               |          | GPP80 (I/O)                                       | General Purpose Pin 80.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|               |          | RMTXEN1<br>(Output)                               | Transmit enable for Ethernet port 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| MII1[1]       | I/O      | MTXCLK1 -<br>MII1 Transmit<br>Clock (Input)       | <ul> <li>Provides the timing reference for the transfer of the MTXEN1,<br/>MTXD1 signals. It operates at either 25 MHz (111Mbps) or 2.5<br/>MHz (11Mbps).</li> <li><b>NOTE:</b> Port MII1 can be connected to Ethernet 1. See Section<br/>20. "Physical Signal Routing" on page 414 for more<br/>details.<br/>When not connected to Ethernet 1, Port MII1 is con-<br/>nected to Ethernet 0 and Ethernet 1 RMII interfaces or<br/>used as GPP. See Section 19. "General Purpose<br/>Ports" on page 405 for more details.</li> </ul> |
|               |          | GPP81 (I/O)                                       | General Purpose Pin 81.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|               |          | RM50CLK<br>(input)                                | RMII clock input (50MHz)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |



| Pin Name      | Туре                  | Full Name                                               | Description                                                                                                                                                                 |
|---------------|-----------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port MII1 (Co | ntinued)              |                                                         |                                                                                                                                                                             |
| MII1[2]       | I/O                   | MTXD1[3] -<br>MII1 Transmit<br>Data Bit [3]<br>(Output) | Data nibble bit [3] output to the external PHY device. Synchro-<br>nous to MTXCLK1.                                                                                         |
|               |                       | GPP82 (I/O)                                             | General Purpose Pin 82.                                                                                                                                                     |
|               |                       | RMTXD0[1]<br>(Output)                                   | RMII transmit data bit [1] for port 0.                                                                                                                                      |
| MII1[3]       | I/O                   | MTXD1[2] -<br>MII1 Transmit<br>Data Bit [2]<br>(Output) | Data nibble bit [2] output to the external PHY device. Synchro-<br>nous to MTXCLK1.                                                                                         |
|               |                       | GPP83 (I/O)                                             | General Purpose Pin 83.                                                                                                                                                     |
|               |                       | RMTXD0[0]<br>(Output)                                   | RMII transmit data bit [0] for port 0.                                                                                                                                      |
| MII1[4]       | I/O                   | MTXD1[1] -<br>MII1 Transmit<br>Data Bit [1]<br>(Output) | Data nibble bit [1] output to the external PHY device. Synchro-<br>nous to MTXCLK1.                                                                                         |
|               |                       | GPP84 (I/O)                                             | General Purpose Pin 84.                                                                                                                                                     |
|               | RMTXD1[1]<br>(Output) | RMII transmit data bit [1] for port 1.                  |                                                                                                                                                                             |
| MII1[5]       | 111[5] I/O            | MTXD1[0] -<br>MII1 Transmit<br>Data Bit [0]<br>(Output) | Data nibble bit [0] output to the external PHY device. Synchro-<br>nous to MTXCLK1.                                                                                         |
|               |                       | RMTXD1[0]<br>(Output)                                   | RMII transmit data bit [0] for port 1.                                                                                                                                      |
|               |                       | GPP85 (I/O)                                             | General Purpose Pin 85.                                                                                                                                                     |
| MII1[6]       | I/O                   | MCOL1 - MII1<br>Collision<br>detect (Input)             | Indicates that a collision has been detected on the wire.<br><b>NOTE:</b> This input is ignored in half- and full-duplex mode when<br>MTxEn1 is LOW. MCol1 is asynchronous. |
|               |                       | GPP86 (I/O)                                             | General Purpose Pin 86.                                                                                                                                                     |
|               |                       | RMTXEN0<br>(Output)                                     | RMII transmit enable for Ethernet port 0.                                                                                                                                   |

 Table 12:
 LAN Pin Assignments (Continued)

| Pin Name      | Туре     | Full Name                                             | Description                                                                                                                |
|---------------|----------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| Port MII1 (Co | ntinued) |                                                       |                                                                                                                            |
| MII1[7]       | I/O      | MRXD1[3] -<br>MII1 Receive<br>Data Bit [3]<br>(Input) | Data nibble bit [3] input from external PHY. Synchronous to MRXCLK1.                                                       |
|               |          | GPP87 (I/O)                                           | General Purpose Pin 87.                                                                                                    |
|               |          | RMRXD0[1]<br>(Input)                                  | RMII receive data bit [1] for port 0.                                                                                      |
| MII1[8]       | I/O      | MRXD1[2] -<br>MII1 Receive<br>Data Bit [2]<br>(Input) | Data nibble bit [2] input from external PHY. Synchronous to MRXCLK1.                                                       |
|               |          | GPP88 (I/O)                                           | General Purpose Pin 88.                                                                                                    |
|               |          | RMRXD0[0]<br>(Input)                                  | RMII receive data bit [0] for port 0.                                                                                      |
| MII1[9]       | I/O      | MRXD1[1] -<br>MII1 Receive<br>Data Bit [1]<br>(Input) | Data nibble bit [1] input from external PHY. Synchronous to MRXCLK1.                                                       |
|               |          | GPP89 (I/O)                                           | General Purpose Pin 89.                                                                                                    |
|               |          | RMRXD1[1]<br>(Input)                                  | RMII receive data bit [1] for port 1.                                                                                      |
| MII1[10]      | I/O      | MRXD1[0] -<br>MII1 Receive<br>Data Bit [0]<br>(Input) | Data nibble bit [0] input from external PHY. Synchronous to MRXCLK1.                                                       |
|               |          | GPP90 (I/O)                                           | General Purpose Pin 90.                                                                                                    |
|               |          | RMRXD1[0]<br>(Input)                                  | RMII receive data bit [0] for port 1.                                                                                      |
| MII1[11]      | I/O      | MRXER1 -<br>MII1 Receive<br>Error (Input)             | Indicates that an error was detected in the received frame.<br><b>NOTE:</b> This input is ignored when MRXDV1 is inactive. |
|               |          | GPP91 (I/O)                                           | General Purpose Pin 91.                                                                                                    |



| Pin Name       | Туре     | Full Name                                          | Description                                                                                                                                                                                                                                                                          |
|----------------|----------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port MII1 (Cor | ntinued) |                                                    |                                                                                                                                                                                                                                                                                      |
| MII1[12]       | I/O      | MRXCLK1 -<br>MII1 Receive<br>Clock (Input)         | <ul> <li>Provides the timing reference for the transfer of the MRXDV1,<br/>MRXD1 and MRXER1 signals. Operates at either 25 MHz<br/>(111Mbps) or 2.5 MHz (11Mbps).</li> <li><b>NOTE:</b> The nominal frequency of MRXCLK1 must match the<br/>nominal frequency of MTXCLK1.</li> </ul> |
|                |          | GPP92 (I/O)                                        | General Purpose Pin 92.                                                                                                                                                                                                                                                              |
| MII1[13]       | I/O      | MRXDV1 -<br>MII1 Receive<br>Data Valid<br>(Input)  | Indicates that valid data is present on RXD1 lines. Synchronous to MRXCLK1.                                                                                                                                                                                                          |
|                |          | GPP93 (I/O)                                        | General Purpose Pin 93.                                                                                                                                                                                                                                                              |
|                |          | RMCRSDV1<br>(Input)                                | RMII CRS_DV for port 1.                                                                                                                                                                                                                                                              |
| MII1[14]       | I/O      | MCRS1 - MII1<br>Carrier Sense<br>(Input)           | In half-duplex mode, indicates that either the transmit or receive medium is non-idle. MCRS1 is ignored in full-duplex.                                                                                                                                                              |
|                |          | GPP94 (I/O)                                        | General Purpose Pin 94.                                                                                                                                                                                                                                                              |
|                |          | RMCRSDV0<br>(Input)                                | RMII CRS_DV for port 0.                                                                                                                                                                                                                                                              |
| Port MDC and   | I MDIO   |                                                    |                                                                                                                                                                                                                                                                                      |
| MDC            | 0        | MII Manage-<br>ment Inter-<br>face Clock<br>Signal | MII management serial data transfers are clocked by this clock output.                                                                                                                                                                                                               |
| MDIO           | I/O      | MII Manage-<br>ment Inter-<br>face Data<br>Signal  | MII management serial data to and from the PHYs is transmitted on this line.                                                                                                                                                                                                         |
| LAN total: 32  |          |                                                    |                                                                                                                                                                                                                                                                                      |

 Table 12:
 LAN Pin Assignments (Continued)

| Table 13: | GPP Pin | Assignments |
|-----------|---------|-------------|
|-----------|---------|-------------|

| Pin Name | Туре | Full Name     | Description                                                            |
|----------|------|---------------|------------------------------------------------------------------------|
| GPP[0]   | I/O  | BCLK0 (Input) | One of the input clocks that can be used for the Baud Rate Generators. |
|          |      | GPP0 (I/O)    | General purpose I/O pin for system use.                                |

| Pin Name | Туре | Full Name            | Description                                                            |
|----------|------|----------------------|------------------------------------------------------------------------|
| GPP[1]   | I/O  | BCLK1 (Input)        | One of the input clocks that can be used for the Baud Rate Generators. |
|          |      | GPP1 (I/O)           | General purpose I/O pin for system use.                                |
| GPP[2]   | I/O  | BRGO0 (Out-<br>put)  | Baud Rate Generator's output (from Baud Rate Generator 0).             |
|          |      | GPP2 (I/O)           | General purpose I/O pin for system use.                                |
| GPP[3]   | I/O  | BRGO1 (Out-<br>put)  | Baud Rate Generator's output (from Baud Rate Generator 1).             |
|          |      | GPP3 (I/O)           | General purpose I/O pin for system use.                                |
| GPP[4]   | I/O  | TRCLK0<br>(Input)    | Input receive clock to TDM channel0.                                   |
|          |      | GPP4 (I/O)           | General purpose I/O pin for system use.                                |
| GPP[5]   | I/O  | TRCLK1<br>(Input)    | Input receive clock to TDM channel1.                                   |
|          |      | GPP5 (I/O)           | General purpose I/O pin for system use.                                |
| GPP[6]   | I/O  | TRCLK2<br>(Input)    | Input receive clock to TDM channel2.                                   |
|          |      | OTSCLK4<br>(Output)  | Output Tx clock from MPSC4.                                            |
|          |      | GPP6 (I/O)           | General purpose I/O pin for system use.                                |
| GPP[7]   | I/O  | TRCLK3<br>(Input)    | Input receive clock to TDM channel3.                                   |
|          |      | OTSCLK5<br>(Output)  | Output Tx clock from MPSC5.                                            |
|          |      | GPP7 (I/O)           | General purpose I/O pin for system use.                                |
| GPP[8]   | I/O  | TOCLK0 (Out-<br>put) | Output clock from TDM channel0.                                        |
|          |      | GPP8 (I/O)           | General purpose I/O pin for system use.                                |
| GPP[9]   | I/O  | TOCLK1 (Out-<br>put) | Output clock from TDM channel1.                                        |
|          |      | GPP9 (I/O)           | General purpose I/O pin for system use.                                |
| GPP[10]  | I/O  | TOCLK2 (Out-<br>put) | Output clock from TDM channel2.                                        |
|          |      | OTSCLK2<br>(Output)  | Output Tx clock from MPSC2.                                            |
|          |      | GPP10 (I/O)          | General purpose I/O pin for system use.                                |

| Table 13: | GPP Pin Assignments (Continued) |
|-----------|---------------------------------|
|-----------|---------------------------------|



| Pin Name      | Туре   | Full Name            | Description                                                                                                                                                                                                                                       |
|---------------|--------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPP[11]       | I/O    | TOCLK3 (Out-<br>put) | Output clock from TDM channel3.                                                                                                                                                                                                                   |
|               |        | OTSCLK3<br>(Output)  | Output Tx clock from MPSC3.                                                                                                                                                                                                                       |
|               |        | GPP11 (I/O)          | General purpose I/O pin for system use.                                                                                                                                                                                                           |
| GPP[12]       | I/O/OD |                      | A general purpose I/O pin for system use.<br>When configured as functional output, this pin features an<br>open-drain output.<br><b>NOTE:</b> See Section 19. "General Purpose Ports" on page 405<br>for details about GPP configuration options. |
| GPP[13]       | I/O/OD |                      | A general purpose I/O pin for system use.<br>When configured as functional output, this pin features an<br>open-drain output.<br><b>NOTE:</b> See Section 19. "General Purpose Ports" on page 405<br>for details about GPP configuration options. |
| GPP[14]       | I/O    |                      | A general purpose I/O pin for system use.                                                                                                                                                                                                         |
| GPP[15]       | I/O    |                      | A general purpose I/O pin for system use.                                                                                                                                                                                                         |
| GPP Total: 16 |        |                      |                                                                                                                                                                                                                                                   |

Table 13: GPP Pin Assignments (Continued)

#### Table 14: Interrupt Interface Pin Assignments

| Pin Name           | Туре               | Full Name            | Description                                                                                                                                                                                                                       |  |
|--------------------|--------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Interrupt0*        | I/O                | Interrupt0           | Driven by the GT-96100A to signal that one (or more) of the internal (unmasked) interrupt sources within the GT-96100A is set.                                                                                                    |  |
| Interrupt1*        | OD                 | Interrupt1           | Driven by the GT-96100A to signal that one (or more) of the internal (unmasked) interrupt sources within the GT-96100A is set.<br>This pin features an open-drain output.                                                         |  |
| SerInt0*           | I/O                | Serial<br>Interrupt0 | Driven by the GT-96100A to signal that one (or more) of the internal (unmasked) SERIAL interrupt sources within the GT-96100A is set. This signal is dedicated only to interrupt events that occur within the communication unit. |  |
| SerInt1*           | I/O                | Serial<br>Interrupt1 | Driven by the GT-96100A to signal that one (or more) of the internal (unmasked) SERIAL interrupt sources within the GT-96100A is set. This signal is dedicated only to interrupt events that occur within the communication unit. |  |
| Interrupt Total: 4 | Interrupt Total: 4 |                      |                                                                                                                                                                                                                                   |  |

| Pin Name          | Туре | Full Name                               | Description                                                                     |
|-------------------|------|-----------------------------------------|---------------------------------------------------------------------------------|
| WDE*              | I/O  | Watchdog<br>Expired (Out-<br>put)       | Asserts to indicate that the watchdog timer in the GT-96100A expired.           |
| NMI*              | I/O  | Non Maskable<br>Interrupt (Out-<br>put) | Asserted by the GT-96100A to indicate that a non maskable interrupt is pending. |
| Watchdog Total: 2 |      |                                         |                                                                                 |

 Table 15:
 Watchdog Interface Pin Assignments

### Table 16: Test Interface Pin Assignments

| <b></b>       |      |                           |                                                                                                                                                                   |
|---------------|------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Name      | Туре | Full Name                 | Description                                                                                                                                                       |
| JTAG[0]       | I    | TCLK - JTAG<br>Clock      | Input clock for test logic. TMS and TDI are received on the ris-<br>ing edge, TDO is driven from the falling edge. This signal deter-<br>mines the shifting rate. |
| JTAG[1]       | I    | TMS - JTAG<br>Mode Select | A broadcast test signal that controls test logic operation.                                                                                                       |
| JTAG[2]       | I    | TDI - JTAG<br>Data In     | Serial data input.                                                                                                                                                |
| JTAG[3]       | 0    | TDO - JTAG<br>Data Out    | Serial data output. Tristate changes on negative change of JTCLK.                                                                                                 |
| JTAG[4]       | I    | TRST - JTAG<br>RESET      | Asynchronous reset to the JTAG controller.                                                                                                                        |
| TEST Total: 5 |      | •                         |                                                                                                                                                                   |

| Table 17: | Clock/Control | Interface | Pin | Assignments |
|-----------|---------------|-----------|-----|-------------|
|-----------|---------------|-----------|-----|-------------|

| Pin Name  | Туре | Full Name   | Description                                                                                                                                                         |
|-----------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TClk      | Ι    | Clock       | Master clock input to the GT-96100A (up to 100MHz). TClk is used for the SysAD interface and the Device interface. TClk must be driven for <b>ALL</b> applications. |
| Reset*    | I    | Reset       | Must be asserted for any reset sequence.                                                                                                                            |
| VccPLL    | I    | Vcc for PLL | Used for supplying a low-noise power to the internal PLL.                                                                                                           |
| VssPLL    | I    | Vss for PLL | Used for supplying a low-noise ground to the internal PLL.                                                                                                          |
| ByPassPLL | I    | ByPass PLL  | This is used for PLL bypass mode:<br>0 - PLL is not bypassed (normal mode)<br>1 - PLL is bypassed                                                                   |



| Pin Name         | Туре   | Full Name                | Description                                                                                                                                                                                           |
|------------------|--------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OutModePLL       | I      | Output Mode<br>PLL Clock | This pin controls the clock output function of the PLL:<br>0 - PLL generated clock is driven on ClkOutPLL pin.<br>1 - PLL generated clock is not driven out (i.e. ClkOutPLL pin is<br>in hi-z state). |
| ClkOutPLL        | 0      | Clock Output<br>for PLL  | This pin is used for driving the PLL generated clock. To enable this pin, the OutModePLL pin must be pulled low.                                                                                      |
| Clock/Control To | tal: 7 | ·                        |                                                                                                                                                                                                       |

 Table 17:
 Clock/Control Interface Pin Assignments (Continued)



## 3. Address Space Decoding

The GT-96100A has a fully programmable address map. Two address spaces exist: the CPU address space and the PCI address space (see Figure 2.) Both address maps use a two-stage decoding process where major device regions are decoded first, then the individual devices are subdecoded.







### 3.1 Two Stage Decoding Process

The system resources are divided into the following groups:

- SCS[1:0]\*
- SCS[3:2]\*
- CS[2:0]\*
- CS[3] & BootCS\*
- Internal Registers
- PCI 0 I/O
- PCI\_0 Memory0/1
- PCI 1 I/O
- PCI\_1 Memory0/1

# **NOTE:** PCI\_1 I/0 and PCI\_1 Memory0/1 will only exist if the GT-96100A is configured for both PCI\_0 and PCI\_1.

Each group can have a minimum of 2 Mbytes and a maximum of 4 Gbytes of address space. The individual devices in the device groups are further sub decoded to 1 Mbyte resolution. Table 18 shows the CPU decode and device sub-decode associations. Table 19 shows the same process for PCI\_0 and Table 20 shows the process for PCI\_1.

| CPU Decoder      | Associated Device Sub-Decoders                                                        |
|------------------|---------------------------------------------------------------------------------------|
| SCS[1:0]*        | SCS[0]*<br>SCS[1]*                                                                    |
| SCS[3:2]*        | SCS[2]*<br>SCS[3]*                                                                    |
| CS[2:0]*         | CS0*<br>CS1*<br>CS2*                                                                  |
| BootCS*/CS3*     | BootCS*<br>CS3*                                                                       |
| PCI_0 I/O        | None.<br>Accesses decoded for PCI_0 I/O are bridged to PCI_0 I/O transfers.           |
| PCI_0 Memory 0/1 | None.<br>Accesses decoded for PCI_0 Memory 0/1 are bridged to PCI Memory transfers.   |
| PCI_1 I/O        | None.<br>Accesses decoded for PCI_1 I/O are bridged to PCI_1 I/O transfers.           |
| PCI_1 Memory 0/1 | None.<br>Accesses decoded for PCI_1 Memory 0/1 are bridged to PCI_1 Memory transfers. |
| Internal         | None.<br>Decodes to the GT-96100A internal registers.                                 |

 Table 18:
 CPU and Device Decoder Mappings

| PCI Base Address Register (BAR)<br>Decoder <sup>1</sup> | Associated Device Sub-Decoders                                                |
|---------------------------------------------------------|-------------------------------------------------------------------------------|
| SCS[1:0] *                                              | SCS0*                                                                         |
| - BAR 0 at 0x10                                         | SCS1*                                                                         |
| SCS[3:2]*                                               | SCS2*                                                                         |
| - BAR 1 at 0x14                                         | SCS3*                                                                         |
| CS[2:0]*<br>- BAR 2 at 0x18                             | CS0*<br>CS1*<br>CS2*                                                          |
| BootCS*/CS3*                                            | BootCS*                                                                       |
| - BAR 3 at 0x1C                                         | Cs3*                                                                          |
| Internal Registers (Memory)<br>- BAR 4 at 0x20          | None<br>Decodes PCI_0 memory accesses to the GT-96100A<br>internal registers. |
| Internal Registers (I/O)                                | None.                                                                         |
| - BAR 5 at 0x24                                         | Decodes PCI_0 I/O accesses to the GT-96100A internal registers.               |
| Expansion ROM                                           | None.                                                                         |
| - BAR at 0x30                                           | Decodes directly to CS3*.                                                     |

| Table 19: PC | _0 Base Address | Register and Device | Decoder Mappings |
|--------------|-----------------|---------------------|------------------|
|--------------|-----------------|---------------------|------------------|

1. This mapping also applies to the swap BARs located in PCI function 1, if enabled.

| PCI Base Address Register (BAR)<br>Decoder <sup>1</sup> | Associated Device Sub-Decoders                                                 |
|---------------------------------------------------------|--------------------------------------------------------------------------------|
| SCS[1:0]*                                               | SCS0*                                                                          |
| - BAR 0 at 0x90                                         | SCS1*                                                                          |
| SCS[3:2]*                                               | SCS2*                                                                          |
| - BAR 1 at 0x94                                         | SCS3*                                                                          |
| CS[2:0]*<br>- BAR 2 at 0x98                             | CS0*<br>CS1*<br>CS2*                                                           |
| BootCS*/CS3*                                            | BootCS*                                                                        |
| - BAR 3 at 0x9C                                         | Cs3*                                                                           |
| Internal Registers (Memory)<br>- BAR 4 at 0xa0          | None.<br>Decodes PCI_1 memory accesses to the GT-96100A<br>internal registers. |

| PCI Base Address Register (BAR)<br>Decoder <sup>1</sup> | Associated Device Sub-Decoders                                  |
|---------------------------------------------------------|-----------------------------------------------------------------|
| Internal Registers (I/O)                                | None.                                                           |
| - BAR 5 at 0xa4                                         | Decodes PCI_1 I/O accesses to the GT-96100A internal registers. |

| Table 20: | PCI_1 Base | e Address Register a | and Device Decoder | <sup>r</sup> Mappings | (Continued) |
|-----------|------------|----------------------|--------------------|-----------------------|-------------|
|           |            |                      |                    |                       |             |

1. This mapping also applies to the swap BARs located in PCI function 1, if enabled.

### 3.1.1 CPU Side Decoding Process

Decoding on the CPU side starts with the SysAD address being compared with the values in the various CPU Low and High decoder registers. For example, the SCS[1:0]\* CPU High and Low decoder registers set the address range in which the SCS0\* and SCS1\* signals are active (i.e. where DRAM banks 0 and 1 are located.) The comparison works as follows:

- 1. Bits 35:32 of the SysAD address are compared against bits 14:11 in the various CPU Low decode registers. These values must match exactly. This effectively sets a 4 Gbyte "page" for the resource group.
- 2. Bits 31:21 of the SysAD address are compared against bits 10:0 in the various CPU Low decode registers. The value of the SysAD bits must be greater than or equal to the Low decode value. This sets the lower boundary for the region.
- 3. Bits 31:21 of the SysAD address are compared against the High decode registers. The value of the SysAD bits must be less than or equal to this value. This sets the upper bound for the region.
- 4. If all of the above are true, then the resource group is selected and a subdecode is performed to determine the specific resource.

An example of the CPU resource group decode process is shown in Figure 3.



#### Figure 3: CPU-Side Resource Group Decode Function and Example

'eq' equal to 'ge' greater or equal to 'le' less or equal to If the SysAD address is between the Low and the High decode addresses, then the access is passed to the Device Unit for sub-decode.

| 35 | 34 | 33 | 32 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | SysAD Address<br>Bits        |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------|
| eq | eq | eq | eq | ge |    | Low Processor<br>Decode Reg  |
|    |    |    |    | le |    | High Processor<br>Decode Reg |

Example: Set up a SysAD decode region that starts at 0xA.4000.0000 and is 512Mbytes in length (0xA.4000.0000 to 0xA.5FFF.FFFF):

| 35 | 34 | 33 | 32 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | SysAD Address<br>Bits        |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------|
| 1  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    | Low Processor<br>Decode Reg  |
|    |    |    | ,  | 0  | 1  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |    | High Processor<br>Decode Reg |

Once a CPU resource group has been decoded, it must be subdecoded to determine which physical device should be accessed within that group. This decoding is controlled by the device Low and High decode registers. The comparison works as follows:

- 1. Bits 31:20 of the SysAD address are compared against the relevant device Low decode registers. The value of the SysAD bits must be greater than or equal to the Low decode value. This sets the lower boundary for the sub-decode region.
- 2. Bits 31:20 of the SysAD address are compared against the relevant device High decode registers. The value of the SysAD bits must be less than or equal to this value. This sets the upper bound for the sub-decode region.
- 3. If all of the above are true, then the specific device is selected and an access to that device is performed.

Figure 4 illustrates the device decode process that occurs after the CPU resource group has been decoded.





#### Figure 4: Device Sub-Decode Function and Example

Example: Using the previous CPU decode example (0xA.4000.0000 to 0xA.5FFF.FFFF), place a device sub-decode in the first 384 Meg (0xA.4000.0000 to 0xA.57FF.FFFF).





### 3.1.2 PCI Side Decoding Process

Decoding on the PCI side starts with the PCI address being compared with the values in the various Base Address Registers. For example, the SCS[1:0]\* Base Address register sets the PCI base address range in which the SCS0\* and SCS1\* signals are active (i.e., where DRAM banks 0 and 1 are located in PCI space).

Once a resource group has been decoded by a BAR, it must be subdecoded to determine which physical device should be accessed within that group. This decoding is controlled by the Device Low and High decode registers.

**NOTE:** These registers are the same ones used for CPU-side decoding. This means that the PCI and SysAD memory maps are coupled at the device decoders. Address bits 31:20 (the bits compared by the Device decoders) for any given device overlap in both the PCI and SysAD maps.

The sub-decoding comparison works as follows:

- 1. Bits 31:20 of the PCI address are compared against bits the relevant device Low decode registers. The value of the PCI address bits must be greater than or equal to the Low decode value. This sets the lower boundary for the sub-decode region.
- 2. Bits 31:20 of the PCI address are compared against the relevant device's High decode registers. The value of the PCI address bits must be less than or equal to this value. This sets the upper bound for the sub-decode region.
- 3. If all of the above are true, the specific device is selected and an access to that device is performed.

Figure 5: Bank Size Register Function Example (16Meg Decode)

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 |                                      |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------|
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | Bank Size Reg                        |
| =  | =  | =  | =  | =  | =  | =  | =  | x  | x  | x  | x  | x  | x  | x  | x  | x  | x  | x  | x  | Comparison<br>against PCI<br>address |

'=' must match exactly 'x' don't care



### 3.2 Disabling Address Decoders

CPU interface address decoders can be disabled by setting the Low decoder value higher than the High decoder value.

Device sub-decoder can be disabled by setting the Low decoder value higher than the High decoder value.

PCI address decoders can be disabled by setting the BAR's corresponding bit in Base Address registers' Enable to 1.

### 3.3 DMA Unit Address Decoding

The IDMA controller uses the address mapping of the CPU interface.

**NOTE:** CPU interface address mapping to determine whether the source address is located in one of the SDRAM banks, Device banks, PCI\_0 or PCI\_1. The same is true for destination address and next record address.DMA address decoding is only up to address bit [31]. Bits [35:32] of CPU address decoding registers are ignored.

### 3.4 Address Space Decoding Errors

When the CPU tries to access an address from the SysAD that is not supported, the GT-96100A:

- Latches the address into the Bus Error Address registers (offsets 0x70,0x78).
- Issues a bus error (over SysCmd[5]), if the access was a read access.
- Issues an interrupt, if the access was a read or write access.

This feature is useful during software debugging, when errant code can cause fetches from unsupported addresses.

When SysAD matches one of CPU interface address spaces, but misses the associated subdecoders, the GT-96100A:

- Issues a bus error (over SysCmd[5]), if the access was a read access.
- Sets the MemOut bit in the Interrupt Cause register.

When a PCI access hits in a Base Address register then misses in the associated subdecoders:

- Random data is returned on a read and write data is discarded.
- Latches the address into the Address Decode Error register (offset 0x470).
- The MemOut bit in the Interrupt Cause register is also set.

Accesses that miss all of the GT-96100A BARs result in no response at all from the GT-96100A.

When a DMA accesses an unmapped address, DMAOut bit in the interrupt Cause register is set.

**NOTE:** Never program address space decoders to overlap. Programming address space decoders to overlap results in unpredictable behavior.

## 3.5 Default Memory Map

The default CPU memory map that is valid following RESET is shown in Table 21. The default PCI map and BAR sizing information is shown in Table 22 and Table 23.

Table 21: CPU and Device Decoder Default Address Mapping

| CPU Decode<br>Range and Size                   | Resource<br>Group       | Device Decode<br>Range and Size                                                  | Device<br>Selected      |
|------------------------------------------------|-------------------------|----------------------------------------------------------------------------------|-------------------------|
| 0x0 to 0x0.00FF.FFFF<br>16 Megabytes           | SCS[1:0]*               | 0x0 to 0x0.007F.FFFF<br>8 Megabytes                                              | SCS0*                   |
|                                                |                         | 0x0.0080.0000 to 0x0.00FF.FFFF<br>8 Megabytes                                    | SCS1*                   |
| 0x0.0100.0000 to 0x0.01FF.FFFF<br>16 Megabytes | SCS[3:2]*               | 0x0.0100.0000 to 0x0.017F.FFFF<br>8 Megabytes                                    | SCS2*                   |
|                                                |                         | 0x0.0180.0000 to 0x0.01FF.FFFF<br>8 Megabytes                                    | SCS3*                   |
| 0x0.1400.0000 to 0x0.1400.0FFF<br>4 Kbytes     | Internal Regis-<br>ters | No subdecode.<br>Access bridged directly to the GT-<br>96100A internal registers | Internal Regis-<br>ters |
| 0x0.1000.0000 to 0x0.11FF.FFFF<br>32 Megabytes | PCI0 I/0                | No subdecode.<br>Access bridged directly to PCI I/0<br>space                     | PCI0                    |
| 0x0.1200.0000 to 0x0.13FF.FFFF<br>32 Megabytes | PCI0 Mem0               | No subdecode.<br>Access bridged directly to PCI<br>memory space                  | PC10                    |
| 0x0.1C00.0000 to 0x0.1E1F.FFFF<br>34 Megabytes | CS[2:0]                 | 0x0.1C00.0000 to<br>0x0.1C7F.FFFF<br>8 Megabytes                                 | CS0*                    |
|                                                |                         | 0x0.1C80.0000 to<br>0x0.1CFF.FFFF<br>8 Megabytes                                 | CS1*                    |
|                                                |                         | 0x0.1D00.0000 to<br>0x0.1DFF.FFFF<br>16 Megabytes                                | CS2*                    |
|                                                |                         | 0x0.1E00.0000 to<br>0x0.1E1F.FFFF not accessible                                 |                         |
| 0x0.1F00.0000 to 0x0.1FFF.FFFF<br>16 Megabytes | CS[3] and<br>BootCS*    | 0x0.1F00.0000 to<br>0x0.1FBF.FFFF<br>12 Megabyte                                 | CS3*                    |
|                                                |                         | 0x0.1FC0.0000 to<br>0x0.1FFF.FFFF<br>4 Megabytes                                 | BootCS*                 |

| CPU Decode<br>Range and Size                   | Resource<br>Group | Device Decode<br>Range and Size                                 | Device<br>Selected |
|------------------------------------------------|-------------------|-----------------------------------------------------------------|--------------------|
| 0x0.F200.0000 to 0x0.F3FF.FFFF<br>32 Megabytes | PCI0 Mem1         | No subdecode.<br>Access bridged directly to PCI<br>memory space | PCI0               |
| 0x0.2000.0000 to 0x0.21FF.FFFF<br>32 Megabytes | PCI1 I/0          | No subdecode<br>Access bridged directly to PCI I/<br>O space    | PCI1               |
| 0x0.2200.0000 to 0x0.23FF.FFFF<br>32 Megabytes | PCI1 Mem0         | No subdecode.<br>Access bridged directly to PCI<br>memory space | PCI1               |
| 0x0.2400.0000 to 0x0.25FF.FFFF<br>32 Megabytes | PCI1 Mem1         | No subdecode.<br>Access bridged directly to PCI<br>memory space | PCI1               |

#### Table 22: PCI Function 0 and Device Decoder Default Address Mapping

| PCI Function 0 Decode<br>Range and Size                        | Resource<br>Group       | Device Decode<br>Range and Size                  | Device<br>Selected      |
|----------------------------------------------------------------|-------------------------|--------------------------------------------------|-------------------------|
| 0x0 to 0x0.00FF.FFFF<br>16 Megabytes in Memory Space           | SCS[1:0]*               | 0x0 to 0x0.007F.FFFF<br>8 Megabytes              | SCS0*                   |
|                                                                |                         | 0x0.0080.0000 to<br>0x0.00FF.FFFF<br>8 Megabytes | SCS1*                   |
| 0x0.0100.0000 to 0x0.01FF.FFFF<br>16 Megabytes in Memory Space | SCS[3:2]*               | 0x0.0100.0000 to<br>0x0.017F.FFFF<br>8 Megabytes | SCS2*                   |
|                                                                |                         | 0x0.0180.0000 to<br>0x0.01FF.FFFF<br>8 Megabytes | SCS3*                   |
| 0x0.1400.0000 to 0x0.1400.0FFF<br>4 Kbytes in Memory Space     | Internal Regis-<br>ters | No subdecode                                     | Internal Regis-<br>ters |
| 0x0.1400.0000 to 0x0.1400.0FFF<br>4 Kbytes in I/O Space        | Internal Regis-<br>ters | No subdecode.                                    | Internal Regis-<br>ters |



| PCI Function 0 Decode<br>Range and Size                                                 | Resource<br>Group       | Device Decode<br>Range and Size                                              | Device<br>Selected |
|-----------------------------------------------------------------------------------------|-------------------------|------------------------------------------------------------------------------|--------------------|
| 0x0.1C00.0000 to 0x0.1DFF.FFFF<br>32 Megabytes in Memory Space                          | CS[2:0]                 | 0x0.1C00.0000 to<br>0x0.1C7F.FFFF<br>8 Megabytes                             | CS0*               |
|                                                                                         |                         | 0x0.1C80.0000 to<br>0x0.1CFF.FFFF<br>8 Megabytes                             | CS1*               |
|                                                                                         |                         | 0x0.1D00.0000 to<br>0x0.1DFF.FFFF<br>16 Megabytes                            | CS2*               |
| 0x0.1F00.0000 to 0x0.1FFF.FFFF<br>16 Megabytes in Memory Space                          | CS[3] and<br>BootCS*    | 0x0.1F00.0000 to<br>0x0.1FBF.FFFF<br>12 Megabyte                             | CS3*               |
|                                                                                         |                         | 0x0.1FC0.0000 to<br>0x0.1FFF.FFFF<br>4 Megabytes                             | BootCS*            |
| 0x0.1F00.000 to 0x0.1FFF.FFFF<br>16 Megabytes (uses CS[3] and<br>BootCS* size register) | PCI<br>Expansion<br>ROM | No subdecode.<br>This decoder is used only during<br>PC BIOS initialization. | CS3*               |

#### Table 22: PCI Function 0 and Device Decoder Default Address Mapping (Continued)

# Table 23: PCI Function 1 (Byte Order Swap) and Device Decoder Default Address Mapping

| PCI Function 0 Decode<br>Range and Size                        | Resource<br>Group | Device Decode<br>Range and Size                  | Device<br>Selected |
|----------------------------------------------------------------|-------------------|--------------------------------------------------|--------------------|
| 0x0 to 0x0.00FF.FFFF<br>16 Megabytes in Memory Space           | SCS[1:0]*         | 0x0 to 0x0.007F.FFFF<br>8 Megabytes              | SCS0*              |
|                                                                |                   | 0x0.0080.0000 to<br>0x0.00FF.FFFF<br>8 Megabytes | SCS1*              |
| 0x0.0100.0000 to 0x0.01FF.FFFF<br>16 Megabytes in Memory Space | SCS[3:2]*         | 0x0.0100.0000 to<br>0x0.017F.FFFF<br>8 Megabytes | SCS2*              |
|                                                                |                   | 0x0.0180.0000 to<br>0x0.01FF.FFFF<br>8 Megabytes | SCS3*              |



| PCI Function 0 Decode<br>Range and Size                        | Resource<br>Group     | Device Decode<br>Range and Size                  | Device<br>Selected |
|----------------------------------------------------------------|-----------------------|--------------------------------------------------|--------------------|
| 0x0.1F00.0000 to 0x0.1FFF.FFFF<br>16 Megabytes in Memory Space | CS[3]* and<br>BootCS* | 0x0.1F00.0000 to<br>0x0.1FBF.FFFF<br>12 Megabyte | CS3*               |
|                                                                |                       | 0x0.1FC0.0000 to<br>0x0.1FFF.FFFF<br>4 Megabytes | BootCS*            |

# Table 23: PCI Function 1 (Byte Order Swap) and Device Decoder Default Address Mapping (Continued)

### 3.6 Address Remapping

The GT-96100A supports address remapping on both the CPU interface and the PCI interfaces.

**NOTE:** Although the IDMA controllers use the CPU address decode registers, the source and destination DMA addresses are NEVER remapped.

### 3.6.1 CPU Address Remapping

The resources that can be addressed by the CPU are the following:

- SDRAM banks (SCS[1:0]\*, SCS[3:2]\*)
- Devices (CS[2:0]\*, CS[3]\* & BootCS\*)
- PCI\_0 IO
- PCI\_0 Memory0/1
- PCI\_1 IO
- PCI\_1 Memory0/1

**NOTE:** PCI\_1 IO and PCI\_1 Memory0/1 are only addressable if the device is configured for both PCI\_0 and PCI\_1 on RESET.

Each resource addressed by the CPU has a Remap register associated with it. These registers are listed in Section 4.10.2 "CPU Address Decode Registers" on page 87.

An address presented on the SysAD bus by the CPU is decoded with the following steps:

- 1. Address bits [35:21] are checked for a hit in the CPU decoders.
- 2. Assuming there is a hit in the CPU decoders, the HIT address will have bits 35:32 discarded. Bits 20:0 are left unchanged. Bits[31:21] are remapped as follows: Going from the most significant bit (MSB) to least significant bit (LSB) of the HIT address bits [31:21], any bit found matching to its respective bit in the LOW decode register's bits [10:0] will cause the according bit in the remap register to REPLACE the original address bit. Upon first mismatch, all remaining LSBs of address bits[31:21] are unchanged.
- 3. Address bits [31:20] of the *remapped address* are checked to be a hit in the Device decoders.
- 4. Assuming there is a hit in the Device decoders, the HIT address will be transferred to the resource.

See Figure 6 outlining this address remapping procedure.

#### 







#### 3.6.2 Writing to Decode Registers

When a LOW decode register is written to, the least significant 11 bits are written to the associated remap register, simultaneously.

When a remap register is written to, only its contents are affected.

Following RESET, the default value of a remap register is equal to its associated LOW Decode register bits [10:0].

Unless a specific write operation to a remap register takes place, a 1:1 mapping is maintained. Also, changing a LOW Decode register's contents automatically returns its associated space to a 1:1 mapping. This allows for backward software compatibility with other Galileo Technology devices such as the GT-64010A and the GT-64011 core logic devices.

### 3.6.3 PCI Address Remapping

The PCI slave interface has the ability to remap addresses of PCI transactions to memory using PCI remap registers. There are seven registers for PCI\_0 and seven registers for PCI\_1, if implemented.

These registers correspond to the following PCI Base Address Registers:

- SCS[1:0]\*
- SCS[3:2]\*
- CS[2:0]\*
- CS[3]\* & BootCS\*
- Swapped SCS[1:0]\*
- Swapped SCS[3:2]\*
- Swapped CS[3]\* and BootCS\*

These registers are listed in the Register Section as part of PCI Internal Registers, Section 7.14.1 "PCI Internal Registers" on page 172. The offsets for these registers are 0xc48 - 0xc64. Each MAP register is 32-bits wide. Each MAP register is 32-bits wide, where bits [12:0] are Read Only.

When an address is presented on the PAD lines, the address decoder in the PCI slave compares the PCI address to its base/size registers. If there is a HIT in one of the seven Base Address registers listed above, then the address undergoes remapping in accordance to the right Remap register in the non-masked address bits (by size register). An example of this is summarized in Table 24.

Table 24: PCI Address Remapping Example

| PCI address                             | 0x1D98.7654 |
|-----------------------------------------|-------------|
| SCS[1:0]* BAR                           | 0x1F00.0000 |
| SCS[1:0]* Size                          | 0x03FF.FFFF |
| SCS[1:0]* Remap Register                | 0x3F00.0000 |
| Remapped PCI Address Presented to SDRAM | 0x3D98.7654 |



**NOTE:** The size register is programmed to 0x03FF.FFF. This indicates that this BAR requires a hit in the six MSB (bits 31:26) bits of the PCI address for their to be a hit in the BAR. Therefore, the PCI address 0x1DXX.XXXX is a hit in a BAR programmed to 0x1FXX.XXXX as bits 31-26 of both of these addresses is 0b0001.11.

Then according to the Remap register, these same bit locations will be remapped to 6b111111. The rest of the PCI address bits (i.e. [25:0]) remain unchanged. This means that the final PCI slave address will be 0x3D987654.

### 3.6.4 Writing to Decode Registers

When a BAR register is written to, the associated remap register is written to, simultaneously. When a remap register is written to, only its contents are affected.

Following RESET, the default value of a remap register is equal to its associated BAR decode register.

Unless a specific write operation to a remap register takes place, a 1:1 mapping is maintained. Also, changing a BAR register's contents automatically returns its associated space to a 1:1 mapping. This allows for backward software compatibility with other Galileo Technology devices such as the GT-64010A and the GT-64011 core logic devices.

## 3.7 Using the CPU PCI Override

In default, the CPU interface supports 512Mbyte PCI memory address space (256Mbyte on PCI\_0 Mem0, 256Mbyte on PCI\_0 Mem1). If configured to both PCI\_0 and PCI\_1, it supports 512Mbyte also on PCI\_1. The CPU PCI override feature enables larger PCI memory address space.

The CPU configuration register includes four PCI override bits - two bits per PCI\_0 and two bits per PCI\_1. Each bit pair controls whether the PCI window is 2Gbyte, 1Gbyte, or the default.

Setting the PCI override bits are set to '01', and SysAD bits[31:30] match bits [10:9] of the PCI Mem0 Low decode address register, the transaction is directed to PCI Mem0. This effectively sets a 1Gbyte window in the PCI memory address space.

**NOTE:** If Bits[31:30] do not match bits [10:9] of PCI Mem0 Low decode address register, the address is compared against all other address decode registers.

When PCI override bits are set to '10', and SysAD bit[31] matches bit [10] of the PCI Mem0 Low decode address register, the transaction is directed to PCI Mem0. This effectively sets a 2Gbyte window to PCI.

**NOTE:** If bit[31] does not match bit [10] of PCI Mem0 Low decode address register, the address is compared against all other address decode registers.

If PCI override bits are set to '00' there is no PCI override (default address decoding).



**NOTE:** When PCI override is enabled, there is no address remapping from the CPU to the PCI.

## 3.8 Using the DMA to PCI Bypass

In default, the IDMA controller uses CPU interface address decoding. However, the IDMA controller supports direct access to PCI bus, bypassing this address decoding.

In each of the four DMA channel control registers, there are six bits:

- Two bits per source address.
- Two bits per destination address.
- Two bits per next record address.

Each bit pair controls whether the address should be directed to PCI\_0 memory space, to PCI\_1 memory space, or run through CPU address decoding.



## 4. CPU INTERFACE DESCRIPTION

The GT-96100A SysAD bus interface allows the CPU to gain access to the GT-96100A's internal registers, PCI interface and the memory/device bus (AD bus). The SysAD bus supports accesses from one to 32 bytes in length.

The SysAD bus on the GT-96100A is a slave-only interface. The GT-96100A will never master the SysAD bus.

## 4.1 CPU Interface Signals

The CPU interface incorporates the following signals:

| Signal                            | Туре | Description                                                                                                                                                                                                    |
|-----------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SysAd[63:0] - Master Address/Data | I/O  | Transfers multiplexed address/data.                                                                                                                                                                            |
| SysCmd[8:0] - Master Port Command | I/O  | Transfers information about the access (read/write, size) and the data (good/bad, last word).                                                                                                                  |
| SysADC[7:0] - Master Data Check   | I/O  | An 8-bit bus containing parity for the SysAD bus.<br>SysADC is valid on data cycles only.                                                                                                                      |
| ValidOut*                         | I    | Indicates that the local master is driving valid address/data/command on the SysAD bus.                                                                                                                        |
| ValidIn*                          | 0    | Indicates that the GT-96100A is driving valid data/ command on the SysAD bus.                                                                                                                                  |
| WrRdy* <sup>1</sup>               | 0    | Indicates that the GT-96100A is capable of accept-<br>ing a write transaction up to eight 32-bit words in<br>length.                                                                                           |
| Release*                          | I    | Indicates to the GT-96100A that the local master<br>will not drive the SysAD after the current clock<br>cycle. For example, the local master is floating the<br>SysAD and SysCmd bus for completion of a read. |
| Interrupt*                        | 0    | An "OR" of all the internal interrupt sources on the GT-96100A.                                                                                                                                                |
| ScMatch                           | 1    | L2 cache Tag RAM hit indication.                                                                                                                                                                               |
| TcDOE*                            | 0    | L2 cache data RAM output enable. Asserted by the GT-96100A on L2 read hit.                                                                                                                                     |
| TcTCE*                            | 1    | L2 cache Tag RAM chip enable. Sampled by the GT-96100A to identify L2 access.                                                                                                                                  |
| TcWord[1:0]                       | 0    | L2 cache word index. Driven by theGT-96100A dur-<br>ing L2 read miss.                                                                                                                                          |

#### Table 25: CPU Interface Signals

1. There is no RdRdy\* signal output from the GT-96100A. This signal should be tied LOW on the CPU as the GT-96100A is always ready to accept a read command.



The SysAD bus is synchronous with respect to TClk and is locked with respect to the AD bus. The SysAD bus may be asynchronous with respect to the PCI bus or locked to the PCI bus for lower synchronization latency.

# 4.2 SysAD, SysADC, and SysCmd Buses

The SysAD and SysCmd bus protocol implemented by the GT-96100A is completely compatible with the 64-bit Orion bus protocol used by the IDT R4xxx, R5000, and R7000 processors. The GT-96100A extends this protocol to support bursts less than four 64-bit words. These extensions can be used by DMA engines on the SysAD bus for more efficient use of the interface.

The SysAD[63:0] bus is a 64-bit multiplexed address/data bus. The local CPU drives address for a single cycle then either drives data (for a write) or floats the bus in anticipation of returned data (for a read.)

SysADC[7:0] is valid during data cycles only. It provides parity information for data on the SysAD bus. SysADC has the same timing as SysAD.

The SysCmd[8:0] bus conveys the following information about the transaction:

- The direction (read/write).
- The size (byte, short, word, multi-word).
- The status of the data (good/bad/last.).

SysCmd is driven by the CPU (or other local master) during the address phase of a transaction (with direction/ size information) and for the duration of a write (with good/bad/last information.) The GT-96100A drives SysCmd during the data phase of read transactions.

The encodings for SysCmd[8:0] are shown in the tables below.

**NOTE:** Many encodings are not defined. These encodings are reserved and must not be used. A summary of bit usage is shown below.

| SysCmd Bit | Function                                                                                                                                                  |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| SysCmd[8]  | 0 = Transaction information (read/write/size)<br>1 = Data information (good/bad/last)                                                                     |
| SysCmd[7]  | Indicates last data/not last data during data cycles.<br><b>NOTE:</b> Must be 0 for address cycles.                                                       |
| SysCmd[6]  | <ul><li>0 = Read transaction during address cycles</li><li>1 = Write transaction during address cycles</li><li>NOTE: Must be 0 for data cycles.</li></ul> |
| SysCmd[5]  | Indicates error status for data cycles.<br>NOTE: Must be 0 for address cycles.                                                                            |

| Table 26 | · Sv | sCmd  | Rit S | Summary    |
|----------|------|-------|-------|------------|
|          | . 0, | Joina |       | Juiiiiai y |

| SysCmd Bit  | Function                                                                                                                                                                  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SysCmd[4]   | <ul> <li>0 = Check the Data &amp; Check-bits during data cycles</li> <li>1 = Do not check Data during data cycles</li> <li>NOTE: Must be 1 for address cycles.</li> </ul> |
| SysCmd[3:0] | Encoded to indicate size of the transfer during address cycles.<br>Reserved during data cycles.                                                                           |

## Table 26: SysCmd Bit Summary (Continued)

# Table 27: Address Phase SysCmd[8:0] Encodings (driven by CPU)

| SysCmd[8:0] Encoding <sup>1</sup> |   |   |   |   | od | ing | 1 |   |                     |                                               |
|-----------------------------------|---|---|---|---|----|-----|---|---|---------------------|-----------------------------------------------|
| 8                                 | 7 | 6 | 5 | 4 | 3  | 2   | 1 | 0 | Command<br>Mnemonic | Command Description                           |
| 0                                 | 0 | 0 | 0 | 1 | 1  | 0   | 0 | 0 | RdByte              | Read a single byte.                           |
| 0                                 | 0 | 0 | 0 | 1 | 1  | 0   | 0 | 1 | RdShort             | Read 16 bits.                                 |
| 0                                 | 0 | 0 | 0 | 1 | 1  | 0   | 1 | 0 | RdTriByte           | Read 3 bytes.                                 |
| 0                                 | 0 | 0 | 0 | 1 | 1  | 0   | 1 | 1 | RdWord              | Read 4 bytes (single word).                   |
| 0                                 | 0 | 0 | 0 | 1 | 1  | 1   | 0 | 0 | Rd5Byte             | Read 5 bytes.                                 |
| 0                                 | 0 | 0 | 0 | 1 | 1  | 1   | 0 | 1 | Rd6Byte             | Read 6 bytes.                                 |
| 0                                 | 0 | 0 | 0 | 1 | 1  | 1   | 1 | 0 | Rd7Byte             | Read 7 bytes.                                 |
| 0                                 | 0 | 0 | 0 | 1 | 1  | 1   | 1 | 1 | RdDWord             | Read a double-word (64 bits).                 |
| 0                                 | 0 | 0 | 0 | 1 | 0  | х   | х | 0 | Rd4Words            | Not supported.                                |
| 0                                 | 0 | 0 | 0 | 1 | 0  | х   | 0 | 1 | Rd8Words            | Read eight words (32 bytes) in a 4-DW burst.  |
| 0                                 | 0 | 0 | 0 | 0 | Х  | Х   | х | Х | Invalid             | Reserved.                                     |
| 0                                 | 0 | 1 | 0 | 1 | 1  | 0   | 0 | 0 | WrByte              | Write a single byte.                          |
| 0                                 | 0 | 1 | 0 | 1 | 1  | 0   | 0 | 1 | WrShort             | Write 16 bits.                                |
| 0                                 | 0 | 1 | 0 | 1 | 1  | 0   | 1 | 0 | WrTriByte           | Write 3 bytes.                                |
| 0                                 | 0 | 1 | 0 | 1 | 1  | 0   | 1 | 1 | WrWord              | Write 4 bytes (single word).                  |
| 0                                 | 0 | 1 | 0 | 1 | 1  | 1   | 0 | 0 | Wr5Byte             | Read 5 bytes.                                 |
| 0                                 | 0 | 1 | 0 | 1 | 1  | 1   | 0 | 1 | Wr6Byte             | Read 6 bytes.                                 |
| 0                                 | 0 | 1 | 0 | 1 | 1  | 1   | 1 | 0 | Wr7Byte             | Read 7 bytes.                                 |
| 0                                 | 0 | 1 | 0 | 1 | 1  | 1   | 1 | 1 | Wr2Words            | Write a double word (8 bytes).                |
| 0                                 | 0 | 1 | 0 | 1 | 0  | Х   | Х | 0 | Wr4Words            | Not supported.                                |
| 0                                 | 0 | 1 | 0 | 1 | 0  | Х   | 0 | 1 | Wr8Words            | Write eight words (32 bytes) in a 4-DW burst. |



| 5 | SysCmd[8:0] Encoding <sup>1</sup> |   |   |   |   |   | ing | 1 | Command             |                       |
|---|-----------------------------------|---|---|---|---|---|-----|---|---------------------|-----------------------|
| 8 | 7                                 | 6 | 5 | 4 | 3 | 2 | 1   | 0 | Command<br>Mnemonic | Command Description   |
| 0 | 0                                 | 1 | 1 | 0 | 0 | Х | Х   | Х | NullReq             | Null Request command. |
| 0 | 0                                 | 1 | 1 | х | 1 | х | х   | х | Invalid             | Reserved.             |

| Table 27: Address Phase SysCmd[8:0] Encodings (driven by CPU) (Continu |
|------------------------------------------------------------------------|
|------------------------------------------------------------------------|

1. 'X' denotes "don't care" but 'X' signals must be driven to a valid 0/1.

#### Table 28: Read Response SysCmd[8:0] Encodings (driven by the GT-96100A)

| s | SysCmd[8:0] Encoding <sup>1</sup> |   |   |   | ing | 1 | 0 a man an d |   |                     |                                                                                                                 |
|---|-----------------------------------|---|---|---|-----|---|--------------|---|---------------------|-----------------------------------------------------------------------------------------------------------------|
| 8 | 7                                 | 6 | 5 | 4 | 3   | 2 | 1            | 0 | Command<br>Mnemonic | Command Description                                                                                             |
| 1 | 1                                 | 0 | E | 0 | Х   | Х | Х            | х | RD &Chk             | Indicates valid data and data-check-bit within a<br>burst.<br>E = 0 Data is good<br>E = 1 Data is erroneous     |
| 1 | 1                                 | 0 | E | 1 | Х   | Х | Х            | Х | RD &NoChk           | Indicates valid data within a burst (no check-bit).<br>E = 0 Data is good<br>E = 1 Data is erroneous            |
| 1 | 0                                 | 0 | Ш | 0 | x   | x | x            | x | REOD &Chk           | Indicates last valid data and data-checkbit within a<br>burst.<br>E = 0 Data is good<br>E = 1 Data is erroneous |
| 1 | 0                                 | 0 | E | 1 | Х   | Х | Х            | Х | REOD<br>&NoChk      | Indicates last valid data in a burst (no check-bit).<br>E = 0 Data is good<br>E = 1 Data is erroneous           |

1. 'X' denotes "don't care" but 'X' signals are driven to a valid 0/1 by the GT-96100A.



| Sy | SysCmd[8:0] Encoding <sup>1</sup> |   |   |   | g <sup>1</sup> |   |   |   |                     |                                                                                                             |
|----|-----------------------------------|---|---|---|----------------|---|---|---|---------------------|-------------------------------------------------------------------------------------------------------------|
| 8  | 7                                 | 6 | 5 | 4 | 3              | 2 | 1 | 0 | Command<br>Mnemonic | Command Description                                                                                         |
| 1  | 1                                 | 1 | E | 0 | х              | х | х | х | WD &Chk             | Indicates valid data and data-check-bit within a<br>burst.<br>E = 0 Data is good<br>E = 1 Data is erroneous |
| 1  | 1                                 | 1 | E | 1 | Х              | х | х | х | WD &NoChk           | Indicates valid data within a burst (No check-bit).<br>E = 0 Data is good<br>E = 1 Data is erroneous        |
| 1  | 0                                 | 1 | E | 0 | x              | x | x | x | WEOD &Chk           | Indicates valid data and data-check-bit within a<br>burst.<br>E = 0 Data is good<br>E = 1 Data is erroneous |
| 1  | 0                                 | 1 | E | 1 | Х              | Х | Х | Х | WEOD<br>&NoChk      | Indicates last valid data in a burst (No check-bit).<br>E = 0 Data is good<br>E = 1 Data is erroneous       |

| Table 29: | <b>CPU Write S</b> | ysCmd[8:0] | ] Encodings | (driven b | y local master) |  |
|-----------|--------------------|------------|-------------|-----------|-----------------|--|
|           |                    |            |             |           |                 |  |

1. 'X' denotes "don't care" but 'X' signals are driven to a valid 0/1 by the GT-96100A.

## 4.2.1 SysAD Read Protocol

SysAD reads occur in three phases: Table 30: SysAD Read Phases

| Phase           | Description                                                                                  |
|-----------------|----------------------------------------------------------------------------------------------|
| Address         | Address information is driven on the SysAD bus and command information is driven on SysCmd.  |
| Mid burst-data  | The GT-96100A drives data on the SysAD bus and a read response on SysCmd.                    |
| Last burst-data | The GT-96100A drives data on the SysAD bus and a read end-of-data (REOD) response on SysCmd. |

**NOTE:** If the read command requires parity, then check bits will be driven by the GT-96100A together with SysAD data for every data transfer.

The address phase for all transactions begins with the assertion of ValidOut\* to the GT-96100A. Valid address and command information must be present on SysAD and SysCmd during this phase. Release\* must also be asserted to the GT-96100A to indicate that the local master is releasing mastership of the SysAD/SysCmd/ SysADC buses to the GT-96100A for completion of the read. ValidOut\* is deasserted at the end of the phase since the CPU is no longer driving information on SysAD/SysCmd.



For transactions longer than 64 bits, the mid-burst data phase is entered next. The GT-96100A:

- Drives valid data on SysAD.
- Drives bits on SysADC[7:0] for parity.
- Drives a valid read response (mnemonic = RD) on SysCmd.
- Assert ValidIn\* to qualify the SysAD, SysADC, and SysCmd buses (see Figure 8).

The GT-96100A transitions to the last-burst data phase on the last datum of the transfer. This state is differentiated by from the mid-burst state by the REOD command driven on the SysCmd bus. The last-burst data phase is also entered for the datum returned for a double word, single word, or sub-word, read.

On the clock cycle following REOD, the GT-96100A floats the SysAD, SysADC, and SysCmd buses, returning ownership to the CPU.



Figure 7: Double Word (8 bytes) Read by CPU With Parity Check Bits

# 





# 4.2.2 SysAD Write Protocol

CPU writes occur in three phases:

 Table 31:
 SysAD Write Phases

| Phase                 | Description                                                                                                                        |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Address               | Address information is driven on the SysAD bus and command information is driven on SysCmd.                                        |
| Mid-burst write data  | The Local Master drives data on the SysAD bus, possibly Parity data on SysADC[7:0], and a write command (mnemonic = WD) on SysCmd. |
| Last-burst write data | The Local Master drives data on the SysAD bus and a write end-of-data (WEOD) command on SysCmd.                                    |

**NOTE:** If the write command requires parity, then check bits are driven by the Local Master together with SysAD data for every data transfer.

The address phase for write transactions begins with the assertion of ValidOut\* to the GT-96100A. Valid address and command information must be present on the SysAD and SysCmd busses during this phase. Release\* remains high for write transactions since the Local Master is not relinquishing ownership of the bus. ValidOut\* remains asserted throughout a write transaction as the CPU is always driving valid information on SysAD/ SysADC/SysCmd.

For transactions longer than 64 bits, the mid-burst data write phase is entered next. The CPU drives valid data on SysAD, a valid write command (mnemonic = WD) on SysCmd (see Figure 9).





Figure 9: CPU Four Word Burst Write

The GT-96100A transitions to the last-burst write data phase on the last datum of the transfer. This state is differentiated from the mid-burst state by the WEOD command driven on the SysCmd bus. The last-burst data phase is also entered for the datum written for a single word, or sub-word, write. On the clock cycle following WEOD, the GT-96100A returns to the idle state.

**NOTE:** CPU writes cannot be issued as long as WrRdy\* is deasserted (HIGH). If WrRdy\* is high and an CPU write is attempted, data from previous write cycles may be corrupted (see Section 4.3 "Operation of WrRdy\* and the Internal Write Posting Queues" on page 79.) All MIPs compliant processors follow this protocol. Only DMA engines on the SysAD bus need to be concerned with sampling WrRdy\* before initiating a write.

# 4.3 Operation of WrRdy\* and the Internal Write Posting Queues

The GT-96100A's CPU interface includes a write posting queue that absorbs local CPU writes at zero wait-states. This is required per the MIPs SysAD bus write protocol.

The write posting queue has four address entries and eight 64-bit data entries. The GT-96100A signals if there is room in the CPU write posting queue by asserting WrRdy\*. If WrRdy\* is asserted, the CPU may issue a write of up to eight words or four double words.

MIPs compliant processors such as the R4XXX/R5000/R7000 sample WrRdy\* automatically before issuing a write.

# 4.4 CPU Write Modes and Write Patterns Supported

The GT-96100A supports both pipelined and R4XXX/R5000/R7000 compatible write modes (with two dead cycles between consecutive writes). The default mode is pipelined. However, the R4XXX mode can be selected in the CPU Interface Configuration Register.

The CPU interface supports only DDDD and DXDXDXDX write patterns. One of these two write patterns must be selected via the CPU serial initialization bitstream during the CPU reset process. Bit 16 of the CPU Interface Configuration register (0x000) must be programmed according to the write pattern programming of the CPU.

**NOTE:** In the above explanation, 'D' represents data and 'X' is a wait state.



# 4.5 CPU Interface Endianess

The GT-96100A provides the capability to swap the data transferred to or from the internal registers and to or from the PCI interface.

NOTE: Data written to or from the memory controller is NEVER swapped.

The GT-96100A interface endianess to the CPU is programmed on RESET by sampling the Interrupt\* pin, see Section 22. "Reset Configuration" on page 452. The setting of this pin programs the Endianess bit in the CPU Configuration register at 0x000. When accessing the internal registers, the endianess of the data will be determined by the Interrupt\* pin's setting.

**NOTE:** If set to BIG endian, data is swapped.

The setting of the ByteSwap bit in the PCI Internal Command Register, bit 0 of 0xc00, determines how data transactions from the CPU to/from PCI are handled along with the setting of bit 12 in the CPU Configuration Register, 0x000. Both of these bits are set to the same value as the pin strapping of the Interrupt\*, but can be reprogrammed after RESET.

The setting of MByteSwap bit and MWordSwap bit in the PCI Internal Command register, determines how data transactions from the CPU to or from the PCI are handled along with the setting of the Endianess bit in the CPU Configuration register. Both MByteSwap and Endianess bits are set to the same value as the pin strapping of the Interrupt\* (resulting PCI interface working in little-endian mode). These bits can be re-programmed after RESET.

# 4.6 Burst Order

The GT-96100A supports only the sub-block ordered bursts used by Orion MIPs processors. Sub-block ordered bursts are optimized for the burst patterns used by most SDRAMs.

### 4.7 MIPS L2 Cache Support

The GT-96100A supports second level cache placed on the SysAD bus. It does not include L2 cache controller, but it supports L2 required signaling, as defined in the R5000 specification.

GT-96100A samples the ScMatch signal. If a CPU access hits the L2 cache line (Tag RAM asserts ScMatch signal), the GT-96100A ignores the transaction, enabling the CPU to complete the transaction against L2 cache.

If the CPU initiates a block read transaction with ScTCE\* asserted (indicating a L2 read request), and ScMatch is asserted two cycles after issue cycle (indicating a L2 hit), the GT-96100A ignores the transaction, but keeps ScDOE\* asserted, enabling L2 data RAM drive read data on the SysAD bus. ScDOE[1:0] word index is driven by the R5000 L2 cache controller.

In case cache miss (ScMatch deasserted two cycles after block read issue cycle), the GT-96100A responds to the transaction. It also deasserts ScDOE\* preventing L2 data RAM from driving the bus, and drives ScWord[1:0] for the L2 data RAM to load the data that the GT-96100A returns to CPU. An example of L2 read miss is shown in Figure 10.





Figure 10: R5000 L2 Read Miss Example

# 4.8 Multiple GT-96100A Support

Up to four GT-96100A devices can be connected to the CPU System Interface without the need for any glue logic. This capability increases the address space and adds significant flexibility for system design.

Enable multiple GT-96100A devices by sampling the value of DAdr[10] on RESET, see Section 22. "Reset Configuration" on page 452. If this pin is sampled HIGH, multiple GT-96100A devices are enabled. The value of DAdr[10] sampled on RESET will also set bit 18, MultiGT, of the CPU Configuration register at 0x000. This bit is programmable after RESET.

**NOTE:** This pin must be tied LOW if there is only one GT-96100A device.

If multiple GT-96100A devices are enabled, the values sampled on Ready\* and CSTiming\* determine the ID of the particular GT-96100A device, as shown in Table 32. This sampled values also program the MultiGTAct bits [1:0] in the MultiGTID Register, 0x120. These bits are programmable after RESET.

| Pin               | Configuration Function                                            |
|-------------------|-------------------------------------------------------------------|
| Ready*, CSTiming* | Multi-GT-96100A Address ID                                        |
| 00 - 01-          | GT responds to SysAD[26,25]=00<br>GT responds to SysAD[26,25]= 01 |
| 10 -              | GT responds to SysAD[26,25]=10                                    |
| 11-               | GT responds to SysAD[26,25]= 11                                   |
|                   | <b>NOTE:</b> Boot GT-96100A must be programmed to 11              |

Table 32: Pin Strapping the GT-96100A ID



### 4.8.1 Hardware Connections

When Multiple GT-96100A devices are enabled, the WrRdy\*, ValidIn\*, and ScDOE\* signals have slightly different functionality versus when only one GT-96100A is enabled.

| Table 33: | WrR | dy*, Validln*, | and ScDOE* | Signal Multiple | GT-96100A | Functionality |  |
|-----------|-----|----------------|------------|-----------------|-----------|---------------|--|
|           |     |                |            |                 |           |               |  |

| Signal   | Multiple GT-96100A Functionality                                                                                                                                                                                                                |  |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| WrRdy*   | An open-source output requiring a 4.7 KOhm pull-down resistor. All WrRdy* outputs from the GT-96100A devices must be tied together to drive the CPU WrRdy* input. WrRdy* is driven LOW for one cycle before floating the output.                |  |  |
| ValidIn* | An open-drain output requiring a 4.7 KOhm pull-up resistor. All ValidIn* outputs from the GT-<br>96100A devices must be tied together to drive the CPU ValidIn* input.<br>ValidIn* is driven HIGH for one cycle before floating the output.     |  |  |
| ScDOE*   | An open-source output requiring a 4.7 KOhm pull-down resistor. All ScDOE* outputs from the GT-96100A devices must be tied together to drive the CPU and Secondary cache inputs. ScDOE* is driven LOW for one cycle before floating the outputs. |  |  |

# 4.8.2 MultiGT Bit In The CPU Configuration Register

When the MultiGT bit is SET, the CPU Interface address decoding reduces to:

- If (SysAD[26:25] == ID) AND (it's a WRITE), the access is directed to the internal space of the CPU Interface registers. Bits[11:0] define the specific register offset.
- If (SysAD[26:25] == ID) AND (it's a READ) AND (SysAD[27] == 0), the access is directed to the internal space of the CPU Interface registers. Bits[11:0] define the specific register offset.
- If (SysAD[26:25] == ID) AND (it's a READ) AND (SysAD[27] == 1), the access is directed to BootCS\*. Since 0x0.1FC0.0000 implies SysAD[26:25] == 3, the GT 96100A holding the boot device should be strapped to ID = 3.
- **NOTE:** As long as MultiGT bit is SET, there is no access to PCI, SDRAM and Devices and DMA internal registers. Access is available only to the CPU interface internal registers and to boot ROM.
  - When the MultiGT bit is CLEARED, the CPU Interface resumes normal address decoding.
- **NOTE:** After the MultiGT bit is CLEARED, WrReady\*, ValidIn\*, and ScDOE\* signals still operate as sustained 3-state (STS) outputs.



## 4.8.3 Initializing a Multiple GT-96100A System

This section contains an example of connecting two GT-96100A devices to the same CPU. In actuality, it is possible to connect up to four GT-96100A devices to the same CPU.

Use the following procedure for initializing a system with two GT-96100A devices attached to the same CPU.

**NOTE:** Assuming that the two GT-96100A devices are called GT-1 and GT-2, respectively; both devices have DAdr[10] pulled to VCC (enabling MultiGT mode). GT-1 has Ready\* and CSTiming\* tied to 11 (boot GT-96100A). GT-2 has Ready\* and CSTiming\* tied to 00. GT-1 has the BootRom.

Table 34: Initializing a Multiple GT-96100A System

| Initialization Steps                                                                       | Description                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1. Access GT-1's BootROM and reconfigure GT-2's CPU Interface address space registers.     | After reset, the processor executes from the BootROM on GT-1<br>because the address on SysAD is 0x0.1FCx.xxxx where<br>SysAD[27:25] = 111 and it's a read cycle. Registers on GT-1 are<br>accessible via address SysAD[26:25]=11, [20:0]=offset]. Registers on<br>GT-2 are accessible via address [SysAD[26:25]=00, [20:0]=offset].                               |
| 2. Access GT-1's BootROM and reconfigure GT-1's CPU Interface address space registers.     | Reconfigures ALSO, the Internal space address decode register, so that later (once Multi-GT mode is disabled) the user can distinguish between internal accesses to GT-1 or GT-2.                                                                                                                                                                                 |
| 3. Lower GT-2 BootCS* high decode<br>register BELOW 0x0.1FCx.xxxx (i.e.<br>0x0.1FBx.xxxx). | Causes GT-2 to ignore accesses to 0x0.1FCx.xxxx once taken out of MultiGT mode. Further, the address mapping of register and memory space in the GT-96100A and on their interfaces must be unique. In other words, the four PCI address ranges, two SDRAM ranges, I/O space, and internal GT-96100A register spaces of both system controllers must be different. |
| 4. Clear GT-2 Multi-GT mode bit.                                                           |                                                                                                                                                                                                                                                                                                                                                                   |
| 5. Clear GT-1 Multi-GT mode bit.                                                           |                                                                                                                                                                                                                                                                                                                                                                   |

Both GT-96100A devices will now resume NORMAL operation with USUAL address decoding.

**NOTE:** In MultiGT mode, the GT-96100A does not support address mismatch in the CPU Interface decode. In other words, if the CPU attempts a READ of which the address is not mapped in ANY of the GT-96100A devices in the system, ValidIn\* is not returned to the CPU and the system will halt.

### 4.8.4 Multi-GT Restrictions

- 1. Due to System Interface loading, maximum operating frequency will decrease as the number of GT-96100A devices increase.
- 2. When Multi-GT support is enabled and if the CPU and GT-96100A are in Pipeline Writes mode (bit 11, WriteMode, in the CPU Interface Configuration register 0x0, reset to 0), a contention for one clock cycle on the WrRdy\* signal may occur. As a result, only R4000 mode (no Pipeline writes 1 wait state between transactions) is allowed When Multi-GT support is enabled.



# 4.9 CPU Interface Restrictions

1. The GT-96100A does not support access of more than 4 bytes to internal space.

# 4.10 CPU Interface Control Registers

## Table 35: CPU Interface Register Map

| Description                           | Offset | Page Number |
|---------------------------------------|--------|-------------|
| CPU Configuration                     |        |             |
| CPU Interface Configuration           | 0x000  | page 85     |
| Multi-GT Register                     | 0x120  | page 87     |
| CPU Address Decode                    |        |             |
| SCS[1:0]* Low Decode Address          | 0x008  | page 87     |
| SCS[1:0]* High Decode Address         | 0x010  | page 87     |
| SCS[3:2]* Low Decode Address          | 0x018  | page 88     |
| SCS[3:2]* High Decode Address         | 0x020  | page 88     |
| CS[2:0]* Low Decode Address           | 0x028  | page 88     |
| CS[2:0]* High Decode Address          | 0x030  | page 88     |
| CS[3]* & Boot CS* Low Decode Address  | 0x038  | page 88     |
| CS[3]* & Boot CS* High Decode Address | 0x040  | page 89     |
| PCI_0 I/O Low Decode Address          | 0x048  | page 89     |
| PCI_0 I/O High Decode Address         | 0x050  | page 89     |
| PCI_0 Memory 0 Low Decode Address     | 0x058  | page 89     |
| PCI_0 Memory 0 High Decode Address    | 0x060  | page 89     |
| PCI_0 Memory 1 Low Decode Address     | 0x080  | page 90     |
| PCI_0 Memory 1 High Decode Address    | 0x088  | page 91     |
| PCI_1 I/O Low Decode Address          | 0x090  | page 90     |
| PCI_1 I/O High Decode Address         | 0x098  | page 90     |
| PCI_1 Memory 0 Low Decode Address     | 0x0a0  | page 90     |
| PCI_1 Memory 0 High Decode Address    | 0x0a8  | page 91     |
| PCI_1 Memory 1 Low Decode Address     | 0x0b0  | page 91     |
| PCI_1 Memory 1 High Decode Address    | 0x0b8  | page 91     |
| Internal Space Decode                 | 0x068  | page 91     |



| Description                         | Offset | Page Number |
|-------------------------------------|--------|-------------|
| SCS[1:0]* Address Remap             | 0x0d0  | page 91     |
| SCS[3:2]* Address Remap             | 0x0d8  | page 92     |
| CPU Address Decode (Continued)      |        |             |
| CS[2:0]* Remap                      | 0x0e0  | page 92     |
| CS[3]* & Boot CS* Remap             | 0x0e8  | page 92     |
| PCI_0 I/O Remap                     | 0x0f0  | page 92     |
| PCI_0 Memory 0 Remap                | 0x0f8  | page 92     |
| PCI_0 Memory 1 Remap                | 0x100  | page 93     |
| PCI_1 I/O Remap                     | 0x108  | page 93     |
| PCI_1 Memory 0 Remap                | 0x110  | page 93     |
| PCI_1 Memory 1 Remap                | 0x118  | page 93     |
| CPU Sync Barrier                    |        |             |
| PCI_0 Sync Barrier Virtual Register | 0x0c0  | page 94     |
| PCI_1 Sync Barrier Virtual Register | 0x0c8  | page 94     |

| Table 35: | CPU Interface Register N | (Continued) |
|-----------|--------------------------|-------------|
|-----------|--------------------------|-------------|

# 4.10.1 CPU Configuration Registers

# Table 36: CPU Interface Configuration, Offset: 0x000

| Bits | Field Name | Function                                                                                                                                                                                   | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 8:0  | Reserved   | Cache Operation Mapping<br>Indicates which address bits the GT–<br>64012 uses for cache flush and cache<br>invalidate operations. Bits [8:0] corre-<br>spond to SysAD[35:27].<br>Must be 0 | 0x0           |
| 9    | Reserved   | Secondary Cache support<br>0 - GT–64012 not present<br>1 - GT–64012 present<br>Must be 0                                                                                                   | 0x0           |
| 10   | Reserved   | Reserved<br>Must be 0                                                                                                                                                                      | 0x0           |

# 

| Bits  | Field Name         | Function                                                                                                                                                                                                  | Initial Value                            |
|-------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| 11    | WriteMode          | Write mode<br>0 - Pipelined writes mode<br>1 - R4000 mode<br>There must be at least two dead-cycles<br>minimum between consecutive address-<br>phase.                                                     | 0x0                                      |
| 12    | Endianess          | Byte orientation<br>0 - Big endian<br>1 - Little endian<br><b>NOTE:</b> Affects only the internal registers<br>and the PCI Configuration data<br>register.                                                | Sampled at RESET via the Interrupt* pin. |
| 13    | Reserved           | Must be 0.                                                                                                                                                                                                | 0x0                                      |
| 14    | R5KL2_present      | Second level cache present<br>0 - R5KL2 not present<br>1 - R5KL2 present                                                                                                                                  | 0x0                                      |
| 15    | External_Hit_Delay | Register second level cache ScMatch sig-<br>nal <sup>1</sup> .<br>0 - Not sampled inside the GT-96100A.<br>1 - Sampled inside the GT-96100A.                                                              | 0x0                                      |
| 16    | CPU WriteRate      | CPU Data Write Rate<br>0 - DXDXDXDX<br>1 - DDDD                                                                                                                                                           | 0x0                                      |
| 17    | Stop_Retry         | Relevant only if PCI Retry was enabled<br>(DAdr[6] was sampled 0 at reset).<br>0 - Continue to Retry all PCI transactions<br>targeted to the controller's PCI slave<br>1 - Stop Retry of PCI transactions | 0x0                                      |
| 18    | MultiGT            | Multiple GT-96100A support<br>0 - Not Supported<br>1 - Supported                                                                                                                                          | Sampled at RESET via the DAdr[10] pin    |
| 19    | SysADCValid        | GT-96100A to CPU SysADC Connection<br>0 - Not connected (no parity)<br>1 - Connected                                                                                                                      | 0x0                                      |
| 21:20 | PCI_0_Override     | 00 - Normal address decoding<br>01 - 1Gbyte PCI_0 Mem0 space<br>10 - 2Gbyte PCI_0 Mem0 space<br>11 - Reserved                                                                                             | 0x0                                      |
| 23:22 | Reserved           |                                                                                                                                                                                                           | 0x0                                      |

## Table 36: CPU Interface Configuration, Offset: 0x000 (Continued)



| Bits  | Field Name     | Function                                                                                                      | Initial Value |
|-------|----------------|---------------------------------------------------------------------------------------------------------------|---------------|
| 25:24 | PCI_1_Override | 00 - Normal address decoding<br>01 - 1Gbyte PCI_1 Mem0 space<br>10 - 2Gbyte PCI_1 Mem0 space<br>11 - Reserved | 0x0           |
| 31:26 | Reserved       |                                                                                                               | 0x0           |

| Table 36 <sup>.</sup> | CPU Interface | Configuration  | Offset: 0x000 | (Continued) |
|-----------------------|---------------|----------------|---------------|-------------|
|                       |               | ooninguration, |               | oonunucu)   |

1. TagRAMs used with L2/L3 cache output the ScMatch signal registered. If for some reason, the TagRAM in use outputs the ScMatch signal non-registered, this bit must be set to 1 to maintain timing relationship between the cache and the GT-96100A.

| Table 37: | Multi-GT | register. | Offset: | 0x120 |
|-----------|----------|-----------|---------|-------|
|           |          | register, | 011301. | 07120 |

| Bits | Field Name | Function                                                                                                | Initial Value                                           |
|------|------------|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
| 1:0  | MultiGTAct | Multi-GT Activity bits<br>These bits represent the ID to which the<br>GT-96100A responds with activity. | Value sampled at reset<br>on Ready* and CSTim-<br>ing*. |
| 31:2 | Reserved   |                                                                                                         | 0x0                                                     |

## 4.10.2 CPU Address Decode Registers

#### Table 38: SCS[1:0]\* Low Decode Address, Offset: 0x008

| Bits  | Field Name | Function                                                                                    | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | SDRAM banks 1 and 0 are accessed<br>when the decoded addresses are<br>between Low and High. | 0x0000        |
| 31:15 | Reserved   |                                                                                             | 0x0           |

#### Table 39: SCS[1:0]\* High Decode Address, Offset: 0x010

| Bits  | Field Name | Function                                                                                    | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | SDRAM banks 1 and 0 are accessed<br>when the decoded addresses are<br>between Low and High. | 0x07          |
| 31:11 | Reserved   |                                                                                             | 0x0           |

| Bits  | Field Name | Function                                                                                    | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | SDRAM banks 3 and 2 are accessed<br>when the decoded addresses are<br>between Low and High. | 0x0008        |
| 31:15 | Reserved   |                                                                                             | 0x0           |

#### Table 40: SCS[3:2]\* Low Decode Address, Offset: 0x018

#### Table 41: SCS[3:2]\* High Decode Address, Offset: 0x020

| Bits  | Field Name | Function                                                                                    | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | SDRAM banks 3 and 2 are accessed<br>when the decoded addresses are<br>between Low and High. | 0x0F          |
| 31:11 | Reserved   |                                                                                             | 0x0           |

#### Table 42: CS[2:0]\* Low Decode Address, Offset: 0x028

| Bits  | Field Name | Function                                                                                         | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | Device banks 2, 1, and 0 are accessed<br>when the decoded addresses are<br>between Low and High. | 0x00e0        |
| 31:15 | Reserved   |                                                                                                  | 0x0           |

#### Table 43: CS[2:0]\* High Decode Address, Offset: 0x030

| Bits  | Field Name | Function                                                                                         | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | Device banks 2, 1, and 0 are accessed<br>when the decoded addresses are<br>between Low and High. | 0xF0          |
| 31:11 | Reserved   |                                                                                                  | 0x0           |

#### Table 44: CS[3]\* & Boot CS\* Low Decode Address, Offset: 0x038

| Bits  | Field Name | Function                                                                                                | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | Device bank 3 and the boot bank are<br>accessed when the decoded addresses<br>are between Low and High. | 0x00f8        |
| 31:15 | Reserved   |                                                                                                         | 0x0           |



| Bits  | Field Name | Function                                                                                                | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | Device bank 3 and the boot bank are<br>accessed when the decoded addresses<br>are between Low and High. | 0xFF          |
| 31:11 | Reserved   |                                                                                                         | 0x0           |

 Table 45:
 CS[3]\* & Boot CS\* High Decode Address, Offset: 0x040

#### Table 46: PCI\_0 I/O Low Decode Address, Offset: 0x048

| Bits  | Field Name | Function                                                                                           | Initial Value |
|-------|------------|----------------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | The PCI_0 I/O address space is accessed<br>when the decoded addresses are<br>between Low and High. | 0x0080        |
| 31:15 | Reserved   |                                                                                                    | 0x0           |

#### Table 47: PCI\_0 I/O High Decode Address, Offset: 0x050

| Bits  | Field Name | Function                                                                                           | Initial Value |
|-------|------------|----------------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | The PCI_0 I/O address space is accessed<br>when the decoded addresses are<br>between Low and High. | 0x8F          |
| 31:11 | Reserved   |                                                                                                    | 0x0           |

#### Table 48: PCI\_0 Memory 0 Low Decode Address, Offset: 0x058

| Bits  | Field Name | Function                                                                                              | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | The PCI_0 memory address space is<br>accessed when the decoded addresses<br>are between Low and High. | 0x0090        |
| 31:15 | Reserved   |                                                                                                       | 0x0           |

#### Table 49: PCI\_0 Memory 0 High Decode Address, Offset: 0x060

| Bits  | Field Name | Function                                                                                              | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | The PCI_0 memory address space is<br>accessed when the decoded addresses<br>are between Low and High. | 0x9F          |
| 31:11 | Reserved   |                                                                                                       | 0x0           |

| Bits  | Field Name | Function                                                                                              | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | The PCI_0 memory address space is<br>accessed when the decoded addresses<br>are between Low and High. | 0x0790        |
| 31:15 | Reserved   |                                                                                                       | 0x0           |

| Table 50: | PCI_0 Memory 1 Low Decode Address, Offset: 0x080 |
|-----------|--------------------------------------------------|
|-----------|--------------------------------------------------|

#### Table 51: PCI\_0 Memory 1 High Decode Address, Offset: 0x088

| Bits  | Field Name | Function                                                                                              | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | The PCI_0 memory address space is<br>accessed when the decoded addresses<br>are between Low and High. | 0x79F         |
| 31:11 | Reserved   |                                                                                                       | 0x0           |

### Table 52: PCI\_1 I/O Low Decode Address, Offset: 0x090

| Bits  | Field Name | Function                                                                                           | Initial Value |
|-------|------------|----------------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | The PCI_1 I/O address space is accessed<br>when the decoded addresses are<br>between Low and High. | 0x0100        |
| 31:15 | Reserved   |                                                                                                    | 0x0           |

#### Table 53: PCI\_1 I/O High Decode Address, Offset: 0x098

| Bits  | Field Name | Function                                                                                           | Initial Value |
|-------|------------|----------------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | The PCI_1 I/O address space is accessed<br>when the decoded addresses are<br>between Low and High. | 0x10F         |
| 31:11 | Reserved   |                                                                                                    | 0x0           |

#### Table 54: PCI\_1 Memory 0 Low Decode Address, Offset: 0x0a0

| Bits  | Field Name | Function                                                                                              | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | The PCI_1 memory address space is<br>accessed when the decoded addresses<br>are between Low and High. | 0x0110        |
| 31:15 | Reserved   |                                                                                                       | 0x0           |



| Bits  | Field Name | Function                                                                                             | Initial Value |
|-------|------------|------------------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | The PCI_1 memory address space will be accessed when the decoded addresses are between Low and High. | 0x11F         |
| 31:11 | Reserved   |                                                                                                      | 0x0           |

 Table 55:
 PCI\_1 Memory 0 High Decode Address, Offset: 0x0a8

#### Table 56: PCI\_1 Memory 1 Low Decode Address, Offset: 0x0b0

| Bits  | Field Name | Function                                                                                              | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------|---------------|
| 14:0  | Low        | The PCI_1 memory address space is<br>accessed when the decoded addresses<br>are between Low and High. | 0x0120        |
| 31:15 | Reserved   |                                                                                                       | 0x0           |

#### Table 57: PCI\_1 Memory 1 High Decode Address, Offset: 0x0b8

| Bits  | Field Name | Function                                                                                              | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------|---------------|
| 10:0  | High       | The PCI_1 memory address space is<br>accessed when the decoded addresses<br>are between Low and High. | 0x12F         |
| 31:11 | Reserved   |                                                                                                       | 0x0           |

#### Table 58: Internal Space Decode, Offset: 0x068

| Bits  | Field Name | Function                                                                                                   | Initial Value |
|-------|------------|------------------------------------------------------------------------------------------------------------|---------------|
| 14:0  | IntDecode  | Registers inside the GT-96100A are accessed when SysAD bits 35:21 match the value programmed in bits 14:0. | 0x00a0        |
| 31:15 | Reserved   |                                                                                                            | 0x0           |

#### Table 59: SCS[1:0]\* Address Remap, Offset: 0x0d0

| Bits  | Field Name      | Function                                           | Initial Value |
|-------|-----------------|----------------------------------------------------|---------------|
| 10:0  | SCS[1:0]*_Remap | CPU address remap to resources for SDRAM 0 region. | 0x0           |
| 31:11 | Reserved        |                                                    | 0x0           |

| Bits  | Field Name      | Function                                          | Initial Value |
|-------|-----------------|---------------------------------------------------|---------------|
| 10:0  | SCS[3:2]*_Remap | CPU address remap to resources of SDRAM 1 region. | 0x008         |
| 31:11 | Reserved        |                                                   | 0x0           |

#### Table 60: SCS[3:2]\* Address Remap, Offset: 0x0d8

#### Table 61: CS[2:0]\* Address Remap, Offset: 0x0e0

| Bits  | Field Name     | Function                                           | Initial Value |
|-------|----------------|----------------------------------------------------|---------------|
| 10:0  | CS[2:0]*_Remap | CPU address remap to resources of Device 0 region. | 0x0e0         |
| 31:11 | Reserved       |                                                    | 0x0           |

#### Table 62: CS[3]\* & Boot CS\* Address Remap, Offset: 0x0e8

| Bits  | Field Name                  | Function                                              | Initial Value |
|-------|-----------------------------|-------------------------------------------------------|---------------|
| 10:0  | CS[3]*_&_<br>Boot CS*_Remap | CPU address remap to resources of<br>Device 1 region. | 0x0f8         |
| 31:11 | Reserved                    |                                                       | 0x0           |

#### Table 63: PCI\_0 IO Address Remap, Offset: 0x0f0

| Bits  | Field Name     | Function                                           | Initial Value |
|-------|----------------|----------------------------------------------------|---------------|
| 10:0  | PCI_0_IO_Remap | CPU address remap to resources of PCI_0 IO region. | 0x080         |
| 31:11 | Reserved       |                                                    | 0x0           |

#### Table 64: PCI\_0 Memory 0 Address Remap, Offset: 0x0f8

| Bits  | Field Name           | Function                                                 | Initial Value |
|-------|----------------------|----------------------------------------------------------|---------------|
| 10:0  | PCI_0_Mem0_<br>Remap | CPU address remap to resources of PCI_0 Memory 0 region. | 0x090         |
| 31:11 | Reserved             |                                                          | 0x0           |



| Bits  | Field Name           | Function                                                 | Initial Value |
|-------|----------------------|----------------------------------------------------------|---------------|
| 10:0  | PCI_0_Mem1_<br>Remap | CPU address remap to resources of PCI_0 Memory 1 region. | 0x790         |
| 31:11 | Reserved             |                                                          | 0x0           |

Table 65: PCI\_0 Memory 1 Address Remap, Offset: 0x100

#### Table 66: PCI\_1 IO Address Remap, Offset: 0x108

| Bits  | Field Name     | Function                                           | Initial Value |
|-------|----------------|----------------------------------------------------|---------------|
| 10:0  | PCI_1_IO_Remap | CPU address remap to resources of PCI_1 IO region. | 0x100         |
| 31:11 | Reserved       |                                                    | 0x0           |

#### Table 67: PCI\_1 Memory 0 Address Remap, Offset: 0x110

| Bits  | Field Name           | Function                                                    | Initial Value |
|-------|----------------------|-------------------------------------------------------------|---------------|
| 10:0  | PCI_1_Mem0_<br>Remap | CPU address remap to resources of<br>PCI_1 Memory 0 region. | 0x110         |
| 31:11 | Reserved             |                                                             | 0x0           |

| Table 68: | PCI_1 Memory | y 1 Address Remap | Offset: 0x118 |
|-----------|--------------|-------------------|---------------|
|-----------|--------------|-------------------|---------------|

| Bits  | Field Name           | Function                                                 | Initial Value |
|-------|----------------------|----------------------------------------------------------|---------------|
| 10:0  | PCI_1_Mem1_<br>Remap | CPU address remap to resources of PCI_1 Memory 1 region. | 0x120         |
| 31:11 | Reserved             |                                                          | 0x0           |



# 4.10.3 CPU Sync Barrier

## Table 69: PCI\_0 Sync Barrier Virtual Register, Offset: 0x0c0

| Bits | Field Name    | Function                                                                                                                                                                                                                                                                      | Initial Value |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | SyncBarrier_0 | A CPU read from this register creates a synchronization barrier cycle. When Vali-<br>dln* is returned to the CPU, both of the PCI_0 slave FIFOs are guaranteed to be empty. The read data returned to the CPU is random and should be ignored.<br>This register is READ ONLY. | 0x0           |

## Table 70: PCI\_1 Sync Barrier Virtual Register, Offset: 0x0c8

| Bits | Field Name    | Function                                                                                                                                                                                                                                                                                  | Initial Value |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | SyncBarrier_1 | A CPU read from this register creates a<br>synchronization barrier cycle. When Vali-<br>dIn* is returned to the CPU, both of the<br>PCI_1 slave FIFOs are guaranteed to be<br>empty. The read data returned to the CPU<br>is random and should be ignored.<br>This register is READ ONLY. | 0x0           |



# 5. **MEMORY CONTROLLER**

The GT-96100A's Memory Controller consists of an integrated SDRAM controller and a device controller. The SDRAM controller has a 15-bit address bus (DAdr[12:0],BankSel[1:0]) and shares the 64-bit address/data (AD) bus for data transfers. The device controller uses the 64-bit muxed AD bus for both address and data transfers.

All memory and I/O devices in a GT-96100A system are connected to the AD bus (the SysAD bus is used primarily as a point-to-point connection between the CPU and the GT-96100A system.)

The memory controller only MASTER reads and writes transactions to SDRAM or devices. It receives the instructions for these transactions from the CPU, IDMA controller, or a PCI device on the PCI interface.

NOTE: A device may not master transactions via the GT-96100A's memory controller.

The GT-96100A's memory controller supports both 32 or 64-bit SDRAM as well as 8-, 16-, 32-, and 64-bit devices.

**NOTE:** Whenever this datasheet refers to 64-bit SDRAM, it means 64-bits of data plus eight additional bits for ECC.

The GT-96100A supports two arbitration schemes for memory controller requests. The default arbitration is shown in Figure 11, while a modified arbitration scheme is shown in Figure 12.





#### Figure 11: Memory Controller Default Arbitration

NOTE: Only if the memory controller is idle, a Low Priority UMA request is granted.









The modified arbitration reduces the latency associated with CPU memory read transactions.<sup>1</sup>

Programming the memory controller's arbitration mode is done using bit 10 of the SDRAM Burst Mode register (see Table 107, "SDRAM Burst Mode, Offset: 0x478," on page 135).



# 5.1 SDRAM Controller

The SDRAM controller supports up to four banks of SDRAMs.

The SDRAM configuration register (0x448) contains configuration information which is valid for the four banks. Various access parameters can be programmed on a per bank basis as each bank has its own parameters register (0x44c - 0x458).

The supported address depth of the SDRAM can vary for each bank, depending on whether 16, 64, 128 or 256Mbit SDRAMs are used (see Section 5.2 "Connecting the Address Bus to the SDRAM" on page 106 for more information). Up to 256 Mbytes can be addressed by each SCS for a total SDRAM address space of 512 Mbytes by the GT-96100A system.

# 5.1.1 SDRAM Configuration Register (0x448)

The SDRAM Configuration Register contains parameters which are used for all of the SDRAM banks used with the GT-96100A.

## 5.1.1.1 Refresh Rates

The GT-96100A implements standard SCAS before SRAS refreshing.

The refresh rate for the SDRAM banks is programmable using the RefIntCnt field in the SDRAM Configuration Register, see Table 105. For example, the default value of RefIntCnt is 0x200. If TClk is 100 MHz, than a refresh sequence will occur every 5us. This is derived from 100MHz (=10ns) \* 0x200 (512d) = 5.12us.

Every instance that the refresh counter in the GT-96100A device reaches its terminal count, a refresh request is sent to the Memory Controller. This request enters the arbiter. Once the AD bus is idle and the last SDRAM or Device transaction has finished, the refresh cycle begins.

**NOTE:** If a UMA transaction is being serviced, the external SDRAM master is responsible for refreshing the SDRAM. See Section 5.6 "Unified Memory Architecture (UMA) Support" on page 113.

### 5.1.1.2 Non-staggered and staggered Refresh

Non-staggered or staggered refresh for each bank can be programmed according to StagRef in the SDRAM configuration register.

In non-staggered refresh, SCS[3:0]\* and SRAS\* and SCAS\* simultaneously asserts refreshing all banks at the same time as shown in Figure 13.

If the SDRAM Controller is programmed to perform staggered refresh (default), SCS[3:0]\* will not simultaneously assert LOW together with SRAS\*, following the low-going SCAS\*. Rather, SCS[0]\* will first go LOW for 1 cycle, followed by SCS[1]\* on the next TClk, and so on. After the last SCS[3]\* has asserted LOW for 1 cycle, SCAS\* and SRAS\* will go HIGH again. Staggered Refresh is useful for load balancing, shown in Figure 14.











### 5.1.1.3 Read Modify Write Enable/ECC

The GT-96100A supports Error Checking and Correction of 64-bit wide SDRAMs.

**NOTE:** See Section 6. "Data Integrity" on page 143 for more information about ECC.

For 64-bit SDRAMs with ECC enabled, ECC is generated and written to the ADP[7:0] lines on 64-bit writes during the same cycle that the data is written.

Bit 15 enables or disables read modify write protocol to SDRAM. If ECC is enabled in any of the DRAM banks, this bit must be set to 1 to enable read modify write.

ECC checking and generation requires a 72-bit DIMM to store the ECC information. In order to generate the ECC on partial writes, the current ECC bits must first be read and then modified during the partial write. The protocol for the read modify write transaction is as follows:

- 1. Read the existing data and ECC information. On this read, all SDQM\* lines are asserted (LOW). This means that the BE (byte enable) for the ECC byte can be connected to any of the SDQM[7:0]\* outputs. The ECC data is read on the ADP[7:0] inputs.
- 2. Modify the ECC information based on the data that is to be written. The modification of the ECC byte is done in the GT-96100A system.



3. Write the new data and new ECC byte.

Figure 15 illustrates the procedure used to generate ECC in a partial write to SDRAM.





# 5.1.2 Duplicating Signals

Some systems require using duplicate signals due to loading requirements. The following sections outlines which signals can be duplicated by setting the appropriate bit in the SDRAM Configuration Register.

#### 5.1.2.1 Duplicating SDRAM Control Lines

SRAS\*, SCAS\*, and DWr\* are the control lines for SDRAM. These signals can be duplicated on different pins for loading considerations.

Setting bit 19 to 0 means these SRAS\*, SCAS\*, and DWr\* signals are not duplicated on other pins (default).

Setting bit 19 to 1 means SRAS\*, SCAS\*, and DWr\* signals are duplicated on DMAReq[0]\*/MREQ\*, DMAReq[3]\*, and BypsOE\*/MGNT, respectively. These pins are no longer usable as DMAReq[0]\*/MREQ\*, DMAReq[3]\*, and MGNT\*/BypOE\* when bit 19 is set to 1. Regardless of the pin strapping of DAdr[7] sampled on RESET (UMA enable), when bit 19 is set to 1, the duplication of SRAS\*, SCAS\*, and DWr\* on the DMAReq[0]\*, DMAReq[3]\*, and BypsOE\* pins takes priority over setting DMAReq[0]\* to MREQ\* and BypsOE\* to MGNT.



## 5.1.2.2 Duplicating DAdr[11] and BankSel[1] on DMAReq[2:1]\*

DAdr[11] and BankSel[1] are used for 64/128/256 Mbit SDRAM. These signals can be duplicated on different pins for loading considerations.

Setting bit 20 to 0 means these pins are not duplicated on other pins (default).

Setting bit 20 to 1 means DAdr[11] and Banksel[1] signals are duplicated on DMAReq[2]\* and DMAReq[1]\*, respectively. These pins are no longer usable as DMAReq[2]\* and DMAReq[1]\* when bit 20 is set to 1.

**NOTE:** If ECC is implemented in the system, ADP[5:4] cannot be used as DAdr[11] and BankSel[1]. Therefore, to use DAdr[11] and BankSel[1], program bit 20 to 1 and use DMAReq[2:1]\* as DAdr[11] and BankSel[1].

#### 5.1.2.3 DMA End of Transfer Pins Functionality

The IDMA controllers use the End of Transfer pins to give an external device the ability to terminate a current DMA transfer. See Table 236 for more information about this feature.

Bit 21 controls the function of DMAReq[3]\*. Setting this bit to 0 means DMAReq[3]\* functions as DMA Request for channel 3. Setting this bit to 1 means DMAReq3\* functions as End of Transfer for channel 0, EOT0.

Likewise, setting bit 22 to 0 means Ready\* functions as Ready. And, setting this bit to 1 means Ready\* functions as End of Transfer for channel 1, EOT[1].

| Primary<br>Signal<br>Name | Secondary<br>Signal Name<br>(Programmed<br>on RESET) | Bit 19 = 1 | Bit 20 = 1 | Bit 21 = 1 | Bit 22 = 1 |
|---------------------------|------------------------------------------------------|------------|------------|------------|------------|
| DMAReq[0]*                | MREQ*                                                | SRAS*      |            |            |            |
| DMAReq[1]*                |                                                      |            | BankSel[1] |            |            |
| DMAReq[2]*                |                                                      |            | DAdr[11]   |            |            |
| DMAReq[3]*                |                                                      | SCAS*      |            | EOT[0]     |            |
| Ready*                    |                                                      |            |            |            | EOT[1]     |
| BypsOE*                   | MGNT*                                                | DWr*       |            |            |            |

Table 71: DMAReq\*, Ready\* and BypsOE\* Functionality



## 5.1.2.4 Multiplexing DAdr[12]

If any of the SDRAM banks is configured to 256Mbit, an additional DRAM address bit is required. If bit 24 is set to 1, DAdr[12] is driven on DMAReq[3]\* pin. If bit 24 is set to 0, it is driven on ADP[0] pin.

**NOTE:** If ECC is implemented in the system, ADP[0] cannot be used as DAdr[12]. To use DAdr[12], program bit 24 to 1 and use DMAReq[3]\* as DAdr[12].

## 5.1.3 Registered SDRAM Support

The GT-96100A SDRAM controller can be configured to interface registered SDRAM DIMMs.

Setting bit 23 to 1means the registered SDRAM is enabled and the SDRAM controller drives and samples SDRAM signals accordingly. The SDRAM controller compensates the clock cycle needed for the DIMM samples SDRAM control signals. Only 64-bit registered SDRAMs are supported.

# 5.1.4 SDRAM Operation Mode Register (0x474)

The SDRAM Operation Mode Register is a 3-bit register used to execute commands other than standard memory reads and writes to the SDRAM. These operations include:

- Normal SDRAM Mode (0x0)
- NOP Commands (0x1)
- Precharge All Banks (0x2)
- Writing to the SDRAM Mode Register (0x3)
- Force a Refresh Cycle (0x4)

In order to execute one of the above commands on the SDRAM, the following procedure must occur:

- 1. SDRAM Operation Mode Register must be written the corresponding value. Either the CPU or a PCI device can master this transaction.
- 2. This write must be followed by a dummy word (32-bit) write to the corresponding SDRAM.
- 3. To complete the command, the SDRAM Operation Mode Register must be written 0x0 to place it back into Normal SDRAM Mode.

#### 5.1.4.1 Normal SDRAM Mode

The SDRAM Operation Mode Register must be written 0x0 to enable normal reading and writing to the SDRAM.

#### 5.1.4.2 NOP Commands

The NOP command is used to perform a NOP to an SDRAM which is selected by the SDRAM Chip Select (SCS[3:0]\*). This prevents unwanted commands from being registered during idle or wait states.

### 5.1.4.3 Precharge All Banks

The Precharge Bank command is used to deactivate the open row in a particular bank or the open row in both banks.

Once a bank has been precharged, it is in the idle state and must be activated prior to any read or write commands being issued to that bank.



#### 5.1.4.4 Writing to the SDRAM's Parameter Register

Each SDRAM has its own Mode Register. The Mode Register defines the specific operation mode for the SDRAM. This definition includes the selection of a burst length, SCAS latency, operating mode, etc.

**NOTE:** Refer to the SDRAM data sheet for more information about this register.

Typically, the Mode Register of each SDRAM is initialized on boot-up of the system and is kept static. The GT-96100A has the flexibility to allow the CPU or a PCI Master to update the SDRAM's Mode Register at any time during the operation.

The parameters that the GT-96100A can change are the CAS latency and the burst length. To change these parameters in the SDRAM's Mode Register:

- 1. Update the corresponding SDRAM Bank Parameters Register (0x44c 0x458) with the correct values.
- 2. The SDRAM Operation Mode Register must be written to 0x3. This indicates a Write Command to the SDRAM Mode Register.
- 3. This write must be followed by a dummy word (32-bit) write to the corresponding SDRAM whose Mode Register must be updated.
- 4. Finally, the SDRAM Operation Mode Register must be written 0x0 to place it back into Normal SDRAM Mode.

The GT-96100A uses the following procedure to automatically initialize the SDRAM on boot up.

**NOTE:** This default initialization can be easily overwritten by the procedure described above.

- 1. SRAS\* and DWr\* are asserted with DAdr[10] HIGH and SCS[3:0] = 0000. This indicates a Precharge to all SDRAM Banks.
- 2. SRAS\* and SCAS\* are asserted with SCS[3:0] = 0000. This indicates a CBR (CAS before RAS) refresh to all SDRAM Banks. This occurs twice in a row.
- 3. SRAS\*, SCAS\*, and DWr\* are asserted four times in a row.
  - Once with SCS[3:0] = 1110.
  - Once with SCS[3:0] = 1101.
  - Once with SCS[3:0] = 1011.
  - And, once with SCS[3:0] = 0111.

This command programs each of the SDRAM Mode Registers by activating each of the four chip selects (SCS[3:0]) individually.

The GT-96100A automatically initializes the SDRAM on boot up to Sub-block burst ordering as required for MIPS CPUs block reads.

**NOTE:** The GT-96100A always programs the SDRAM's mode register to burst in sub-block order which support the MIPS CPU burst order. The other modes that are programmed following boot up are the default values of the SDRAM control and parameters register.

Set the GT-96100A to initialize to linear ordering by programing SDRAM Burst Mode register to 0x9 and then following the above procedure. Initializing to linear ordering is only possible with a linear burst read type CPU.

#### 5.1.4.5 Force Refresh

The Force Refresh Command is used to execute a refresh cycle on the particular bank that is accessed.

# 5.1.5 SDRAM Address Decode Register (0x47c)

The Address Decode Register is a three bit register which determines how bits of an address, presented on the SysAD or PCI bus, are translated to row and column address bits on DAdr[12:0] and BankSel[1:0]. This flexibility allows the designer to choose the address decode setting. This gives the software the best chance This improves the software's capability of interleaving and enhancing overall system performance.

**NOTE:** The row and column address translation is different for 16 Mbit, 64/128 Mbit, 256 Mbit SDRAMs, 32bit and 64-bit SDRAM banks. The address decoding depends on the setting of AddrDecode. See Table 76 for the SRAS\* and SCAS\* address translation from the SysAD interface and PCI.

|                      | -                                                             |                                                               |
|----------------------|---------------------------------------------------------------|---------------------------------------------------------------|
| AddrDecode,<br>0x47c | SysAD/PCI Bits used for<br>SRAS* on BankSel[0],<br>DAdr[10:0] | SysAD/PCI Bits used for<br>SCAS* on BankSel[0],<br>DAdr[10:0] |
| 000                  | 4, 21-11                                                      | 4, "0", 23-22, 10-5, 3-2                                      |
| 001                  | 5, 21-11                                                      | 5, "0", 23-22, 10-6, 4-2                                      |
| 010                  | 11, 21-12, 10                                                 | 11, "0", 23-22, 9-2                                           |
| 011                  | 12, 21-13, 11-10                                              | 12, "0", 23-22, 9-2                                           |
| 100                  | 20, 21, 19-10                                                 | 20, "0", 23-22, 9-2                                           |
| 101                  | 21, 20-10                                                     | 21, "0", 23-22, 9-2                                           |
| 110                  | 22, 21-11                                                     | 22, "0", 23, 10-2 (only for x4 & x8)                          |
| 111                  | 23, 21-11                                                     | 23, "0", 22, 10-2 (only for x4)                               |

Table 72: SysAD/PCI Address Decoding for 32-bit SDRAM, 16 Mbit

| Table 73: | SysAD/PCI Address Decoding for 64-bit SDRAM, 256/512 Mbit |
|-----------|-----------------------------------------------------------|
|-----------|-----------------------------------------------------------|

| AddrDecode, | SysAD/PCI Bits used for<br>SRAS* on BankSel[0],<br>BankSel[1], DAdr[12:0] | SysAD/PCI Bits used for<br>SCAS* on BankSel[0],<br>BankSel[1], DAdr[12:0] |
|-------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 000         | Illegal setting for 64, 128Mbit and 256Mbit SDRAM                         |                                                                           |
| 001         | 6, 7, 25-13                                                               | 6, 7, 29-28, "0", 27-26, 12-8, 5-3                                        |
| 010         | 11, 12, 25-13                                                             | 11, 12, 29-28, "0", 27-26, 10-3                                           |
| 011         | 13, 14, 25-15, 12-11                                                      | 13, 14, 29-28, "0", 27-26, 10-3                                           |
| 100         | 21, 22, 25-23, 20-11                                                      | 21, 22, 29-28, "0", 27-26, 10-3                                           |
| 101         | 23, 24, 25, 22-11                                                         | 23, 24, 29-28, "0", 27-26, 10-3                                           |
| 110         | 24, 25, 23-11                                                             | 24, 25, 29-28, "0", 27-26, 10-3                                           |
| 111         | 25, 26, 27, 22-11                                                         | 25, 26, 29-28, "0", 24-23, 10-3                                           |



| AddrDecode,<br>0x47c | SysAD/PCI Bits used for<br>SRAS* on BankSel[0],<br>BankSel[1], DAdr[11:0] | SysAD/PCI Bits used for<br>SCAS* on BankSel[0],<br>BankSel[1], DAdr[11:0] |
|----------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 000                  | Illegal setting for 64, 128Mbit and 256Mbit SDRAM                         |                                                                           |
| 001                  | 5, 6, 23-12                                                               | 5, 6, "00", 25-24, 11-7, 4-2                                              |
| 010                  | 11, 12, 23-13, 10                                                         | 11, 12, "00", 25-24, 9-2                                                  |
| 011                  | 12, 13, 23-14, 11-10                                                      | 12, 13, "00", 25-24, 9-2                                                  |
| 100                  | 20, 21, 23-22, 19-10                                                      | 20, 21, "00", 25-24, 9-2                                                  |
| 101                  | 22, 23, 21-10                                                             | 22, 23, "00", 25-24, 9-2                                                  |
| 110                  | 23, 24, 21-10                                                             | 23, 24, "00", 25, 22, 9-2<br>(only for x4 & x8)                           |
| 111                  | 24, 25, 21-10                                                             | 24, 25, "00", 26, 22, 9-2<br>(Only for x4)                                |

 Table 74:
 SysAD/PCI Address Decoding for 32-bit SDRAM, 64 Mbit

| AddrDecode,<br>0x47c | SysAD/PCI Bits used for<br>SRAS* on BankSel[0],<br>BankSel[1], DAdr[11:0] | SysAD/PCI Bits used for<br>SCAS* on BankSel[0],<br>BankSel[1], DAdr[11:0] |
|----------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 000                  | Illegal setting for 64, 128Mbit and 256Mbit SDRAM                         |                                                                           |
| 001                  | 6, 7, 24-13                                                               | 6, 7, 27, "0", 26-25, 12-8, 5-3                                           |
| 010                  | 11, 12, 24-13                                                             | 11, 12, 27, "0", 26-25, 10-3                                              |
| 011                  | 13, 14, 24-15, 12-11                                                      | 13, 14, 27, "0", 26-25, 10-3                                              |
| 100                  | 21, 22, 24-23, 20-11                                                      | 21, 22, 27, "0", 26-25, 10-3                                              |
| 101                  | 23, 24, 22-11                                                             | 23, 24, 27, "0", 26-25, 10-3                                              |
| 110                  | 24, 25, 22-11                                                             | 24, 25, 27, "0", 26, 23, 10-3<br>(Only for x4 & x8)                       |
| 111                  | 25, 26, 22-11                                                             | 25, 26, 27, "0", 24-23, 10-3<br>(Only for x4)                             |



| AddrDecode,<br>0x47c | SysAD/PCI Bits used for<br>SRAS* on BankSel[0],<br>BankSel[1], DAdr[12:0] | SysAD/PCI Bits used for<br>SCAS* on BankSel[0],<br>BankSel[1], DAdr[12:0] |
|----------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 000                  | Illegal setting for 64, 128Mbit and 256Mbit SDRAM                         |                                                                           |
| 001                  | 6, 7, 25-13                                                               | 6, 7, 29-28, "0", 27-26, 12-8, 5-3                                        |
| 010                  | 11, 12, 25-13                                                             | 11, 12, 29-28, "0", 27-26, 10-3                                           |
| 011                  | 13, 14, 25-15, 12-11                                                      | 13, 14, 29-28, "0", 27-26, 10-3                                           |
| 100                  | 21, 22, 25-23, 20-11                                                      | 21, 22, 29-28, "0", 27-26, 10-3                                           |
| 101                  | 23, 24, 25, 22-11                                                         | 23, 24, 29-28, "0", 27-26, 10-3                                           |
| 110                  | 24, 25, 23-11                                                             | 24, 25, 29-28, "0", 27-26, 10-3                                           |
| 111                  | 25, 26, 27, 22-11                                                         | 25, 26, 29-28, "0", 24-23, 10-3                                           |

#### Table 76: SysAD/PCI Address Decoding for 64-bit SDRAM, 256 Mbit

# 5.2 Connecting the Address Bus to the SDRAM

Connecting the address bus to SDRAM is very simple with The GT-96100A. The SDRAM controller has its own address bus and its depends on whether a 16 Mbit or 64 Mbit SDRAMs are being used.

#### 5.2.1 16 MBit SDRAMs

For 16 Mbit SDRAMs, DAdr[10:0] and BankSel[0] are outputs of the GT-96100A and must be directly connected to address bits 10-0 and Bank Select of the actual SDRAM.

**NOTE:** DAdr[11] and BankSel[1] are not used when connecting to 16 Mbit SDRAMs. These lines are in HIGH-Z state when accessing 16Mbit SDRAMs.

During a SRAS cycle, a valid row address is placed on the DAdr[10:0] and BankSel[0] lines. During the SCAS cycle, a valid column address is placed on DAdr[9:0] (10-bit). DAdr[10] is used as the auto-precharge select bit and is always written 0 during SCAS cycles. BankSel[0] is held constant from the SRAS cycle.

With 16 MBit SDRAMs, the GT-96100A supports a maximum of 4M addresses, 12 address bits for SRAS and 10 address bits for SCAS.

### 5.2.2 64/128 Mbit SDRAMs

For 64/128 MBit SDRAMs, DAdr[11:0] and BankSel[1:0] are outputs of the GT-96100A and must be directly connected to address bits 11-0 and Bank Select of the actual SDRAM.

During a SRAS cycle, a valid row address is placed on the DAdr[11:0] and BankSel lines. During the SCAS cycle, a valid column address is placed on DAdr[11,9:0] (11-bit). DAdr[10] is used as the auto-precharge select bit and is always written 0 during SCAS cycles. BankSel is held constant from the SRAS cycle.

With 64 MBit SDRAMs, the GT-96100A supports a maximum of 16M addresses, 14 address bits for SRAS and 10 address bits for SCAS (DAdr[11] is ignored and is in HIGH-Z state when accessing 64 Mbit SDRAMs).



With 128 MBit SDRAMs, the GT-96100A supports a maximum of 32M addresses, 14 address bits for SRAS and 11 address bits for SCAS.

# 5.2.3 256 Mbit SDRAMs

For 256/512 MBit SDRAMs, DAdr[12:0] and BankSel[1:0] are outputs of the GT-96100A and must be connected directly to address bits 12-0 and Bank Select of the actual SDRAM.

During a SRAS cycle, a valid row address is placed on the DAdr[12:0] and BankSel lines. During the SCAS cycle, a valid column address is placed on DAdr[12-11,9:0] (12-bit). DAdr[10] is used as the auto-precharge select bit and is always written 0 during SCAS cycles. BankSel is held constant from the SRAS cycle.

With 256/512 MBit SDRAMs, the GT-96100A supports a maximum of 128M addresses, 15 address bits in SRAS and 12 address bits in SCAS. For a 64 bit wide SDRAM built from 128Mx4bit memories, 1Gbyte can be addressed by a single SDRAM device decoder.

# 



#### Figure 16: 512 Mbit/64-bit SDRAM Connection to Memory Bus Using x8 Devices

# 5.3 Programmable SDRAM Parameters

The SDRAM controller of the GT-96100A device supports a wide range of SDRAMs with different access times and each bank can be programmed independently by the SDRAM Bank[3:0] Parameter registers (0x44c-0x458). These parameters include the number of clock cycles (based on TClk) between active SRAS\* and SCAS\*.

**NOTE:** To update the SCAS\* Latency or the Burst Length, follow the procedure outlined in Section 5.1.4.4 "Writing to the SDRAM's Parameter Register" on page 103 to update the SDRAM's Mode Register. Table 77 describes the programmable functions of the SDRAM parameters.

| Function                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCAS* Latency                       | SCAS* Latency is the number of TClks from the assertion of SCAS* to the sampling of the first read data. This parameter can be programmed to be either 2 or 3 TClks. Selecting this parameter depends on TClk frequency and the speed grade of the SDRAM.<br>NOTE: Check your SDRAM data sheet for the most optimal setting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Flow-through                        | <ul> <li>Bit 2 specifies the number of times that the data is sampled by the GT-96100A on SDRAM reads when bypass is not enabled (bit 9 = 0). This option is included for future designs which will run at faster clock frequencies.</li> <li>NOTE: As of January 1999, Flow-through mode must always be enabled (bit 2 = 1). If ECC or registered SDRAM are used, Flow-through must be disabled (bit 2 = 0).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| SRAS* Precharge                     | Bit 3 specifies the SRAS precharge time. This parameter specifies the number of TClks following a precharge cycle that a new SRAS* transaction may generate.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 64-bit Interleaving                 | Bit 5 specifies the number of banks that are supported for interleaving if the bank is set for $64/128/256$ Mbit SDRAM. If the bank is NOT set for $64/128/256$ Mbit SDRAM (bit $11 = 0$ ), the setting of this bit is irrelevant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bank Width                          | Bit 6 specifies the data width of the particular bank.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bank Location                       | Bit 7 specifies the location of the bank if the bank is set for 32-bit SDRAM. If the bank is not set for 32-bit SDRAM (bit 6 = 1), the setting of this bit is irrelevant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ECC Support                         | Bit 8 enables or disables ECC on a 64-bit wide SDRAM bank.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 64-bit Bypass Mode for<br>CPU Reads | <ul> <li>Bit 9 enables or disables 64-bit SDRAM Read bypass.</li> <li>NOTE: This option is only for SDRAM banks configured as 64-bit (the option is not available for devices).</li> <li>An optional bypass mode is available for CPU reads where a clock cycle of latency can be eliminated when the CPU executes read cycles from 64-bit SDRAM. The bypass mode requires additional bus switches to enable direct data flow to the CPU. Instead of passing response data from the SDRAM to the GT-96100A prior to presenting it to the CPU, data flows directly from the SDRAM to the CPU via bus switches. This reduces the latency from ValidOut* to ValidIn* from 9 TClk cycles to 8.</li> <li>NOTE: The bypass is used for partial reads as well. Reads from 64-bit SDRAM are no longer sampled by the GT-96100A prior to presenting the data to</li> </ul> |
|                                     | the CPU.<br>64-bit bypass can only be enabled if the bank is set for 64-bit (bit 6 = 1).<br>No writes are transferred via the bypass switches at any time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| SRAS* to SCAS*                      | Bit 10 specifies the number of TClks that the GT-96100A inserts between the asser-<br>tion of SRAS* with a valid row address to the assertion of SCAS* with a valid col-<br>umn address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Table 77: | Programmable S | SDRAM | Parameters |
|-----------|----------------|-------|------------|
|-----------|----------------|-------|------------|

| Function                                  | Description                                                                                                                                                 |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16/64/128/256 MBit<br>SDRAM Configuration | Bits [14,11] specify when the particular bank supports 16, 64/128, or 256 MBit SDRAMs.<br>NOTE: The value of 10 is a reserved setting and must not be used. |
| Burst Length                              | Bit 13 specifies the data burst length supported for the particular SDRAM bank.<br>The data can be either 32 or 64 bit, depending on the setting of bit 6.  |

#### Table 77: Programmable SDRAM Parameters (Continued)

# 5.4 SDRAM Performance

Depending on the setting of certain variables, SDRAM performance can vary on both the CPU and PCI interface.

# 5.4.1 CPU Access to SDRAM

SDRAM performance on the CPU interface is based on the latency between the CPU's assertion of ValidOut\* to the GT-96100A's assertion of ValidIn\* returning the first data on a burst read (cache line read).

Performance is different if the 64-bit Bypass feature is enabled. Table 78 summarizes the latency between Valid-Out\* and ValidIn\* on SDRAM reads. After the first data is read, the remaining data is returned with zero wait states. For example, if bypass is enabled and the CPU executes a cache line read from memory, data will be returned with 8-1-1-1 performance when bypass is enabled.

Table 78: CPU SDRAM Performance on Reads

| SDRAM device                | Number of TClks between<br>ValidOut* to ValidIn* |
|-----------------------------|--------------------------------------------------|
| Bypass Enabled <sup>1</sup> | 8                                                |
| Bypass Not Enabled          | 9                                                |

1. See Table 77 for more information about the bypass feature.

On CPU writes to SDRAM, the data cycles will follow the address cycle with zero wait states. Further, the next data of a burst can also be written on the next clock cycle (zero wait states).

# 5.4.2 PCI Read Performance from SDRAM

The following sections outlines SDRAM memory performance. These figures depend on a number of variables including the PClk/TClk ratio, as well as the sync. mode that the device is configured for. The following numbers are based on the fastest SDRAM settings.



Performance is rated on three events:

| Event                                   | Description                                                                                                                                      |  |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PCI Read request from SDRAM.            | This event is based on the number of clocks between Frame* being asserted by a PCI master to the assertion of SRAS* by the SDRAM controller.     |  |
| Data from SDRAM con-<br>troller to PCI. | This event is based on the number of clocks between the first data placed on the AD bus until TRdy* is asserted on the PCI bus by the GT-96100A. |  |
| Latency till first data.                | This event is based on the number of clocks between a PCI master asserting Frame* to the assertion of TRdy* by the GT-96100A.                    |  |

#### Table 79: Events Determining PCI Read Performance from SDRAM

There are five different sync. modes that the GT-96100A can be placed in depending on the PClk/TClk ratio. These sync. modes are:

| Sync. Mode       | Description                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| SYNC MODE 0, x00 | No assumptions on TClk/PClk ratio.                                                                                                    |
| SYNC MODE 1, 001 | PClk frequency is greater than or equal to 1/2 TClk frequency.                                                                        |
| SYNC MODE 2, 01x | PClk frequency is synchronized $^{1}$ to TClk frequency and greater than or equal to 1/2 TClk frequency                               |
| SYNC MODE 5, 101 | PClk frequency is greater than or equal to 1/3 TClk frequency but smaller than 1/2 TClk frequency.                                    |
| SYNC MODE 6, 11x | PClk frequency is synchronized to TClk frequency and greater than or equal to 1/3 TClk frequency but smaller than 1/2 TClk frequency. |

#### Table 80: GT-96100A Sync. Modes

1. If TClk and PClk are synchronized, see Section 32.1 "TClk/PClk Restrictions" on page 516.

| TCIk/PCIk<br>Frequency | Sync.  |             |                |              |
|------------------------|--------|-------------|----------------|--------------|
| (MHz)                  | Mode   | Event       | # of TClk      | # of PCIk    |
| 100/33                 | 0      | A<br>B<br>C | 9<br>12<br>26  | 3<br>5<br>10 |
|                        | 5      | A<br>B<br>C | 10<br>12<br>26 | 3<br>5<br>10 |
| 100/50                 | 0      | A<br>B<br>C | 8<br>8<br>20   | 4<br>5<br>12 |
|                        | 1      | A<br>B<br>C | 8<br>8<br>20   | 4<br>5<br>12 |
| 100/66                 | 0      | A<br>B<br>C | 5<br>6<br>16   | 4<br>5<br>12 |
|                        | 1      | A<br>B<br>C | 6<br>6<br>16   | 4<br>5<br>12 |
| 100/33                 | 0      | A<br>B<br>C | 14<br>12<br>30 | 5<br>4<br>10 |
|                        | 5      | A<br>B<br>C | 14<br>12<br>30 | 5<br>4<br>10 |
|                        | 6 or 7 | A<br>B<br>C | 12<br>8<br>24  | 4<br>3<br>8  |
| 100/50                 | 0      | A<br>B<br>C | 11<br>9<br>24  | 6<br>5<br>12 |
|                        | 1      | A<br>B<br>C | 11<br>9<br>24  | 6<br>5<br>12 |
|                        | 2      | A<br>B<br>C | 9<br>5<br>18   | 5<br>3<br>9  |

# Table 81: SDRAM Performance Summary PCI Read Accesses

| TCIk/PCIk<br>Frequency<br>(MHz) | Sync.<br>Mode | Event       | # of TClk    | # of PCIk    |
|---------------------------------|---------------|-------------|--------------|--------------|
| 100/66                          | 0             | A<br>B<br>C | 9<br>8<br>21 | 6<br>6<br>14 |
|                                 | 1             | A<br>B<br>C | 9<br>8<br>21 | 6<br>6<br>14 |

Table 81: SDRAM Performance Summary PCI Read Accesses (Continued)

# 5.5 SDRAM Bank Interleaving

The GT-96100A supports two bank interleaving with 16 Mbit SDRAM and two or four bank interleaving with 64 Mbit SDRAMs. The SDRAM Address Control Register (0x47c) determines what address bits are used for SRAS and SCAS cycles. This allows flexibility for different software applications to select an address decoding scheme which may give data accesses a better probability of interleaving.

Interleaving provides higher system performance by hiding SRAS to SCAS cycles and precharge time of a pending transaction during the data cycles of a current transaction. This reduces the number of wait states before data can be read from or written to SDRAM, thus, increasing bandwidth. Interleaving occurs when two independent resources require access to SDRAM. These resources can be the CPU, PCI\_0, PCI\_1, or one of the IDMA controllers.

At the end of every SDRAM memory transaction, the GT-96100A will precharge the bank.

# 5.6 Unified Memory Architecture (UMA) Support

The GT-96100A supports UMA. This feature allows an external master device to share the same physical SDRAM memory is controlled by the GT-96100A device. This feature works according to the VESA Unified Memory Architecture (VUMA) specification<sup>1</sup>.

A VUMA device refers to any type of controller which needs to share the same physical system memory and have direct access to it as shown in Figure 17.

<sup>1.</sup> More information about the VESA Unified Memory Architecture can be found at http://www.vesa.org



#### Figure 17: VUMA Device and The GT-96100A sharing SDRAM

# 5.6.1 UMA Hardware Support

UMA is enabled by a pin strapping option. If DAdr[7] is sampled LOW on RESET, DMAReq[0]\* is programmed to function as MREQ\*. The BypsOE\* pin will function as MGNT\* as long as bit 9 is 0 for all of the SDRAM Bank Parameters registers (bypass disabled).

**NOTE:** The Bypass feature and UMA cannot be used simultaneously.

MREQ\* is an input into the GT-96100A and must be an output for the VUMA device. This signal is used by the VUMA device to make a request of GT-96100A to access the shared SDRAM. MREQ\* should be driven by the VUMA device on a rising edge of TClk. MREQ\* is sampled on a rising edge of TClk by the GT-96100A.

MGNT\* is an output of the GT-96100A and must be an input to the VUMA device. This signal is used by the GT-96100A to inform the VUMA device that it can access the shared SDRAM. MGNT\* is driven by the GT-96100A on a rising edge of TClk. MGNT\* must be sampled by the VUMA device on a rising edge of TClk.

Table 82: UMA AC Timing Parameters

| Signals | Description                    | Min. | Max. | Unit | Loading |
|---------|--------------------------------|------|------|------|---------|
| MREQ*   | Setup.                         | 3    |      | ns   |         |
| MREQ*   | Hold.                          | 1    |      | ns   |         |
| MGNT*   | Output Delay From TClk rising. | 2    | 10   | ns   | 30 pF   |

NOTE: The AC timing parameters are shown in Section 32. "AC Timing" on page 513.



## 5.6.2 SDRAM Pins

Once MGNT\* is asserted by the GT-96100A and the VUMA device is granted access to SDRAM, the SCS[3:0]\*, SRAS\*, SCAS\*, DWr\*, AD[63:0], DQM[8:0], DAdr[11:0], and BankSel[1:0] are held in sustained tri-state until the GT-96100A regains access to SDRAM. During this period, the VUMA device must drive these signals to access SDRAM.

When the GT-96100A and the VUMA device hands the bus over to each other, they must drive all of the above signals HIGH for one TClk and then float the pins (except the SDRAM address lines). The SDRAM address lines do not need to be driven high before floating the bus. A sample waveform is shown in Figure 18.





# 5.6.3 Address Decoding

The GT-96100A complies with the standard for CPU address to SDRAM Row and Column addressing. See Section 5.1.5 "SDRAM Address Decode Register (0x47c)" on page 104 to see how the CPU address translation is performed. This register (0x47c) should be programmed with the binary value of 010 in order to properly use the UMA feature when using 16 Mbit/64-bit SDRAM.

**NOTE:** As of January 1999, there is no standard for UMA SDRAM addressing when using 16 Mbit/32-bit SDRAM or 64 MBit SDRAMs (32 or 64 bit).

## 5.6.4 Arbitration

As shown in Figure 17 on page 114, the VUMA device arbitrates with the GT-96100A for access to SDRAM through MREQ\* and MGNT\*, which should be synchronous to TClk.

The GT-96100A is always the default owner of the SDRAM and access to this memory is only allowed to the VUMA device upon demand.

The GT-96100A has the right to take the VUMA device off of the bus by de-asserting MGNT\*.

The VUMA device may request access to SDRAM with either a low or high priority, and both of these priorities are conveyed to the core logic through the MREQ\* signal.



| Low Priority Request                                                                                                               |
|------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                    |
| MREQ*                                                                                                                              |
| High Priority Request                                                                                                              |
|                                                                                                                                    |
| MREQ*                                                                                                                              |
| Pending Low Priority converted to a High Priority                                                                                  |
|                                                                                                                                    |
| MREQ* NOTE: Any other transitions asserted other than those shown in this figure will keep the state machine in the current state. |

#### Figure 19: MREQ\* Requests from the VUMA Device

#### 5.6.4.1 VUMA Device Access to SDRAM Rules

There are certain rules that must be followed when the VUMA device makes a request for access to the SDRAM.

 Once MREQ\* is asserted by the VUMA device for a low priority request, it must keep it asserted until the VUMA device is given access to SDRAM via MGNT\*. The only reason to change the status of the MREQ\* pin is to raise a high priority request or raise the priority of an already pending low priority request.

- If MGNT\* is sampled asserted, the VUMA device must not de-assert MREQ\*. Instead, the VUMA device will have ownership of SDRAM and must continue asserting MREQ\* until it has completed its transaction.

- If MGNT\* is sampled de-asserted, the VUMA device can de-assert MREQ\* for one clock and assert it again regardless of the status of MGNT\*. After re-assertion, the VUMA device must keep MREQ\* asserted until the GT-96100A gives the VUMA device access to SDRAM via MGNT\*.

- 2. The VUMA device may only assert the MREQ\* for the purpose of accessing SDRAM and must stay asserted until MGNT\* is sampled asserted except to raise the priority request. No speculative requests or request abortion is allowed.
- 3. Once the VUMA device samples MGNT\* as asserted, it gains and retains access to SDRAM until MREQ\* is de-asserted.
- 4. The GT-96100A always asserts MGNT\* for one clock cycle only, and immediately requests back ownership of the bus.



- 5. The VUMA device retains ownership of SDRAM indefinitely. The standard calls for the VUMA device to keep ownership for no longer than 60 TClks before it must release the bus. This is not a requirement for the GT-96100A and it will wait until the VUMA device releases the bus by de-asserting MREQ\*.
- 6. When the VUMA device has ownership of the bus, it has full responsibility to execute refresh cycles on the SDRAM.
- 7. Once the VUMA device de-asserts MREQ\* to transfer ownership back to the GT-96100A either on its own, or because of a preemption requires, MREQ\* should be de-asserted for at least 2 TClks before asserting it again to raise a request.

# 5.6.5 Latencies, Low and High Priority

If a VUMA device places a low priority request for access to SDRAM, there is no set time specified by the GT-96100A to assert MGNT\*. Once there are no pending transactions to the memory controller, MGNT\* is asserted.

If a VUMA device places a high priority request for an access to SDRAM, the GT-96100A has a maximum of 35 TClks before it asserts MGNT\*.

# 5.6.6 Total Request

The GT-96100A immediately requests back ownership of the bus after MGNT\* assertion.

If bit 4 of SDRAM Bank2 Parameters register is set to 1, DMAReq[3]\*/SCAS\* pin functions as a total request pin. It indicates that there is a real internal request inside the GT-96100A that requires SDRAM bus ownership.

NOTE: This may cause some difficulty to implement a fair arbitration mechanism on the SDRAM bus.

# 5.6.7 Disable Refresh

In some applications, the GT-96100A will be most of the time OFF the SDRAM bus. The bus master has full responsibility to execute refresh cycles on the SDRAM.

In such applications, the user may want to disable the GT-96100A's refresh cycles (make memory controller arbitration cycle shorter).

Disable refresh cycles by setting bit 4 of SDRAM Bank1 Parameters register to 1.

## 5.6.8 Internal Register Reads with UMA Enabled

In order for the GT-96100A to return the data of an internal register read, the SDRAM and Memory Controller must have control over the AD bus. Therefore, the logic controller the input of MREQ\* to the GT-96100A must de-assert its request of the memory.

The internal register read transaction is held off until the GT-96100A obtains mastership of the memory bus.



# 5.7 Device Controller

The device controller supports up to five group of devices. Various access parameters can be programmed on a per group basis as each group has its own parameters register (0x45c - 0x46c).

The supported memory space of each device can vary for each bank up to 256 Mbytes. The width of each device may be 8, 16, 32 or 64-bits. The maximum total device address space is 512 Mbytes for all five groups.

The five individual chip selects are typically broken up into four individual device groups plus one chip select for a boot device (non-volatile memory). Each device group can have unique programmable timing parameters to accommodate different device types (e.g. Flash, ROM, I/O Controllers). The devices share the local AD bus with the SDRAM. Unlike the SDRAM, the devices use the AD bus as a multiplexed address and data bus.

In the address phase, the device controller puts an address on the AD bus with a corresponding Chip Select asserted. ALE indicates the AD bus is output as address with a valid CS\*. ALE is used to latch the address and the CS\* in an external latch. ALE is HIGH by default, making the latch transparent.<sup>1</sup> ALE goes LOW a half clock cycle before CSTiming\* is asserted for the particular read or write transaction. At the completion of the transaction, ALE goes HIGH again on the same rising TClk that CSTiming\* is de-asserted.

CS\* must then be qualified (OR-tied) with CSTiming\*. A read or write cycle is indicated by DevRW\*. The CSTiming\* signal is valid for the programmable number of cycles of the specific CS\* is active. TurnOff, AccTo-First and AccToNext can be set in registers 0x45c - 0x46c for each group's read timing parameters. ALEtoWr, WrActive, and WrHigh are set for each group's write timing parameters. There are certain restrictions to setting these timing parameters. See Section 5.9 "Memory Controller Restrictions" on page 126 before configuring these bits.

**NOTE:** Some of these parameters can be extended by the Ready\* pin. See Section 5.7.10 "Ready\* Support" on page 122.

# 5.7.1 TurnOff

TurnOff is the number of TClk cycles that the GT-96100A does not drive the memory bus after a read from a device. This prevents contention on the memory bus after a read cycle for a slow device.

This parameter is measured from the number of cycles between the de-assertion of DevOE\* (an externally extracted signal which is the logical OR between CSTiming\* and inverted DevRW\*) to an new AD bus cycle.

# 5.7.2 AccToFirst

AccToFirst defines the number of cycles in a read access from the assertion of CS\* (first rising TClk where CS\* is asserted LOW) to the cycle that the first data is sampled by the GT-96100A.

**NOTE:** This parameter can be extended by the Ready\* pin. See Section 5.7.10 "Ready\* Support" on page 122.

1. Note that this definition of ALE is slightly different than the GT-64010A/11/14/60. ALE on these devices is default LOW, and is only asserted HIGH for a half clock cycle to latch the address. This change in definition for ALE on the GT-96100A has no affect on system performance or architecture.



# 5.7.3 AccToNext

AccToNext defines the number of cycles in a read access from the cycle that the first data is latched to the cycle to the next data is latched (in burst accesses). This parameter can also be thought of as the delay between the rising edge of TClk which data is latched to the rising edge of TClk where the next data is latched in a burst cycle.

**NOTE:** This parameter can be extended by the Ready\* pin. See Section 5.7.10 "Ready\* Support" on page 122.

# 5.7.4 ALEtoWr

There are eight byte write signals, Wr[7:0]\*. ALEtoWr can also be thought of as the delay between the rising edge of TClk which drives ALE LOW to the assertion of Wr\*, or for the first write pulse.

**NOTE:** The Wr[7:0]\* signals are asserted and de-asserted off of the FALLING edge of TClk.

#### 5.7.5 WrActive

WrActive is the number of TClks that Wr\* are active (asserted). This parameter is measured from the first rising edge of TClk where Wr\* is asserted LOW to the last rising edge of TClk where Wr\* is LOW for that particular write pulse.

**NOTE:** This parameter can be extended by the Ready\* pin. See Section 5.7.10 "Ready\* Support" on page 122. The Wr[7:0]\* signals are asserted and de-asserted off of the FALLING edge of TClk.

# 5.7.6 WrHigh

WrHigh is the number of TClks that Wr\* is inactive between burst writes. This parameter is measured from the first rising edge of TClk where Wr\* is de-asserted HIGH to the last rising edge of TClk where Wr\* is HIGH.

On the next rising edge of TClk, Wr\* is asserted LOW for the next write pulse.

**NOTE:** The Wr[7:0]\* signals are asserted and de-asserted off of the FALLING edge of TClk. The previous data remains on the AD bus during WrHigh.

## 5.7.7 Device Bank Width and Location

Bit 21:20 of the Device Bank[3:0] Parameter registers (0x45c-0x46c), DevWidth, specifies whether the data width of the particular device bank is 8, 16, 32 (default except for BootCS\*), or 64 bits. If the bank is set for 8-, 16-, or 32-bit operation, it can either reside on the even half (31:0) or odd half (63:32) by setting bit 23, DevLoc.

Selecting the even or the odd half allows for load balancing.

In case of a 64-bit device, DevLoc has no meaning.

# Galileo



#### Figure 20: Waveform Showing Device Read Parameters

#### NOTES:

- 1. CS\* is driven off the same rising TClk\* as ALE. Throughout consecutive transactions to the same device, CS\* remains asserted. This is why CS\* must always be qualified with CSTiming.
- 2. The GT–96100A may start a new AD cycle after TurnOff.





Figure 21: Waveform Showing Device Write Parameters

- 1. CS\* is driven off the same rising TClk\* as ALE. Throughout consecutive transactions to the same device, CS\* will remain asserted. This is why CS\* must ALWAYS be qualified with CSTiming\*.
- 2. Wr[7:0]\* are asserted and deasserted from the falling edge of TClk.

# 5.7.8 Burst Writes

The device controller supports up to eight word burst accesses.

The burst address is supported by a 3-bit wide address bus (BAdr[2:0]) that is different from the latched address on the multiplexed AD bus.

**NOTE:** BAdr[2:0] are the same pins as the least significant SDRAM address lines, DAdr[2:0]. See Section 33. "Pinout Table, 492 Pin BGA" on page 533 for more information.

# 5.7.9 Packing and Unpacking Data and Burst Support

The AD bus supports the packing of data into a 64-bit double word, in reads from devices that are 8-, 16-, or 32bits wide. Devices that are 8- or 16-bits wide are supported by partial reads (up to 64-bits).

The controller supports CPU writes of one to eight bytes to 8-bit or 16-bit wide devices. Therefore, 8 and 16-bit devices MUST NOT be mapped to cacheable regions. The reason is that the R4xxx/R5000/R7000 have an eight or 16 word (32 or 64 bytes) cache line size. This would equate to a burst of 32/64 8-bit accesses or 16/32 16-bit accesses.

The GT-96100A supports cached accesses to 32- and 64-bit device spaces. It supports DMA/PCI writes of one to eight bytes to 8-bit or 16-bit wide devices.



#### 5.7.10 **Ready\*** Support

The Ready\* pin is sampled on three occasions:

- One clock before the data is sampled to the GT-96100A.
- During both AccToFirst (see Figure 22) and AccToNext (see Figure 23) phases of read cycles. •
- On the last rising edge of the WrActive (see below) phase during a write cycle. •

During all other phases Ready\* is not sampled by the GT-96100A.

If Ready\* is not asserted during the WrActive, AccToFirst, or AccToNext phases. These phases are extended until Ready\* is asserted again. The transaction may be indefinitely held off until Ready\* is asserted.

NOTE: There are no SDRAM refreshes as long as an access to a device is not completed. Use Ready\* carefully on device accesses so it not interfere with the SDRAM refresh.



#### Figure 22: Ready\* Extending AccToFirst on Read Cycle

1. CS\* is unven on the same rising TClk\* as ALE. Throughout consecutive transactions to the same device, CS\* will remain asserted. This is why CS\* must

always be qualified with CSTiming\* Ready is sampled as deaserted one clock before data should be sampled according to AccToFirst. AD[63:0] is not sampled by GT-96100A on the following rising TClk.

Ready\* is asserted on some following rising TClk. AD[63:0] (Data1) is sampled on the following rising TClk of the rising TClk that Ready\* was asserted. Effectively, AccToFirst is 7 in this example (instead of programmed 5).





#### Figure 23: Ready\* Extending AccToNext on Read Cycle

AD[63:0].

3. Ready<sup>★</sup> is sampled as de-asserted one clock before data should be sampled according to AcctoNext. DATA 2 is NOT sampled.

4. Ready\* is asserted on some following rising TClk.

5. AD[63:0] (DATA 2) is sampled on the following rising TClk of the rising TClk that Ready\* was asserted. Effectively, AccToNext is 5 (instead of the programmed 3).



#### Figure 24: Extending WrActive Parameter on Write Cycle

- why CS\* must ALWAYS be qualified with CSTiming\*.
- 2. Wr[7:0]\* are asserted and de-asserted from the falling edge of TClk.
- Ready\* is asserted on last rising TClk of WrActive, therefore, the GT-96100A assumes the device is written to correctly and continues to the next write cycle.
- Ready\* is deasserted on the last rising TClk of WrActive, therefore, the GT-96100A does NOT continue to the next write cycle effectly
  extending the WrActive parameter. Wr\* remains asserted.
- Ready\* is asserted on the next rising TClk, therefore, the GT–96100A assumes the device has been written to correctly and continues to the next cycle (end of write transaction). Effectively, WrActive is 4 (instead of the programmed 3). For clarification, if there was another word to burst, WrHigh would start counting from the rising TClk denoted by 5, not 4.

# 5.7.11 Parity Support for Devices

The GT-96100A has no dedicated logic to support device parity. If device parity checking is required, it can be implemented externally using '511 devices and some logic for interrupt generation.

Still, the GT-96100A generates EVEN parity on CPU SysADC lines during CPU read transaction from devices.



# 5.8 **Programming the ADP lines for other Functions**

If ECC is enabled for any SDRAM bank, the ADP lines function as pins used for reading and writing the ECC byte.

If ECC is not implemented in the system, the ADP lines are usable for other functions. These functions include duplicating the SDRAM control lines (used for load balancing) and duplicating the ALE signal (used for load balancing).

During RESET, certain pins are sampled (either HIGH or LOW) to select these pin functions, see Section 22. "Reset Configuration" on page 452.

If ECC is not enabled, AND the ADP lines are not programmed to function as other pins on RESET, ADP[3:0] will function as EOT[3:0], see Table 236, "DMA Channel Control Register (0x840 - 0x84c)," on page 221. Further, ADP[4] will be used as BankSel[1] and ADP[5] will be used as DAdr[11]. ADP[7:6] are unused.

Table 83 summarizes the functionality of the ADP lines depending on system configuration.

 Table 83:
 ADP[7:0] Pin Functionality

| ECC IN SYSTEM                                      | NO ECC IN SYSTEM                         |                                        |                                           |
|----------------------------------------------------|------------------------------------------|----------------------------------------|-------------------------------------------|
| Primary Pin<br>(ECC Enabled for<br>any SDRAM bank) | ECC Not Enabled<br>for ANY SDRAM<br>bank | DMAReq[1]*<br>sampled HIGH<br>on RESET | DMAReq[3]*<br>sampled<br>HIGH on<br>RESET |
| ADP[0]                                             | EOT[0]                                   |                                        |                                           |
| ADP[1]                                             | EOT[1]                                   |                                        | ALE                                       |
| ADP[2]                                             | EOT[2]                                   |                                        |                                           |
| ADP[3]                                             | EOT[3]                                   | DWr*                                   |                                           |
| ADP[4]                                             | BankSel[1]                               |                                        |                                           |
| ADP[5]                                             | DAdr[11]                                 |                                        |                                           |
| ADP[6]                                             |                                          | SCAS*                                  |                                           |
| ADP[7]                                             |                                          | SRAS*                                  |                                           |





# 5.9 Memory Controller Restrictions

- 1. Unless the boot device is 64-bits wide, the boot must be on the even half (bits 31:0 of AD[63:0] bus).
- 2. When working with an 8- or 16-bit configured bank, a read/write operation can not exceed 64-bits (eight bytes). Since PCI reads are always prefetchable, PCI access to a 8- or 16-bit wide device is not allowed (unless FRAME\* is asserted for a single PClk cycle).
- 3. When an erroneous address is issued or a burst operation is performed to an 8- or 16-bit device, the GT-96100A forces an interrupt (unless masked). If a sequence of address misses occurs, there is no other interrupt prior to resetting the appropriate bit in the cause register and no new address is registered in the Address Decode Error register (0x470) prior to reading it.
- 4. When the CPU reads from an address which is decoded in the CPU Interface Unit as being a hit for CS[2:0]\* or BootCS\* and CS[3]\* and decoded as a miss in the SDRAM/Device Interface Unit, the cycle completes only if Ready\* is asserted (i.e., driven LOW).

Although being a result of improper and inconsistent programming of the address space defining registers, the following 2 workaround exist:

- Ready\* must be asserted (LOW) when CSTiming\* is inactive (HIGH).
- If the Ready\* signal is not needed in the system, the Ready\* pin must be driven active (LOW).
- 5. The minimum parameter for TurnOff, AccToFirst, AccToNext, WrActive, and WrHigh is 1 and for ALEToWr is 3.
- 6. If address decode (register 0x47c) is set to 0, bursts of 64 bytes to 64-bit SDRAM are not supported. Address decode mode 0 (0x47c) should not be used when using 64, 128, or 256Mbit SDRAMs.
- 7. PCI reads from 8- or 16-bit bank must not be prefetchable.
- 8. Access to SDRAM during SDRAM initialization time after reset results in unpredictable behavior.
- 9. When SDRAM CAS latency is 3, RAS precharge time (bit 3 of SDRAM parameter register) must be programmed to 1.
- 10. When using 64/256 Mbit SDRAM, address decode 0 is not allowed.
- 11. In order for memory controller to return data of an internal register read, it must have control over the AD bus.
- 12. When using aggressive prefetch, the highest address that can be read from the PCI is the last DRAM address minus 0x8.
- 13. Table 84 describes the limitation of a 32 bit device in the GT-96100A.

| Terminology | Word: 32 bit<br>Aligned: aligned to a word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Limitation  | During a read/write cycle of an odd number of words to a 32-bit device from an aligned address, or a read/write cycle to a 32-bit device to an unaligned address, an extra read/write occurs to the complementary word of the double-word address accessed with byte enables not active. This may result in destructive reads and loss of performance while accessing the device.                                                                                                                                                                                                                                                                        |
| Examples    | <ol> <li>CPU writes one word to offset 0 of a 32-bit device.<br/>Result: a write to offset 0 with Wr* asserted and a write to offset 4 with Wr* not asserted.</li> <li>CPU writes one word to offset 4 of a 32 bit device.<br/>Result: a write to offset 0 with Wr* not asserted and a write to offset 4 with Wr* asserted.</li> <li>DMA writes five words to offset 0 of a 32 bit device.<br/>Result: Burst of six bits to the device, with the last Wr* not asserted.</li> <li>NOTE: If Ready* is used, the GT-96100A must sample it active an even number of times. i.e., once for address 0 and once for address 4 (see example 1 above).</li> </ol> |
| Workaround  | <ol> <li>If the device is always accessed for single word transfers, connect the AD[4:2], latched, to the device's least significant address pins instead of the BAdr[2:0]. This prevents destructive reads.</li> <li>Access the device always with an even number of words at double word aligned addresses (e.g. 0x0, 0x8, 0x10). This means that the DMA must have the DatTransLimit field set to at least eight bytes. This will make sure there are no destructive reads and no loss of performance.</li> </ol>                                                                                                                                     |

Table 84: 32-bit Device Limitations



# 5.10 Registered SDRAM Interface Restrictions

- 1. All SDRAM DIMMs must be registered (no support for registered and non-registered DIMMs in one system).
- 2. ALL SDRAM DIMMs are 64-bit (no support for 32-bit registered DIMMs).
- 3. Bit 2 (Flow-Through) in all SDRAM parameters registers is set to 0.

# 5.11 Memory Interface Control Registers

#### Table 85: Memory Interface Register Map

| Description                     | Offset | Page Number |  |  |
|---------------------------------|--------|-------------|--|--|
| SDRAM and Device Address Decode |        |             |  |  |
| SCS[0]* Low Decode Address      | 0x400  | page 130    |  |  |
| SCS[0]* High Decode Address     | 0x404  | page 130    |  |  |
| SCS[1]* Low Decode Address      | 0x408  | page 130    |  |  |
| SCS[1]* High Decode Address     | 0x40c  | page 130    |  |  |
| SCS[2]* Low Decode Address      | 0x410  | page 131    |  |  |
| SCS[2]* High Decode Address     | 0x414  | page 131    |  |  |
| SCS[3]* Low Decode Address      | 0x418  | page 131    |  |  |
| SCS[3]* High Decode Address     | 0x41c  | page 131    |  |  |
| CS[0]* Low Decode Address       | 0x420  | page 131    |  |  |
| CS[0]* High Decode Address      | 0x424  | page 132    |  |  |
| CS[1]* Low Decode Address       | 0x428  | page 132    |  |  |
| CS[1]* High Decode Address      | 0x42c  | page 132    |  |  |
| CS[2]* Low Decode Address       | 0x430  | page 132    |  |  |
| CS[2]* High Decode Address      | 0x434  | page 132    |  |  |
| CS[3]* Low Decode Address       | 0x438  | page 133    |  |  |
| CS[3]* High Decode Address      | 0x43c  | page 133    |  |  |
| Boot CS* Low Decode Address     | 0x440  | page 133    |  |  |
| Boot CS* High Decode Address    | 0x444  | page 133    |  |  |
| Address Decode Error            | 0x470  | page 133    |  |  |



| Description                 | Offset | Dege Number |
|-----------------------------|--------|-------------|
| Description                 | Offset | Page Number |
| SDRAM Configuration         |        |             |
| SDRAM Configuration         | 0x448  | page 134    |
| SDRAM Operation Mode        | 0x474  | page 135    |
| SDRAM Burst Mode            | 0x478  | page 135    |
| SDRAM Address Decode        | 0x47c  | page 136    |
| SDRAM Parameters            |        |             |
| SDRAM Bank0 Parameters      | 0x44c  | page 137    |
| SDRAM Bank1 Parameters      | 0x450  | page 138    |
| SDRAM Bank2 Parameters      | 0x454  | page 138    |
| SDRAM Bank3 Parameters      | 0x458  | page 139    |
| ECC                         |        |             |
| ECC Upper Data              | 0x480  | page 139    |
| ECC Lower Data              | 0x484  | page 139    |
| ECC from Memory             | 0x488  | page 139    |
| ECC Calculated              | 0x48c  | page 139    |
| ECC Error report            | 0x490  | page 140    |
| Device Parameters           |        |             |
| Device Bank0 Parameters     | 0x45c  | page 140    |
| Device Bank1 Parameters     | 0x460  | page 141    |
| Device Bank2 Parameters     | 0x464  | page 141    |
| Device Bank3 Parameters     | 0x468  | page 141    |
| Device Boot Bank Parameters | 0x46c  | page 142    |

 Table 85:
 Memory Interface Register Map (Continued)

# 5.11.1 SDRAM and Device Address Decode

Table 86: SCS[0]\* Low Decode Address, Offset: 0x400

| Bits  | Field Name | Function                                                                      | Initial Value |
|-------|------------|-------------------------------------------------------------------------------|---------------|
| 11:0  | Low        | SDRAM bank 0 is accessed when the decoded addresses are between Low and High. | 0x00          |
| 31:12 | Reserved   |                                                                               | 0x0           |

#### Table 87: SCS[0]\* High Decode Address, Offset: 0x404

| Bits  | Field Name | Function                                                                      | Initial Value |
|-------|------------|-------------------------------------------------------------------------------|---------------|
| 11:0  | High       | SDRAM bank 0 is accessed when the decoded addresses are between Low and High. | 0x07          |
| 31:12 | Reserved   |                                                                               | 0x0           |

#### Table 88: SCS[1]\* Low Decode Address, Offset: 0x408

| Bits  | Field Name | Function                                                                      | Initial Value |
|-------|------------|-------------------------------------------------------------------------------|---------------|
| 11:0  | Low        | SDRAM bank 1 is accessed when the decoded addresses are between Low and High. | 0x08          |
| 31:12 | Reserved   |                                                                               | 0x0           |

#### Table 89: SCS[1]\* High Decode Address, Offset: 0x40c

| Bits  | Field Name | Function                                                                      | Initial Value |
|-------|------------|-------------------------------------------------------------------------------|---------------|
| 11:0  | High       | SDRAM bank 1 is accessed when the decoded addresses are between Low and High. | 0x0f          |
| 31:12 | Reserved   |                                                                               | 0x0           |



| Bits  | Field Name | Function                                                                      | Initial Value |
|-------|------------|-------------------------------------------------------------------------------|---------------|
| 11:0  | Low        | SDRAM bank 2 is accessed when the decoded addresses are between Low and High. | 0x10          |
| 31:12 | Reserved   |                                                                               | 0x0           |

Table 90: SCS[2]\* Low Decode Address, Offset: 0x410

#### Table 91: SCS[2]\* High Decode Address, Offset: 0x414

| Bits  | Field Name | Function                                                                      | Initial Value |
|-------|------------|-------------------------------------------------------------------------------|---------------|
| 11:0  | High       | SDRAM bank 2 is accessed when the decoded addresses are between Low and High. | 0x17          |
| 31:12 | Reserved   |                                                                               | 0x0           |

#### Table 92: SCS[3]\* Low Decode Address, Offset: 0x418

| Bits  | Field Name | Function                                                                      | Initial Value |
|-------|------------|-------------------------------------------------------------------------------|---------------|
| 11:0  | Low        | SDRAM bank 3 is accessed when the decoded addresses are between Low and High. | 0x18          |
| 31:12 | Reserved   |                                                                               | 0x0           |

#### Table 93: SCS[3]\* High Decode Address, Offset: 0x41c

| Bits  | Field Name | Function                                                                      | Initial Value |
|-------|------------|-------------------------------------------------------------------------------|---------------|
| 11:0  | High       | SDRAM bank 3 is accessed when the decoded addresses are between Low and High. | 0x1f          |
| 31:12 | Reserved   |                                                                               | 0x0           |

#### Table 94: CS[0]\* Low Decode Address, Offset: 0x420

| Bits  | Field Name | Function                                                                       | Initial Value |
|-------|------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | Low        | Device bank 0 is accessed when the decoded addresses are between Low and High. | 0xc0          |
| 31:12 | Reserved   |                                                                                | 0x0           |

| Bits  | Field Name | Function                                                                       | Initial Value |
|-------|------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | High       | Device bank 0 is accessed when the decoded addresses are between Low and High. | 0xc7          |
| 31:12 | Reserved   |                                                                                | 0x0           |

#### Table 95: CS[0]\* High Decode Address, Offset: 0x424

#### Table 96: CS[1]\* Low Decode Address, Offset: 0x428

| Bits  | Field Name | Function                                                                       | Initial Value |
|-------|------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | Low        | Device bank 1 is accessed when the decoded addresses are between Low and High. | 0xc8          |
| 31:12 | Reserved   |                                                                                | 0x0           |

#### Table 97: CS[1]\* High Decode Address, Offset: 0x42c

| Bits  | Field Name | Function                                                                       | Initial Value |
|-------|------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | High       | Device bank 1 is accessed when the decoded addresses are between Low and High. | 0xcf          |
| 31:12 | Reserved   |                                                                                | 0x0           |

#### Table 98: CS[2]\* Low Decode Address, Offset: 0x430

| Bits  | Field Name | Function                                                                       | Initial Value |
|-------|------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | Low        | Device bank 2 is accessed when the decoded addresses are between Low and High. | 0xd0          |
| 31:12 | Reserved   |                                                                                | 0x0           |

#### Table 99: CS[2]\* High Decode Address, Offset: 0x434

| Bits  | Field Name | Function                                                                       | Initial Value |
|-------|------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | High       | Device bank 2 is accessed when the decoded addresses are between Low and High. | 0xdf          |
| 31:12 | Reserved   |                                                                                | 0x0           |



| Bits  | Field Name | Function                                                                       | Initial Value |
|-------|------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | Low        | Device bank 3 is accessed when the decoded addresses are between Low and High. | 0xf0          |
| 31:12 | Reserved   |                                                                                | 0x0           |

#### Table 100: CS[3]\* Low Decode Address, Offset: 0x438

#### Table 101: CS[3]\* High Decode Address, Offset: 0x43c

| Bits  | Field Name | Function                                                                       | Initial Value |
|-------|------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | High       | Device bank 3 is accessed when the decoded addresses are between Low and High. | 0xfb          |
| 31:12 | Reserved   |                                                                                | 0x0           |

#### Table 102: Boot CS\* Low Decode Address, Offset: 0x440

| Bits  | Field Name | Function                                                                   | Initial Value |
|-------|------------|----------------------------------------------------------------------------|---------------|
| 11:0  | Low        | Boot bank is accessed when the decoded addresses are between Low and High. | 0xfc          |
| 31:12 | Reserved   |                                                                            | 0x0           |

#### Table 103: Boot CS\* High Decode Address, Offset: 0x444

| Bits  | Field Name | Function                                                                   | Initial Value |
|-------|------------|----------------------------------------------------------------------------|---------------|
| 11:0  | High       | Boot bank is accessed when the decoded addresses are between Low and High. | 0xff          |
| 31:12 | Reserved   |                                                                            | 0x0           |

#### Table 104: Address Decode Error, Offset: 0x470

| Bits | Field Name | Function                                                                                                                                                                     | Initial Value |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | ErrAddr    | The addresses of accesses to invalid<br>address ranges (those not in the range<br>programmed in the SDRAM or device<br>decode registers) are captured in this reg-<br>ister. | Oxffffffff    |



# 5.11.2 SDRAM Configuration

# Table 105: SDRAM Configuration, Offset: 0x448

| Bits | Field Name | Function                                                                                                                                     | Initial Value |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 13:0 | RefIntCnt  | Refresh Interval Count Value                                                                                                                 | 0x0200        |
| 14   | Interleave | Bank Interleaving Control<br>0 - Interleaving enabled<br>1 - Interleaving disabled                                                           | 0x0           |
| 15   | RMW        | Enable Read Modify Write<br>0 - Disabled<br>1 - Enabled                                                                                      | 0x0           |
| 16   | StagRef    | Staggered Refresh<br>0 - Staggered refresh<br>1- Non-staggered refresh                                                                       | 0x0           |
| 17   | DisECCEr   | Disable Force ECC Error                                                                                                                      | 0x0           |
| 18   | IntOorT    | Interrupt One or Two                                                                                                                         | 0x0           |
| 19   | DupCntl    | Duplicate Control Pins<br>0 - Do not duplicate<br>1 - Duplicate control pins<br>• DMAReq0* = SRAS*<br>• DMAReq3* = SCAS*<br>• BypsOE* = DWr* | 0x0           |
| 20   | DupBA      | Duplicate Bank Addresses<br>0 - Do not duplicate<br>1 - Duplicate bank addresses<br>• DMAReq[2]* = DAdr[11]<br>• DMAReq[1]* = BankSel[1]     | 0x0           |
| 21   | DupEOT0    | Duplicate End of Transfer 0<br>0 - Do not duplicate<br>1 - Duplicate End of Transfer 0<br>• DMAReq[3]* = EOT0                                | 0x0           |
| 22   | DupEOT1    | Duplicate End of Transfer 1<br>0 - Do not duplicate<br>1 - Duplicate End of Transfer 1<br>• Ready* = EOT1                                    | 0x0           |
| 23   | RegSDRAM   | Registered SDRAM Enable<br>0 - Disable<br>1 - Enable                                                                                         | 0x0           |



| Bits  | Field Name | Function                                                                                  | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------|---------------|
| 24    | DAdr12Sel  | DAdr[12] Pin Select<br>0 - DAdr[12] driven on ADP[0]<br>1 - DAdr[12] driven on DMAReq[3]* | 0x0           |
| 31:25 | Reserved   |                                                                                           | 0x0           |

#### Table 106: SDRAM Operation Mode, Offset: 0x474

| Bits | Field Name | Function                                                                                                                                                                                                      | Initial Value |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 2:0  | SDRAMOp    | Special SDRAM Mode Select<br>000 - Normal SDRAM mode<br>001 - NOP command<br>010 - All banks precharge command<br>011 - Mode register command enable<br>100 - CBR cycle enable<br>101,110, and 111 - Reserved | 0x0           |
| 31:3 | Reserved   |                                                                                                                                                                                                               | 0x0           |

#### Table 107: SDRAM Burst Mode, Offset: 0x478

| Bits  | Field Name      | Function                                                                                                                                                                                                                                                                                                                                                       | Initial Value |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1:0   | Reserved        | Must be 0x1.                                                                                                                                                                                                                                                                                                                                                   | 0x1           |
| 2     | Burst_Order     | 0 - Linear<br>1 - Sub-block                                                                                                                                                                                                                                                                                                                                    | 0x1           |
| 9:3   | Reserved        | Must be 0x1.                                                                                                                                                                                                                                                                                                                                                   | 0x1           |
| 10    | ArbitrationMode | <ul> <li>This bit controls the internal arbitration scheme employed by the memory control unit:</li> <li>0 - Normal arbitration mode (round robin: CPU -&gt; PCI -&gt; DMA -&gt;).</li> <li>1 - CPU preferred arbitration mode (CPU -&gt; PCI -&gt; CPU -&gt; DMA).</li> <li>NOTE: Setting this bit is allowed only after the SDRAM was programmed.</li> </ul> | 0x0           |
| 11    | Reserved        | Must be 0.                                                                                                                                                                                                                                                                                                                                                     | 0x0           |
| 31:12 | Reserved        | Read Only 0.                                                                                                                                                                                                                                                                                                                                                   | Х             |

| Bits | Field Name | Function                                                                                                                  | Initial Value |
|------|------------|---------------------------------------------------------------------------------------------------------------------------|---------------|
| 2:0  | AddrDecode | SDRAM Address Decode<br>See Section 5.1.5 "SDRAM Address<br>Decode Register (0x47c)" on page 104 for<br>more information. | 0x2           |
| 31:3 | Reserved   |                                                                                                                           | 0x0           |

# Table 108: SDRAM Address Decode, Offset: 0x47c



# 5.11.3 SDRAM Parameters

# Table 109: SDRAM Bank0 Parameters, Offset: 0x44c

| Bits | Field Name  | Function                                                                                                                                                                       | Initial Value |
|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1:0  | CASLat      | CAS Latency<br>Identical for all SDRAM banks.<br>1 - 2 cycles<br>2 - 3 cycles<br>3 and 0 - Reserved<br><b>NOTE:</b> This value must be the same as<br>in the SRAStoSCAS field. | 0x1           |
| 2    | FlowThrough | Flow-Through Enable<br>0 - One sample<br>1 - No Sample<br><b>NOTE:</b> Must be set to 0 if ECC or regis-<br>tered SDRAM is enabled.                                            | 0x1           |
| 3    | SRASPrchg   | SRAS Precharge Time<br>0 - 2 cycle<br>1 - 3 cycles                                                                                                                             | 0x0           |
| 4    | Reserved    | Must be set to 0.                                                                                                                                                              | 0x0           |
| 5    | 64bitInt    | 64-bit SDRAM Interleaving<br>0 - 2 way bank interleaving<br>1 - 4 way bank interleaving                                                                                        | 0x0           |
| 6    | BankWidth   | Width of SDRAM bank<br>0 - 32 (36) bit wide SDRAM<br>1 - 64 (72) bit wide SDRAM                                                                                                | 0x0           |
| 7    | BankLoc     | <ul> <li>32-bit SDRAM Bank Location</li> <li>NOTE: Not applicable when using 64-bit SDRAMs.</li> <li>0 - Even, AD[31:0]</li> <li>1 - Odd, AD[63:32]</li> </ul>                 | 0x0           |
| 8    | ECC         | ECC support for the bank.<br>0 - No ECC support<br>1 - ECC supported                                                                                                           | 0x0           |
| 9    | Bypass      | Bypass enable to CPU<br>0 - No Bypass<br>1 - Bypass                                                                                                                            | 0x0           |
| 10   | SRAStoSCAS  | SRAS to SCAS delay<br>0 - 2 cycles<br>1 - 3 cycles<br><b>NOTE:</b> This value must be the same as<br>in the CASLat field.                                                      | 0x0           |

| Bits  | Field Name | Function                                                                      | Initial Value |
|-------|------------|-------------------------------------------------------------------------------|---------------|
| 11    | SDRAMSize0 | 16 or 64/128/256 Mbit SDRAM<br>0 - 16 Mbit SDRAM<br>1 - 64/128/256 Mbit SDRAM | 0x0           |
| 12    | Reserved   | Must be set to 0.                                                             | 0x0           |
| 13    | BrstLen    | Burst Length<br>0 - Burst of 8<br>1 - Burst of 4                              | 0x0           |
| 14    | SDRAMSize1 | 256 Mbit SDRAM support<br>0 - 16 or 64/128 Mbit SDRAM<br>1 - 256Mbit SDRAM    | 0x0           |
| 31:15 | Reserved   |                                                                               | 0x0           |

| Table 109: SDRAM Bank0 Parameters | , Offset: 0x44c (Continued) |
|-----------------------------------|-----------------------------|
|-----------------------------------|-----------------------------|

# Table 110: SDRAM Bank1 Parameters, Offset: 0x450

| Bits  | Field Name      | Function                                                                     | Initial Value |
|-------|-----------------|------------------------------------------------------------------------------|---------------|
| 3:0   | Various         | Fields function as in SDRAM Bank0.                                           | 0x5           |
| 4     | Disable_Refresh | Disable refresh of ALL SDRAM banks.<br>0 - Do refresh<br>1 - Disable refresh | 0x0           |
| 14:5  | Various         | Fields function as in SDRAM Bank0.                                           | 0x0           |
| 31:15 | Reserved        |                                                                              | 0x0           |

# Table 111: SDRAM Bank2 Parameters, Offset: 0x454

| Bits  | Field Name   | Function                                                                                                                | Initial Value |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------|---------------|
| 3:0   | Various      | Fields function as in SDRAM Bank0.                                                                                      | 0x5           |
| 4     | TREQ*_Enable | UMA Total Request pin enable.<br>0 - Disable<br>1 - Enable<br>DMAReq[3]*/SCAS* pin functions as a<br>total request pin. | 0x0           |
| 14:5  | Various      | Fields function as in SDRAM Bank0.                                                                                      | 0x0           |
| 31:15 | Reserved     |                                                                                                                         | 0x0           |



| Bits  | Field Name | Function                           | Initial Value |
|-------|------------|------------------------------------|---------------|
| 3:0   | Various    | Fields function as in SDRAM Bank0. | 0x5           |
| 4     | Reserved   | Must be 0.                         | 0x0           |
| 14:5  | Various    | Fields function as in SDRAM Bank0. | 0x0           |
| 31:15 | Reserved   |                                    | 0x0           |

Table 112: SDRAM Bank3 Parameters, Offset: 0x458

# 5.11.4 ECC

#### Table 113: ECC Upper Data, Offset: 0x480

| Bits | Field Name | Function                                        | Initial Value |
|------|------------|-------------------------------------------------|---------------|
| 31:0 | ECCUpData  | Bits[63:32] of the last data with an ECC error. | 0x0           |

#### Table 114: ECC Lower Data, Offset: 0x484

| Bits | Field Name | Function                                       | Initial Value |
|------|------------|------------------------------------------------|---------------|
| 31:0 | ECCLoData  | Bits[31:0] of the last data with an ECC error. | 0x0           |

#### Table 115: ECC from Mem, Offset: 0x488

| Bits | Field Name | Function                                 | Initial Value |
|------|------------|------------------------------------------|---------------|
| 7:0  | ECCMem     | Eight bits of ECC code read from memory. | 0x0           |
| 31:8 | Reserved   |                                          | 0x0           |

#### Table 116: ECC Calculated, Offset: 0x48c

| Bits | Field Name | Function                                                | Initial Value |
|------|------------|---------------------------------------------------------|---------------|
| 7:0  | ECCCalc    | Eight bits of ECC code calculated inside the GT-96100A. | 0x0           |
| 31:8 | Reserved   |                                                         | 0x0           |

| Bits | Field Name | Function                                                                                                                             | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1:0  | ECCErr     | Number of ECC errors<br>00 - No errors<br>01 - One error detected and corrected<br>10 - Two or more errors detected<br>11 - Reserved | 0x0           |
| 31:2 | Reserved   |                                                                                                                                      | 0x0           |

# Table 117: ECC Error Report, Offset: 0x490

# 5.11.5 Device Parameters

#### Table 118: Device Bank0 Parameters, Offset: 0x45c

| Bits  | Field Name | Function                                                                                                                                                                                                           | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 2:0   | TurnOff    | The number of cycles between the de-<br>assertion of DevOE* to a new AD bus<br>cycle.<br><b>NOTE:</b> An externally extracted signal<br>which is the logical OR between<br>CSTiming* and inverted<br>DevRW*.       | 0x7           |
| 6:3   | AccToFirst | The number of cycles in a read access<br>from the assertion of CS* to the cycle<br>when the data is latched (by the external<br>latches).<br>Extend the number of cycles via the<br>Ready* pin.                    | 0xf           |
| 10:7  | AccToNext  | The number of cycles in a read access<br>from the cycle that the first data is latched<br>to the cycle that the next data is latched (in<br>burst accesses).<br>Extend the number of cycles via the<br>Ready* pin. | 0xf           |
| 13:11 | ALEtoWr    | The number of cycles from ALE de-<br>asserted to the assertion of Wr*.                                                                                                                                             | 0x7           |
| 16:14 | WrActive   | The number of cycles Wr* signals are<br>active.<br>Extend the number of cycles via the<br>Ready* pin.                                                                                                              | 0x7           |
| 19:17 | WrHigh     | The number of cycles between de-asser-<br>tion and assertion of Wr* signals.                                                                                                                                       | 0x7           |



| Bits  | Field Name | Function                                                                                                                                                                                                   | Initial Value |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 21:20 | DevWidth   | Device Width<br>00 - 8 bits<br>01 - 16 bits<br>10 - 32 bits<br>11 - 64 bits                                                                                                                                | 0x2           |
| 22    | DMAFlyBy   | Forwarded to BootCS* during Flyby DMA                                                                                                                                                                      | 0x1           |
| 23    | DevLoc     | <ul> <li>32/16/8 bit device location</li> <li>0 - Even bank <ul> <li>AD[31:0], AD[15:0], and AD[7:0]</li> </ul> </li> <li>1 - Odd bank <ul> <li>AD[63:32], AD[47:32], and AD[39:32]</li> </ul> </li> </ul> | 0x0           |
| 24    | Reserved   | Read only.                                                                                                                                                                                                 | 0x0           |
| 25    | Reserved   | Must be 0.                                                                                                                                                                                                 | 0x0           |
| 29:26 | DMAFlyBy   | Forwarded to CS[3:0]* during FlyBy DMA.                                                                                                                                                                    | 0xe           |
| 31:30 | Reserved   | Must be 0.                                                                                                                                                                                                 | 0x0           |

#### Table 119: Device Bank1 Parameters, Offset: 0x460

| Bits | Field Name | Function                            | Initial Value |
|------|------------|-------------------------------------|---------------|
| 31:0 | Various    | Fields function as in Device Bank0. | 0x386fffff    |

#### Table 120: Device Bank2 Parameters, Offset: 0x464

| Bits | Field Name | Function                            | Initial Value |
|------|------------|-------------------------------------|---------------|
| 31:0 | Various    | Fields function as in Device Bank0. | 0x386fffff    |

#### Table 121: Device Bank3 Parameters, Offset: 0x468

| Bits | Field Name | Function                            | Initial Value |
|------|------------|-------------------------------------|---------------|
| 31:0 | Various    | Fields function as in Device Bank0. | 0x38?fffff    |

| Table 122 | Device I | Root Bank  | Parameters  | Offset: 0x46c |
|-----------|----------|------------|-------------|---------------|
|           | Device   | DUUL Dalik | raiameters, |               |

| Bits | Field Name | Function                                                                          | Initial Value |
|------|------------|-----------------------------------------------------------------------------------|---------------|
| 31:0 | Various    | Fields function as in Device Bank0.<br>Bits bits [29:26] and bit 22 are reserved. | 14?fffff      |

**NOTE:** In case of Bank3 or Boot Bank, bits [23:20] are shown as '?' because bits 21:20 are sampled at reset via DAdr[4:3] to define the width of the boot device.



# 6. DATA INTEGRITY

GT-96100A supports:

- Parity generation and checking on CPU and PCI interfaces.
- ECC generation and checking on SDRAM interfaces.
- Errors propagation between these the CPU, PCI, and SDRAM interfaces.

# 6.1 SDRAM ECC

The GT-96100A implements Error Checking and Correction (ECC) on accesses to the SDRAM. It supports detection and correction of one data bit error, detection of two bits error, and detection of three or four bit errors, if residing in the same nibble.

# 6.1.1 ECC Calculation

Each of the 64 data bits and eight check bits has a unique 8-bit ECC check code, as shown in Table 123. For example, data bit 12 has the check value of 01100001, and check bit 5 has the check value of 00100000.

|           |          |   | ļ | ECC | Number of |   |   |   |   |       |
|-----------|----------|---|---|-----|-----------|---|---|---|---|-------|
| Check Bit | Data Bit | 7 | 6 | 5   | 4         | 3 | 2 | 1 | 0 | 1s in |
|           | 63       | 1 | 1 | 0   | 0         | 1 | 0 | 0 | 0 | 3     |
|           | 62       | 1 | 1 | 0   | 0         | 0 | 1 | 0 | 0 | 3     |
|           | 61       | 1 | 1 | 0   | 0         | 0 | 0 | 1 | 0 | 3     |
|           | 60       | 1 | 1 | 0   | 0         | 0 | 0 | 0 | 1 | 3     |
|           | 59       | 1 | 1 | 1   | 1         | 0 | 1 | 0 | 0 | 5     |
|           | 58       | 1 | 0 | 0   | 0         | 1 | 1 | 1 | 1 | 5     |
| 4         |          | 0 | 0 | 0   | 1         | 0 | 0 | 0 | 0 | 1     |
| 3         |          | 0 | 0 | 0   | 0         | 1 | 0 | 0 | 0 | 1     |
|           | 57       | 1 | 1 | 1   | 0         | 0 | 0 | 0 | 0 | 3     |
|           | 56       | 1 | 0 | 1   | 1         | 0 | 0 | 0 | 0 | 3     |
|           | 55       | 0 | 0 | 0   | 0         | 1 | 1 | 1 | 0 | 3     |
|           | 54       | 0 | 0 | 0   | 0         | 1 | 0 | 1 | 1 | 3     |
|           | 53       | 1 | 1 | 1   | 1         | 0 | 0 | 1 | 0 | 3     |
|           | 52       | 0 | 0 | 0   | 1         | 1 | 1 | 1 | 1 | 5     |
| 5         |          | 0 | 0 | 1   | 0         | 0 | 0 | 0 | 0 | 5     |
| 2         |          | 0 | 0 | 0   | 0         | 0 | 1 | 0 | 0 | 1     |

#### Table 123: ECC Code Matrix

#### Table 123: ECC Code Matrix (Continued)

|           | ECC Code Bits |   |   |   |   |   |   |   |   | Number of          |
|-----------|---------------|---|---|---|---|---|---|---|---|--------------------|
| Check Bit | Data Bit      | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Number of<br>1s in |
|           | 51            | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1                  |
|           | 50            | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 3                  |
|           | 49            | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 3                  |
|           | 48            | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 3                  |
|           | 47            | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 3                  |
|           | 46            | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 3                  |
|           | 45            | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 3                  |
|           | 44            | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 3                  |
|           | 43            | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 3                  |
|           | 42            | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 3                  |
|           | 41            | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 3                  |
|           | 40            | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 3                  |
|           | 39            | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 3                  |
|           | 38            | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 3                  |
|           | 37            | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 3                  |
|           | 36            | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 3                  |
|           | 35            | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 3                  |
|           | 34            | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 3                  |
|           | 33            | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 3                  |
|           | 32            | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 3                  |
|           | 31            | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 3                  |
|           | 30            | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 3                  |
|           | 29            | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 3                  |
|           | 28            | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 3                  |
|           | 27            | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 3                  |
|           | 26            | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 3                  |
|           | 25            | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 3                  |
|           | 24            | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 3                  |
|           | 23            | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 3                  |



|           |          |   | ECC Code Bits |   |   |   | Newskara |   |   |                    |
|-----------|----------|---|---------------|---|---|---|----------|---|---|--------------------|
| Check Bit | Data Bit | 7 | 6             | 5 | 4 | 3 | 2        | 1 | 0 | Number of<br>1s in |
|           | 22       | 0 | 1             | 0 | 0 | 0 | 1        | 0 | 1 | 3                  |
|           | 21       | 0 | 0             | 1 | 0 | 0 | 1        | 0 | 1 | 3                  |
|           | 20       | 0 | 0             | 0 | 1 | 0 | 1        | 0 | 1 | 3                  |
|           | 19       | 1 | 0             | 0 | 0 | 1 | 1        | 0 | 0 | 3                  |
|           | 18       | 0 | 1             | 0 | 0 | 1 | 1        | 0 | 0 | 3                  |
|           | 17       | 0 | 0             | 1 | 0 | 1 | 1        | 0 | 0 | 3                  |
|           | 16       | 0 | 0             | 0 | 1 | 1 | 1        | 0 | 0 | 3                  |
|           | 15       | 0 | 1             | 1 | 0 | 1 | 0        | 0 | 0 | 3                  |
|           | 14       | 0 | 1             | 1 | 0 | 0 | 1        | 0 | 0 | 3                  |
|           | 13       | 0 | 1             | 1 | 0 | 0 | 0        | 1 | 0 | 3                  |
|           | 12       | 0 | 1             | 1 | 0 | 0 | 0        | 0 | 1 | 3                  |
|           | 11       | 1 | 1             | 1 | 1 | 1 | 0        | 0 | 0 | 5                  |
|           | 10       | 0 | 1             | 0 | 0 | 1 | 1        | 1 | 1 | 5                  |
| 7         |          | 1 | 0             | 0 | 0 | 0 | 0        | 0 | 0 | 1                  |
| 0         |          | 0 | 0             | 0 | 0 | 0 | 0        | 0 | 1 | 1                  |
|           | 9        | 0 | 1             | 1 | 1 | 0 | 0        | 0 | 0 | 3                  |
|           | 8        | 1 | 1             | 0 | 1 | 0 | 0        | 0 | 0 | 3                  |
|           | 7        | 0 | 0             | 0 | 0 | 0 | 1        | 1 | 1 | 3                  |
|           | 6        | 0 | 0             | 0 | 0 | 1 | 1        | 0 | 1 | 3                  |
|           | 5        | 1 | 1             | 1 | 1 | 0 | 0        | 0 | 1 | 5                  |
|           | 4        | 0 | 0             | 1 | 0 | 1 | 1        | 1 | 1 | 5                  |
| 6         |          | 0 | 1             | 0 | 0 | 0 | 0        | 0 | 0 | 1                  |
| 1         |          | 0 | 0             | 0 | 0 | 0 | 0        | 1 | 0 | 1                  |
|           | 3        | 1 | 0             | 0 | 0 | 0 | 0        | 1 | 1 | 3                  |
|           | 2        | 0 | 1             | 0 | 0 | 0 | 0        | 1 | 1 | 3                  |
|           | 1        | 0 | 0             | 1 | 0 | 0 | 0        | 1 | 1 | 3                  |
|           | 0        | 0 | 0             | 0 | 1 | 0 | 0        | 1 | 1 | 3                  |

 Table 123: ECC Code Matrix (Continued)



The GT-96100A calculates ECC by taking the EVEN parity of ECC check codes of all data bits that are logic one. For example, if the 64 bit data is 0x45. The binary equivalent is 01000101. From Table 123, the required check codes are 00001101 (bit[6]), 01000011 (bit[2]) and 00010011 (bit[0]). Bitwise XOR of this check codes (even parity) result in ECC value of 01011101.

On a write transaction to a 64-bit wide SDRAM, if ECC is enabled, the GT-96100A calculates the new ECC and writes it to the ECC bank along with the data that is written to the data bank. Since the ECC calculation is based on a 64-bit data width, if the write transaction is smaller than 64 bits, the GT-96100A runs a read modify write sequence.

For a read transaction from a 64-bit wide SDRAM, if ECC is enabled, the GT-96100A reads a 64-bit data and 8bit ECC. It calculates ECC based on the 64-bit data and then compares it against the received ECC. The result of this comparison (bitwise XOR between received ECC and calculated ECC) is called syndrome. If the syndrome is 00000000, both the received data and ECC are correct. If the syndrome is any other value, it is assumed either the received data or the received ECC are in error.

If the syndrome contains a single 1, there is a single bit error in the ECC byte. For example, if the received data is 0x45, the calculated ECC is 01011101, as explained before. If the received ECC is 01010101, the resulting syndrome is 00001000. Table 123 shows that this syndrome corresponds to check bit 3. GT-96100A will not report nor correct this type of error.

If the syndrome contains three or five 1's, it indicates that there is at least one data bit error. For example, if the received data is 0x45, the calculated ECC is 01011101, as explained before. If the received ECC is 00011110, the resulting syndrome is 01000011. This syndrome includes three 1's and it corresponds to data bit 2 as shown in Table 123. GT-96100A corrects the data by inverting data bit 2 (the corrected data is 0x41).

If the result syndrome contains two 1's, it indicates that there is a double-bit error.

If the result syndrome contains four 1's, it indicates a 4-bit error located in four consecutive bits of a nibble.

If the result syndrome contains three or five 1's and does not corresponds to any data bit, it indicates a triple-bit error within a nibble.

These types of errors cannot be corrected. The GT-96100A reports an error but will not change the data.

**NOTE:** ECC is not supported in bypass mode (data must go through GT-96100A in order to be checked and corrected).

## 6.1.2 ECC Error Report

If the GT-96100A identifies an ECC data bit error, it sets MemErr bit in Interrupt Cause register (an interrupt is asserted if not masked).

Additionally, it stores error information in dedicated registers.

- The 64-bit data in ECC Upper Data and ECC Lower Data registers.
- The ECC byte read from memory in ECC from Memory register.
- The calculated ECC byte in ECC Calculated register.
- Address bits[31:2] of the erroneous data in ECC Address register. In bits[1:0] it reports whether it was a single data bit error or multiple data bits error.



# 6.2 PCI Parity Support

The GT-96100A implements all parity features required by PCI spec, including PAR, PERR\*, and SERR\* generation and checking (also PAR64 in case of 64-bit PCI configuration).

As an initiator, the GT-96100A generates even parity on PAR signals for address phase and data phase of write transaction. It samples PAR on data phase of read transactions. If the GT-96100A detects bad parity and PErrEn bit in Status and Command Configuration register is set, it asserts PERR\*.

As a target, the GT-96100A generates even parity on PAR signal for data phase of a read transaction. It samples PAR on address phase and data phase of write transactions. If the GT-96100A detects bad parity and PErrEn bit in Status and Command Configuration register is set, it asserts PERR\*.

The GT-96100A asserts SERR\* if any of the following occur:

- Detects a bad address parity as a target.
- Detects a bad data parity on a write transaction as a master (detects PERR\* asserted).
- Detects a bad data parity on a read transaction as a master.
- Detects ECC error on read from SDRAM or Device.
- Performs master abort.
- Detects target abort.

SERR\* is asserted if SErrEn bit in Status and Command configuration register is set to 1 and if SERR\* is not masked through SERR Mask register.

NOTE: For a description of the Serr0\* and Serr1\* registers, see Table 418 and Table 419.

# 6.3 Parity Support for Devices

There is no dedicated logic in the GT-96100A to support devices parity. If Devices parity checking is required, it can be implemented externally using '511 devices and some logic for interrupt generation.

Still, the GT-96100A generates EVEN parity on CPU SysADC lines during CPU read transaction from devices.

# 6.4 CPU Parity Support

CPU parity is supported through SysADC lines.

On write transactions, CPU drives even parity on SysADC. The GT-96100A samples the incoming data driven on SysAD and the parity driven on SysADC. In case of parity error, the GT-96100A latches:

- The address in CPU Error address register.
- The data in CPU Error Data register.
- The parity in CPU Error Parity register.

On read transactions, CPU drives even parity on SysADC, in parallel to the data it drives on SysAD.

CPU parity errors are reported through CPUOut interrupt bit in the interrupt cause register, and through SysCmd[5] in case of read transaction.

**NOTES:**CPU Error Address register is also used to latch the address in case of CPU address decoding error. More over, CPUOut interrupt bit is used both for CPU address decoding error as well as CPU parity error indication. In order for interrupt handler to distinguish between the two interrupts events, it needs to read CPU Error Data register and compare against its previous value. If register value changed, it implies it is a parity error.

The CPUOut interrupt bit is set in case of parity error only if SysADCValid bit in CPU Configuration register is set to 1.

# 6.5 Data Integrity Flow

## 6.5.1 CPU writes to SDRAM and PCI

The GT-96100A samples the SysADC (CPU parity) lines when the CPU performs a write transaction to PCI or SDRAM. Parity checking is performed by the GT-96100A.

If a parity error occurs, the GT-96100A latches the address, data, and parity lines, see Section 6.6 "Register Information" on page 150. The GT-96100A also generates an interrupt (via Interrupt\*) to the CPU indicating a parity error has been detected on the CPU parity lines.

In addition, the GT-96100A forces two ECC errors when writing the data to the SDRAM. This feature is configured through ForceEccErr bit in SDRAM Configuration register, see Section 6.6 "Register Information" on page 150. This will make sure that when the data is read by another resource, the ECC bits will indicate erroneous data to the reading device.

## 6.5.2 CPU reads from SDRAM

The GT-96100A samples the ADP (SDRAM ECC) lines when the CPU performs a read transaction from the SDRAM. An ECC check is performed by the GT-96100A SDRAM interface.

In case there is a 2-bit ECC error, the GT-96100A generates an interrupt to the CPU and drives the Bus\_Err bit (SysCmd[5]) to the CPU. The SysADC lines will NOT drive the wrong value, assuming the Bus\_Err and the interrupt are sufficient indications for the CPU.

In case of a single-bit ECC error, the default does NOT interrupt the CPU and the error is corrected. The GT-96100A can be programmed to interrupt the CPU on single bit ECC errors, see Section 6.6 "Register Information" on page 150. Regardless, the data is corrected and then returned to the CPU. Also, the address, data, ECC bits, and an indication for single or double ECC errors are latched in the GT-96100A ECC error report registers, see Section 6.6 "Register Information" on page 150.

## 6.5.3 CPU reads from PCI

When the CPU reads data from the PCI, the PAR signal (and PAR64 in case of 64-bit PCI) is sampled. In case PAR does NOT match the data, an interrupt to the CPU is generated.



## 6.5.4 PCI writes to GT-96100A SDRAM

When a PCI master writes data to the GT-96100A's SDRAM, the PAR signal (PAR64 in case of 64-bit PCI) is sampled. In case PAR does NOT match the data, PERR\* is asserted on the PCI bus and an interrupt to the CPU is generated. The ECC bits will not be intentionally damaged while being written to the SDRAM (GT-96100A will generate correct ECC to SDRAM based on the written data, ignoring the bad PAR indication).

## 6.5.5 PCI reads from the SDRAM

When a PCI master reads data from the GT-96100A's SDRAM, the GT-96100A samples the ADP (SDRAM ECC) lines. An ECC check is performed by the GT-96100A.

In case there is a 2-bit ECC error, the GT-96100A generates an interrupt to the CPU (and PCI) and defaults to driving PAR with the correct value matching the data. This feature is configured, see Section 6.6 "Register Information" on page 150, and PAR can be chosen to be driven with a value NOT matching the data.

In case of a single ECC error, an interrupt to the CPU (and PCI) is generated and the data is corrected and returned to the PCI. PAR will drive a correct value, matching the data.

In both cases the address, data, ECC bits, and an indication for single or double ECC errors are latched in the GT-96100A ECC error report registers.

## 6.5.6 DMA cycles

There is no change in the implementation of data integrity during DMA transfers from the GT-64120 device. If a parity/ECC error is detected during a DMA transfer from the SDRAM or from the PCI, an interrupt is generated.

In case of a single-bit ECC error, the default does NOT interrupt the CPU and the error is corrected. The GT-96100A can be programmed to interrupt the CPU on single-bit ECC errors, see Section 6.6 "Register Information" on page 150. Regardless, the data is corrected and then returned to the DMA Unit. Also, the address, data, ECC bits, and an indication for single or double ECC errors are latched in the GT-96100A ECC error report registers.

# 6.6 Register Information

Table 124 describes the registers used to implement parity and ECC in the GT-96100A.

| Table 124: Registers for Implementing Parity and ECC |  |
|------------------------------------------------------|--|
|------------------------------------------------------|--|

| Register                                                     | Offset           | Description                                                                                                                                                                                                                                                                                                 |
|--------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU Error<br>Address                                         | 0x70             | Holds the lower 32 bits of the address during a parity error on SysADC (CPU write).                                                                                                                                                                                                                         |
|                                                              | 0x78             | Holds the upper 5 bits of the CPU address during a parity error on SysADC (CPU write).                                                                                                                                                                                                                      |
| CPU Error                                                    | 0x128            | Holds the lower 32 bits of the data during a parity error on SysADC (CPU write).                                                                                                                                                                                                                            |
| Data                                                         | 0x130            | Holds the upper 32 bits of the data during a parity error on SysADC (CPU write).                                                                                                                                                                                                                            |
| CPU Error<br>Parity                                          | 0x138            | Holds the SysADC lines when parity error is detected (CPU write).                                                                                                                                                                                                                                           |
| ECC Error<br>Address                                         | 0x490            | <ul> <li>Bits [31:2] holds the 30 MSB of the address to the SDRAM when an ECC error is detected (CPU/PCI/DMA read from SDRAM).</li> <li>Bit [1], if active, indicates that two or more ECC errors are detected.</li> <li>Bit [0] - If active, indicates that a single bit ECC error is detected.</li> </ul> |
| ECC Error 0x480<br>Data 0x484                                |                  | Holds the upper 32 bits of the data when an error is detected (CPU/PCI/DMA read from SDRAM).                                                                                                                                                                                                                |
|                                                              |                  | Holds the lower 32 bits of the data when an error is detected (CPU/PCI/DMA read from SDRAM).                                                                                                                                                                                                                |
| ECC from<br>Memory                                           | 0x488            | Holds the ECC read from memory when an error is detected.                                                                                                                                                                                                                                                   |
| ECC Calcula-<br>tion                                         | 0x48C            | Holds the value calculated by the GT-96100A as correct ECC. This value may be helpful during debug.                                                                                                                                                                                                         |
| Force bad<br>PAR on PCI                                      | 0xc00,<br>bit 26 | 0 - Par always drives matching value (Default).<br>1 - Par will drive wrong value if ECC error detected.                                                                                                                                                                                                    |
| read bad ECC<br>from SDRAM                                   | 0xc80,<br>bit 26 |                                                                                                                                                                                                                                                                                                             |
| Force SDRAM<br>ECC error on<br>CPU writes<br>with bad parity | 0x448,<br>bit 17 | <ul> <li>0 - SDRAM interface unit writes two ECC errors to the SDRAM (Default).</li> <li>1 - ECC will always be written correctly to the SDRAM.</li> </ul>                                                                                                                                                  |
| Interrupt for 1<br>or 2 ECC<br>errors                        | 0x448,<br>bit 18 | <ul><li>0 - Interrupt only if two ECC errors are detected (Default).</li><li>1 - Interrupt when one or two ECC errors are detected.</li></ul>                                                                                                                                                               |



# 6.7 CPU Errors Report Registers

#### Table 125: CPU Error Address (Low), Offset: 0x070

| Bits | Field Name | Function                                                                                                                                         | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | llegLoAdd  | This register captures bits 31:0 of an illegal 36-<br>bit address, or an address of a CPU write<br>transaction with bad parity driven on SysADC. | 0x0           |

#### Table 126: CPU Error Address (High), Offset: 0x078

| Bits | Field Name | Function                                                                                                                                   | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 3:0  | llegHiAdd  | This register captures bits 35:32 of an illegal 36-bit address, or an address of a CPU write transaction with bad parity driven on SysADC. | 0x0           |
| 31:4 | Reserved   |                                                                                                                                            | 0x0           |

#### Table 127: CPU Error Data (Low), Offset: 0x128

| Bits | Field Name | Function                                                                         | Initial Value |
|------|------------|----------------------------------------------------------------------------------|---------------|
| 31:0 | DataErr    | Holds the lower 32 bits of the data during a parity error on SysADC (CPU write). | 0xffffffff    |

#### Table 128: CPU Error Data (High), Offset: 0x130

| Bits | Field Name | Function                                                                         | Initial Value |
|------|------------|----------------------------------------------------------------------------------|---------------|
| 31:0 | DataErr    | Holds the upper 32 bits of the data during a parity error on SysADC (CPU write). | 0xffffffff    |

#### Table 129: CPU Error Parity, Offset: 0x138

| Bits | Field Name | Function                                                            | Initial Value |
|------|------------|---------------------------------------------------------------------|---------------|
| 7:0  | ParErr     | Holds the SysADC lines when a parity error is detected (CPU write). | 0xff          |
| 31:8 | Reserved   | Reserved.                                                           | 0x0           |



# 7. PCI INTERFACES

The GT-96100A can be configured to have two 32-bit PCI buses, or one 64-bit PCI bus; all compliant with Revision 2.1 of the PCI Specification.

Both 3.3V and 5V operations are supported through the use of universal PCI buffers. Support for the  $I_2O$  specification is also included.

# 7.1 Reset Configuration

At reset, the GT-96100A can be configured to have one 64-bit PCI interface or two 32-bit PCI interfaces, see Section 22. "Reset Configuration" on page 452. Each PCI interface can be either a master initiating a PCI bus operation or a target responding to a PCI bus operation.

**NOTE:** When the GT-96100A is configured with two 32-bit PCI interfaces, both interfaces are almost identical in behavior and structure. The only difference is that PCI interface 1 (PCI\_1) does not support locked cycles and does not have a separate interrupt signal.

If no reference is made to a particular PCI interface, then the description in this section applies to both interfaces.

# 7.2 PCI Master Operation

When the CPU or the internal DMA machine initiates a bus cycle to a PCI device, the GT-96100A needs to decode the target address to determine which address space is being accessed.

If the GT-96100A is configured as one 64-bit PCI interface, then PCI\_0 registers are used for address comparison and remapping.

If the GT-96100A is configured with two 32-bit PCI buses, the address registers of both interfaces are used for comparison. Based on the match results, either PCI\_0 or PCI\_1 becomes the master on the PCI bus and translates the cycle into the appropriate PCI bus cycle.

Supported master PCI cycles are:

- Memory Read
- Memory Write
- Memory Read Line
- Memory Read Multiple
- Memory Write and Invalidate
- I/O Read
- I/O Write
- Configuration Read
- Configuration Write
- Interrupt Acknowledge
- Special Cycle



Memory Write and Invalidate and Memory Read Line cycles are carried out when the transaction accessing PCI memory space requests a data transfer equal to the PCI cache line size. In case the transfer initiator is a DMA engine, the requested address must be cache line aligned. In case of write transaction, Memory Write and Invalidate Enable bit in the Configuration Command register must be set. When the PCI cache line size is set equal to 0, the GT-96100A never issues Memory Write and Invalidate or Memory Read Line cycles.

Memory Read Multiple is carried out when the transaction accessing PCI memory space requests a data transfer greater than the PCI cache line size.

As a master, the GT-96100A does not issue Dual Address cycles (DAC) or Lock cycles on the PCI.

The PCI posted write buffer in the GT-96100A permits the CPU to complete CPU-to-PCI memory writes even if the PCI bus is busy. The posted data is written to the target PCI device when the PCI bus becomes available.

## 7.2.1 PCI Master CPU Address Space Decode and Translation

Local masters access the PCI space through the PCI\_0/1 Memory 0, PCI\_0/1 Memory 1, and PCI\_0/1 I/O decoders in CPU address space.

CPU accesses claimed by these decoders are translated into the appropriate PCI cycles by the appropriate PCI interface (PCI\_0 only in case of 64-bit PCI interface). The address seen on the CPU bus is copied directly to the PCI bus (unless the CPU-to-PCI address remapping capability is enabled.) For example, if an access to 0x1200.0040 is programmed to be bridged as a memory read from PCI, the active PCI address for this cycle will be 0x1200.0040.

## 7.2.2 PCI Master CPU Byte Swapping

All accesses to PCI space by the CPU can have the data byte order swapped as the data moves through the GT-96100A. Byte swapping is turned on via the MByteSwap bit in the PCI Internal Command register (0xc00.)

When the GT-96100A is configured for 64-bit PCI mode, byte swapping occurs across all eight byte lanes when the ByteSwap bit is set for PCI\_0.



## 7.2.3 PCI Master FIFOs

If the GT-96100A is configured to have one 64-bit PCI interface, then this interface includes a FIFO of eight entries, each 64-bits wide (64 bytes total), see Figure 25.





If the GT-96100A is configured to have two 32-bit PCI interfaces, then each master interface includes its own FIFO of eight entries, each 64-bits wide, see Figure 26. During writes to the PCI interface, the target PCI unit receives write data from the CPU interface or the DMA unit. When the PCI bus is granted, the PCI master's FIFO delivers the write data to the target on the PCI bus.







Upon receiving the first 32- or 64-bit data from the CPU interface or DMA unit, the PCI master interface requests the PCI bus, if the GT-96100A is not already parked. Once granted, the appropriate write cycle is started on the PCI bus.

During reads, the PCI master interface FIFO receives read data from the PCI bus and delivers it to the CPU interface or the DMA unit. Upon receiving the first word or doubleword from the PCI target, the data is forwarded to the requesting unit (CPU interface or DMA unit). The GT-96100A supports sub-block ordering during CPU reads, therefore if the original read request address is not aligned to a cache line boundary, then the first 32-bit word (or 64-bit double-word in case of a 64-bit PCI interface) returned to the requesting unit is delayed until it is received from the PCI target, since reads across the PCI bus are linear.

The GT-96100A internal architecture allows zero wait-state data transfer over the PCI bus (Irdy\* continuously asserted) during both master reads and writes.

## 7.2.4 PCI Master DMA

The GT-96100A's internal DMA engines act as PCI bus masters while transferring data to/from the PCI bus. The DMA engines only issue PCI memory space read and write cycles. The type of cycle issued follows the same rules as for the CPU.

The DMA engines transfers data between PCI devices using the on-chip DMA FIFOs for temporary storage.

**NOTE:** See Section 9. "Independent DMA Controllers (IDMA Controllers)" on page 219 for a detailed description of the DMA engines.

## 7.2.5 PCI Master RETRY Counter

RETRYs detected by the PCI master interface are normally handled transparently from the point of view of the CPU or DMA engines.

In some rare circumstances, however, a target device may RETRY the GT-96100A excessively (or forever.) Use the Retry Counter to recover from this condition. Every time the number of RETRYs equals the value in the Retry Counter, the GT-96100A aborts the cycle and sends an interrupt to the CPU. If the cycle was a read, undefined data is returned and the ERROR bit is set within the data identifier.

Disable the Retry Counter by setting the Retry count to zero.



## 7.3 PCI Target Interface

The GT-96100A responds to the following PCI cycles as a target device:

- Memory Read
- Memory Write
- Memory Read Line
- Memory Read Multiple
- Memory Write and Invalidate
- I/O Read
- I/O Write
- Configuration Read
- Configuration Write
- Locked Read to PCI\_0 only
- Locked Write to PCI\_0 only

The GT-96100A will not act as a target for Interrupt Acknowledge, Special, and Dual Address cycles. These cycles are ignored.)

## 7.3.1 PCI Target FIFOs

The GT-96100A incorporates dual 64-byte posted write/read prefetch buffers, per PCI interface. These buffers allow full memory (AD) and PCI bus concurrency. The dual FIFOs can operate in a "ping-pong" fashion, each FIFO alternating between filling and draining, see Figure 27 and Figure 28.

When the GT-96100A is the target of PCI write cycles, data is first written to one of the FIFOs. When the first FIFO fills up (64 bytes), the data is written to the destination from the first FIFO while the second FIFO is filled. This "ping-pong" operation continues as long as data is received from the PCI bus. The GT-96100A de-asserts TRDY for 2 PCI clocks while switching target FIFOs.

Occasionally, the PCI target interface cannot drain the FIFOs (i.e. write to local memory) as fast as data is received. This occurs when access to memory is prevented (possibly by excessive CPU accesses) or when the target memory is particularly slow. In this case, the GT-96100A's PCI target interface de-asserts TRDY until one of the FIFOs is empty again and might even issue a DISCONNECT to the PCI bus if reached timeout, see Section 22. "Reset Configuration" on page 452.

The target FIFOs are also used to align data bursts that do not start on 64-byte boundaries for more efficient processing by the GT-96100A's memory subsystem. When an incoming burst passes a 64-byte boundary, the target FIFOs switch and the remainder of the burst (now aligned to a 64-byte boundary) fills the new FIFO. TRDY deasserts for two PCI clocks when the FIFO switch occurs.





Figure 27: PCI Target Interface "Ping-Pong" FIFOs





Figure 28: PCI Target Interface FIFOs Operational Example

NOTE: Graphic shows only 8 of the 16 entries in the FIFOs (in 32-bit mode)

## 7.3.2 Controlling Burst Length

The GT-96100A's memory interface is capable of maximum burst of eight data bursts to SDRAM or devices, regardless of the device width. This implies that if the device is 64-bits wide, it can burst up to 64 bytes in a single transaction. If the device is 32-bits wide it can burst up to 32 bytes per transaction and so on.

The PCI target is limited to requesting burst reads/writes from the memory interface that are not greater than the bursts supported by the controller. Each PCI target FIFO corresponds to a single memory interface transaction. The PCI target has a programmable FIFO depth. The MaxBurst register (offset 0xc40) defines the FIFO depth per each Base Address Register. If the FIFO depth is set to 16 (MaxBurst = 1) then the maximum burst is 64 bytes to/from the memory interface. If the FIFO depth is eight (MaxBurst = 0) then a maximum burst of 32 bytes is supported on the memory interface.

The system's software must program the MaxBurst register properly.

**NOTE:** In order to support PCI bursts to a 32-bit SDRAM or device, MaxBurst must be set to 0. This is also true for a 64-bit SDRAM programed to burst length of 4.

MaxBurst may be used for performance optimization in systems with 64-bit wide memory. In some cases, it is sometimes preferred to keep the bursts short to allow CPU or DMA to get more memory interface bandwidth. In this case, setting the MaxBurst value to 8 may be an appropriate strategy.



## 7.3.3 PCI Target Read Prefetching

The target FIFOs are also used for read prefetch. The Memory Read (MR), Memory Read Line (MRL), and Memory Read Multiple (MRM) cycles are executed as prefetchable read cycles.

The Device/DRAM Unit fills the target FIFOs as soon as it is determined that the PCI request will be longer than a single word (based on how long Frame\* is asserted.) The "aggressiveness" of the prefetch is controlled by the type of read command (MR/MRL/MRM) and the state of the bits for each of the read command types in the Prefetch/Max\_Burst register.

By default, the only "aggressive" prefetched read is the Memory Read Multiple. Both Memory Read and Memory Read Line commands are marked for aggressive prefetch via the Prefetch/Max\_Burst register. With aggressive prefetch, as soon as at least one word is delivered from the FIFO to the PCI bus, the PCI slave requests from the Device/DRAM unit to prefetch into the second FIFO.

**NOTE:** When using aggressive prefetch, the upper address allowed to be read from the PCI is last DRAM address minus 0x8.

In a non-aggressive prefetch, read cycle data is prefetched into only one of the target FIFOs. Data is not fetched into the second FIFO until all the data from the first FIFO is delivered to the PCI bus. MR and MRL cycles are by default, non-aggressive prefetch.

**NOTE:** All three types of read commands will result in prefetch (multiple read cycles) on the Device/DRAM bus unless Frame\* is only asserted for a single cycle.

Cycles to internal registers and Configuration cycles are non-postable nor prefetchable. These cycles are always single word.

**NOTE:** If a PCI master attempts to burst transaction to internal register, the GT-96100A disconnects after the first TRDY\*.

## 7.3.4 PCI Target Address Space Decode and Byte Swapping

The GT-96100A decodes accesses on the PCI bus, for which it may be a target, by the values programmed into the Base Address registers (BARs).

There are two sets of BARs for each PCI interface: regular BARs (in PCI Function 0) and swap BARs (in PCI Function 1). Accesses decoded by the regular BARs are passed without modifying the data to or from the target memory device. Accesses decoded by the swap BARs are passed with to or from the target memory device after converting the endianess of the data (e.g. little-endian to big-endian).

The GT-96100A uses a two stage decode process for accesses through the PCI devices target interface. Once a PCI access is determined to be a "hit" based on the BAR comparison, the address is passed to the Device Unit for sub-decode. For example, PCI\_0 Base Address Register 0 in Function 0 (PCI\_0 BAR0) decodes non-byte swapped accesses to the SDRAM controlled by either SCS[0]\* or SCS[1]\*. The GT-96100A then uses the values programmed into the SCS[0]\* Low and SCS[0] High decode registers to determine if the access is to the SDRAM in SCS[0]\* space.

NOTE: The second stage decoders are shared with the CPU, see Figure 9 on page 79.

If the target address of a PCI write transaction "hits" based on the BAR decode, then misses in the Device Unit, transaction is completed properly on the PCI bus, but data is NOT written to memory. In case of read transaction, although there is no actual read from memory, transaction is completed properly on PCI bus, but the data driven



on the bus is undefined (unless timeout is reached first - RETRY termination). In both cases, MemOut bit in interrupt cause register is set (and interrupt is generated if not masked).

## 7.3.5 Enhancing Target Interface Performance

The GT-96100A includes special performance tuning features for the PCI target interface. The PCI\_0/1 Timeout0 and Timeout1 registers allow the designer to force the GT-96100A to wait either longer than normal, or shorter than normal, before issuing a RETRY/DISCONNECT.

The Timeout0 value of PCI device0 or device1 sets the number of clocks the device will wait for the first data of an access before issuing a RETRY. The Timeout1 value sets the number of clocks the device will wait between subsequent data phases during an access before issuing a DISCONNECT. The PCI 2.1 specifications sets the maximum for both of these at 16 clocks (Timeout0) and 8 clocks (Timeout1) respectively. However, in many systems, especially those with long SDRAM latencies, it may be necessary to "bend" these restrictions.<sup>1</sup>

**NOTE:** A value of 0x00 in Timeout0 or Timeout1 means "never timeout"

If excessive RETRY/DISCONNECT behavior occurs in the system, lengthen the Timeout0/1 values. This behavior may result from excessive memory activity due to the CPU or DMA engines and the PCI interface failing to access the SDRAM within 16 clocks.

The settings in the Prefetch/Max\_Burst registers provide another area for performance optimization. Turning on aggressive prefetch for all read types results in a significant performance improvement, depending on the length and type of read commands.

**NOTE:** If a system uses many short reads from a PCI, aggressive prefetch on speculative reads that are not used wastes bandwidth on the Device/DRAM bus.

# 7.4 PCI Synchronization Barriers

The GT-96100A considers some cycles to be "synchronization barrier" cycles. In such cycles, the GT-96100A confirms that at the end of the cycle there remains no posted data within the chip. These cycles can be initiated either from the PCI slave side or the CPU side.

The slave "synchronization barrier" cycles are Lock Read (for PCI\_0 only) and Configuration Read. If there is no posted data within the device, the cycle ends normally. If after a retry period there is still posted data, the cycle is retried. Until the original cycle ends, any other (different address/command) "synchronization barrier" cycles are retried.

Lock Read is a "synchronization barrier" cycle that lasts during the entire Lock period. For Example, when the slave of PCI\_0 is locked, all Configuration Reads are retried. Also, all cycles addressed to internal registers are retried until Lock ends.

The CPU interface treats I/O Reads to PCI and Configuration Reads as "synchronization barrier" cycles as well. These reads are responded to once no posted data remains within the GT-96100A.

<sup>1.</sup> The PCI specification also states that a master may not enforce target rules. In other words, even if the GT-96100A takes longer than 16 clocks to return the first data, the master must wait.



The GT-96100A provides the CPU with a simpler way to perform synchronization with PCI buffers<sup>1</sup>. The CPU issues a read command to "PCI\_0/1 Sync Barrier Virtual" register to synchronize PCI\_0/1 buffers. The response dummy read completes once no posted data remains within the addressed PCI interface.

# 7.5 PCI Master Configuration

The GT-96100A translates CPU read and write cycles into configuration cycles using PCI configuration mechanism #1 (per the PCI specification). Mechanism #1 defines a way to translate the CPU cycles into both PCI configuration cycles on the PCI bus and accesses to the GT-96100A's internal configuration registers.

The GT-96100A includes two registers per PCI device: Configuration Address (at offset 0xcf8 for PCI0 and 0xcf0 for PCI1) and Configuration Data (at offset 0xcfc for PCI0 and 0xcf4 for PC1). The mechanism for accessing configuration registers is to write a value into the Configuration Address register that specifies:

- PCI bus number.
- The device on that bus.
- The function number within the device.
- The configuration register within that device/function being accessed.

A subsequent read or write to the Configuration Data register (at 0xcfc/0xcf4) then causes the GT-96100A to translate that Configuration Address value to the requested cycle on the PCI bus.

If the BusNum field in the Configuration Address register equals 0 but the DevNum field is other than 0, a Type0 access is performed that addresses a device attached to the local PCI bus. If the BusNum field in the Configuration Address register is other than 0, a Type1 access is performed that addresses a device attached to a remote PCI bus.

The GT-96100A performs address stepping for PCI configuration cycles. This allows for the use of the highorder PCI AD signals as IdSel signals through resistive coupling.<sup>2</sup> Table 130 shows DevNum to IdSel mapping.

| DevNum[15:11] | PAD_0[31:11]/PAD_1[31:11]  |
|---------------|----------------------------|
| 00001         | 0 0000 0000 0000 0000 0001 |
| 00010         | 0 0000 0000 0000 0000 0010 |
| 00011         | 0 0000 0000 0000 0000 0100 |
| 00100         | 0 0000 0000 0000 0000 1000 |
| -             | -                          |
| -             | -                          |
| -             | -                          |
| 10101         | 1 0000 0000 0000 0000 0000 |
| 00000,        |                            |
| 10110 - 11111 | 0 0000 0000 0000 0000 0000 |

1. This mechanism is not compatible with the GT-64010A and GT-64011 devices.

2. "Resistive Coupling" is a fancy way of saying "hook a resistor from ADx to IdSel" on a given device. Look at the Galileo-4PB backplane schematics for examples.



The CPU accesses the GT-96100A's internal configuration registers when the fields DevNum and BusNum in the Configuration Address register are equal to 0. The GT-96100A Configuration registers are also accessed from the PCI bus when the GT-96100A is a target responding to PCI configuration read and write cycles.

The CPU accesses the GT-96100A internal PCI\_1 configuration registers through PCI\_0 Configuration Address and Data registers (0xcf8,0xcfc). For example, in order to access the GT-96100A's PCI\_1 Class Code and Rev Id register, CPU software should write 0x80000088 to PCI\_0 Configuration Address register (0xcf8), and then read/write PCI\_0 Configuration Data register. CPU will use PCI\_1 Configuration Address register (0xcf0) and Configuration Data register (0xcf4) only in order to generate a configuration read/write transaction on PCI\_1 bus.

The CPU interface unit cannot distinguish between an access to the GT-96100A's PCI configuration space and an access to an external PCI device configuration space. Both are accessed using an access to the GT-96100A's internal space (i.e. Configuration Data register). The software engineer must keep this in mind, especially when byte swapping is enabled on the PCI interface. In this case, internal configuration registers and configuration registers in external devices will appear to have a different neediness.

The configuration enable bit (ConfigEn) in the Configuration Address register must be set before the Configuration Data register is read or written. An attempt of CPU read a configuration register without this bit set, will result in undefined data returned on Sassed bus

## 7.5.1 Special Cycles and Interrupt Acknowledge

A Special cycle is generated whenever the Configuration Data register is written to and the Configuration Address register has been previously written with 0 for BusNum, 1f for DevNum, 7 for FunctNum and 0 for Reg-Num.

An Interrupt acknowledge cycle is generated whenever the Interrupt Acknowledge (0xc34) register is read.

# 7.6 Target Configuration and Plug and Play

The GT-96100A includes all of the required plug and play PCI configuration registers. These registers, as well as the GT-96100A's internal registers are accessible from both the CPU and the PCI bus.

The GT-96100A acts as a two function device when being configured from the PCI bus. The base address registers available in Function 0 are used to decode accesses for which there is no byte swapping.

Function 1 is used to decode byte swapped addresses.

All other registers are shared between Function 0 and Function 1, as shown in Figure 29.



#### Figure 29: PCI Configuration Header

Function 0 Header

| FUNCTION O READER       |                              |             |           |     |  |
|-------------------------|------------------------------|-------------|-----------|-----|--|
| Device ID Vendor ID     |                              |             |           | 00h |  |
| Sta                     | itus                         | Com         | mand      | 04h |  |
|                         | Class Code                   |             | Rev ID    | 08h |  |
| BIST                    | BIST Header Latency Line Siz |             |           | 0Ch |  |
|                         | SCS[1:                       | 0] BAR      |           | 10h |  |
|                         | SCS[3:                       | 2] BAR      |           | 14h |  |
|                         | CS[2:0] BAR                  |             |           |     |  |
| CS[3] & BootCS BAR      |                              |             |           |     |  |
| Mem Mapped Internal BAR |                              |             |           |     |  |
|                         | IO Mapped I                  | nternal BAR |           | 24h |  |
|                         | Rese                         | erved       |           | 28h |  |
| Subsys                  | stem ID                      | Subsystem   | Vendor ID | 2Ch |  |
| Expansion ROM BAR       |                              |             |           | 30h |  |
| Reserved Cap.Ptr        |                              |             |           | 34h |  |
| Reserved                |                              |             |           | 38h |  |
| Max_Lat                 | Min_Gnt                      | Int. Pin    | Int. Line | 3Ch |  |
|                         |                              |             |           |     |  |

|                         | 00h |
|-------------------------|-----|
|                         | 04h |
|                         | 08h |
|                         | 0Ch |
| Swap SCS[1:0] BAR       | 10h |
| Swap SCS[3:2] BAR       | 14h |
| Reserved                | 18h |
| Swap CS[3] & BootCS BAR | 1Ch |
| Reserved                | 20h |
| Reserved                | 24h |
|                         | 28h |
|                         | 2Ch |
| Reserved                | 30h |
|                         | 34h |
|                         | 38h |
|                         | 3Ch |

Function 1 Header

# Alia

Reserved

Aliased to function 0 register

Read Only 0

## 7.6.1 Plug and Play Base Address Register Sizing

Systems adhering to the plug and play configuration standard determine the size of a base address register's decode range by first writing 0xFFFF.FFFF to the BAR and then reading back the value contained in the BAR. Any bits that were unchanged (i.e., read back a zero) indicate that they cannot be set and are therefore not part of the address comparison. With this information, the size of the decode region can be determined.<sup>1</sup>

The GT-96100A responds to BAR sizing requests based on the values programmed into the Bank Size registers. These registers can be loaded automatically after RESET from the system ROM (see Section 7.6.2 "PCI Auto-load of Configuration Registers at RESET" on page 164).

## 7.6.2 PCI Autoload of Configuration Registers at RESET

Thirteen PCI registers per PCI interface can be automatically loaded after Rst\*. Autoload mode is enabled by asserting the DAdr[0] pin LOW on Rst\*. Any PCI transactions targeted for the GT-96100A must be retried while the loading of the PCI configuration registers is in process.

<sup>1.</sup> Refer to the PCI specification for more information on the BAR sizing process.

The PCI register values are loaded from the ROM controlled by BootCS\*. These register values are shown in Table 131 for PCI\_0 and in Table 132 for PCI\_1. Although the configuration register information is typically stored in a Boot ROM device, a PLD device can also be programmed to store this information.

**NOTE:** The PLD should be programmed to support burst read cycles.

Table 131: PCI\_0 Registers Loaded at RESET

| Register                       | Offset | Boot Device Address |
|--------------------------------|--------|---------------------|
| Command                        | 0xc00  | 0x1ffff80           |
| Timeout & Retry Counters       | 0xc04  | 0x1fffff84          |
| RAS[1:0]* Bank Size            | 0xc08  | 0x1fffff88          |
| RAS[3:2]* Bank Size            | 0xc0c  | 0x1fffff8c          |
| CS[2:0]* Bank Size             | 0xc10  | 0x1fffff90          |
| CS[3]* & Boot CS* Bank Size    | 0xc14  | 0x1fffff94          |
| Conf_en                        | 0xc3c  | 0x1fffff98          |
| Prefetch/Max_burst             | 0xc40  | 0x1fffff9c          |
| Device and Vendor ID           | 0x000  | 0x1ffffa0           |
| Class Code and Revision ID     | 0x008  | 0x1ffffa4           |
| Cache_line/Latency             | 0x00c  | 0x1ffffa8           |
| Subsystem Device and Vendor ID | 0x02c  | 0x1ffffac           |
| Interrupt Pin and Line         | 0x03c  | 0x1ffffb0           |

#### Table 132: PCI\_1 Registers Loaded at RESET

| Register                    | Offset | Boot Device Address |
|-----------------------------|--------|---------------------|
| Timeout & Retry Counters    | 0xc80  | 0x1ffffc0           |
| Counter                     | 0xc84  | 0x1ffffc4           |
| RAS[1:0]* Bank Size         | 0xc88  | 0x1ffffc8           |
| RAS[3:2]* Bank Size         | 0xc8c  | 0x1ffffcc           |
| CS[2:0]* Bank Size          | 0xc90  | 0x1ffffd0           |
| CS[3]* & Boot CS* Bank Size | 0xc94  | 0x1fffffd4          |
| Conf_en                     | 0xcbc  | 0x1fffffd8          |
| Prefetch/Max_burst          | 0xcc0  | 0x1fffffdc          |
| Device and Vendor ID        | 0x080  | 0x1ffffe0           |
| Class Code and Revision ID  | 0x088  | 0x1ffffe4           |
| Cache_line/Latency          | 0x08c  | 0x1ffffe8           |



| Register                       | Offset | Boot Device Address |  |
|--------------------------------|--------|---------------------|--|
| Subsystem Device and Vendor ID | 0x0ac  | 0x1ffffec           |  |
| Interrupt Pin and Line         | 0x0bc  | 0x1fffff0           |  |

#### Table 132: PCI\_1 Registers Loaded at RESET (Continued)

## 7.6.3 Expansion ROM Functionality

The GT-96100A implements the PCI Expansion ROM as required by PC boot devices. The PCI Expansion ROM functionality is enabled by strapping DAdr[5] low at RESET, see Section 22. "Reset Configuration" on page 452.

If the PCI Expansion ROM is disabled, expansion ROM register (offset 0x30 of PCI configuration space) acts as reserved register and returns only 0 when read.

When the expansion ROM is enabled by the pin strapping option, the PCI Expansion ROM BAR appears in the GT-96100A's PCI\_0 configuration header. However, the Expansion ROM decoder shares functionality with the SCS[3]\*/BootCS\* resource. In normal operation (i.e., after the BIOS initialization is complete), the Expansion ROM is disabled via bit 0 in the Expansion ROM BAR. During BIOS boot, however, the BIOS "turns on" the Expansion ROM decoder by setting bit 0. When the Expansion ROM decoder is "on" the following happens in PCI\_0:

- The PCI target acts as if the Timeout0 and Timeout1 MSBs are 1 (which means initial value of 0x8f and 0x87 respectively). This is done to allow for the long default access time from 8-bit boot ROMs.
- The Device unit will bypass it's address decoding for all transactions from PCI that are targeted to expansion ROM or SCS[3]\*/BootCS\*. All of these transactions assert CS[3] regardless of the actual address.
- The GT-96100A acts this way as long as bit[0] of expansion ROM register is set to 1. The BIOS must clear this bit when it is done executing/probing the Expansion ROM. If the BIOS does not clear bit[0] of expansion ROM BAR, program this bit to 0 from CPU side.

# 7.7 PCI Bus/Device Bus/CPU Clock Synchronization

The PCI interface is designed to run asynchronously with respect to the AD and CPU buses.

The synchronization delay between these two clock domains can be reduced by running the interfaces in synchronized mode. An example would be having the CPU/AD buses running at 66MHz and the PCI bus running at a 33MHz frequency that was derived from the 66MHz.

Latency through the GT-96100A is reduced to a minimum when synchronized mode is selected. The synchronization mode is set via the SyncMode bits in the PCI Internal Command registers (0xc00/0xc80). See Section 2.4.2 "PCI Read Performance from SDRAM" on page 117 for a full description.

**NOTE:** TClk cycle must be smaller than PClk cycle by at least 1 ns (T tclk < Tpclk + 1ns).



# 7.8 64-bit PCI Configuration

The GT-96100A is configured to work as a 64-bit PCI device if DAdr[2] and FRAME1\*/REQ64\* pins are sampled LOW on reset, see Section 22. "Reset Configuration" on page 452.

NOTE: The hold time for REQ64\*, in respect to RST\* rise, is 0, as required by the PCI spec.

When the GT-96100A is configured to a 64-bit PCI, both master and target interfaces are configured to execute 64-bit transactions, whenever possible.

The PCI master interface always attempts to generate 64-bit transactions (asserts REQ64#) except for I/O or configuration transactions or when the required data is less than 64 bits. If the transaction target does not respond with ACK64#, the master completes the transaction as a 32-bit transaction.

The PCI target interface always responds with ACK64# to a 64-bit transaction, except for accesses to configuration space or internal registers.

**NOTE:** PClk1 must be tied to PClk0 on 64-bit PCI configuration.

# 7.9 Retry Enable

Some applications require that the local MIPS CPU program the PCI configuration registers in advance of other bus masters accessing them. In a PC add-in card application, for example, the MIPS CPU must set the device ID, BAR size requirements, etc. before the BIOS attempts to configure the card. The GT-96100A provides a mechanism by which the PCI target interface retries all transactions until this configuration is complete. This prevents race conditions between the local MIPS processor and the BIOS.

If DAdr[6] pin is sampled low on reset, the GT-96100A PCI target retries any transaction targeted to the GT-96100A's space. The GT-96100A stays in this retry mode until the Stop Retry bit in CPU configuration register (0x000) is set to 1.

# 7.10 Locked Cycles

The GT-96100A locks a cache line (fixed at 32 bytes) in the local memory address space when responding to Lock sequences on the PCI bus.

When a cache line is locked, any new PCI access to an address within the locked cache line (except accesses initiated by the LOCK owner) is terminated with RETRY. Also, every access from CPU or DMA to the locked cache line is on hold until the LOCK ends.

Although the GT-96100A does not support the Lock\* pin on PCI\_1, any access from PCI\_1 to a locked cache line is not completed until the LOCK ends.



# 7.11 Hot-Swap Support

The GT-96100A is CompactPCI Hot Swap Capable. It supports the following hot swap device requirements:

- All PCI outputs float when RST# is asserted.
- All the GT-96100A's PCI state machines are kept in their idle state while RST# is asserted.
- The GT-96100A PCI interface does not leave it's idle state until PCI bus is in an IDLE state. If reset is de-asserted in the middle of a PCI transaction, the GT-96100A PCI interface stays in it's idle state until PCI bus is back in idle).
- The GT-96100A has no assumptions on clock behavior prior to it's setup to the rising edge of RST#.
- The GT-96100A is tolerant of the 1V precharge voltage during insertion.
- The GT-96100A can be powered from Early VCC.

# 7.12 PCI Power Management Support

The GT-96100A is PCI Power Management compliant. It contains the required configuration registers as shown in Figure 30.

#### Figure 30: Power Management Registers



The GT-96100A supports Power Management through reset configuration pins SDQM[1:0], each pin per each PCI interface.

If sampled HIGH, power management is enabled. Bit[4] of Configuration Status register is set, indicating the existence of a capability list. A capability list pointer register is implemented at offset 0x34, pointing to power management configuration registers implemented at offset 0x40 and 0x44.

If sampled LOW, capability list is not supported and a capability pointer as well as PMC registers are reserved.

Power Management registers are accessible from both CPU and PCI. Whenever PCI\_0 or PCI\_1 updates Power State bits (bits[1:0] of PMCSR register), bit[21] of interrupt cause register is set (bit[21] of high interrupt cause register in case of PCI\_1 PMCSR configuration register) and an interrupt to CPU or PCI is generated, if not masked by interrupt mask registers. When Power Management is enabled, bit[21] in the interrupt cause register is used as a power management interrupt rather than a doorbell interrupt, see Interrupt section for details.

**NOTE:** The GT-96100A does not support it's own power down. It only supports the software capability to power down the CPU or other on board devices.



# 7.13 PCI Interface Restrictions

## 7.13.1 General

1. TClk cycle must be smaller than PClk cycle by at least 1ns (T tclk  $\leq$  Tpclk + 1ns).

#### 7.13.2 Master

1. Latency count, as specified in LatTimer (PCI Configuration Register 0x00c), must not be programmed to less than 6.

## 7.13.3 Slave

- 1. The set bits in the Bank Size registers must be sequential.
- 2. When the slave is locked, in order to prevent a deadlock, all transactions to internal registers (I/O or memory cycles) are not supported (retry will be issued).
- 3. Timeout0 value (PCI internal Register 0xc04) must not be programed to less than 2.
- 4. All PCI reads result in prefetch read from the target device regardless of the BAR prefetch bit value, unless FRAME\* is asserted for a single clock cycle.
- 5. If 64-bit SDRAM/device is used that supports bursts of eight 64-bit words, the MaxBurst can only be set to 1 (i.e. 64 bytes).

# 7.14 PCI Control and Configuration Registers

#### Table 133: PCI Control and Configuration Register Map

| Description                       | Offset | Page Number |
|-----------------------------------|--------|-------------|
| PCI Internal                      |        |             |
| PCI_0 Command                     | 0xc00  | page 172    |
| PCI_1 Command                     | 0xc80  | page 174    |
| PCI_0 Time Out & Retry            | 0xc04  | page 174    |
| PCI_1 Time Out & Retry            | 0xc84  | page 174    |
| PCI_0 SCS[1:0]* Bank Size         | 0xc08  | page 175    |
| PCI_1 SCS[1:0]* Bank Size         | 0xc88  | page 175    |
| PCI_0 SCS[3:2]* Bank Size         | 0xc0c  | page 175    |
| PCI_1 SCS[3:2]* Bank Size         | 0xc8c  | page 176    |
| PCI_0 CS[2:0]* Bank Size          | 0xc10  | page 176    |
| PCI_1 CS[2:0]* Bank Size          | 0xc90  | page 176    |
| PCI_0 CS[3]* & Boot CS* Bank Size | 0xc14  | page 177    |

| Description                                       | Offset                   | Page Number |  |  |  |
|---------------------------------------------------|--------------------------|-------------|--|--|--|
| PCI Internal (Continued)                          | PCI Internal (Continued) |             |  |  |  |
| PCI_1 CS[3]* & Boot CS* Bank Size                 | 0xc94                    | page 177    |  |  |  |
| PCI_0 Internal Registers Space Size               | 0xc20                    | page 177    |  |  |  |
| PCI_1 Internal Registers Space Size               | 0xca0                    | page 178    |  |  |  |
| PCI_0 Base Address Registers' Enable              | 0xc3c                    | page 178    |  |  |  |
| PCI_1 Base Address Registers' Enable              | 0xcbc                    | page 179    |  |  |  |
| PCI_0 Prefetch/Max Burst Size                     | 0xc40                    | page 179    |  |  |  |
| PCI_1 Prefetch/Max Burst Size                     | 0xcc0                    | page 179    |  |  |  |
| PCI_0 SCS[1:0]* Base Address Remap                | 0xc48                    | page 180    |  |  |  |
| PCI_1 SCS[1:0]* Base Address Remap                | 0xcc8                    | page 180    |  |  |  |
| PCI_0 SCS[3:2]* Base Address Remap                | 0xc4c                    | page 181    |  |  |  |
| PCI_1 SCS[3:2]* Base Address Remap                | 0xccc                    | page 181    |  |  |  |
| PCI_0 CS[2:0]* Base Address Remap                 | 0xc50                    | page 182    |  |  |  |
| PCI_1 CS[2:0]* Base Address Remap                 | 0xcd0                    | page 182    |  |  |  |
| PCI_0 CS[3]* & Boot CS* Address Remap             | 0xc54                    | page 182    |  |  |  |
| PCI_1 CS[3]* & Boot CS* Address Remap             | 0xcd4                    | page 182    |  |  |  |
| PCI_0 Swapped SCS[1:0]* Base Address Remap        | 0xc58                    | page 180    |  |  |  |
| PCI_1 Swapped SCS[1:0]* Base Address Remap        | 0xcd8                    | page 180    |  |  |  |
| PCI_0 Swapped SCS[3:2]* Base Address Remap        | 0xc5c                    | page 181    |  |  |  |
| PCI_1 Swapped SCS[3:2]* Base Address Remap        | 0xcdc                    | page 181    |  |  |  |
| PCI_0 Swapped CS[3]* & BootCS* Base Address Remap | 0xc64                    | page 183    |  |  |  |
| PCI_1 Swapped CS[3]* & BootCS* Base Address Remap | 0xce4                    | page 183    |  |  |  |
| PCI_0 Configuration Address                       | 0xcf8                    | page 183    |  |  |  |
| PCI_1 Configuration Address                       | 0xcf0                    | page 184    |  |  |  |
| PCI_0 Configuration Data Virtual Register         | 0xcfc                    | page 184    |  |  |  |
| PCI_1 Configuration Data Virtual Register         | 0xcf4                    | page 184    |  |  |  |
| PCI_0 Interrupt Acknowledge Virtual Register      | 0xc34                    | page 184    |  |  |  |
| PCI_1 Interrupt Acknowledge Virtual Register      | 0xc30                    | page 184    |  |  |  |

## Table 133: PCI Control and Configuration Register Map (Continued)

| Description                                         | Offset | Page Number |
|-----------------------------------------------------|--------|-------------|
| PCI Configuration                                   |        |             |
| PCI_0 Device and Vendor ID                          | 0x000  | page 185    |
| PCI_1 Device and Vendor ID                          | 0x080  | page 185    |
| PCI_0 Status and Command                            | 0x004  | page 186    |
| PCI_1 Status and Command                            | 0x084  | page 186    |
| PCI_0 Class Code and Revision ID                    | 0x008  | page 188    |
| PCI_1 Class Code and Revision ID                    | 0x088  | page 188    |
| PCI_0 BIST, Header Type, Latency Timer, Cache Line  | 0x00c  | page 188    |
| PCI_1 BIST, Header Type, Latency Timer, Cache Line  | 0x08c  | page 189    |
| PCI_0 SCS[1:0]* Base Address                        | 0x010  | page 190    |
| PCI_1 SCS[1:0]* Base Address                        | 0x090  | page 190    |
| PCI_0 SCS[3:2]* Base Address                        | 0x014  | page 191    |
| PCI_1 SCS[3:2]* Base Address                        | 0x094  | page 191    |
| PCI_0 CS[2:0]* Base Address                         | 0x018  | page 191    |
| PCI_1 CS[2:0]* Base Address                         | 0x098  | page 192    |
| PCI_0 CS[3]* & Boot CS* Base Address                | 0x01c  | page 192    |
| PCI_1 CS[3]* & Boot CS* Base Address                | 0x09c  | page 192    |
| PCI_0 Internal Registers Memory Mapped Base Address | 0x020  | page 193    |
| PCI_1 Internal Registers Memory Mapped Base Address | 0x0a0  | page 193    |
| PCI_1 SCS[1:0]* Base Address                        | 0x090  | page 190    |
| PCI_0 SCS[3:2]* Base Address                        | 0x014  | page 191    |
| PCI_0 Internal Registers I/O Mapped Base Address    | 0x024  | page 193    |
| PCI_1 Internal Registers I/O Mapped Base Address    | 0x0a4  | page 193    |
| PCI_0 Subsystem ID and Subsystem Vendor ID          | 0x02c  | page 194    |
| PCI_1 Subsystem ID and Subsystem Vendor ID          | 0x0ac  | page 194    |
| Expansion ROM Base Address Register                 | 0x030  | page 194    |
| PCI_0 Interrupt Pin and Line                        | 0x03c  | page 195    |
| PCI_1 Interrupt Pin and Line                        | 0x0bc  | page 195    |

## Table 133: PCI Control and Configuration Register Map (Continued)

| Description                                  | Offset | Page Number |  |
|----------------------------------------------|--------|-------------|--|
| PCI Configuration, Function 1                |        |             |  |
| PCI_0 Swapped SCS[1:0]* Base Address         | 0x110  | page 198    |  |
| PCI_1 Swapped SCS[1:0]* Base Address         | 0x190  | page 198    |  |
| PCI_0 Swapped SCS[3:2]* Base Address         | 0x114  | page 198    |  |
| PCI_1 Swapped SCS[3:2]* Base Address         | 0x194  | page 199    |  |
| PCI_0 Swapped CS[3]* & Boot CS* Base Address | 0x11c  | page 199    |  |
| PCI_1 Swapped CS[3]* & Boot CS* Base Address | 0x19c  | page 200    |  |

### Table 133: PCI Control and Configuration Register Map (Continued)

## 7.14.1 PCI Internal Registers

| Bits | Field Name            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Initial Value                                                                                                    |
|------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| 0    | MByteSwap             | Master Byte Swap.<br>When set to zero, the GT-96100A PCI<br>master swaps the bytes of the incoming<br>and outgoing PCI data (swap the 8 bytes<br>of a long-word).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Set to the same value<br>sampled at reset into<br>bit[12] of the CPU Inter-<br>face Configuration regis-<br>ter. |
| 3:1  | SyncMode <sup>1</sup> | <ul> <li>Indicates the ratio between TClk and PClk as follows:</li> <li>x00 - Default mode. When the PClk ranges from DC to 66MHz. This mode works in all cases.</li> <li><b>NOTE:</b> Use following settings for higher performance.</li> <li>001 - When PClk is higher than or equal to half the TClk frequency (e.g. when TClk is 100MHz, SyncMode can be set to 001 if the PCl frequency is higher than or equal to 50MHz).</li> <li>01x - When the two clocks are synchronized and PClk is higher than or equal to half of TCLK frequency (e.g. TClk = 100MHz, PClk = 50MHz).</li> <li>101 - When PClk is higher than or equal to a third of the TClK frequency but less than half of the TCLK frequency.</li> <li>11x - When the two clocks are synchronized and PClk is higher than or equal to third of the TCLK frequency.</li> </ul> | 0x0                                                                                                              |

## Table 134: PCI\_0 Command, Offset: 0xc00



| Bits  | Field Name   | Function                                                                                                                                                                                                                                                                                             | Initial Value                                                                                                       |
|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| 7:4   | Reserved     | Read only.                                                                                                                                                                                                                                                                                           | 0x0                                                                                                                 |
| 9:8   | Reserved     | Must be 0.                                                                                                                                                                                                                                                                                           | 0x0                                                                                                                 |
| 10    | MWordSwap*   | Master Word Swap<br>When set to 1, the GT-96100A PCI master<br>swaps the words of the incoming and out-<br>going PCI data (swaps the 2 words of a<br>long-word).<br><b>NOTE:</b> Not supported when using a 64-<br>bit PCI interface.                                                                | 0x0                                                                                                                 |
| 11    | SWordSwap*   | Slave Word Swap<br>When set to 1, the GT-96100A PCI slave<br>swaps the words of the incoming and out-<br>going PCI data (swap the 2 words of a<br>long-word), if there is an address hit in one<br>of SDRAM or Devices BARs.<br><b>NOTE:</b> Not supported when using a 64-<br>bit PCI interface.    | 0x0                                                                                                                 |
| 12    | SSBWordSwap* | Slave Swap BAR Word Swap.<br>When set to 1, the GT-96100A PCI slave<br>swaps the words of the incoming and out-<br>going PCI data (swap the 2 words of a<br>long-word), if address hit in one of<br>SDRAM or Devices Swap BARs.<br><b>NOTE:</b> Not supported when using a 64-<br>bit PCI interface. | 0x0                                                                                                                 |
| 15:13 | Reserved     | Must be 0.                                                                                                                                                                                                                                                                                           | 0x0                                                                                                                 |
| 16    | SByteSwap    | Slave Byte Swap.<br>When set to zero, the GT-96100A PCI<br>slave swaps the bytes of the incoming and<br>outgoing PCI data (swap the 8 bytes of a<br>long-word).                                                                                                                                      | Set to the same value as<br>sampled at reset into<br>bit[12] of the CPU Inter-<br>face Configuration regis-<br>ter. |
| 31:17 | Reserved     | Must be 0.                                                                                                                                                                                                                                                                                           | 0x0                                                                                                                 |

1. Regardless of the selected syncmode, PClk frequency must be smaller than TClk frequency by at least 1MHz.

| Bits | Field Name | Function                       | Initial Value    |
|------|------------|--------------------------------|------------------|
| 31:0 | Various    | Same as for the PCI_0 Command. | 0x0 <sup>1</sup> |

#### Table 135: PCI\_1 Command, Offset: 0xc80

1. For bit 16, set to the same value as sampled at reset into bit[12] of the CPU Interface Configuration register.

Table 136: PCI\_0 Time Out & ReTry, Offset: 0xc04

| Bits  | Field Name | Function                                                                                                                                                                                                                                                        | Initial Value |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 7:0   | Timeout0   | Specifies in PCI clock units the number of<br>clocks that the GT-96100A, as a slave,<br>holds the PCI bus before the generation of<br>retry termination.<br>A value of 0x00 means "never timeout".<br>Used for the first data transfer.                         | 0x0f          |
| 15:8  | Timeout1   | Specifies in PCI clock units the number of<br>clocks that the GT-96100A, as a slave,<br>holds the PCI bus before the generation of<br>disconnect termination.<br>A value of 0x00 means "never timeout".<br>Used for data transfers following the first<br>data. | 0x07          |
| 23:16 | RetryCtr   | Specifies the number of retries of the GT-<br>96100A Master. The GT-96100A gener-<br>ates an interrupt when this timer expires.<br>A value of 0x00 means "retry forever".<br>The number in RetryCtr does not include<br>the first access of the transaction.    | 0x0           |
| 31:24 | Reserved   |                                                                                                                                                                                                                                                                 | 0x0           |

NOTE: See also Section 7.6.3 "Expansion ROM Functionality" on page 166

#### Table 137: PCI\_1 Time Out & ReTry, Offset: 0xc84

| Bits | Field Name | Function                              | Initial Value |
|------|------------|---------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 Time Out and ReTry. | 0x070f        |



| Bits  | Field Name | Function                                                                                                                                                                                                                        | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                                                                                                                                                                      | 0x0           |
| 31:12 | BankSize   | Specifies the SCS[1:0]* address mapping<br>in conjunction with the SCS[1:0]* Base<br>Address register.                                                                                                                          | 0x00fff       |
|       |            | 0 - The corresponding bit in the address<br>and in the base address must be equal in<br>order to have a hit.                                                                                                                    |               |
|       |            | 1 -The corresponding bit in the address is a "don't-care".                                                                                                                                                                      |               |
|       |            | For example, bit 12 set to 1 indicates that<br>the SCS[1:0]* size is 8KBytes. The set bits<br>in the Bank Size must be sequential (e.g.<br>000001, 000011, 000111 are correct<br>values, whereas 000010 and 000100<br>are not). |               |

| Table 138: PCI_0 SCS[1 | 0] Bank Size, Offset: 0xc08 |
|------------------------|-----------------------------|
|------------------------|-----------------------------|

### Table 139: PCI\_1 SCS[1:0]\* Bank Size, Offset: 0xc88

| Bits | Field Name | Function                               | Initial Value |
|------|------------|----------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 SCS[1:0]* Bank Size. | 0x00fff000    |

#### Table 140: PCI\_0 SCS[3:2]\* Bank Size, Offset: 0xc0c

| Bits  | Field Name | Function                                                                                                                                                                                                                        | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                                                                                                                                                                      | 0x0           |
| 31:12 | BankSize   | Specifies the SCS[3:2]* address mapping<br>in conjunction with the SCS[3:2]* Base<br>Address register.                                                                                                                          | 0x00fff       |
|       |            | 0 -The corresponding bit in the address<br>and in the base address must be equal in<br>order to have a hit.                                                                                                                     |               |
|       |            | 1 - The corresponding bit in the address is a "don't-care".                                                                                                                                                                     |               |
|       |            | For example, bit 12 set to 1 indicates that<br>the SCS[3:2]* size is 8KBytes. The set bits<br>in the Bank Size must be sequential (e.g.<br>000001, 000011, 000111 are correct<br>values, whereas 000010 and 000100<br>are not). |               |

#### Table 141: PCI\_1 SCS[3:2]\* Bank Size, Offset: 0xc8c

| Bits | Field Name | Function                               | Initial Value |
|------|------------|----------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 SCS[3:2]* Bank Size. | 0x00fff000    |

#### Table 142: PCI\_0 CS[2:0]\* Bank Size, Offset: 0xc10

| Bits  | Field Name | Function                                                                                                                                                                                                                         | Initial Value |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only                                                                                                                                                                                                                        | 0x0           |
| 31:12 | BankSize   | Specifies the CS[2:0]* address mapping in<br>conjunction with the CS[2:0]* Base<br>Address register.                                                                                                                             | 0x01fff       |
|       |            | 0 - The corresponding bit in the address<br>and in the base address must be equal in<br>order to have a hit.                                                                                                                     |               |
|       |            | 1 - The corresponding bit in the address is a "don't-care".                                                                                                                                                                      |               |
|       |            | For example, bit 12 set to '1' indicates that<br>the CS[2:0]* size is 8KBytes. The set bits<br>in the Bank Size must be sequential (e.g.<br>000001, 000011, 000111 are correct<br>values, whereas 000010 and 000100<br>are not). |               |

#### Table 143: PCI\_1 CS[2:0]\* Bank Size, Offset: 0xc90

| Bits | Field Name | Function                              | Initial Value |
|------|------------|---------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 CS[2:0]* Bank Size. | 0x01fff000    |



| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Initial Value |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0           |
| 31:12 | BankSize   | Specifies the CS[3]* and Boot CS*<br>address mapping in conjunction with the<br>CS[3]* and Boot CS* Base Address regis-<br>ter.<br>0 - The corresponding bit in the address<br>and in the base address must be equal in<br>order to have a hit.<br>1 - The corresponding bit in the address is<br>a "don't-care".<br>For example, bit 12 set to '1' indicates that<br>the CS[3]*/ Boot CS* size is 8KBytes. The<br>set bits in the Bank Size must be sequen-<br>tial (e.g. 000001, 000011, 000111<br>are correct values, whereas 000010 and<br>000100 are not). | 0x00fff       |

| Table 144: PCI | 0 CS[3]* and | d Boot CS* | Bank Size. | Offset: 0xc14 |
|----------------|--------------|------------|------------|---------------|
|                |              |            | Burn Oizo, |               |

### Table 145: PCI\_1 CS[3]\* and Boot CS\* Bank Size, Offset: 0xc94

| Bits | Field Name | Function                                            | Initial Value |
|------|------------|-----------------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 CS[3]* and Boot CS*<br>Bank Size. | 0x00fff000    |

#### Table 146: PCI\_0 Internal Registers Space Size, Offset: 0xc20

| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0           |
| 31:12 | BankSize   | Specifies the internal registers address<br>mapping in conjunction with the Internal<br>Registers Base Address register.<br>0 - The corresponding bit in the address<br>and in the base address must be equal in<br>order to have a hit.<br>1 - The corresponding bit in the address is<br>a "don't-care".<br>For example, bit 12 set to '1' indicates that<br>the internal registers space size is<br>8KBytes. The set bits in the BankSize<br>must be sequential (e.g. 000001,<br>000011, 000111 are correct values,<br>whereas 000010 and 000100 are not). | 0x00000       |

| Bits | Field Name | Function                                         | Initial Value |
|------|------------|--------------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 Internal Registers Space Size. | 0x0000000     |

## Table 147: PCI\_1 Internal Registers Space Size, Offset: 0xca0

### Table 148: PCI\_0 Base Address Registers' Enable, Offset: 0xc3c

| Bits | Field Name              | Function                                                                                                   | Initial Value |
|------|-------------------------|------------------------------------------------------------------------------------------------------------|---------------|
| 0    | SwCS[3]_&_Boot_C<br>SEn | Controls address matching with Swapped<br>CS[3]* & Boot CS* base/size.<br>0 - Enable<br>1 - Disable        | 0x1           |
| 1    | SwSCS[3:2]En            | Controls address matching with Swapped<br>SCS[3:2]* base/size.<br>0 - Enable<br>1 - Disable                | 0x1           |
| 2    | SwSCS[1:0]En            | Controls address matching with Swapped<br>SCS[1:0]* base/size.<br>0 - Enable<br>1 - Disable                | 0x1           |
| 3    | IntlOEn                 | Controls address matching with internal<br>registers I/O mapped base/size.<br>0 - Enable<br>1 - Disable    | 0x1           |
| 4    | IntMeMEn                | Controls address matching with internal<br>registers memory mapped base/size.<br>0 - Enable<br>1 - Disable | 0x0           |
| 5    | CS[3]*_&_Boot_CSE<br>n  | Controls address matching with CS[3]* &<br>Boot CS* base/size.<br>0 - Enable<br>1 - Disable                | 0x0           |
| 6    | CS[2:0]En               | Controls address matching with CS[2:0]*<br>base/size.<br>0 - Enable<br>1 - Disable                         | 0x0           |
| 7    | SCS[3:2]En              | Controls address matching with SCS[3:2]*<br>base/size.<br>0 - Enable<br>1 - Disable                        | 0x0           |



| Bits | Field Name | Function                                                                            | Initial Value |
|------|------------|-------------------------------------------------------------------------------------|---------------|
| 8    | SCS[1:0]En | Controls address matching with SCS[1:0]*<br>base/size.<br>0 - Enable<br>1 - Disable | 0x0           |
| 31:9 | Reserved   |                                                                                     | 0x0           |

#### Table 148: PCI\_0 Base Address Registers' Enable, Offset: 0xc3c (Continued)

#### Table 149: PCI\_1 Base Address Registers' Enable, Offset: 0xcbc

**NOTE:** RESERVED if configured for only PCI\_0)

| Bits | Field Name | Function                                          | Initial Value |
|------|------------|---------------------------------------------------|---------------|
| 31:0 | Various    | Same As for PCI_0 Base Address registers' enable. | 0x0f          |

**NOTE:** The GT-96100A prevents disabling both memory mapped base/size address matching and I/O mapped base/size address matching at the same time (bits 3 and 4 cannot simultaneously be set to 1).

Table 150: PCI\_0 Prefetch/Max Burst Size, Offset: 0xc40

| Bits | Field Name   | Function                           | Initial Value |
|------|--------------|------------------------------------|---------------|
| 0    | Dram0MaxBrst | SCS[1:0]* Max Burst Length         | 0x0           |
| 1    | Dram1MaxBrst | SCS[3:2]* Max Burst Length         | 0x0           |
| 2    | Dev0MaxBrst  | CS[2:0]* Max Burst Length          | 0x0           |
| 3    | Dev1MaxBrst  | CS[3]* & Boot CS* Max Burst Length | 0x0           |
| 4    | RdMemPref    | Read Memory Prefetch               | 0x0           |
| 5    | RdLnPref     | Read Line Prefetch                 | 0x0           |
| 6    | RdMulPref    | Read Multiple Prefetch             | 0x1           |
| 31:7 | Reserved     |                                    | 0x0           |

# Table 151: PCI\_1 Prefetch/Max Burst Size, Offset: 0xcc0

**NOTE:** RESERVED if configured for only PCI\_0.

| Bits | Field Name | Function                                   | Initial Value |
|------|------------|--------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 Prefetch/Max Burst Size. | 0x040         |

| Bits  | Field Name | Function                                                                          | Initial Value |
|-------|------------|-----------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                        | 0x0           |
| 31:12 | DRAM0Remap | SCS[1:0]* memory address remap from<br>PCI side.                                  | 0x0           |
|       |            | Reserved if this BAR is disabled through<br>PCI_0 Base Address Registers' Enable. |               |

#### Table 152: PCI\_0 SCS[1:0]\* Base Address Remap, Offset: 0xc48

## Table 153: PCI\_1 SCS[1:0]\* Base Address Remap, Offset: 0xcc8

**NOTE:** RESERVED if configured for only PCI\_0.

| Bits  | Field Name | Function                                                                                                                             | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                                                                           | 0x0           |
| 31:12 | DRAM0Remap | SCS[1:0]* memory address remap from<br>PCI side<br>Reserved if this BAR is disabled through<br>PCI_1 Base Address Registers' Enable. | 0x0           |

#### Table 154: PCI\_0 Swapped SCS[1:0]\* Base Address Remap, Offset: 0xc58

| Bits  | Field Name              | Function                                                                                                                                     | Initial Value |
|-------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved                | Read only.                                                                                                                                   | 0x0           |
| 31:12 | Swapped_DRAM0_<br>Remap | Swapped SCS[1:0]* memory address<br>remap from PCI side<br>Reserved if this BAR is disabled through<br>PCI_0 Base Address Registers' Enable. | 0x0           |

## Table 155: PCI\_1 Swapped SCS[1:0]\* Base Address Remap, Offset: 0xcd8

**NOTE:** RESERVED if configured for only PCI\_0.

| Bits  | Field Name             | Function                                                                                                                                     | Initial Value |
|-------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved               | Read only.                                                                                                                                   | 0x0           |
| 31:12 | Swapped_<br>DRAM0Remap | Swapped SCS[1:0]* memory address<br>remap from PCI side<br>Reserved if this BAR is disabled through<br>PCI_1 Base Address Registers' Enable. | 0x0           |



| Bits  | Field Name | Function                                                                          | Initial Value |
|-------|------------|-----------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                        | 0x0           |
| 31:12 | DRAM1Remap | SCS[3:2]* memory address remap from<br>PCI side                                   | 0x01000       |
|       |            | Reserved if this BAR is disabled through<br>PCI_0 Base Address Registers' Enable. |               |

#### Table 156: PCI\_0 SCS[3:2]\* Base Address Remap, Offset: 0xc4c

### Table 157: PCI\_1 SCS[3:2]\* Base Address Remap, Offset: 0xccc

| NOTE: | RESERVED | if configured for | only PCI_0. |
|-------|----------|-------------------|-------------|

| Bits  | Field Name | Function                                                                                                                             | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                                                                           | 0x0           |
| 31:12 | DRAM1Remap | SCS[3:2]* memory address remap from<br>PCI side<br>Reserved if this BAR is disabled through<br>PCI_1 Base Address Registers' Enable. | 0x01000       |

# Table 158: PCI\_0 Swapped SCS[3:2]\* Base Address Remap, Offset: 0xc5c

| Bits  | Field Name             | Function                                                                                                                                     | Initial Value |
|-------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved               | Read only.                                                                                                                                   | 0x0           |
| 31:12 | Swapped_<br>DRAM1Remap | Swapped SCS[3:2]* memory address<br>remap from PCI side<br>Reserved if this BAR is disabled through<br>PCI_0 Base Address Registers' Enable. | 0x01000       |

#### Table 159: PCI\_1 Swapped SCS[3:2]\* Base Address Remap, Offset: 0xcdc (RESERVED if configured for only PCI\_0)

| Bits  | Field Name             | Function                                                                                                                                     | Initial Value |
|-------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved               | Read only.                                                                                                                                   | 0x0           |
| 31:12 | Swapped_<br>DRAM1Remap | Swapped SCS[3:2]* memory address<br>remap from PCI side<br>Reserved if this BAR is disabled through<br>PCI_1 Base Address Registers' Enable. | 0x01000       |

| Bits  | Field Name | Function                                                                          | Initial Value |
|-------|------------|-----------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                        | 0x0           |
| 31:12 | Dev0Remap  | CS[2:0]* memory address remap from PCI side                                       | 0x1c000       |
|       |            | Reserved if this BAR is disabled through<br>PCI_0 Base Address Registers' Enable. |               |

### Table 160: PCI\_0 CS[2:0]\* Base Address Remap, Offset: 0xc50

# Table 161: PCI\_1 CS[2:0]\* Base Address Remap, Offset: 0xcd0

**NOTE:** RESERVED if configured for only PCI\_0.

| Bits  | Field Name | Function                                                                                                                            | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                                                                          | 0x0           |
| 31:12 | Dev0Remap  | CS[2:0]* memory address remap from PCI<br>side<br>Reserved if this BAR is disabled through<br>PCI_1 Base Address Registers' Enable. | 0x1c000       |

### Table 162: PCI\_0 CS[3]\* & BootCS\* Base Address Remap, Offset: 0xc54

| Bits  | Field Name | Function                                                                       | Initial Value |
|-------|------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                     | 0x0           |
| 31:12 | Dev1Remap  | CS[3]* & BootCS* memory address remap<br>from PCI side                         | 0x1f000       |
|       |            | Reserved if this BAR is disabled through PCI_0 Base Address Registers' Enable. |               |

### Table 163: PCI\_1 CS[3]\* & BootCS\* Base Address Remap, Offset: 0xcd4

**NOTE:** RESERVED if configured for only PCI\_0.

| Bits  | Field Name | Function                                                                          | Initial Value |
|-------|------------|-----------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved   | Read only.                                                                        | 0x0           |
| 31:12 | Dev1Remap  | CS[3]* & BootCS* memory address remap<br>from PCI side                            | 0x1f000       |
|       |            | Reserved if this BAR is disabled through<br>PCI_1 Base Address Registers' Enable. |               |



| Bits  | Field Name            | Function                                                                       | Initial Value |
|-------|-----------------------|--------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved              | Read only.                                                                     | 0x0           |
| 31:12 | Swapped_<br>Dev1Remap | Swapped CS[3]* & BootCS* memory<br>address remap from PCI side                 | 0x1f000       |
|       |                       | Reserved if this BAR is disabled through PCI_0 Base Address Registers' Enable. |               |

## Table 164: PCI\_0 Swapped CS[3]\*& BootCS\* Base Address Remap, Offset: 0xc64

# Table 165: PCI\_1 Swapped CS[3]\* & BootCS\* Base Address Remap, Offset: 0xce4 NOTE: RESERVED if configured for only PCI\_0.

| Bits  | Field Name            | Function                                                                                                                                            | Initial Value |
|-------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 11:0  | Reserved              | Read only.                                                                                                                                          | 0x0           |
| 31:12 | Swapped_<br>Dev1Remap | Swapped CS[3]* & BootCS* memory<br>address remap from PCI side<br>Reserved if this BAR is disabled through<br>PCI_1 Base Address Registers' Enable. | 0x1f000       |

### Table 166: PCI\_0 Configuration Address, Offset: 0xcf8

| Bits  | Field Name | Function                                                                                                                           | Initial Value |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1:0   | Reserved   | Read only.                                                                                                                         | 0x0           |
| 7:2   | RegNum     | Indicates the register number.                                                                                                     | 0x00          |
| 10:8  | FunctNum   | Indicates the function type.                                                                                                       | 0x0           |
| 15:11 | DevNum     | Indicates the device number.                                                                                                       | 0x00          |
| 23:16 | BusNum     | Indicates the bus number.                                                                                                          | 0x00          |
| 30:24 | Reserved   | Read only.                                                                                                                         | 0x0           |
| 31    | ConfigEn   | When set, an access to the Configuration<br>Data register is translated into a Configu-<br>ration or Special cycle on the PCI bus. | 0x0           |

| Bits | Field Name | Function                                                                                                                                                    | Initial Value |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | Config     | The data is transferred to/from the PCI<br>bus when the CPU accesses this register<br>and the ConfigEn bit in the Configuration<br>Address register is set. | 0x000         |
|      |            | A CPU access to this register means the GT-96100A performs a Configuration or Special cycle on the PCI bus.                                                 |               |

## Table 167: PCI\_0 Configuration Data, Offset: 0xcfc

### Table 168: PCI\_1 Configuration Address, Offset: 0xcf0

**NOTE:** RESERVED if configured for only PCI\_0.

| Bits | Field Name | Function                                 | Initial Value |
|------|------------|------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 Configuration Address. | 0x000         |

# Table 169: PCI\_1 Configuration Data, Offset: 0xcf4 NOTE: RESERVED if configured for only PCI\_0.

| Bits | Field Name | Function                              | Initial Value |
|------|------------|---------------------------------------|---------------|
| 31:0 | Config     | Same as for PCI_0 Configuration Data. | 0x000         |

#### Table 170: PCI\_0 Interrupt Acknowledge Virtual Register, Offset: 0xc34

| Bits | Field Name | Function                                                                                            | Initial Value |
|------|------------|-----------------------------------------------------------------------------------------------------|---------------|
| 31:0 | IntAck_0   | A CPU read access to this register forces<br>an interrupt acknowledge cycle on PCI_0.<br>Read only. | 0x0           |

#### Table 171: PCI\_1 Interrupt Acknowledge Virtual Register, Offset: 0xc30

| Bits | Field Name | Function                                                                                            | Initial Value |
|------|------------|-----------------------------------------------------------------------------------------------------|---------------|
| 31:0 | IntAck_1   | A CPU read access to this register forces<br>an interrupt acknowledge cycle on PCI_1.<br>Read only. | 0x0           |



0x9653

# 7.14.2 PCI Configuration Registers

All PCI Configuration registers are located at their standard offset when accessed from their corresponding PCI bus. For example, if a master on PCI\_0 performs a PCI configuration cycle on PCI\_0's Status and Command register, the register is located at 0x004. Likewise, if a master on PCI\_1 performs a PCI configuration cycle on PCI\_1's Status and Command register, the register is located at 0x004.

On the other hand, if a master on PCI\_0 performs a PCI configuration cycle on PCI\_1's Status and Command register, the register is located at 0x084. Likewise, if a master on PCI\_1 performs a PCI configuration cycle on PCI\_0's Status and Command register, the register is located at 0x084.

If the CPU masters PCI configuration cycles, PCI\_0 configuration registers are located at their standard offsets and PCI\_1 configuration registers are located at 0x80 + standard offset.

**NOTE:** All PCI\_1 configuration registers are reserved if the GT-96100A is configured for only PCI\_0 operation.

 

 PCI\_0 or CPU; 0x080 from PCI\_1

 Bits
 Field Name
 Function
 Initial Value

 15:0
 VenID
 Provides the GT-96100A's manufacturer. Read only.
 0x11ab

Read Only.

device0 ID number.

#### Table 172: PCI\_0 Device and Vendor ID, Offset: 0x000 from PCI\_0 or CPU; 0x080 from PCI\_1

### Table 173: PCI\_1 Device and Vendor ID, Offset: 0x080 from PCI\_0 or CPU; 0x000 from PCI\_1

| Bits | Field Name | Function                           | Initial Value |
|------|------------|------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 Device and VenID | 0x965311ab    |

Provides the unique GT-96100A PCI

31:16

DevID

| Bits | Field Name | Function                                                                                                                                 | Initial Value                         |  |  |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--|--|
| 0    | IOEn       | Controls the GT-96100A's response to I/O<br>accesses.<br>0 - Disable<br>1 - Enable                                                       | 0x0                                   |  |  |
| 1    | MEMEn      | Controls the GT-96100A's response to<br>memory accesses.<br>0 - Disable<br>1 - Enable                                                    | 0x0                                   |  |  |
| 2    | MasEn      | Controls the GT-96100A's ability to act as<br>a master on the PCI bus.<br>0 - Disable<br>1 - Enable                                      | 0x0                                   |  |  |
| 3    | Reserved   | Read only.                                                                                                                               | 0x0                                   |  |  |
| 4    | MemWrInv   | Controls the GT-96100A's ability to gener-<br>ate memory write and invalidate com-<br>mands on the PCI bus.<br>0 - Disable<br>1 - Enable | 0x0                                   |  |  |
| 5    | Reserved   | Read only.                                                                                                                               | 0x0                                   |  |  |
| 6    | PErrEn     | Controls the GT-96100A's ability to<br>respond to parity errors on the PCI by<br>asserting the PErr* pin.<br>0 - Disable<br>1 - Enable   | 0x0                                   |  |  |
| 7    | Reserved   | Read only.                                                                                                                               | 0x0                                   |  |  |
| 8    | SErrEn     | Controls the GT-96100A's ability to assert<br>the SErr* pin.<br>0 - Disable<br>1 - Enable                                                | 0x0                                   |  |  |
| 19:9 | Reserved   | Read only.                                                                                                                               | 0x0                                   |  |  |
| 20   | CapList    | Capability List Support                                                                                                                  | Sampled at Rst* via<br>SDQM[0]* pin.  |  |  |
| 21   | 66MHzEn    | 66MHz Capable.<br>The GT-96100A PCI interface is capable<br>of running at 66MHz regardless of this bit<br>value.                         | Sampled at RESET via the DAdr[9] pin. |  |  |
| 22   | Reserved   | Read only.                                                                                                                               | 0x0                                   |  |  |
|      |            | •                                                                                                                                        |                                       |  |  |

# Table 174: PCI\_0 Status and Command, Offset: 0x004 from PCI\_0 or CPU; 0x084 from PCI\_1



| Bits  | Field Name | Function                                                                                                                | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------|---------------|
| 23    | TarFastBB  | Read only.<br>Indicates that the GT-96100A is capable of<br>accepting fast back-to-back transactions<br>on the PCI bus. | 0x1           |
| 24    | DataParDet | This bit is set by the GT-96100A when it detects a data parity error during master operation.                           | 0x0           |
| 26:25 | DevSelTim  | These pins indicate that the GT-96100A's DevSel timing (medium), per the PCI stan-<br>dard.                             | 0x1 Read only |
| 27    | Reserved   | Read only.                                                                                                              | 0x0           |
| 28    | TarAbort   | This bit is set upon target abort.                                                                                      | 0x0           |
| 29    | MasAbort   | This pin is set upon master abort.                                                                                      | 0x0           |
| 30    | SysErr     | This pin is set upon system error.                                                                                      | 0x0           |
| 31    | DetParErr  | This pin is set upon detection of a parity error in master or slave operations.                                         | 0x0           |

| Table 174: PCI_0 Status and Command, Offset: 0x004 from |
|---------------------------------------------------------|
| PCI_0 or CPU; 0x084 from PCI_1 (Continued)              |

NOTE: For bits 24 and 28 to 31, the user cannot set the bit. The user can only clear the bit by writing 1 to it.

Table 175: PCI\_1 Status and Command, Offset: 0x084 from PCI\_0 or CPU; 0x004 from PCI\_1

| Bits  | Field Name | Function                             | Initial Value                        |
|-------|------------|--------------------------------------|--------------------------------------|
| 19:0  | Various    | Same as for PCI_0 status and command |                                      |
| 20    | CapList    | Capability List Support              | Sampled at Rst* via<br>SDQM[1]* pin. |
| 31:21 | CapList    | Same as for PCI_0 status and command |                                      |



| PCI_0 or CPU; 0x088 from PCI_1 |            |                                                                                            |                                                            |
|--------------------------------|------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------|
| Bits                           | Field Name | Function                                                                                   | Initial Value                                              |
| 7:0                            | RevID      | Indicates the GT-96100A's PCI_0 revision number.                                           | 0x03                                                       |
| 15:8                           | Reserved   | Read only.                                                                                 | 0x0                                                        |
| 23:16                          | SubClass   | Indicates the GT-96100A's subclass.<br>0x00 - Host bridge device<br>0x80 - Memory device   | 0x80                                                       |
| 31:24                          | BaseClass  | Indicates the GT-96100A's base class.<br>0x02 - Network controller<br>0x05 - Memory device | Depends on value sam-<br>pled at reset on Bank-<br>Sel[0]. |

# Table 176: PCI\_0 Class Code and Revision ID, Offset: 0x008 from PCI\_0 or CPU; 0x088 from PCI\_1

#### Table 177: PCI\_1 Class Code and Revision ID, Offset: 0x088 from PCI\_0 or CPU; 0x008 from PCI\_1

| Bits | Field Name | Function                                          | Initial Value                                              |
|------|------------|---------------------------------------------------|------------------------------------------------------------|
| 31:0 | Various    | Same as for PCI_0 class code and revi-<br>sion ID | Depends on value sam-<br>pled at reset on Bank-<br>Sel[0]. |

# Table 178: PCI\_0 BIST, Header Type, Latency Timer, Cache Line, Offset: 0x00c from PCI\_0 or CPU; 0x08c from PCI\_1

| Bits  | Field Name | Function                                                                           | Initial Value |
|-------|------------|------------------------------------------------------------------------------------|---------------|
| 7:0   | CacheLine  | Specifies the GT-96100A's cache line size.                                         | 0x00          |
| 15:8  | LatTimer   | Specifies, in units of PCI bus clocks, the value of the GT-96100A's latency timer. | 0x00          |
| 23:16 | HeadType   | Specifies the layout of bytes 10h through 3fh.                                     | 0x00          |
| 31:24 | BIST       | Built In Self Test<br>Reserved                                                     | 0x00          |



# Table 179: PCI\_1 BIST, Header Type, Latency Timer, Cache Line, Offset: 0x08c from PCI\_0 or CPU; 0x00c from PCI\_1

| Bits | Field Name | Function                                                     | Initial Value |
|------|------------|--------------------------------------------------------------|---------------|
| 31:0 | Various    | As in PCI_0 BIST, Header Type, Latency<br>Timer, Cache Line. | 0x00          |

The BIST Field is reserved and is hardwired to 0.

Device and Vendor ID (0x000), Class Code and Revision ID (0x008), and Header Type (0x00e) fields are read only from the PCI bus. These fields can be modified and read via the CPU bus.

**NOTE:** For more information on these fields, refer to the PCI specification.

Access of PCI masters to SDRAM banks, Devices and internal space is achieved once there is a match between the address presented over the PCI bus and the space defined by the respective Base/Size register pair. The GT-96100A incorporates three Swapped Base Address registers for SCS[1:0]\*, SCS[3:2]\*, CS[3]\*, and BootCS\*. When the address matches a Swapped Base Address register x, the data transferred will undergo the opposite to what is indicated by the ByteSwap bit (bit[0] of 0xc00). e.g. using this mechanism, one could write data directly to SDRAM and read it byte-swapped without CPU processing.

**NOTE:** The address must not match its respective non-Swap Base Address register.

The Size registers cannot define a zero size space. In order to enable the system designer to use addresses which are within a certain space without having the GT-96100A respond to these addresses, a Base Address Enable register is incorporated. A disabled space will not trigger a device response if the address falls within the space defined by its Base/Size register pair.

| Bits  | Field Name | Function                                                                                                                                              | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0     | MemSpace   | Memory Space Indicator<br>Read only.                                                                                                                  | 0x0           |
| 2:1   | Туре       | Type<br>Read only.                                                                                                                                    | 0x0           |
| 3     | Prefetch   | Prefetch                                                                                                                                              | 0x1           |
| 11:4  | Reserved   | Read only.                                                                                                                                            | 0x0           |
| 31:12 | Base       | Defines the address assignment of SCS[1:0]*, see Table 138.<br>Reserved if this BAR is disabled through PCI_0 Base Address registers' enable setting. | 0x00000       |

## Table 180: PCI\_0 SCS[1:0]\* Base Address, Offset: 0x010 from PCI\_0 or CPU; 0x090 from PCI\_1

### Table 181: PCI\_1 SCS[1:0]\* Base Address, Offset: 0x090 from PCI\_0 or CPU; 0x010 from PCI\_1

| Bits | Field Name | Function                                    | Initial Value |
|------|------------|---------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 SCS[1:0]* Base<br>Address | 0x08          |



| Bits  | Field Name | Function                                                                                                                                                       | Initial Value |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0     | MemSpace   | Memory Space Indicator<br>Read only.                                                                                                                           | 0x0           |
| 2:1   | Туре       | Type<br>Read only.                                                                                                                                             | 0x0           |
| 3     | Prefetch   | Prefetch                                                                                                                                                       | 0x1           |
| 11:4  | Reserved   | Read only.                                                                                                                                                     | 0x0           |
| 31:12 | Base       | Defines the address assignment of<br>SCS[3:2]*, see Table 140.<br>Reserved if this BAR is disabled through<br>PCI_0 Base Address registers' enable<br>setting. | 0x01000       |

# Table 182: PCI\_0 SCS[3:2]\* Base Address, Offset: 0x014 from PCI\_0 or CPU; 0x094 from PCI\_1

#### Table 183: PCI\_1 SCS[3:2]\* Base Address, Offset: 0x094 from PCI\_0 or CPU; 0x014 from PCI\_1

| Bits | Field Name | Function                                     | Initial Value |
|------|------------|----------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 SCS[3:2]* Base<br>Address. | 0x01000008    |

### Table 184: PCI\_0 CS[2:0]\* Base Address, Offset: 0x018 from PCI\_0 or CPU; 0x098 from PCI\_1

| Bits  | Field Name | Function                                                                                                                                             | Initial Value |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0     | MemSpace   | Memory Space Indicator<br>Read only.                                                                                                                 | 0x0           |
| 2:1   | Туре       | Type<br>Read only.                                                                                                                                   | 0x0           |
| 3     | Prefetch   | Prefetch                                                                                                                                             | 0x0           |
| 11:4  | Reserved   | Read only.                                                                                                                                           | 0x0           |
| 31:12 | Base       | Defines the address assignment of CS[2:0]*, see Table 142.<br>Reserved if this BAR is disabled through PCI_0 Base Address registers' enable setting. | 0x1c000       |

# Table 185: PCI\_1 CS[2:0]\* Base Address, Offset: 0x098 from PCI\_0 or CPU; 0x018 from PCI\_1

| Bits | Field Name | Function                                   | Initial Value |
|------|------------|--------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 CS[2:0]* Base<br>Address | ox1c000000    |

### Table 186: PCI\_0 CS[3]\* and Boot CS\* Base Address, Offset: 0x01c from PCI\_0 or CPU; 0x09c from PCI\_1

| Bits  | Field Name | Function                                                                                                                                                                 | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0     | MemSpace   | Memory Space Indicator<br>Read only.                                                                                                                                     | 0x0           |
| 2:1   | Туре       | Type<br>Read only.                                                                                                                                                       | 0x0           |
| 3     | Prefetch   | Prefetch                                                                                                                                                                 | 0x0           |
| 11:4  | Reserved   | Read only.                                                                                                                                                               | 0x0           |
| 31:12 | Base       | Defines the address assignment of CS[3]*<br>and Boot CS*, see Table 144.<br>Reserved if this BAR is disabled through<br>PCI_0 Base Address registers' enable<br>setting. | 0x1f000       |

### Table 187: PCI\_1 CS[3]\* and Boot CS\* Base Address, Offset: 0x09c from PCI\_0 or CPU; 0x01c from PCI\_1

| Bits | Field Name | Function                                               | Initial Value |
|------|------------|--------------------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 CS[3]* and Boot CS*<br>Base Address. | 0x1f000000    |



| Bits  | Field Name | Function                                                                                                                                                                 | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0     | MemSpace   | Memory Space Indicator<br>Read only.                                                                                                                                     | 0x0           |
| 2:1   | Туре       | Type<br>Read only.                                                                                                                                                       | 0x0           |
| 3     | Prefetch   | Prefetch<br>Read only.                                                                                                                                                   | 0x0           |
| 11:4  | Reserved   | Read only.                                                                                                                                                               | 0x0           |
| 31:12 | MemMapBase | Defines the address assignment of the<br>GT-96100A's internal registers.<br>Reserved if this BAR is disabled through<br>PCI_0 Base Address registers' enable<br>setting. | 0x14000       |

# Table 188: PCI\_0 Internal Registers Memory Mapped Base Address, Offset: 0x020 from PCI\_0 or CPU; 0x0a0 from PCI\_1

# Table 189: PCI\_1 Internal Registers Memory Mapped Base Address, Offset: 0x0a0 from PCI\_0 or CPU; 0x020 from PCI\_1

| Bits | Field Name | Function                                                             | Initial Value |
|------|------------|----------------------------------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 Internal register's<br>Memory Mapped Base Address. | 0x14000000    |

# Table 190: PCI\_0 Internal Registers I/O Mapped Base Address, Offset: 0x024 from PCI\_0 or CPU; 0x0a4 from PCI\_1

| Bits  | Field Name | Function                                                                                                                                                                 | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0     | MemSpace   | IO Space Indicator                                                                                                                                                       | 0x1           |
| 11:1  | Reserved   | Read only.                                                                                                                                                               | 0x0           |
| 31:12 | IOMapBase  | Defines the address assignment of the<br>GT-96100A's internal registers.<br>Reserved if this BAR is disabled through<br>PCI_0 Base Address registers' enable<br>setting. | 0x14000       |

#### Table 191: PCI\_1 Internal Registers I/O Mapped Base Address, Offset: 0x0a4 from PCI\_0 or CPU; 0x024 from PCI\_1

| Bits | Field Name | Function                                                       | Initial Value |
|------|------------|----------------------------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 Internal register's I/O Mapped Base Address. | 0x14000001    |

# Table 192: PCI\_0 Subsystem Device and Vendor ID, Offset: 0x02c from PCI\_0 or CPU; 0x0ac from PCI\_1

| Bits  | Field Name | Function                                                  | Initial Value |
|-------|------------|-----------------------------------------------------------|---------------|
| 15:0  | VenID      | Provides the subsystem vendor Identifica-<br>tion number. | 0x0           |
| 31:16 | DevID      | Provides the subsystem device identifica-<br>tion number. | 0x0           |

### Table 193: PCI\_1 Subsystem Device and Vendor ID, Offset: 0x0ac from PCI\_0 or CPU; 0x02c from PCI\_1

| Bits | Field Name | Function                                             | Initial Value |
|------|------------|------------------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 subsystem device and<br>vendor ID. | 0x0           |

### Table 194: Expansion ROM Base Address Register, Offset: 0x030 from PCI\_0 or CPU; 0x0b0 from PCI\_1

| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                    | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0     | ERDecEn    | Expansion ROM Decode Enable<br>0 - Disable<br>1 - Enable                                                                                                                                                                                                                                                                                                                                                    | 0x0           |
| 11:1  | Reserved   |                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0           |
| 31:12 | ERBase     | Defines the address of the expansion<br>ROM memory space region assigned to<br>the GT-96100A. This is where the expan-<br>sion ROM code appears in system mem-<br>ory when bit 0 of this register contains a<br>value of 1 and bit 1 of this device's Com-<br>mand Register contains a value of 1.<br>This register is reserved in case Expan-<br>sion ROM was not enabled at Reset<br>(DAdr[5] sampled 0). | 0x1f000       |



## Table 195: PCI\_0 Capability List Pointer Register, Offset: 0x034 from PCI\_0 or CPU, 0xb4 from PCI\_1<sup>1</sup>

| Bits | Field Name | Function                               | Initial Value |
|------|------------|----------------------------------------|---------------|
| 7:0  | CapPtr     | Capability List Pointer.<br>Read only. | 0x40          |
| 31:8 | Reserved   |                                        | 0x0           |

1. Reserved if Power management is disabled

# Table 196: PCI\_1 Capability List Pointer Register, Offset: 0x0b4<sup>1</sup> from PCI\_0 or CPU, 0x34 from PCI\_1

| Bits | Field Name | Function                               | Initial Value |
|------|------------|----------------------------------------|---------------|
| 7:0  | CapPtr     | Capability List Pointer.<br>Read only. | 0x40          |
| 31:8 | Reserved   |                                        | 0x0           |

### Table 197: PCI\_0 Interrupt Pin and Line, Offset: 0x03c from PCI\_0 or CPU; 0x0bc from PCI\_1

| Bits  | Field Name | Function                                                                                  | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------|---------------|
| 7:0   | IntLine    | Provides interrupt line routing information.                                              | 0x0           |
| 15:8  | IntPin     | Indicates which interrupt pin is used by the GT-96100A.<br>NOTE: The GT-96100A uses INTA. | 0x1           |
| 31:16 | Reserved   | Read only.                                                                                | 0x0           |

### Table 198: PCI\_1 Interrupt Pin and Line, Offset: 0x0bc from PCI\_0 or CPU; 0x03c from PCI\_1

| Bits | Field Name | Function                                  | Initial Value |
|------|------------|-------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 interrupt pin and line. | 0x00000100    |



| Bits  | Field Name | Function                                                                                             | Initial Value |
|-------|------------|------------------------------------------------------------------------------------------------------|---------------|
| 7:0   | CapID      | Capability ID<br>Read only from PCI.                                                                 | 0x1           |
| 15:8  | NullPTR    | Null Pointer<br>Indicates that PMC is the last item in the<br>capability list.<br>Read Only from PCI | 0x0           |
| 18:16 | PMCVer     | PCI Power Management Spec Revision<br>Read only from PCI.                                            | 0x1           |
| 19    | PMECIk     | PME Clock<br>Read only from PCI.                                                                     | 0x1           |
| 20    | Reserved   | Read only from PCI.                                                                                  | 0x0           |
| 21    | DSI        | Device Specific Initialization<br>Read only from PCI.                                                | 0x0           |
| 24:22 | AuxCur     | Auxulary Current Requirements<br>Read only from PCI.                                                 | 0x0           |
| 25    | D1Sup      | D1 Power Management State Support<br>Read only from PCI                                              | 0x0           |
| 26    | D2Sup      | D2 Power Management State Support<br>Read only from PCI.                                             | 0x0           |
| 31:27 | PMESup     | PME* Signal Support<br>Read Only from PCI.                                                           | 0x0           |

# Table 199: PCI\_0 PMC Register, Offset: 0x040 from PCI\_0 or CPU, 0x0c0 from PCI\_1<sup>1</sup>

1. Reserved if Power Management is disabled

# Table 200: PCI\_1 PMC Register, Offset: 0x0c0 from

PCI\_0 or CPU, 0x040 from PCI\_1<sup>1</sup>

| Bits | Field Name | Function                        | Initial Value |
|------|------------|---------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 PMC register. | 0x00090001    |



| Dite  | Field Neme | Function                                              | Initial Value |
|-------|------------|-------------------------------------------------------|---------------|
| Bits  | Field Name | Function                                              | Initial Value |
| 1:0   | PState     | Power State                                           | 0x0           |
| 7:2   | Reserved   | Read only from PCI.                                   | 0x0           |
| 8     | PME_EN     | PME* Pin Assertion Enable<br>Read only from PCI.      | 0x0           |
| 12:9  | DSel       | Data Select<br>Read only from PCI.                    | 0x0           |
| 14:13 | DScale     | Data Scale<br>Read only from PCI.                     | 0x0           |
| 15    | PME_Stat   | PME* Pin Status<br>Read only from PCI.                | 0x0           |
| 21:16 | Reserved   | Read only from PCI.                                   | 0x0           |
| 22    | B2_B3      | B2/B3 Select<br>Read only from PCI.                   | 0x0           |
| 23    | BPCC_En    | Bus Power/Clock Control Enable Read<br>only from PCI. | 0x0           |
| 31:24 | Data       | State Data<br>Read only from PCI.                     | 0x0           |

# Table 201: PCI\_0 PMCSR Register, Offset: 0x044 from PCI\_0 or CPU, 0x0c4 from PCI\_1<sup>1</sup>

### Table 202: PCI\_1 PMCSR Register, Offset: 0x0c4 from PCI\_0 or CPU, 0x044 from PCI\_1

| Bits | Field Name | Function                          | Initial Value |
|------|------------|-----------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 PMCSR register. | 0x0           |

# 7.14.3 Function 1 Configuration Registers

The GT-96100A acts as two function device. It's PCI slave interface responds to configuration transactions to function number 0 or 1. Most of function 1 configuration registers are aliased to function 0 registers or reserved, except of the 3 swap BARs. To access any of the Swap Base Address registers, a configuration access addressed to function 1 must be used with the appropriate offset. If an offset other than 0x010, 0x014, or 0x01c is accessed when specifying function 1, the transaction accesses the corresponding offset register in function 0. Configuration transactions to any other function number are ignored.

The GT-96100A acts as two function device regardless of multi-function bit (bit[7] in Header Type). However, this bit value after reset is 0. In a PC environment, in order for a BIOS to recognize the GT-96100A as a multi-function device (if swap BARs are required in the system), set this bit and enable the swap BARs (Base Address Enable register) before BIOS starts. This can be done by programing by CPU software or by using the GT-96100A's Auto-Load option.

| Bits  | Field Name | Function                                                                                                                                                | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0     | MemSpace   | Memory Space Indicator<br>Read only.                                                                                                                    | 0x0           |
| 2:1   | Туре       | Type<br>Read only.                                                                                                                                      | 0x0           |
| 3     | Prefetch   | Prefetch                                                                                                                                                | 0x1           |
| 11:4  | Reserved   | Read only.                                                                                                                                              | 0x0           |
| 31:12 | Base       | Defines the address assignment of<br>Swapped SCS[1:0]*.<br>Reserved if this BAR is disabled through<br>PCI_0 Base Address registers' enable<br>setting. | 0x0           |

#### Table 203: Function1 PCI\_0 Swapped SCS[1:0]\* Base Address, Offset: 0x110 from PCI\_0 or CPU; 0x190 from PCI\_1

#### Table 204: Function 1 PCI\_1 Swapped SCS[1:0]\* Base Address, Offset: 0x190 from PCI\_0 or CPU; 0x110 from PCI\_1

| Bits | Field Name | Function                                            | Initial Value |
|------|------------|-----------------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 Swapped SCS[1:0]*<br>Base Address | 0x08          |

### Table 205: Function 1 PCI\_0 Swapped SCS[3:2]\* Base Address, Offset: 0x114 from PCI\_0 or CPU; 0x194 from PCI\_1

| Bits | Field Name | Function                             | Initial Value |
|------|------------|--------------------------------------|---------------|
| 0    | MemSpace   | Memory Space Indicator<br>Read only. | 0x0           |

| Table 205: Function 1 PCI_0 Swapped SCS[3:2]* Base Address,   |
|---------------------------------------------------------------|
| Offset: 0x114 from PCI_0 or CPU; 0x194 from PCI_1 (Continued) |

| Bits  | Field Name | Function                                                                                                                                                | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 2:1   | Туре       | Type<br>Read only.                                                                                                                                      | 0x0           |
| 3     | Prefetch   | Prefetch                                                                                                                                                | 0x1           |
| 11:4  | Reserved   | Read only.                                                                                                                                              | 0x0           |
| 31:12 | Base       | Defines the address assignment of<br>Swapped SCS[3:2]*.<br>Reserved if this BAR is disabled through<br>PCI_0 Base Address registers' enable<br>setting. | 0x01000       |

# Table 206: Function 1 PCI\_1 Swapped SCS[3:2]\* Base Address, Offset: 0x194 from PCI\_0 or CPU; 0x114 from PCI\_1

| Bits | Field Name | Function                                             | Initial Value |
|------|------------|------------------------------------------------------|---------------|
| 31:0 | Various    | Same as for PCI_0 Swapped SCS[3:2]*<br>Base Address. | 0x01000008    |

### Table 207: Function 1 PCI\_0 Swapped CS[3]\* & Boot CS\* Base Address, Offset: 0x11c from PCI\_0 or CPU; 0x19c from PCI\_1

| Bits  | Field Name | Function                                                                                | Initial Value |
|-------|------------|-----------------------------------------------------------------------------------------|---------------|
| 0     | MemSpace   | Memory Space Indicator<br>Read only.                                                    | 0x0           |
| 2:1   | Туре       | Type<br>Read only.                                                                      | 0x0           |
| 3     | Prefetch   | Prefetch                                                                                | 0x0           |
| 11:4  | Reserved   | Read only.                                                                              | 0x0           |
| 31:12 | Base       | Defines the address assignment of CS[3]* and Boot CS*, see Table 144.                   | 0x1f000       |
|       |            | Reserved if this BAR is disabled through PCI_0 Base Address registers' enable setting.) |               |

# Table 208: Function 1 PCI\_1 Swapped CS[3]\* & Boot CS\* Base Address, Offset: 0x19c from PCI\_0 or CPU; 0x11c from PCI\_1

| Bits | Field Name | Function                                              | Initial Value |
|------|------------|-------------------------------------------------------|---------------|
| 31:0 | Various    | As in PCI_0 Swapped CS[3]* and Boot CS* Base Address. | 0x1f000000    |



# 8. INTELLIGENT I/O (120) STANDARD SUPPORT

The GT-96100A includes hardware support for the Intelligent I/O (I<sub>2</sub>O) Standard.

This support includes all of the registers required for implementing the  $I_2O$  Messaging Unit as defined in the  $I_2O$  Specification. This Messaging Unit (MU) is compatible with that found in Intel's i960Rx processors. However, the combination of MIPS processors and the GT-96100A delivers as much as 20 times the integer performance of the i960RP.

The  $I_2O$  hardware support found in the GT-96100A also provides designers of non- $I_2O$  embedded systems with important benefits. For example, the circular queue support in the MU provides a simple, powerful mechanism for passing queued messages between intelligent agents on a PCI bus. Even the simple message and doorbell registers improve the efficiency of communication between agents on PCI.

**NOTE:** Even if you have no intention of using the entire I<sub>2</sub>O "stack", Galileo Technology recommends reading this entire section to learn about improving the application of the hardware to the design.

# 8.1 Overview

The best source for an overview description of I<sub>2</sub>O support is in the I<sub>2</sub>O specification documentation.

The I<sub>2</sub>O specification defines a standard mechanism for passing messages between a host processor (a Pentium<sup>TM</sup>, for example) and intelligent I/O processors (a networking card based on the GT-96100A and a MIPS processor, for example.) This same message passing mechanism is used to pass messages between peers in a system.

I<sub>2</sub>O is defined to be bus independent but, in the real world, it runs over the PCI. The basic process is quite simple:

- 1. A master wishing to post a message to a device, fetches a pointer from the device from a defined register in the target devices PCI memory space (one of the I<sub>2</sub>O registers).
- 2. The master assembles the message in the targets memory space and then posts the fetched pointer into another register in the target device. Posting the pointer generates an interrupt to the target's processor.

The  $I_2O$  specification documentation also defines a simpler mechanism for implementing message passing through doorbell and message registers. The GT-96100A also includes this support.

# 8.2 I<sub>2</sub>O Registers

From the PCI side, the registers used to implement  $I_2O$  support resides in the first 128 bytes of the memory region defined by RAS[1:0] Base Address register in PCI function 0 of PCI interface  $0^1$ . The  $I_2O$  registers are accessible from the CPU side through an offset from the CPU Internal Space Base register.

NOTE: Index registers are not supported in GT-96100A.

<sup>1.</sup> There is no  $I_2O$  support on the PCI\_1 interface.



# Table 209: I<sub>2</sub>O PCI and CPU Offsets

| I <sub>2</sub> O Register            | PCI Side <sup>1</sup> | CPU Side <sup>2</sup> |
|--------------------------------------|-----------------------|-----------------------|
| Inbound Message Register 0           | 0x10                  | 0x1c10                |
| Inbound Message Register 1           | 0x14                  | 0x1c14                |
| Outbound Message Register 0          | 0x18                  | 0x1c18                |
| Outbound Message Register 1          | 0x1c                  | 0x1c1c                |
| Inbound Doorbell Register            | 0x20                  | 0x1c20                |
| Inbound Interrupt Cause Register     | 0x24                  | 0x1c24                |
| Inbound Interrupt Mask Register      | 0x28                  | 0x1c28                |
| Outbound Doorbell Register           | 0x2c                  | 0x1c2c                |
| Outbound Interrupt Cause Register    | 0x30                  | 0x1c30                |
| Outbound Interrupt Mask Register     | 0x34                  | 0x1c34                |
| Inbound Queue Port Virtual Register  | 0x40                  | 0x1c40                |
| Outbound Queue Port Virtual Register | 0x44                  | 0x1c44                |
| Queue Control Register               | 0x50                  | 0x1c50                |
| Queue Base Address Register          | 0x54                  | 0x1c54                |
| Inbound Free Head Pointer Register   | 0x60                  | 0x1c60                |
| Inbound Free Tail Pointer Register   | 0x64                  | 0x1c64                |
| Inbound Post Head Pointer Register   | 0x68                  | 0x1c68                |
| Inbound Post Tail Pointer Register   | 0x6c                  | 0x1c6c                |
| Outbound Free Head Pointer Register  | 0x70                  | 0x1c70                |
| Outbound Free Tail Pointer Register  | 0x74                  | 0x1c74                |
| Outbound Post Head Pointer Register  | 0x78                  | 0x1c78                |
| Outbound Post Tail Pointer Register  | 0x7c                  | 0x1c7c                |
| RESERVED                             | 0x80 to 4K            | -                     |
| SDRAM Ras[1:0]                       | >4K                   | -                     |

1. Offset from BAR0 in PCI Memory Space

2. Offset from CPU Internal Space Base register (location in MIPS CPU memory space)



# 8.3 Enabling I<sub>2</sub>O Support

The  $I_2O$  registers are only visible from the PCI side when  $I_2O$  support is enabled via the pin strapping option shown in the RESET Configuration section.

When I<sub>2</sub>O support is disabled, the locations from BAR0+0x0 to BAR0+0x7F appear as SDRAM.

# 8.4 Register Map Compatibility with the i960Rx Family

The GT-96100A's register map is compatible with the  $I_2O$  specification. However, some of the registers found in Intel's i960Rx processors are not implemented. This information is shown in Table 210.

| Register<br>Name        | GT-96100A       | i960Rx      | Comment                                                                                                                                                         |
|-------------------------|-----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| APIC Register<br>Select | Not implemented | Implemented | No APIC support required for the GT-<br>96100A, not a part of the $I_2O$ spec.                                                                                  |
| APIC Window<br>Select   | Not implemented | Implemented | No APIC support required for the GT-<br>96100A, not a part of the $I_2O$ spec.                                                                                  |
| Index Registers         | Not implemented | Implemented | Index registers are not used for $I_2O$ message passing so this is not a compatibility issue. Index registers are implemented as normal SDRAM in the GT-96100A. |

Table 210: Register Differences Between the GT-96100A and i960Rx

# 8.5 Message Registers

The GT-96100A uses the message registers to send and receive short messages over the PCI bus, without transferring data into local memory. When written, message registers may cause an interrupt to be generated either to the MIPS CPU or to the PCI bus. There are two types of message registers:

- Inbound messages are sent by an external PCI bus agent and received by the GT-96100A
- Outbound messages are sent by the GT-96100A's local CPU and received by an external PCI agent

The interrupt status for inbound messages is recorded in the Inbound Interrupt Cause register.

The interrupt status for outbound messages is recorded in the Outbound Interrupt Cause register.

# 8.5.1 Inbound Messages

There are two Inbound Message registers (IMRs).

When an IMR is written from the PCI side, a maskable interrupt request is generated in the Inbound Interrupt Status register (IISR). If this request is unmasked, an interrupt request is issued to the MIPS CPU. The interrupt is cleared when the CPU writes a value of 1 to the Inbound Message Interrupt bit in the IISR. The interrupt may be masked through the mask bits in the Inbound Interrupt Mask register.



# 8.5.2 Outbound Messages

There are two Outbound Message registers (OMRs).

When an OMR is written from the CPU side, a maskable interrupt request is generated in the Outbound Interrupt Status register (OISR). If this request is unmasked, an interrupt request is issued to the PCI\_0 unit. The interrupt is cleared when an external PCI agent writes a value of 1 to the Outbound Message Interrupt bit in the OISR. The interrupt may be masked through the mask bits in the Outbound Interrupt Mask register.

# 8.6 Doorbell Registers

The GT-96100A uses the doorbell registers to request interrupts on the PCI and CPU buses. There are two types of doorbell registers:

- Inbound doorbells are set by an external PCI bus agent to request interrupt service from the MIPS CPU
- Outbound doorbells are set by the GT-96100A's local CPU and to request an interrupt on PCI

# 8.6.1 Outbound Doorbells

The local MIPS processor generates an interrupt request to the PCI bus by setting bits in the Outbound Doorbell register (ODR). The interrupt may be masked in the OIMR register, however masking the interrupt does not prevent the corresponding bit from being set in the ODR.

External PCI agents clear the interrupt by setting bits in the ODR to 1 through a write.

# 8.6.2 Inbound Doorbells

The PCI bus can generate an interrupt request to the local MIPS processor by setting bits in the Inbound Doorbell register (IDR). The interrupt may be masked in the IIMR register, however masking the interrupt does not prevent the corresponding bit from being set in the IDR.

The CPU clears the interrupt by setting bits in the IDR (writing a 1).

# 8.7 Circular Queues

The circular queues form the heart of the  $I_2O$  message passing mechanism, and are also the most powerful part of the MU built into the GT-96100A. There are four circular queues in the MU: two inbound and two outbound.

# 8.7.1 Inbound Message Queues

There are two inbound message queues:

- The Inbound Posts queue is for messages from other PCI agents for the MIPS CPU to process
- The Inbound Free queue is for messages from MIPS CPU to PCI agent in response to an incoming message.



The two inbound queues allow external PCI agents to post inbound messages for the local MIPS CPU in one queue and receive free messages (no longer in use) returning from the MIPS CPU. The process is as follows:

- 1. An external PCI agent posts an inbound message.
- 2. The MIPS CPU receives and processes the message.
- 3. When the processing is complete, the MIPS CPU places the message back into the inbound free queue so that it may be reused.

# 8.7.2 Outbound message queues

There are two outbound message queues:

- The Outbound Post queue is for messages from the MIPS CPU to other PCI agents to process.
- The Outbound Free queue is for messages are from PCI agent to the MIPS CPU in response to an outgoing message.

The two outbound queues allow the MIPS CPU to post outbound messages for external PCI agents in one queue and receive free messages (no longer in use) returning from external PCI agents. The process is as follows:

- 1. The MIPS CPU posts an outbound message.
- 2. The external PCI agent receives and processes the message.
- 3. When the processing is complete, the external PCI agent places the message back into the outbound free queue so that it may be reused.

# 8.7.3 Memory for Circular Queues

Data storage for the circular queues must be allocated in local SDRAM.

The base address for the queues is set in the Queue Base Address register (QBAR). Each queue entry is a 32-bit data value. The circular queue sizes range from 4K entries (16Kbytes) to 64K entries (256Kbytes) yielding a total local memory allotment of 64Kbytes to 1Mbyte. All four queues must be the same size and be contiguous in the memory space. Queue size is set in the Queue Control register.

The starting address of each queue is based on the QBAR address and the size of the queues as shown in the table below.

Table 211: Circular Queue Starting Addresses

| Queue         | Starting Address    |
|---------------|---------------------|
| Inbound Free  | QBAR                |
| Inbound Post  | QBAR + Queue Size   |
| Outbound Post | QBAR + 2*Queue Size |
| Outbound Free | QBAR + 3*Queue Size |

Each queue has a head pointer and a tail pointer kept in the GT-96100A's internal registers. These pointers are offsets from the QBAR. Writes to a queue occur at the head of the queue; reads occur from the tail. The head and tail pointers are incremented by either the CPU software or messaging unit hardware. The pointers wrap around to the first address of a queue when they reach queue size.

PCI read/write from queue is always single-word. An attempt to burst from an  $I_2O$  queue will result in disconnect after 1st data transfer.







# 8.7.4 Inbound/Outbound Queue Port Register Function

The circular queues are accessed by external PCI agents through the Inbound and Outbound Queue Port virtual registers in the I<sub>2</sub>O/PCI address space, decoded by BAR0.

**NOTE:** The Inbound and Outbound Queue Port virtual registers are not read/write physical registers within the GT-96100A. These virtual registers are reading and writing pointers into the circular queues (located in SDRAM) that are controlled by the GT-96100A. Refer to Figure 31.

## 8.7.4.1 Inbound Queue Port Reads and Writes

When Inbound Queue Port (IQP) is written from PCI, the written data is placed on the Inbound Post Queue. The IQP is posting the message to the local CPU. An interrupt is generated to the MIPS CPU when the Inbound Post Queue is written to alert the CPU that a message needs processing. When this register is read from the PCI side, it is returning a free message from the tail of Inbound Free Queue.

## 8.7.4.2 The Outbound Queue Port

The Outbound Queue Port (OQP) returns data from the tail of the Outbound Post Queue when read from the PCI side. The OQP is returning the next message requiring service by the external PCI agent. When this register is written from PCI, the data for the write is placed on the Outbound Free Queue. This, in turn, returns a free message for reuse by the local MIPS CPU.

# 8.7.5 Inbound Post Queue

The Inbound Post Queue holds posted messages from external PCI agents to the MIPS CPU. The MIPS CPU fetches the next message process from the queue tail. External agents post new messages to the queue head. The tail pointer is maintained in software by the MIPS CPU. The head pointer is maintained automatically by the GT-96100A upon posting of a new inbound message.

PCI writes to the IQP are passed to local memory location at QBAR + Inbound Post Head Pointer. After this write completes, the GT-96100A increments the Inbound Post Head Pointer by 4 bytes (1 word); it now points to the next available slot for a new inbound message. An interrupt is also sent to the MIPS CPU to indicate the presence of a new message pointer.

From the time the PCI write ends till the data is actually written to DRAM, any new write to Inbound port will result in RETRY. If queue is full, a new PCI write to the queue will result in RETRY.

Inbound messages are fetched by the MIPS CPU by reading the contents of the address pointed to by the Inbound Post Tail Pointer. It is the CPUs responsibility to increment the tail pointer to point to the next unread message.

# 8.7.6 Inbound Free Queue

The Inbound Free Queue holds available inbound free messages for external PCI agents to use. The MIPS CPU places free messages at the queue head; external agents fetch free messages from the queue tail. The head pointer is maintained in software by the MIPS CPU. The tail pointer is maintained automatically by the GT-96100A upon a PCI agent fetching a new inbound free message (except when there is an error, see below.)



PCI reads from the Inbound Queue Port return data to the local memory location at QBAR + Inbound Free Tail Pointer according to the following conditions:

- If the Inbound Free Queue is not empty (as indicated by Head Pointer not equal to Tail Pointer), then the data pointed to by QBAR + Inbound Free Tail Pointer is returned.
- If the queue is empty (Head Pointer equals Tail Pointer), the value 0xFFFF.FFFF is returned. This indicates there are no Inbound Message slots available (an error condition.)

The MIPS processor places free message buffers in the Inbound Free Queue by writing the pointer to the location pointed to by the head pointer. It is the processor's responsibility to then increment the head pointer.

# 8.7.7 Outbound Post Queue

The Outbound Post Queue holds outbound posted messages from the MIPS CPU to external PCI agents. The MIPS CPU places outbound messages at the queue head; external agents fetch the posted messages from the queue tail. The Outbound Post Tail Pointer is automatically incremented by the GT-96100A. The head pointer must be incremented by the local MIPS CPU.

PCI reads from the Outbound Queue Port return the data pointed to by QBAR + Outbound Post Tail Pointer (the next posted message in the Outbound Queue.) The following conditions apply:

- If the Outbound Post Queue is not empty (the head and tail pointers are not equal), the data is returned as usual and the GT-96100A increments the Outbound Post Tail Pointer
- If the Outbound Post Queue is empty (the head and tail pointers are equal), the value 0xFFFF.FFFF is returned

As long as the Outbound Post Head and Tail pointers are not equal, a PCI interrupt is requested. This is done to indicate the need to have the external PCI agent read the Outbound Post Queue. When the head and tail pointers are equal, no PCI interrupt is generated since no service is required on the part of the external PCI agent (or PCI system host in the case of a PC server.) In either case, the interrupt can be masked in the OIMR register.

The MIPS CPU places outbound messages in the Outbound Post Queue by writing to the local memory location pointed to by the Outbound Post Head Pointer. After writing this pointer, it is the CPU's responsibility to increment the head pointer.

# 8.7.8 Outbound Free Queue

The Outbound Free Queue holds available outbound message buffers for the local MIPS processor to use. External PCI agents place free message at the queue head; the MIPS CPU fetches free message pointers from the queue tail. The tail pointer in maintained in software by the MIPS CPU. The head pointer is maintained automatically by the GT-96100A upon a PCI agent posting a new ("returned") outbound free message.

PCI writes to the Outbound Queue Port result in the data being written to the local memory location at QBAR + Outbound Free Head Pointer. After the write completes, the GT-96100A increments the head pointer.

From the time the PCI write ends till the data is actually written to DRAM, any new write to Outbound port will result in RETRY. If the head pointer and tail pointer become equal (an indication that the queue is full), an interrupt is sent to the MIPS CPU. If queue is full, a new PCI write to the queue will result in RETRY.

The MIPS processor obtains free outbound message buffers from the Outbound Free Queue by reading data from the location pointed to by the tail pointer. It is the processor's responsibility to then increment the tail pointer.

| Table 212: I <sub>2</sub> O Circular Queue Functional Sum |
|-----------------------------------------------------------|
|-----------------------------------------------------------|

| Queue<br>Name    | PCI Port               | Generate<br>PCI<br>Interrupt?      | Generate<br>CPU<br>Interrupt? | Head<br>Pointer<br>maintaine<br>d by | Tail Pointer<br>maintained<br>by |
|------------------|------------------------|------------------------------------|-------------------------------|--------------------------------------|----------------------------------|
| Inbound<br>Post  | Inbound<br>Queue Port  | No                                 | Yes, when queue is<br>written | GT-96100A                            | MIPS CPU                         |
| Inbound<br>Free  |                        | No                                 | No                            | MIPS CPU                             | GT-96100A                        |
| Outbound<br>Post | Outbound<br>Queue Port | Yes, when<br>queue is not<br>empty | No                            | MIPS CPU                             | GT-96100A                        |
| Outbound<br>Free |                        | No                                 | Yes, when queue is<br>full    | GT-96100A                            | MIPS CPU                         |

# 8.8 I<sub>2</sub>O Support Registers

If I<sub>2</sub>O is enabled (i.e., DAdr[8] was sampled '0' at reset) its related registers are accessible from the CPU side and the PCI\_0 side. To access registers from the PCI\_0 side, the address must be in the first 4KBytes of PCI\_0 SCS[1:0]\* Base register space. To access from CPU side, the address must be in the 4KBytes of CPU Internal Space Base register space.

PCI\_1 has no access to I<sub>2</sub>O registers. If PCI\_1 address hits first 4KBytes of PCI\_1 SCS[1:0]\* BAR space, it accesses SDRAM.

If accessed from the PCI\_0 side, address offset is with respect to the PCI\_0 SCS[1:0]\* Base Address register contents. If accessed from the CPU side, address offset is with respect to the CPU Internal Space Base register + 0x1c00.

**NOTE:** I<sub>2</sub>O registers can be accessed from the CPU and PCI\_0 sides (unless stated otherwise). If accessed from the PCI\_0 side, address offset is with respect to the PCI\_0 SCS[1:0]\* Base Address register contents. If accessed from CPU side, the address offset is with respect to the CPU Internal Space Base Register + 0x1c00.

| Description                          | Offset | Page Number |
|--------------------------------------|--------|-------------|
| Inbound Message Register 0           | 0x10   | page 211    |
| Inbound Message Register 1           | 0x14   | page 211    |
| Outbound Message Register 0          | 0x18   | page 211    |
| Outbound Message Register 1          | 0x1c   | page 211    |
| Inbound Doorbell Register            | 0x20   | page 212    |
| Inbound Interrupt Cause Register     | 0x24   | page 212    |
| Inbound Interrupt Mask Register      | 0x28   | page 213    |
| Outbound Doorbell Register           | 0x2c   | page 213    |
| Outbound Interrupt Cause Register    | 0x30   | page 214    |
| Outbound Interrupt Mask Register     | 0x34   | page 214    |
| Inbound Queue Port Virtual Register  | 0x40   | page 215    |
| Outbound Queue Port Virtual Register | 0x44   | page 215    |
| Queue Control Register               | 0x50   | page 215    |
| Queue Base Address Register          | 0x54   | page 216    |
| Inbound Free Head Pointer Register   | 0x60   | page 216    |
| Inbound Free Tail Pointer Register   | 0x64   | page 216    |
| Inbound Post Head Pointer Register   | 0x68   | page 216    |
| Inbound Post Tail Pointer Register   | 0x6c   | page 217    |
| Outbound Free Head Pointer Register  | 0x70   | page 217    |
| Outbound Free Tail Pointer Register  | 0x74   | page 217    |
| Outbound Post Head Pointer Register  | 0x78   | page 218    |
| Outbound Post Tail Pointer Register  | 0x7c   | page 218    |



| Bits | Field Name | Function                                                                                                                                                                                                                                                     | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | InMsg0     | Inbound Message Register_0<br>Read only from the CPU. When written, a<br>bit is set in the Inbound Interrupt Cause<br>register and an interrupt is generated to<br>the CPU (if unmasked). First register of<br>two intended for messages from PCI to<br>CPU. | 0x0           |

Table 214: Inbound Message Register 0, Offset: 0x10

### Table 215: Inbound Message Register 1, Offset: 0x14

| Bits | Field Name | Function                                                                                                                                                                                                                                                        | Initial Value |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | InMsg1     | Inbound Message Register_1<br>Read only from the CPU.<br>When written, a bit is set in the Inbound<br>Interrupt Cause Register and an interrupt<br>is generated to the CPU (if unmasked).<br>Second register of two intended for mes-<br>sages from PCI to CPU. | 0x0           |

### Table 216: Outbound Message Register 0, Offset: 0x18

| Bits | Field Name | Function                                                                                                                                                                                                                                                       | Initial Value |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | OutMsg0    | Outbound Message Register_0<br>Read only from the PCI.<br>When written, a bit is set in the Outbound<br>Interrupt Cause register and an interrupt is<br>generated to the PCI (if unmasked). First<br>register of two intended for messages<br>from CPU to PCI. | 0x0           |

#### Table 217: Outbound Message Register 1, Offset: 0x1c

| Bits | Field Name | Function                                                                                                                                                                                                                                                           | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | OutMsg1    | Outbound Message Register_1<br>Read only from the PCI.<br>When written, a bit is set in the Outbound<br>Interrupt Cause register and an interrupt is<br>generated to the PCI (if unmasked).<br>Second register of two intended for mes-<br>sages from CPUI to PCI. | 0x0           |

| Bits | Field Name | Function                                                                                                                                                                                                                                        | Initial Value |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | InDoor     | Inbound Doorbell Register<br>If not masked by Inbound Interrupt Mask<br>register, setting a bit in this register to 1 by<br>the PCI causes a CPU interrupt. Writing 1<br>to the bit by the CPU clears the bit (and<br>de-assert the interrupt). | 0x0           |

### Table 218: Inbound Doorbell Register, Offset: 0x20

### Table 219: Inbound Interrupt Cause Register, Offset: 0x24

| Bits | Field Name | Function                                                                                                                                            | Initial Value |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | InMsg0Int  | Inbound Message_0 Interrupt<br>This bit is set when Inbound Message 0<br>register is written.<br>The CPU writes it with 1 to clear it. <sup>1</sup> | 0x0           |
| 1    | InMsg1Int  | Inbound Message_1 Interrupt<br>This bit is set when Inbound Message_1<br>register is written. CPU writes it with 1 to<br>clear it. <sup>2</sup>     | 0x0           |
| 2    | InDoorInt  | Inbound Doorbell Interrupt<br>This bit is set when at least one bit of<br>Inbound Doorbell register is set. This bit is<br>read only.               | 0x0           |
| 3    | Reserved   |                                                                                                                                                     | 0x0           |
| 4    | InPQInt    | Inbound Post Queue Interrupt<br>This bit is set when the Inbound Post<br>Queue gets written.<br>The CPU writes it with 1 to clear it.               | 0x0           |
| 5    | OutFQOvr   | Outbound Free Queue Overflow Interrupt<br>This bit is set when the Outbound Free<br>Queue is full.<br>The CPU writes it with 1 to clear it.         | 0x0           |
| 31:6 | Reserved   |                                                                                                                                                     | 0x0           |

1. Unlike Intel's i960RP, bits [8:6] and bit 3 are reserved since the GT-96100A does not support Index, APIC, or NMI mechanisms.

2. An interrupt to CPU is generated if any of the bits 0,1,2,4, or 5 is set to 1 given that its corresponding entry in the Inbound Interrupt Mask Register is NOT set.



| Bits | Field Name   | Function                                                                                                                                                         | Initial Value |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | InMsg0IntMsk | Inbound Message_0 Interrupt Mask                                                                                                                                 | 0x0           |
| 1    | InMsg1IntMsk | Inbound Message_1 Interrupt Mask                                                                                                                                 | 0x0           |
| 2    | InDoorIntMsk | Inbound Doorbell Interrupt Mask                                                                                                                                  | 0x0           |
| 3    | Reserved     |                                                                                                                                                                  | 0x0           |
| 4    | InPQIntMsk   | Inbound Post Queue Interrupt Mask                                                                                                                                | 0x0           |
| 5    | OutFQOvrMsk  | Outbound Free Queue Overflow Interrupt<br>Mask<br>When set, no interrupt to CPU is gener-<br>ated for set OutFQOvr bit in Inbound Inter-<br>rupt Cause Register. | 0x0           |
| 31:6 | Reserved     |                                                                                                                                                                  | 0x0           |

# Table 221: Outbound Doorbell Register, Offset: 0x2c

| Bits | Field Name | Function                                                                                                                                                                                                                                                          | Initial Value |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | OutDoor    | Outbound Doorbell Register<br>Setting a bit in this register to 1 by the<br>CPU causes a PCI interrupt if not masked<br>by the Outbound Interrupt Mask register. <sup>1</sup><br>Writing 1 to the bit by the PCI clears the bit<br>(and de-assert the interrupt). | 0x0           |

1. Unlike Intel's i960RP, there are no reserved bits for PCI interrupts INTA#, INTB#, INTC#, INTD#.

| Bits | Field Name | Function                                                                                                                                                                                 | Initial Value |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | OutMsg0Int | Outbound Message_0 Interrupt<br>This bit is set when Outbound Message_0<br>register is written.<br>The PCI writes it with 1 to clear it.<br>For the CPU, this bit is read only.          | 0x0           |
| 1    | OutMsg1Int | Outbound Message_1 Interrupt<br>This bit is set when Outbound Message_1<br>register is written.<br>PCI writes it with 1 to clear it.<br>For the CPU, this bit is Read Only. <sup>1</sup> | 0x0           |
| 2    | OutDoorInt | Outbound Doorbell Interrupt:<br>This bit is set when at least one bit of Out-<br>bound Doorbell register is set.<br>This bit is read only.                                               | 0x0           |
| 3    | OutPQInt   | Outbound Post Queue Interrupt<br>This bit is set as long as Outbound Post<br>Queue is not empty.<br>This bit is read only.                                                               | 0x0           |
| 31:4 | Reserved   |                                                                                                                                                                                          | 0x0           |

## Table 222: Outbound Interrupt Cause Register, Offset: 0x30

1. An interrupt to PCI is generated if any of the bits 0,1,2, or 3 is set to 1 given that its corresponding entry in the Outbound Interrupt Mask Register is NOT set.

### Table 223: Outbound Interrupt Mask Register, Offset: 0x34

| Bits | Field Name    | Function                                                                                                                                                 | Initial Value |
|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | OutMsg0IntMsk | Outbound Message_0 Interrupt Mask.                                                                                                                       | 0x0           |
| 1    | OutMsg1IntMsk | Outbound Message_1 Interrupt Mask.                                                                                                                       | 0x0           |
| 2    | OutDoorIntMsk | Outbound Doorbell Interrupt Mask                                                                                                                         | 0x0           |
| 3    | OutPQIntMsk   | Outbound Post Queue Interrupt Mask:<br>When set, no interrupt to PCI is generated<br>for set OutPQInt bit in the Outbound Inter-<br>rupt Cause register. | 0x0           |
| 31:4 | Reserved      |                                                                                                                                                          | 0x0           |



| Bits | Field Name | Function                                                                                                         | Initial Value |
|------|------------|------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | InQPVReg   | Inbound Queue Port Virtual Register<br>A PCI write to this port results in a write to<br>the Inbound Post Queue. | 0x0           |
|      |            | A read from this port results in a read from<br>the Inbound Free Queue.<br>Reserved from the CPU side.           |               |

## Table 224: Inbound Queue Port Virtual Register, Offset: 0x40

### Table 225: Outbound Queue Port Virtual Register, Offset: 0x44

| Bits | Field Name | Function                                                                                                                                                                                                                      | Initial Value |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | OutQPVReg  | Outbound Queue Port Virtual Register<br>A PCI write to this port results in a write to<br>the Outbound Free Queue.<br>A read from this port results in a read from<br>the Outbound Post Queue.<br>Reserved from the CPU side. | 0x0           |

### Table 226: Queue Control Register, Offset: 0x50

| Bits | Field Name | Function                                                                                                                                                     | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | CirQEn     | Circular Queue Enable<br>If 0, a PCI write to this queue is ignored;<br>upon a PCI read from queue 0xffffffff is<br>returned.<br>Reserved from the PCI side. | 0x0           |
| 5:1  | CirQSize   | Circular Queue Size<br>00001 - 16 Kbytes<br>00010 - 32 Kbytes<br>00100 - 64 Kbytes<br>01000 - 128 Kbytes<br>10000 - 256 Kbytes<br>Reserved from PCI side.    | 0x1           |
| 31:6 | Reserved   |                                                                                                                                                              | 0x0           |

| Bits  | Field Name | Function                                                   | Initial Value |
|-------|------------|------------------------------------------------------------|---------------|
| 19:0  | Reserved   |                                                            | 0x0           |
| 31:20 | QBAR       | Queue Base Address Register<br>Reserved from the PCI side. | 0x0           |

### Table 227: Queue Base Address Register, Offset: 0x54

## Table 228: Inbound Free Head Pointer Register, Offset: 0x60

| Bits  | Field Name | Function                                                              | Initial Value |
|-------|------------|-----------------------------------------------------------------------|---------------|
| 1:0   | Reserved   |                                                                       | 0x0           |
| 19:2  | InFHPtr    | Inbound Free Head Pointer <sup>1</sup><br>Reserved from the PCI side. | 0x0           |
| 31:20 | QBAR       | Queue Base Address Register<br>Read only.                             | 0x0           |

1. This register is maintained by CPU software. It is reserved for PCI accesses.

### Table 229: Inbound Free Tail Pointer Register, Offset: 0x64

| Bits  | Field Name | Function                                                              | Initial Value |
|-------|------------|-----------------------------------------------------------------------|---------------|
| 1:0   | Reserved   |                                                                       | 0x0           |
| 19:2  | InFTPtr    | Inbound Free Tail Pointer <sup>1</sup><br>Reserved from the PCI side. | 0x0           |
| 31:20 | QBAR       | Queue Base Address Register<br>Read only.                             | 0x0           |

1. This register is incremented by the GT-96100A after a PCI read from Inbound port. It is reserved for PCI accesses.

### Table 230: Inbound Post Head Pointer Register, Offset: 0x68

| Bits  | Field Name | Function                                                              | Initial Value |
|-------|------------|-----------------------------------------------------------------------|---------------|
| 1:0   | Reserved   |                                                                       | 0x0           |
| 19:2  | InPHPtr    | Inbound Post Head Pointer <sup>1</sup><br>Reserved from the PCI side. | 0x0           |
| 31:20 | QBAR       | Queue Base Address Register<br>Read only.                             | 0x0           |

1. This register is incremented by the GT-96100A after a PCI write to Inbound port. It is reserved for PCI accesses.



| Bits  | Field Name | Function                                                              | Initial Value |
|-------|------------|-----------------------------------------------------------------------|---------------|
| 1:0   | Reserved   |                                                                       | 0x0           |
| 19:2  | InPTPtr    | Inbound Post Tail Pointer <sup>1</sup><br>Reserved from the PCI side. | 0x0           |
| 31:20 | QBAR       | Queue Base Address Register<br>Read only.                             | 0x0           |

Table 231: Inbound Post Tail Pointer Register, Offset: 0x6c

1. This register is maintained by the CPU software. It is reserved for PCI accesses.

| Bits  | Field Name | Function                                                               | Initial Value |
|-------|------------|------------------------------------------------------------------------|---------------|
| 1:0   | Reserved   |                                                                        | 0x0           |
| 19:2  | OutFHPtr   | Outbound Free Head Pointer <sup>1</sup><br>Reserved from the PCI side. | 0x0           |
| 31:20 | QBAR       | Queue Base Address Register<br>Read only.                              | 0x0           |

1. This register is incremented by the GT-96100A after PCI write to Outbound port. It is reserved for PCI accesses.

#### Table 233: Outbound Free Tail Pointer Register, Offset: 0x74

| Bits  | Field Name | Function                                                               | Initial Value |
|-------|------------|------------------------------------------------------------------------|---------------|
| 1:0   | Reserved   |                                                                        | 0x0           |
| 19:2  | OutFTPtr   | Outbound Free Tail Pointer <sup>1</sup><br>Reserved from the PCI side. | 0x0           |
| 31:20 | QBAR       | Queue Base Address Register<br>Read only.                              | 0x0           |

1. This register is maintained by CPU software. It is reserved for PCI accesses.

| Bits  | Field Name | Function                                                               | Initial Value |
|-------|------------|------------------------------------------------------------------------|---------------|
| 1:0   | Reserved   |                                                                        | 0x0           |
| 19:2  | OutPHPtr   | Outbound Post Head Pointer <sup>1</sup><br>Reserved from the PCI side. | 0x0           |
| 31:20 | QBAR       | Queue Base Address Register<br>Read only.                              | 0x0           |

### Table 234: Outbound Post Head Pointer Register, Offset: 0x78

1. This register is maintained by the CPU software. It is reserved for PCI accesses.

Table 235: Outbound Post Tail Pointer Register, Offset: 0x7c

| Bits  | Field Name | Function                                                               | Initial Value |
|-------|------------|------------------------------------------------------------------------|---------------|
| 1:0   | Reserved   |                                                                        | 0x0           |
| 19:2  | OutPTPtr   | Outbound Post Tail Pointer <sup>1</sup><br>Reserved from the PCI side. | 0x0           |
| 31:20 | QBAR       | Queue Base Address Register<br>Read only.                              | 0x0           |

1. This register is incremented by the GT-96100A after a PCI read from the Outbound port. It is reserved for PCI accesses.



# 9. INDEPENDENT DMA CONTROLLERS (IDMA CONTROLLERS)

The GT-96100A has four Independent DMA controllers. The IDMA controllers are used to optimize system performance by moving large amounts of data without significant CPU intervention.

Rather than having the CPU read data from one source and write it to another, use the IDMA controllers to directly transfer data independent of the CPU. This allows the CPU to continue executing other instructions simultaneous to the movement of data.

It is possible for each IDMA controller to move data between peripherals on the SDRAM/Device Controller bus, between devices on the PCI buses, or between peripherals on the SDRAM/Device Controller bus and devices on the PCI buses.

Each IDMA transfer uses one of two internal 64-byte FIFOs for moving data. Data is transferred from the source device into an internal FIFO, and from the internal FIFO to the destination device.

The IDMA controller can be programmed to move up to 64KBytes of data per transaction. The burst length of each transfer of each IDMA can be set from 1 to 64 bytes. Accesses can be non-aligned both in the source and the destination.

The GT-96100A has two "72-byte" FIFOs available for the utilization by the DMA engines. Although the maximum DMA burst size is 64 bytes, the extra eight bytes in the FIFO are required for non-double word aligned transfers. Two FIFOs allow for concurrency between two DMA transactions. This means one DMA channel can be reading data from the SDRAM into the first FIFO while another channel is writing data to a PCI target from the second FIFO.

The DMA channels support chained mode of operation. The descriptors are stored in memory, and the DMA engine moves the data until the Null Pointer is reached.

Fly-By DMA transfers are also supported. This type of DMA transfers greatly increase memory bandwidth. Fly-By transfers are permitted to and from a device or to and from SDRAM.

The DMA can be initiated by the CPU writing a register, an external request via a DMAReq\* pin, or from a timer/counter. In cases where the transfer needs to be externally terminated, an End of Transfer (EOT[3:0]) pin must be asserted (driven low) for the corresponding DMA channel.

# 9.1 DMA Channel Registers

Each DMA Channel record consists of the following registers. These registers can be written by the CPU, PCI, or IDMA controller in the process of fetching a new record from memory.

## 9.1.1 Byte Count Register

The Byte Count Register consists of four registers at offsets 0x800 - 0x80c.

This register is programmed with a 16-bit number containing the number of data bytes this channel must DMA. The maximum number of bytes the DMA controller can be configured to transfer is 64K-1. This register decrements at the end of every burst of transmitted data from source to destination.

When the byte count register is 0, or the End of Transfer pin is asserted, the DMA transaction is finished or terminated.



## 9.1.2 Source Address Register

The Source Address Register is at offset 0x810 - 0x81c.

This register is programmed with a 32-bit address. This is the source address for data and can be from the SDRAM/Device controller or from PCI.

This register either increments, decrements, or holds the same value according to bits [3:2] of the Channel Control register, see Table 236.

## 9.1.3 Destination Address Register

The Destination Address register is at offset 0x820 - 0x82c.

This register is programmed with a 32-bit address. This is the destination address for data. It can be programmed to the SDRAM/Device or to PCI.

This register either increments, decrements, or holds the same value according to bits [5:4] of the Channel Control register, see Table 236.

## 9.1.4 Pointer to the Next Record Register

The Pointer to the Next Record Register is at offset 0x830 - 0x83c.

The register contains a 32-bit address where the values for the next DMA Channel record can be loaded for chained operation. This can be from the SDRAM/Device controller or from PCI. The byte count, source address, and destination address must be located at sequential addresses.

**NOTE:** The next record pointer must be 16 bytes aligned. This means bits [3:0] must be set to 0.

A value of 0 (NULL) for this register indicates that this is the last record in the chain. This register is only used when the channel is configured for Chained Mode, see Table 236.

## 9.1.5 Channel Registers

The Channel Register is at offset 0x840 - 0x84c.

This register controls the DMA operation modes. A detailed description of this register's bits is in Table 9.2.



# 9.2 DMA Channel Control Register (0x840 - 0x84c)

Each DMA channel has its own unique control register where certain DMA modes can be programmed. Table 236 provides the bit descriptions for each field in the control register and describes the functionality of the DMA Control Register in certain modes. See Table 264 for further information.

| Function               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| FlyByEn bit            | FlyByEn determines whether or not a DMA transfer uses an internal DMA FIFO to nost the data from the source, prior to transferring it to the destination.<br>The SDRAM address must always be programmed in the Source Address register when performing a fly-by DMA whether the DMA source or destination is the SDRAM.                                                                                                                                                                                                                          |  |
| R/W bit                | This bit is meaningful only in Fly-By mode, FlyByEn bit set to 1.<br>R/W indicates whether the DMA transaction with the SDRAM is a read or write.                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| SrcDir, bits[3:2]      | The SrcDir field contains information about how the source address for the DMA transfer is handled.                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| DestDir, bits[5:4]     | The DestDir field contains information about how the destination address for the DMA transfer is handled.                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| DatTransLim, bits[8:6] | The DatTransLim field contains the burst limit of each data transfer. The burst limit can vary from one to 64 bytes in module-2 steps (i.e. 1, 2, 4, 8,, 64).                                                                                                                                                                                                                                                                                                                                                                                     |  |
| ChainMod, bit 9        | ChainMod determines whether this channel is set in chained mode or not.<br>In chained mode, the channel record's parameters for the current transac-<br>tion (Byte Count, Source, Destination, and Next Record Pointer) must be<br>initialized in SDRAM/Device memory space or PCI devices. The address<br>of the first record must be initialized by writing it to the channel's Next<br>Record Pointer register.<br>In non-chained mode the Byte Count, Source, and Destination Registers must be<br>initialized prior to enabling the channel. |  |
| IntMode, bit 10        | IntMode controls when this channel asserts the DMAComp (DMA Complete) Inter-<br>rupt.<br>If chained mode is disabled, the setting of IntMode is irrelevant and DMAComp<br>Interrupt will be asserted every time the Byte Count reaches 0.                                                                                                                                                                                                                                                                                                         |  |
| TransMod, bit 11       | TransMod indicates whether the channel is set to operate in demand mode or block mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| ChanEn, bit 12         | ChanEn enables or disables the DMA channel.<br>The DMA channel is enabled or disabled via ChanEn if the channel is in Demand<br>or Block Mode.                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| FetNexRec, bit 13      | FetNexRec is a field which is significant only when chained mode is enabled for the channel.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |

Table 236: DMA Channel Control Register (0x840 - 0x84c)

Г

| Function                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DMAActSt, bit 14 (Read<br>Only)                                  | DMAActSt is a read only field that can be polled to see the DMA activity status of the channel.<br>In non-chain mode, this bit is de-asserted when Byte_Count reaches zero. In chain-mode, this bit is de-asserted when the pointer to next record is NULL and Byte_Count reaches zero.<br>This bit is reset if the CPU sets chanEn to 0 during DMA transfer.                                                                                                                                                                                |  |
| SDA, Source/Destina-<br>tion Alignment, bit 15                   | The SDA bit determines whether address alignment is done for source or destina-<br>tion.<br>When a device such as a FIFO is the destination of a DMA, it is recommended to<br>use Destination Alignment to avoid destructive writes. Likewise, if a device such as<br>a FIFO is the source of a DMA, it is recommended to use Source Alignment to<br>avoid destructive reads.<br>If both the DMA Source and Destination addresses are aligned, the meaning of this<br>bit is irrelevant.                                                     |  |
| Mask DMA Requests,<br>MDREQ, bit 16                              | Some slower devices require extra time in order to de-assert a DMA request sig-<br>nal. This bit can be used to provide this extra time.                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| Close Descriptor<br>Enable, CDE, bit 17                          | A DMA transfer may be halted (by an EOT signal or FetchNextRec is asserted)<br>with some data remaining in the buffer pointed at by the current descriptor. This bit<br>allows writing the remaining byte count in bits 31:16 of the Byte_Count field of the<br>descriptor (located in memory).<br>By writing this field, ownership of the descriptor is returned to the CPU. The CPU<br>then calculates the total number of bytes transferred by the DMA channel by sub-<br>tracting the remaining byte count from the original Byte_Count. |  |
| End Of Transfer<br>Enable, EOTE, bit 18                          | This bit provides devices which have access to a DMA engine to stop a DMA trans-<br>fer prior to its completion. In chain mode, this causes fetching a new descriptor<br>from memory (if pointer to next record is not equal to NULL) and executing the next<br>DMA. If the DMA channel is in non-chain mode, then the current DMA transfer is<br>stopped without further action.                                                                                                                                                            |  |
| End Of Transfer Inter-<br>rupt Enable, EOTE, bit<br>19           | EOTIE enables or disables interrupts due to End Of Transfer (EOT) signal activa-<br>tion.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| Abort DMA, ABR, bit 20                                           | It is possible that the CPU may need to abort a DMA transfer and reprogram the DMA. This bit flushes internal indications which would normally not get flushed by a mere channel disable.<br>The ABR bit must be used together with En/Dis if CDE and/or EOT are enabled and the CPU requires to abort a transfer for reprogramming.                                                                                                                                                                                                         |  |
| SLP (bits [22:21]), DLP<br>(bits [24:23]), RLP (bits<br>[26:25]) | SLP, DLP, and RLP bits are used to redefine address space of source, destination, or record address location. These enable overriding the local address space with PCIMem0 or PCIMem1address space.                                                                                                                                                                                                                                                                                                                                          |  |

### Table 236: DMA Channel Control Register (0x840 - 0x84c) (Continued)



| SLP ([22:21]) | Function                                  |
|---------------|-------------------------------------------|
| 00            | Source address is in local address space. |
| 01            | Source address is in PCI_0 memory space.  |
| 10            | Source address is in PCI_1 memory space.  |
| 11            | Reserved.                                 |

### Table 237: Location of Source Address, SLP

## Table 238: Location of Destination Address, DLP

| DLP ([24:23]) Function |                                                |  |
|------------------------|------------------------------------------------|--|
| 00                     | Destination address is in local address space. |  |
| 01                     | Destination address is in PCI_0 memory space.  |  |
| 10                     | Destination address is in PCI_1 memory space.  |  |
| 11                     | Reserved.                                      |  |

### Table 239: Location of Record Address, RLP

| RLP ([26:25]) | Function                                  |
|---------------|-------------------------------------------|
| 00            | Record address is in local address space. |
| 01            | Record address is in PCI_0 memory space.  |
| 10            | Record address is in PCI_1 memory space.  |
| 11            | Reserved.                                 |



#### Figure 32: Chained Mode DMA

|       | GT-96100A Channel 0 DMA Registers      |               |
|-------|----------------------------------------|---------------|
|       | Byte Count (ByteCt)                    |               |
|       | Source Address (SrcAdd)                |               |
|       | Destination Address (DestAddr)         |               |
|       | Next Record Pointer (NextRecPtr): 0x10 | $\overline{}$ |
|       |                                        |               |
| 0x10  | ByteCt                                 | Transfer #1   |
| 0x14  | SrcAdd                                 |               |
| 0x18  | DestAddr                               |               |
| 0x1c  | NextRecPtr: 0x100                      | $\overline{}$ |
|       |                                        |               |
| 0x100 | ByteCt                                 | Transfer #2   |
| 0x104 | SrcAdd                                 |               |
| 0x108 | DestAddr                               |               |
| 0x10c | NextRecPtr: y                          | $\overline{}$ |
|       | •                                      |               |
|       | •                                      |               |
| х     | ByteCt                                 | Transfer #n   |
| х     | SrcAdd                                 |               |
| х     | DestAddr                               |               |
| х     | NULL Pointer: 0x0                      |               |

# 9.3 Restarting a Disabled Channel

In Non-Chained mode, ChanEn must be set to 1.

In Chained mode, the software must find out if the first fetch took place. If it did, only ChanEn is set to 1. If it did not, the FetNexRec is also be set to 1.

# 9.4 Reprogramming an Active Channel

To reprogram an active channel, the channel must first be disabled by setting ChanEn to 0.

If CDE and/or EOTE are set, then ABR must also be set. Then it must be assured that the channel is no longer active (for example by polling the DMAActSt of the channel).

New DMA parameters must be programmed prior to re-enabling the channel via setting ChanEn to 1.



## 9.5 Arbitration

The DMA controller has a programmable arbitration scheme between its four channels. The channels are grouped into two groups:

- One group includes channel 0 and 1
- The other group includes channels 2 and 3.

The channels in each group are programmed to have priority so that a selected channel has the higher priority or the same priority in round robin.

The priority between the two groups is programmed in a similar way so that a selected group has a higher priority or to have the same priority in round robin.

The priority scheme has additional flexibility with the programmable Priority Option. With the Priority Option, the DMA bandwidth allocation is divided in a fairer way.

The DMA arbiter control register can be reprogrammed any time regardless of the channels' status (active or not active).

# 9.6 Current Descriptor Pointer Registers

Each DMA channel has a current descriptor pointer register (CDPTR) associated with it. They are located at offsets 0x870-0x7c.

These descriptor pointers are read/write registers, however, the CPU should not write them. When the NPTR (Next pointer) is written by the CPU, then the CDPTR reloads itself with the same value written to NPTR.

After processing a descriptor, the DMA channel updates the current descriptor using CDPTR, saves NPTR into CDPTR, and fetches a new descriptor. This register is used for closing the current descriptor before fetching the next descriptor.

# 9.7 Design Information

The following sections contain more detailed information about the GT-96100A's IDMA controllers. The following definitions are used throughout this section:

| Term                                         | Definition                                                                                           |  |
|----------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| Device                                       | A device located on the memory bus mapped to one of the GT-96100A's Chip Selects (including BootCS). |  |
| PCI Agent Any device located on the PCI bus. |                                                                                                      |  |
| SDRAM                                        | M SDRAM memory located on the memory bus.                                                            |  |

Table 240: IDMA Controller Design Information Terms and Definitions



## 9.7.1 DMA in Demand Mode

Demand mode is especially designed for transferring data between Memory (Device, SDRAM, PCI agent) and a Device. This is because the DMAAck\* is asserted only when the GT-96100A is accessing a Device.

In this mode, the transfer initiator (usually a Device) asserts DMAReq\* to signal the GT-96100A that a new DMA transfer should begin. As an acknowledgment response, the GT-96100A asserts the DMAAck\* to signal that the asserted DMAReq\* is currently being processed.

In each DMA transfer, the DMA attempts to read the amount of DatTranLim bytes from the source address and writes it to destination address. In the source direction, at the beginning and end of the DMA, there may be less than DatTranLim bytes if the address is not aligned or the remaining Byte Count to be transferred is smaller then the DatTranLim. In the destination direction, the DMA writes all data that was read from the source to the destination. This may happen in two DMA accesses if the destination address is not aligned.

The channel stays active until the Byte Count reaches the terminal count or until the CPU disables the channel.

**NOTE:** If the DMAReq\* is always asserted, then this is equivalent to transfer data in Block Mode.

### 9.7.1.1 Asserting and Deasserting DMAReq\*

The DMAReq\* must be asserted as long as the transfer initiator has at least DatTranLim of bytes to provide (in case that it is the source) or as long as it has space to absorb at least DatTranLim of bytes (in case that it is the destination).

The DMAReq\* should be deasserted by the source when the transfer initiator sees that it does not have at least DatTranLim of bytes to provide (i.e. FIFO empty). DMAReq\* should also be deasserted by the destination when it does not have enough space to absorb at least DatTranLim of bytes (i.e. FIFO full) AND DMAAck\* is asserted LOW.

## 9.7.1.2 Asserting DMAAck\*

The DMAAck\* is asserted only when the GT-96100A accesses a device. It is asserted when ALE is asserted.

### 9.7.1.3 DMAReq\* Sampling

The DMAReq\* is sampled all the time but it influences arbitration only in the DMA arbitration cycle or when all channels are idling. The DMA arbitration cycle is the cycle in which the destination unit inside the GT-96100A acknowledges the last written data from the DMA unit.



| Source       | Destination  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| SDRAM/PCI    | SDRAM/PCI    | In this case it is better to use BlockMode cause Memory is typi-<br>cally ready all the time and DMAAck* is NOT asserted. If you<br>choose to work in Demand mode, DMAAck* should be externally<br>generated (i.e., polling accesses of the GT-96100A to certain<br>addresses).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| Device       | SDRAM or PCI | The Device transfer initiator asserts a DMAReq* when it has at<br>least DatTranLim number of bytes to give. It must de-assert the<br>DMAReq* when no more data is ready and DMAAck* is asserted.<br>Even if another master drives the DMAReq*, the DMAAck* can<br>signal to that master that the GT-96100A is currently accessing<br>the device for read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| SDRAM or PCI | Device       | <ul> <li>The Device transfer initiator asserts a DMAReq* when it has enough room for DatTranLim number of bytes to be written to it and DMAAck* is asserted. Even if another master drives the DMAReq*, the DMAAck* can signal the master that the GT-96100A is currently accessing the device for write.</li> <li><b>NOTE:</b> In this situation, the GT-96100A asserts the DMAAck* when its accessing the device for write. This is problematic if DatTranLimit is smaller than or equals eight bytes. The DMAAck* is seen outside late, and due to this the de-assertion of the DMAReq*, is NOT seen in the DMA arbitration cycle. Although the device does not want to be accessed, a new transfer may begin.</li> <li>If DatTranLimit is bigger then eight bytes there is no problem. In this case, it is recommended to have a device that can accepts bursts.</li> <li>A solution when using one channel only and DatTranLim is less or equal to eight bytes is to set the MDREQ bit.</li> </ul> |  |

| 9.7.1.4   | Transferring data examples/recommendations |
|-----------|--------------------------------------------|
| Table 241 | Source and Data Transfer Examples          |

## 9.7.1.5 DMA in Block Mode

In block mode, no hand shake signals are used to initiate DMA transfers. The DMA unit completes the transfer once the CPU has programmed the DMA and enabled it.

## 9.7.2 Non-Chain Mode

In non-chain mode, the CPU or PCI master initiates the DMA channel parameters (Source, Destination Byte Count and command Registers). The DMA starts to transfer data after the enable bit in the Command register is set to 1. The DMA remains in an active state until the Byte Count reaches a terminal count or until the channel is disabled.



## 9.7.3 Chain Mode

In chain mode, the DMA channel parameters (Source, Destination Byte Count and Pointer to Next Record) are read from records located in Memory, Device, or PCI. The DMA channel stays in the active state until Pointer to Next Record is NULL and the Byte Count reaches the terminal count.

In this mode, an interrupt can be asserted every time the byte count reaches the terminal count or when BOTH the Byte Count reaches the terminal count and the Pointer to Next Record is NULL.

## 9.7.4 Dynamic DMA chaining

Dynamic chaining is when DMA records are added to a chain that an IDMA controller is actively working on. The main issue is to synchronize between when the GT-96100A reads the last chain record (the NULL pointer) to the time the CPU changes the current last DMA record. Following is an algorithm which provides this synchronization mechanism.

- 1. Prepare the new record.
- 2. Change the last record's Pointer to Next Record to point to the new record.
- 3. Read the DMA control register.

```
If the DMAActSt bit is 0 (NOT active) {
   Update the Pointer to Next Record in the GT-96100A
   assert the FetNexRec bit
}
else {
   read the Pointer to Next Record the GT-96100A.
   If it's equal to NULL {
      Mark (by using a flag) that in the next DMA chain complete interrupt
      you'll need to {
         Update the NRP register in the GT-64010
         Write the Fetch Next Record
      }
   }
}
```

## 9.7.5 Fly-by DMA

Fly-by is a way to move data directly from the source of the data to its destination. While the source drives the data onto the data bus, the destination immediately latches it into its buffers/memory. The data does not pass through the GT-96100A. This saves at least half of the AD bus bandwidth. Fly-by cycles are requested by the DMA channel and controlled by the memory unit.

### 9.7.5.1 FlyBy in the GT-96100A

During fly-by, the GT-96100A supplies the full information to the SDRAM involved in the transaction. This includes all control signals (SRAS\*, SCAS\*, SWr\*, SCS\* and SDQM) and the address lines (DAdr, BA0, BA1). For the Device, it supplies the control signals (CSTiming\*, DmaAck\* and DevRdWr\*) that support the same waveforms as if the device were not working in fly-by mode. This means that the DmaAck\* and DevRdWr\* are



latched using ALE. The external logic will have to form the address to the device (if needed) and correct write signals to the device if the device is the destination.

The fly-by cycle is totally compliant with the SDRAM waveforms and the device has to keep up with its speed.

**NOTE:** The "device parameter register" is ignored during flyby transaction.

### 9.7.5.2 How to program the GT-96100A for Fly-By

The DMA control register has two bits for Fly-by indications:

#### Table 242: Fly-By Bits

| Bit      | Description                                                                                                                                                                                                                                                              |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FlyByEn  | DMA accesses are Fly-by, i.e., the data does not enter the internal FIFO.                                                                                                                                                                                                |
| FlyByDir | Determines if the device is the source or the destination. This bit affects the DevRdWr* towards the device. <b>NOTE:</b> The SDRAM address must be written to the source register of the DMA channel, regardless of whether the SDRAM is the source or the destination. |

### 9.7.5.3 Design Considerations

- 1. Device (FIFOs, FPGA) must be fast enough to maintain read/write at SDRAM burst speed.
- 2. For RAS to CAS setting of 3 DMAReq\* must be deasserted within 3 TClk cycles following CSTiming\* assertion.
- 3. For RAS to CAS setting of 2 DMAReq\* must be deasserted within 2 TClk cycles following CSTiming\* assertion.

### 9.7.5.4 Determining CS during Fly-By

Bits [29:26,22] in the DeviceX (Bank0, Bank1, Bank2, Bank3 and Boot) parameter registers are used to determine which CS (Chip Select) are activated during FlyBy.

- DMA channel 0 uses bits [29:26,22] of Bank0 parameter register.
- DMA channel 1 uses bits [29:26,22] of Bank1.
- DMA channel 2 uses bits [29:26,22] of Bank2
- DMA channel 3 uses bits [29:26,22] of Bank3.

The interpretation of bits [29:26,22] is as follows:

- Bit 22 Low BootCS\* are the active CS.
- Bit 26 Low CS0\* are the active CS.
- Bit 27 Low CS1\* are the active CS.
- Bit 28 Low CS2\* are the active CS.
- Bit 29 Low CS3\* are the active CS.

**NOTE:** As a consequence of the nature of this mechanism, only one bit within bits [29:26,22] should be Low.

By default, bit 26 is low. This means CS0 is the active CS unless otherwise programmed.



# 9.8 Initiating a DMA from a Timer/Counter

Each channel can be programmed to have the DMAReq\* sourced from the external DMAReq\* pin or from the associated timer/counter. For example, DMA channel 0 can only be enabled by Timer/Counter 0, DMA channel 1 can only be enabled by Timer/Counter 1, etc. If bit 28 in the DMA command register is set to 1, then when the timer/counter reaches the terminal count, an internal DMAReq\* is set and a new DMA transfer is initiated. When this bit is set to 1, DMAReq\* is ignored. When set to 0, DMAs are initiated by asserting DMAReq\*. Initiating DMA from timer/counter is enabled only in demand mode.

## 9.9 DMA Restrictions

- 1. In order to reprogram a channel after it has been enabled, it must first be checked that the DMAActSt bit is set to NOT ACTIVE (see Table 236). If working in CDE mode or EOTE mode then ABR bit must be set to 1 along with En/Dis bit.
- 2. When Source or Destination address is decremented, both addresses must be double-word-aligned (that is, A2. A1 and A0 should be all zero), and Byte Count must be a multiple of eight (this applies for burst limits greater than eight bytes).
- 3. Burst reads of more than two double-words from PCI devices have all Byte Enables (BEs) active. This implies that DMA read from PCI I/O space must be aligned or with a burst limit no bigger that eight bytes, in order to avoid PCI spec violation (PCI spec defines correlation between two LSB address bits and byte enables on I/O transaction).
- 4. When using the address hold option in the source direction (see Table 236), and SDA bit is set to 1, the source and destination addresses must be double-word aligned.
- 5. When using the address hold option in the destination direction, both source and destination addresses must be double-word aligned.
- 6. Records addresses (NPTR) must be a multiple of 16 bytes. In chained mode, if the descriptors are stored in a device, the device must be 32 or 64 bit. If the descriptors are stored in SDRAM or in PCI memory, there are no restrictions on the width of the resource.
- NOTE: All descriptors must reside on word-aligned addresses.
  - 7. No support for destination alignment (SDA has no affect) when burst limit is 1, 2, or 4 bytes.
  - When DMA accesses an unmapped address (see Section 3.4 "Address Space Decoding Errors" on page 63), it results in unpredictable behavior and the DMA channel might need to be stopped by clearing the activate bit of the channel control register.
  - 9. If the DMA state machine has a pending read of the next descriptor AND the descriptor is located in the PCI space, any PCI accesses to the DMA registers are stopped.
  - 10. If the PCI master accessing the GT-96100A DMA registers and the DMA descriptors resides on the far side of a PCI-to-PCI bridge, a lock-up may occur because the PCI requires that all writes must occur before any reads can take place across a PCI-to-PCI bridge.



## 9.9.1 Fly-by Mode DMA Restrictions

- 1. The device and SDRAM must be the same width, 32 or 64 bit.
- 2. In Fly-By transfers, Byte\_Count must be a multiple of eight and source address must be word aligned.
- 3. The SDRAM CAS latency must be programmed to 2.
- 4. SRASPrchg in all SDRAM parameter registers must pre-programed to 1(e.g. 3 cycles).

# 9.10 DMA Control Registers

#### Table 243: DMA Control Register Map

| Offset | Page Number                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|        |                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 0x800  | page 232                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x804  | page 232                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x808  | page 232                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x80c  | page 233                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x810  | page 233                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x814  | page 233                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x818  | page 233                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x81c  | page 233                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x820  | page 233                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x824  | page 234                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x828  | page 234                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x82c  | page 234                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x830  | page 234                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x834  | page 234                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x838  | page 235                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x83c  | page 235                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x870  | page 235                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x874  | page 235                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x878  | page 235                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x87c  | page 236                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x840  | page 236                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 0x844  | page 239                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|        | 0x800           0x804           0x808           0x808           0x80c           0x80c           0x810           0x810           0x810           0x810           0x810           0x814           0x818           0x820           0x824           0x828           0x828           0x830           0x834           0x838           0x838           0x838           0x8370           0x874           0x878           0x878           0x870 |  |  |

### Table 243: DMA Control Register Map (Continued)

| Description       | Offset | Page Number |
|-------------------|--------|-------------|
| DMA Record        |        |             |
| Channel 2 Control | 0x848  | page 239    |
| Channel 3 Control | 0x84c  | page 239    |
| DMA Arbiter       |        |             |
| Arbiter Control   | 0x860  | page 240    |

## 9.10.1 DMA Record

## Table 244: Channel 0 DMA Byte Count, Offset: 0x800

| Bits  | Field Name | Function                                                                                                                                                   | Initial Value |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 15:0  | ByteCt     | The number of bytes that are left in DMA transfers.                                                                                                        | 0x0           |
| 31:16 | ByteRemain | If CDE is set to 1 and the DMA engine<br>owns the descriptor (i.e. DMA is currently<br>in progress), the remaining bytes to trans-<br>fer will be written. | 0x0           |
|       |            | If the CPU owns the descriptor, these bytes can be written to any value.                                                                                   |               |

### Table 245: Channel 1 DMA Byte Count, Offset: 0x804

| Bits | Field Name | Function                                  | Initial Value |
|------|------------|-------------------------------------------|---------------|
| 31:0 | Various    | Functions as in Channel 0 DMA Byte Count. | 0x0           |

#### Table 246: Channel 2 DMA Byte Count, Offset: 0x808

| Bits | Field Name | Function                                  | Initial Value |
|------|------------|-------------------------------------------|---------------|
| 31:0 | Various    | Functions as in Channel 0 DMA Byte Count. | 0x0           |



| Table 247: Channel 3 DMA E | Byte Count. | Offset: 0x80c |
|----------------------------|-------------|---------------|
|                            | Syle Count, |               |

| Bits | Field Name | Function                                  | Initial Value |
|------|------------|-------------------------------------------|---------------|
| 31:0 | Various    | Functions as in Channel 0 DMA Byte Count. | 0x0           |

#### Table 248: Channel 0 DMA Source Address, Offset: 0x810

| Bits | Field Name | Function                                                        | Initial Value |
|------|------------|-----------------------------------------------------------------|---------------|
| 31:0 | SrcAdd     | The address from which the IDMA control-<br>ler reads the data. | 0x0           |

#### Table 249: Channel 1 DMA Source Address, Offset: 0x814

| Bits | Field Name | Function                                                        | Initial Value |
|------|------------|-----------------------------------------------------------------|---------------|
| 31:0 | SrcAdd     | The address from which the IDMA control-<br>ler reads the data. | 0x0           |

#### Table 250: Channel 2 DMA Source Address, Offset: 0x818

| Bits | Field Name | Function                                                        | Initial Value |
|------|------------|-----------------------------------------------------------------|---------------|
| 31:0 | SrcAdd     | The address from which the IDMA control-<br>ler reads the data. | 0x0           |

#### Table 251: Channel 3 DMA Source Address, Offset: 0x81c

| Bits | Field Name | Function                                                        | Initial Value |
|------|------------|-----------------------------------------------------------------|---------------|
| 31:0 | SrcAdd     | The address from which the IDMA control-<br>ler reads the data. | 0x0           |

#### Table 252: Channel 0 DMA Destination Address, Offset: 0x820

| Bits | Field Name | Function                                                  | Initial Value |
|------|------------|-----------------------------------------------------------|---------------|
| 31:0 | DestAdd    | The address to which the IDMA controller writes the data. | 0x0           |

| Table 253: Channel 1 DMA Destination Address | Offset: 0x824 |
|----------------------------------------------|---------------|
|                                              |               |

| Bits | Field Name | Function                                                  | Initial Value |
|------|------------|-----------------------------------------------------------|---------------|
| 31:0 | DestAdd    | The address to which the IDMA controller writes the data. | 0x0           |

#### Table 254: Channel 2 DMA Destination Address, Offset: 0x828

| Bits | Field Name | Function                                                  | Initial Value |
|------|------------|-----------------------------------------------------------|---------------|
| 31:0 | DestAdd    | The address to which the IDMA controller writes the data. | 0x0           |

#### Table 255: Channel 3 DMA Destination Address, Offset: 0x82c

| Bits | Field Name | Function                                                  | Initial Value |
|------|------------|-----------------------------------------------------------|---------------|
| 31:0 | DestAdd    | The address to which the IDMA controller writes the data. | 0x0           |

#### Table 256: Channel 0 Next Record Pointer, Offset: 0x830

| Bits | Field Name | Function                                                                                                                                                                                                       | Initial Value |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | NextRecPtr | The address for the next record of DMA. A value of 0 means a NULL pointer (end of the chained list).<br><b>NOTE:</b> The next record pointer must be 16 bytes aligned. This means bits [3:0] must be set to 0. | 0x0           |

#### Table 257: Channel 1 Next Record Pointer, Offset: 0x834

| Bits | Field Name | Function                                                                                                                                                                                                       | Initial Value |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | NextRecPtr | The address for the next record of DMA. A value of 0 means a NULL pointer (end of the chained list).<br><b>NOTE:</b> The next record pointer must be 16 bytes aligned. This means bits [3:0] must be set to 0. | 0x0           |



| Bits | Field Name | Function                                                                                                                                                                                                       | Initial Value |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | NextRecPtr | The address for the next record of DMA. A value of 0 means a NULL pointer (end of the chained list).<br><b>NOTE:</b> The next record pointer must be 16 bytes aligned. This means bits [3:0] must be set to 0. | 0x0           |

#### Table 258: Channel 2 Next Record Pointer, Offset: 0x838

#### Table 259: Channel 3 Next Record Pointer, Offset: 0x83c

| Bits | Field Name | Function                                                                                                                                                                                                       | Initial Value |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | NextRecPtr | The address for the next record of DMA. A value of 0 means a NULL pointer (end of the chained list).<br><b>NOTE:</b> The next record pointer must be 16 bytes aligned. This means bits [3:0] must be set to 0. | 0x0           |

#### Table 260: Current Descriptor Pointer 0, Offset: 0x870

| Bits | Field Name | Function                                        | Initial Value |
|------|------------|-------------------------------------------------|---------------|
| 31:0 | CDPTR0     | Channel 0 Current Address Descriptor<br>Pointer | 0x0           |

#### Table 261: Current Descriptor Pointer 1, Offset: 0x874

| Bits | Field Name | Function                                        | Initial Value |
|------|------------|-------------------------------------------------|---------------|
| 31:0 | CDPTR1     | Channel 1 Current Address Descriptor<br>Pointer | 0x0           |

#### Table 262: Current Descriptor Pointer 2, Offset: 0x878

| Bits | Field Name | Function                                        | Initial Value |
|------|------------|-------------------------------------------------|---------------|
| 31:0 | CDPTR2     | Channel 2 Current Address Descriptor<br>Pointer | 0x0           |

| Bits | Field Name | Function                                        | Initial Value |
|------|------------|-------------------------------------------------|---------------|
| 31:0 | CDPTR3     | Channel 3 Current Address Descriptor<br>Pointer | 0x0           |

## Table 263: Current Descriptor Pointer 3, Offset: 0x87c

## 9.10.2 DMA Channel Control

| Bits | Field Name  | Function                                                                                                                                                                                                                                    | Initial Value |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | FlyByEn     | Data Internal/External to DMA FIFO<br>0 - Internal<br>Data is read from source address into<br>DMA FIFO and written to destination<br>address<br>1 - External (Fly By)<br>Data is transferred to/from devices on<br>SDRAM bus from/to SDRAM | 0x0           |
| 1    | RdWrFly     | SDRAM Read/Write<br>Meaningful only in Fly-by mode.<br>0 - Read from SDRAM<br>1 - Write to SDRAM                                                                                                                                            | 0x0           |
| 3:2  | SrcDir      | Source Direction.<br>00 - Increment source address<br>01 - Decrement source address<br>10 - Hold in the same value<br>11 - Reserved                                                                                                         | 0x0           |
| 5:4  | DestDir     | Destination Direction.<br>00 - Increment destination address<br>01 - Decrement destination address<br>10 - Hold in the same value<br>11 - Reserved                                                                                          | 0x0           |
| 8:6  | DatTransLim | Data Transfer Limit in each DMA access.<br>101 - 1 Byte<br>110 - 2 Bytes<br>010 - 4 Bytes<br>000 - 8 Bytes<br>001 - 16 Bytes<br>011 - 32 Bytes<br>111 - 64 bytes                                                                            | 0x0           |



| Bits | Field Name | Function                                                                                                                                                                                                                                                                                                                                       | Initial Value |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 9    | ChainMod   | Chained Mode<br>0 - Chained mode<br>When a DMA access is terminated, the<br>parameters of the next DMA access<br>comes from a record in memory that is<br>pointed to by the NextRecPtr register.<br>1 - Non-Chained mode<br>Only uses the values programmed by the<br>CPU (or PCI) directly into the ByteCt,<br>SrcAdd, and DestAdd registers. | 0x0           |
| 10   | IntMode    | Interrupt Mode<br>0 - Interrupt asserted every time the DMA<br>byte count reaches terminal count.<br>1 - Interrupt every NULL pointer (in<br>Chained mode).                                                                                                                                                                                    | 0x0           |
| 11   | TransMod   | Transfer Mode<br>0 - Demand<br>1 - Block                                                                                                                                                                                                                                                                                                       | 0x0           |
| 12   | ChanEn     | Channel Enable<br>0 - Disable<br>1 - Enable                                                                                                                                                                                                                                                                                                    | 0x0           |
| 13   | FetNexRec  | Fetch Next Record<br>1 - Forces a fetch of the next record, even<br>if the current DMA has not ended.<br>This bit is reset after fetch is completed<br>and is only meaningful in Chained mode.                                                                                                                                                 | 0x0           |
| 14   | DMAActSt   | DMA Activity Status<br>Read only.<br>Assertion of this bit is caused by asserting<br>ChanEn (bit 12).<br>0 - Channel is not active.<br>1 - Channel is active.                                                                                                                                                                                  | 0x0           |
| 15   | SDA        | Source Destination Alignment<br>0 - Alignment is towards the source<br>address.<br>1 - Alignment is towards the destination<br>address<br><b>NOTE:</b> No support for destination align-<br>ment when burst limit is 1, 2, or<br>4 bytes.                                                                                                      | 0x0           |

| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                            | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 16    | MDREQ      | Mask DMA Requests<br>0 - Don't mask<br>1 - Mask DMA requests for 3 cycles start-<br>ing DMA arbitration cycle.                                                                                                                                                                                                                      | 0x0           |
| 17    | CDE        | Close Descriptor Enable<br>If enabled, DMA writes remaining byte<br>count to bits [31:16] of ByteCount field in<br>the descriptor.<br>0 - Disable<br>1 - Enable                                                                                                                                                                     | 0x0           |
| 18    | EOTE       | <ul> <li>End Of Transfer Enable</li> <li>If enabled, DMA transfer can be stopped<br/>in the middle of transfer using the EOT<br/>signal. If DMA channel is working in chain<br/>mode, this will cause fetching a new<br/>descriptor, otherwise the DMA transfer is<br/>stopped.</li> <li>0 - Disable</li> <li>1 - Enable</li> </ul> | 0x0           |
| 19    | EOTIE      | End Of Transfer Interrupt Enable<br>If enabled and EOT pin is asserted, DMA<br>generates an interrupt.<br>0 - Disable<br>1 - Enable                                                                                                                                                                                                 | 0x0           |
| 20    | ABR        | Abort DMA Transfer<br>This bit must be set if the CPU wants to<br>stop and re-program DMA, and CDE (bit<br>17) and/or EOTE (bit 19) is set to 1. When<br>the CPU issues this command, it must<br>also set ChanEn (bit 12) to 0.<br>0 - No influence on channel behavior.<br>1 - Abort DMA.                                          | 0x0           |
| 22:21 | SLP        | Override Source Address<br>00 - No override. Use local address space<br>for source<br>01 - Source address is in PCI_0 memory<br>space.<br>10 - Source address is in PCI_1 memory<br>space.<br>11 - Reserved                                                                                                                         | 0x0           |

## Table 264: Channel 0 Control, Offset: 0x840 (Continued)



| Bits  | Field Name | Function                                                                                                                                                                                                                            | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 24:23 | DLP        | Override Destination Address<br>00 - No override. Use local address space<br>for destination.<br>01 - Destination address is in PC_0 mem-<br>ory space.<br>10 - Destination address is in PCI_1 mem-<br>ory space.<br>11 - Reserved | 0x0           |
| 26:25 | RLP        | Override Record Address<br>00 - No override. Use local address space<br>for record.<br>01 - Record address is in PCI_0 memory<br>space.<br>10 - Record address is in PCI_1 memory<br>space.<br>11 - Reserved                        | 0x0           |
| 27    | Reserved   |                                                                                                                                                                                                                                     | 0x0           |
| 28    | DMAReqSrc  | DMA Request Source<br>0 - Request taken from DMAReq* pin.<br>1 - Request taken from timer/counter.                                                                                                                                  | 0x0           |
| 31:29 | Reserved   |                                                                                                                                                                                                                                     | 0x0           |

## Table 265: Channel 1 Control, Offset: 0x844

| Bits | Field Name | Function                                 | Initial Value |
|------|------------|------------------------------------------|---------------|
| 31:0 | Various    | Fields function as in Channel 0 Control. | 0x0           |

#### Table 266: Channel 2 Control, Offset: 0x848

| Bits | Field Name | Function                                 | Initial Value |
|------|------------|------------------------------------------|---------------|
| 31:0 | Various    | Fields function as in Channel 0 Control. | 0x0           |

### Table 267: Channel 3 Control, Offset: 0x84c

| Bits | Field Name | Function                                 | Initial Value |
|------|------------|------------------------------------------|---------------|
| 31:0 | Various    | Fields function as in Channel 0 Control. | 0x0           |

## 9.10.3 DMA Arbiter

## Table 268: Arbiter Control, Offset: 0x860

| Bits | Field Name  | Function                                                                                                                                                                                                                                                       | Initial Value |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1:0  | PrioChan1/0 | <ul> <li>Priority between Channel 0 and Channel</li> <li>1.</li> <li>00 - Round robin</li> <li>01 - Priority to channel 1 over channel 0</li> <li>10 - Priority to channel 0 over channel 1</li> <li>11 - Reserved</li> </ul>                                  | 0x0           |
| 3:2  | PrioChan3/2 | <ul> <li>Priority between Channel 2 and Channel</li> <li>3.</li> <li>00 - Round robin</li> <li>01 - Priority to channel 3 over 2</li> <li>10 - Priority to channel 2 over 3</li> <li>11 - Reserved</li> </ul>                                                  | 0x0           |
| 5:4  | PrioGrps    | <ul> <li>Priority between the group of channels 0/1 and the group of channels 2/3.</li> <li>00 - Round robin</li> <li>01 - Priority to channels 2/3 over 0/1</li> <li>10 - Priority to channels 0/1 over 2/3</li> <li>11 - Reserved</li> </ul>                 | 0x0           |
| 6    | PrioOpt     | <ul> <li>Priority Option Enabled/Disable</li> <li>0 - High priority device relinquishes the bus for a requesting device for one DMA transaction after it was serviced.</li> <li>1 - High priority device is granted as long as it requests the bus.</li> </ul> | 0x0           |
| 31:7 | Reserved    |                                                                                                                                                                                                                                                                | 0x0           |



# **10. PCI ARBITER**

The GT-96100A integrates two PCI arbiter functions. One is dedicated for PCI\_0 and the other for PCI\_1. The PCI\_0 arbiter handles up to six external agents and one internal agent (PCI\_0 master). The PCI\_1 arbiter supports a total of four external agents in addition to the internal PCI\_1 master<sup>1</sup>.

The PCI arbiters implement a priority based weighted Round Robin (RR) arbitration mechanism. Each agent is assigned a programmable priority tag (either high or low), and the arbitration is done according to these priorities. A simple Round Robin arbitration is performed within each priority level, while a weighted function is implemented for arbitrating between the high priority and the low priority groups.

# 10.1 Interface



Figure 33: PCI Arbiter's Interface Diagram

| Signal    | Description                                                                                                                                                            |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PClk      | PCI Clock                                                                                                                                                              |
| Reset     | Master Reset                                                                                                                                                           |
| Interrupt | Interrupt<br><b>NOTE:</b> This signal is asserted when the arbiter recognizes a "Broken" Master (i.e. a master<br>which does not respond to a grant signal assertion). |
| Gnt_[6:0] | GRANT# output signals<br><b>NOTE:</b> Gnt_[0] of PCI_0 arbiter is internally connected PCI_0 master. The same holds for<br>PCI_1.                                      |
| Req_[6:0] | Input REQ# signals.<br><b>NOTE:</b> Req_[0] of PCI_0 arbiter is internally connected PCI_0 master. The same holds for<br>PCI_1.                                        |

1. The internal design of the PCI arbiter logic handles a total of 7 request/grant pairs for each of the arbiters. But, due to package limitations, the GT-96100A is limited to a total of nine external request/grant pairs. These are divided between PCI\_0 arbiter and PCI\_1 arbiter. Thus, the user cannot connect six external agents to PCI\_0 arbiter and four external agents to PCI\_1 arbiter at the same time (it's either 6 to PCI\_0 and 3 to PCI\_1, or 5 to PCI\_0 and 4 to PCI\_1).

| Signal | Description        |  |
|--------|--------------------|--|
| Frame_ | PCI FRAME# signal. |  |
| IRdy_  | PCI IRDY# signal.  |  |

### Table 269: PCI Arbiter's Interface (Continued)

# 10.2 Arbitration Scheme

As noted above, each of the PCI arbiter's requests has a user programmable priority level associated with it. Two levels of priority are supported: High and Low. PCI Bandwidth allocation per priority is programmable as well, enabling the user to optimize the PCI to application needs.

Arbitration flow is shown in Figure 34.

### Figure 34: PCI Arbitration Flow





In relation to Figure 34, the following points should be noted:

The two request signals (High\_req, Low\_req) are generated by "ANDing" each of the request lines with its respective priority attribute, and ORing the results. For example:
 High req = (req [0] AND (req prio[0]==high)) OR...

 $req = (req_[0] AND (req_prio[0]==nign)) OR...$ 

(req\_[1] AND (req\_prio[1]==high)) OR...

- There is a counter associated with the priority scheme High\_cnt. The counter is used to assign different weights to each priority level. This is a count down counter that decrements each time a high priority request (High\_req) is granted. When High\_cnt expires, a slot is opened for low priority requests, and the counter is set to its preset value.
- Each time a low priority request (Low\_req) is granted, High\_cnt counter is preset.

# **10.3** Arbitration Parking

The PCI arbiter is designed to perform a default parking on the last agent granted. In order to overcome problems that happen with some PCI devices that do not handle parking properly, there is an option to disable parking on a per PCI master basis. This is done via the PCI\_Arbiter\_Configuration register PD[6:0] bits.

**NOTE:** In addition to disabling parking to avoid issues with some problematic devices, the user must also disable parking on any unused request/grant pair. This is required to avoid possible parking on non existent PCI masters. For example, if only 3 external agents are connected to PCI\_0 arbiter (using REQ0/GNT0, REQ1/GNT1, REQ2/GNT2 pins), then PD[6:4] should be set to 1.

# **10.4 PCI Arbiter Configuration Register**

#### Table 270: PCI\_0 Arbiter Configuration Register, Offset: 0x101AE0

| Bits | Field<br>Name | Function                                                                                                                                                                                                                             | lnitial<br>Value |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0    | GCen          | Gap Cycle enable<br>When this bit is set to 1, the PCI arbiter forces grant to be asserted only<br>after the PCI bus is idle. This guarantees two turn around cycles.                                                                | 0                |
| 1    | BDen          | Broken Detection enable<br>Setting this bit to 1 enables the detection of broken master. A master is said<br>to be broken if it fails to respond to grant assertion within a window speci-<br>fied in BV (see BV description above). | 0                |

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Initial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 2     | PAen          | <ul> <li>Priority Arbitration Enable</li> <li>When this bit is set to 1, weighted round robin arbitration is performed between high priority and low priority groups.</li> <li>When this bit is reset, no round robin arbitration takes place and low priority requests are granted only when no high priority request is pending.</li> <li><b>NOTE:</b> If HPPV is set to zero value and PAen is 1, priority scheme is reversed. This means that high priority requests are granted only if no low priority request is pending.</li> <li><b>NOTE:</b> Gap Cycle must be enabled in the PCI Arbiter when working with priority Arbitration.</li> </ul>                                                                                              | 0                |
| 6:3   | BV            | <ul> <li>Broken Value</li> <li>This value sets the maximum number of cycles that the arbiter waits for a PCI master to respond to its grant assertion. If a PCI master fails to assert FRAME* within this time, the PCI arbiter aborts the transaction and performs a new arbitration cycle. In addition, a maskable interrupt is generated.</li> <li><b>NOTE:</b> The PCI arbiter waits for the current transaction to end before starting to count the wait-for-broken cycles.</li> </ul>                                                                                                                                                                                                                                                         | 0                |
| 13:7  | P[6:0]        | Priority<br>These bits assign priority levels to the requests connected to the PCI arbi-<br>ter. When a PM bit is set to 1, priority of the associated request is high.<br>The mapping between P bits and the request/grant pairs is similar to the<br>one shown for PD bits above.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                |
| 20:14 | PD[6:0]       | <ul> <li>Parking Disable</li> <li>These bits can be used to disable parking on any of the PCI masters.</li> <li>When a PD is set to 1, parking on the associated PCI master is disabled.</li> <li>The mapping between the PD bits and the request/grant pairs is as follows: <ul> <li>PD[0] - internal PCI master unit</li> <li>PD[1] - external REQ0/GNT0</li> <li>PD[2] - external REQ1/GNT1</li> <li>PD[3] - external REQ2/GNT2</li> <li>PD[4] - external REQ3/GNT3</li> <li>PD[5] - external REQ4/GNT4</li> <li>PD[5] - external REQ5/GNT5</li> </ul> </li> <li>NOTE: The arbiter parks on the last master granted unless disabled through the PD bit. Also, if PD bits are all 1, the PCI arbiter parks on the internal PCI master.</li> </ul> | 0                |
| 28:21 | HPPV          | High Priority Preset Value<br>This is the preset value of the high priority counter (High_cnt). This counter<br>decrements each time a high priority request is granted. When the counter<br>reaches zero, it reloads with this preset value. The counter also reloads<br>when a low priority request is granted.                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                |

## Table 270: PCI\_0 Arbiter Configuration Register, Offset: 0x101AE0 (Continued)



| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Initial<br>Value |
|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 29   | AR6en         | Arbiter Request 6 enable<br>Setting this bit enables the 6th request/grant pair connection to PCI_0 arbi-<br>ter.<br>0 - pins PB[4], PB[5] are connected to PCI_1 arbiter and function as<br>PARB1_Gnt4, PARB1_Req4.<br>1 - pins PB[4], PB[5] are connected to PCI_0 arbiter and function as<br>PARB0_Gnt6, PARB0_Req6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                |
| 30   | GNT/<br>CLK   | Grant or OTSClk<br>This bit controls the function of pin PB6.<br>0 - this pin to function as OTSCLK1.<br>1- PB6 functions as PABR0_GNT4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                |
| 31   | EN            | Enable<br>Setting this bit to 1 enables operation of the arbiter. When the arbiter is<br>enabled, the internal PCI_0 master is connected to it.<br>The arbiter configuration must be set before the arbiter is enabled. This<br>means two writes must be made to this register. The first write sets the<br>arbiter configuration and must be done with the enable bit set to 0. With the<br>second write, set the enable bit to 1 to enable operation of the arbiter.<br><b>NOTE:</b> When the arbiter is enabled, PCI REQ* and GNT* pins change<br>their function: REQ* becomes Grant (PCI arbiter output) and<br>GNT* becomes Req (PCI arbiter input). For example, enabling<br>PCI_0 arbiter causes (req0*,gnt0*) pair to function as<br>(PARB0_GNT1, PARB0_REQ1) respectively.<br>BV must be set to a value greater than zero, or else there will<br>always be a break detection, as the arbiter waits 0 cycles for<br>FRAME* assertion. | 0                |

### Table 270: PCI\_0 Arbiter Configuration Register, Offset: 0x101AE0 (Continued)

### Table 271: PCI\_1 Arbiter Configuration Register, Offset: 0x101AE4

| Bits | Field Name | Function                                                                                   | lnitial<br>Value |
|------|------------|--------------------------------------------------------------------------------------------|------------------|
| 31:0 | Various    | Similar to PCI_0 arbiter configuration register (except for bit 30:29 which are reserved). | 0                |



# 11. COMMUNICATION INTERFACE UNIT (CIU)

The GT-96100A's IDMA, Ethernet ports, and SDMA engines have one common interface with the other units within the GT-96100A. These other units include the CPU interface unit (Punit), the memory control unit (Dunit), and the PCI unit (Lunit). The common interface supports a single master, meaning that only one agent can gain control and access the memory (through the Dunit) or the PCI (through the Lunit) at a time.

In order to support this shared interface, the GT-96100A provides an arbitration mechanism, which arbitrates between requests generated by the IDMA, SDMA, and Ethernet. The arbitration logic supports multiple priority levels as well as different weights assigned to each priority level. The priority is programmable per request and the weights are programmable per priority.

This arbitration mechanism also handles MASTER type requests. MASTER requests originate within the communication unit and are targeted at other units in the GT-96100A. For example, a request generated by one of the Ethernet units and is targeted at the Dunit (for SDRAM read/write access) is a MASTER request. Similarly, a request generated by the IDMA and is targeted at the PCI unit is also a MASTER request. The transactions associated with MASTER requests are referred to as MASTER transactions.

In addition to handling MASTER type requests and MASTER transactions, the arbiter also handles SLAVE transactions, which originate from other units within the GT-96100A (e.g. Punit, Lunit) and are targeted at the communication unit. SLAVE requests are used by the other units to access internal registers within the communication unit. Arbitration between SLAVE type requests is fixed and gives the highest priority to the Punit (i.e. requests from CPU).

The MASTER/SLAVE arbiter and the associated logic that handle the MASTER/SLAVE transactions are collectively called the Communication Interface Unit (CIU).

This section provides details about the arbitration scheme as well as high level design aspects of the CIU.



# 11.1 CIU Connectivity

Figure 35 shows a block diagram of the connectivity between the CIU and the communication unit agents.

### Figure 35: CIU Connection Diagram



# 11.2 Address Decoding and PCI Override (MASTER)

The GT-96100A's CIU supports two types of MASTER transactions - normal and PCI override.

For normal transactions, the CIU performs address decoding and access either the SDRAM/DEVICE or PCI\_0/ PCI\_1 based on the decoding result. See Section 3. "Address Space Decoding" on page 56 for a description of the address decoding scheme.

The PCI override feature allows the user to direct all transactions from a specific communication agent to the PCI\_0 direction, overriding address decoding. The override feature is programmable for the IDMA, Ethernet, SDMA units. For information on activating this feature, see:

- IDMA: Table 236.
- Ethernet: Table 296.
- SDMA: Table 316.

## **11.2.1 Address Decoding Errors**

The CIU is capable of handling transactions, which result in address decoding errors. If an address decoding error occurs, the CIU performs a dummy transaction with the initiating unit, discards the data, and sets the DMAout bit in the interrupt Main\_Cause register, see Table 391.

# 11.3 Arbitration Scheme

The CIU arbiter is designed to handle one transaction at a time. This could be either a MASTER or SLAVE transaction. Priority at the MATER/SLAVE level is fixed and gives higher priority to SLAVE type transactions. The priorities are listed below (from high to low):

- Punit slave request from CPU (highest priority).
- L0unit slave request from PCI\_0.
- L1unit slave request from PCI\_1.
- MASTER requests (lowest priority).

Arbitration within the MASTER level is very flexible and is detailed in the following sections.

## 11.3.1 Master Arbitration

The arbiter supports MASTER requests from the following sources within the communication unit:

- IDMA,
- Ethernet 1,
- Ethernet 2,
- SDMA 1,
- SDMA 2.

Figure 36 depicts the arbiters' logical connectivity, for MASTER requests.





Figure 36: Arbiter Connectivity

Each of the requests shown in Figure 36 has a user programmable priority level associated with it. The three levels of priority are High, Medium, Low. In addition, bandwidth allocation per priority is programmable as well, providing the user with the capability to optimize memory access to application needs.

Arbitration flow is shown in Figure 37.



### Figure 37: MASTER Arbitration Flow





In relation to Figure 37, note the following:

- The three request signals (High\_req, Med\_req, Low\_req) are generated by ANDing each of the request lines shown in Figure 36 with its respective priority attribute, and ORing the results. For example -
- High\_req = (IDMA\_req AND (IDMA\_prio=high)) OR (SDMA\_req1 AND (SDMA\_prio1=high)) OR...
- There are two counters associated with the priority scheme High\_cnt and Med\_cnt. These counters are used to assign different weights to each priority level. The counters are countdown based on the request being granted. Each time a high priority request (High\_req) is granted, the high priority counter (High\_cnt) is decrement. When High\_cnt reaches zero, a slot is opened for lower priority requests, and the counter is set to its preset value. The same holds for Med\_cnt.
- Each time a lower priority request is granted, the higher level counters are preset. When a medium priority request (Med\_req) is granted, High\_cnt counter is preset. When a low priority request is granted, both High\_cnt and Med\_cnt are preset.

# 11.4 CIU Arbiter Configuration Register

| Bits  | Field Name | Function                                                                                                                                                                                                          | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1:0   | IPL        | IDMA Priority Level<br>These bits assign the priority to the IDMA request<br>according to the following:<br>11 - High priority<br>10 - Medium priority<br>01 - Low priority<br>00 - Disabled (Request is masked.) | 0             |
| 3:2   | EPL1       | Ethernet port Priority Level 1                                                                                                                                                                                    | 0             |
| 5:4   | EPL2       | Ethernet port Priority Level 2                                                                                                                                                                                    | 0             |
| 7:6   | SPL1       | SDMA Priority Level 1<br>These bits assign the priority to the SDMA request 1.<br>See the IPL bit description in this table for details on pri-<br>ority assignment.                                              | 0             |
| 9:8   | SPL2       | SDMA Priority Level 2<br>These bits assign the priority to the SDMA request 2.<br>See the IPL bit description in this table for details on pri-<br>ority assignment.                                              | 0             |
| 15:10 |            | Reserved                                                                                                                                                                                                          | 0             |

#### Table 272: CIU Arbiter Configuration Register, Offset: 0x101AC0

| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                              | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 18:16 | MPPV       | Medium Priority Preset Value         This is the preset value of the medium priority counter         (Med_cnt). When the counter reaches zero, it reloads         with this preset value.         NOTE: If the medium priority counter is enabled         (MPCE bit set to 1), MPPV value must not be         set to zero. A value of zero in MPPV is allowed         only when the counter is disabled (i.e. when         MPCE = 0). | 0             |
| 19    | MPCE       | Medium Priority Counter Enable<br>When set, enables operation of the medium priority<br>counter (Med_cnt).<br>When reset, the medium priority counter is disabled<br>and low priority requests are only granted only when no<br>medium priority request is pending.                                                                                                                                                                   | 0             |
| 22:20 | HPPV       | High Priority Preset Value         This is the preset value of the high priority counter         (High_cnt). When the counter reaches zero, it reloads         with this preset value.         NOTE: If the high priority counter is enabled (HPCE bit set to 1), HPPV value must not be set to zero.         A zero value in HPPV is allowed only when the counter is disabled (i.e. when HPCE = 0).                                 | 0             |
| 23    | HPCE       | High Priority Counter Enable<br>When set, enables operation of the high priority counter<br>(High_cnt).<br>When reset, the high priority counter is disabled and<br>lower priority requests are only granted when no high<br>priority request is pending.                                                                                                                                                                             | 0             |
| 24    | EOR        | Ethernet Unit 0 Software Reset<br>0 - resets the Ethernet_1 unit                                                                                                                                                                                                                                                                                                                                                                      | 0             |
| 25    | E1R        | Ethernet Unit 1 Software Reset<br>0 - resets the Ethernet_1 unit w                                                                                                                                                                                                                                                                                                                                                                    | 0             |
| 30:26 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                             | 0             |
| 31    | BLED       | <ul> <li>Big Little Endian for Descriptors</li> <li>0 - Big Endian</li> <li>1 - Little Endian</li> <li>This bit controls the endianess of all descriptors han-<br/>dled by the Ethernet DMA and the Serial DMA (SDMAs)<br/>engines. It does not affect the data portion - endianess<br/>of the data is controlled via the various DMA configura-<br/>tion registers.</li> </ul>                                                       | 1             |

## Table 272: CIU Arbiter Configuration Register, Offset: 0x101AC0 (Continued)



# **12. 10/100MB ETHERNET UNIT**

# 12.1 Functional Overview

The 10/100Mb Ethernet unit handles all functionality associated with moving packet data between local memory or PCI and the Ethernet ports. The unit in the GT-96100A is designed to support two independent 10/100Mb Ethernet ports.

Each 10/100 Mbit port is fully compliant with the IEEE 802.3 and 802.3u standards and integrates the MAC function and a dual speed MII interface. The port's speed (10 or 100Mb/s) as well as the duplex mode (half or full duplex) is auto-negotiated through the PHY and does not require user intervention. The port also features 802.3x flow-control mode for full-duplex and backpressure mode for half duplex.

Integrated address filtering logic provides support for up to 8K MAC addresses. The address table resides in memory and a proprietary hash function is used for address table management. The address table functionality supports Multicast as well as Unicast address entries.

An important feature related to the address recognition is IGMP packet trapping mode. In this mode layer 3 hardware analysis is performed in order to check if a packet being received is an IGMP packet. Each packet identified as IGMP is queued in the high priority queue of the port from which it was received. The IGMP analysis is performed on the fly, so it does not impact bandwidth capability.

Another important feature related to priority queues is the Type of Service queuing algorithm. This algorithm is based on the decoding in layer 3 of the DSCP field from the IP header. If enabled, the decoded field indexes a 64 entry IPT Table in the Ethernet register space. The 2-bit output of this table sets the priority queue of the received packet.

The Ethernet unit integrates powerful DMA engines, which automatically manage data movement between buffer memory and the ports, and guarantee wire-speed operation on all ports (even when all ports are in 100Mb full-duplex mode). There are two DMA engines per port - one dedicated for receive and the other for transmit.

The DMA logic handles multiple priority queues per port, providing support for priority sensitive data in both directions. There are four receive priority queues and two transmit priority queues per port. Priority information for received packets is either extracted from the packet tag (if the packet is VLAN tagged) or from the destination address entry in the address table (if the packet is not tagged) of the IP parameters as described above. The priority function is MAX (ip\_parameters, vlan\_tag, address\_entry).



# 12.2 Port Features

The 10/100Mb Ethernet port provides the following features:

- IEEE 802.3 compliant MAC layer function.
- IEEE 802.3u compliant MII interface.
- 10/100Mb operation half and full duplex.
- Flow control features:
  - IEEE 802.3x flow-control for full-duplex operation mode.
  - Backpressure for half duplex operation mode.
- Internal and external loopback modes.
- Transmit functions:
  - Short frame (less than 64 bytes) zero padding.
  - Long frames transmission (limited only by external memory size).
  - Programmable values for IPG and Blinder timers.
  - CRC generation (programmable per packet).
  - Automatic frame retransmission upon collision (with programmable retransmit limit).
  - Backoff algorithm execution.
  - Error report.
  - Receive functions:
    - 1/2k or 8k address filtering capability.
    - Address filtering modes:
      - Perfect filtering.
      - Reverse filtering.
      - Promiscuous mode.
      - Broadcast reject mode.
  - IGMP packet trapping (layer 3 analysis in hardware).
  - Automatic discard of errored frames, short (less than 64 bytes) or collided.
  - Reception of long frames (programmable up to 64Kbytes).
  - CRC checking.
  - Pass bad frames mode.
  - Error report.



# 12.3 Operational Description

# 12.3.1 General Overview

The Ethernet unit provides multiple Ethernet ports functionality, with each port capable of running at either 10 or 100Mb/s (half or full-duplex) independently of the other port. Each port interfaces a MII PHY on its serial side and manages packet data transfer between memory and MII. The data is stored in memory buffers, with any single packet spanning multiple buffers if necessary. Upon completion of packet transmission or reception, a status report, which includes error indications, is written by the Ethernet unit to the first or last descriptor associated with this packet.

The buffers are allocated by the CPU and are managed through chained descriptor lists. Each descriptor points to a single memory buffer and contains all the relevant information relating to that buffer (i.e. buffer size, buffer pointer, etc.) and a pointer to the next descriptor. Data is read from buffer or written to the buffer according to information contained in the descriptor. Whenever a new buffer is needed (end of buffer or end of packet), a new descriptor is automatically fetched and the data movement operation is continued using the new buffer.

Figure 38 shows an example of memory arrangement for a single packet using three buffers.



#### Figure 38: Ethernet Descriptors and Buffers

The following sections provide detailed information about the operation and user interface of the Ethernet unit and its logic subsections.

## 12.3.2 Transmit Operation

In order to initialize a transmit operation, the CPU must do the following:

1. Prepare a chained list of descriptors and packet buffers.



- **NOTE:** The TxDMA supports two priority transmit queues high and low. If the user wants to take advantage of this capability, a separate list of descriptors and buffers must be prepared for each of the priority queues.
  - 2. Write the pointer to the first descriptor to the DMA's current descriptor registers (TxCDP) associated with the priority queue to be started. If both priority queues are needed, initialize TxCDP for each queue.
  - 3. Initialize and enable the Ethernet port by writing to the port's configuration and command registers.
  - 4. Initialize and enable the DMA by writing to the DMA's configuration and command registers.

After completing these steps, the DMA starts and performs arbitration between the transmit queues according to the value programmed in Port\_Configuration\_Extend<PRIOtx> (see Table 289 for more details). The DMA then fetches the first descriptor from the specific queue it decided to serve, and starts transferring data from memory buffer to the TX-FIFO. When either 384 bytes of packet data are in the FIFO or when the entire packet is in the FIFO (for packets shorter than 384 bytes), the port initiates transmission of the packet across the MII. While data is read from the FIFO, new data is written into the FIFO by the DMA.

For packets that span more than one buffer in memory, the DMA will fetch new descriptors and buffers as necessary.

When transmission is completed, status is written to the first longword of the last descriptor. The Next Descriptor's address, which belongs to the next packet in the queue, is written to the current descriptor pointer register.

This process (starting with DMA arbitration) is repeated as long as there are packets pending in the transmit queues.

Figure 39 shows how the TX descriptors are managed when a two buffers packet is transmitted.





#### Figure 39: Ethernet Packet Transmission Example

2. Packet 1 - transmitting 2nd buffer



#### 3. Packet 2 - transmitting 1st buffer



1. TxCDP = Transmit Current Descriptor Pointer



Ownership of any descriptor other than the last is returned to CPU upon completion of data transfer from the buffer pointed by that descriptor. The Last descriptor, however, is returned to CPU ownership only after the actual transmission of the packet is completed. While changing the ownership bit of the last descriptor, the DMA also writes status information, which indicates any errors that might have happened during transmission of this packet.

# 12.3.2.1 Retransmission (Collision)

Full collision support is integrated into the Ethernet port for half duplex operation mode.

In half duplex operation mode, a collision event is indicated each time receive and transmit are active simultaneously. When that happens, active transmission is stopped, jam pattern is transmitted and collision count for the packet increments. The packet is retransmitted after a waiting period, which conforms to the binary Backoff algorithm specified in the IEEE 802.3 standard. Retransmit process continues for multiple collision events as long as a specified limit is not reached. This retransmit limit, which sets the maximum number or transmit retries for a single packet, is defined by the IEEE 802.3 as 16. However, the user can program a different value (see Table 296 for more details). The event of a single packet colliding 16 times is known as **EXCESSIVE COLLISION**.

As long as a packet is being retransmitted, its last descriptor is kept under port ownership. When a successful transmission takes place (i.e. no collision), a status word containing collision information is written to the last descriptor and ownership is returned to CPU.

If a retransmit limit is reached with no successful transmission, a status word with error indication is written to the packet's last descriptor, and the transmit process continuous with the next packet.

It is important to note that collision is considered legal only if it happens before transmitting the 65th byte of a packet. Any collision event that happens outside the first 64 byte window is known as **LATE COLLISION**, and is considered a fatal network error. Late collision is reported to the CPU through packet status, and no retransmission is done.

**NOTE:** A collision occurring during the transmission of the transmit packet's last two bytes are not detected.

# 12.3.2.2 Zero Padding (for short packets)

Zero Padding is a term used to denote the operation of adding zero bytes to a packet. This feature is used for CPU off-loading.

The Ethernet port offers a per packet padding request bit in the TX descriptor. This causes the port logic to enlarge packets shorter than 64 bytes by appending zero bytes. When this feature is used, only packets equal or larger than 64 bytes are transmitted as is. Packets smaller than 64 bytes are zero padded and transmitted as 64 byte packets.

## 12.3.2.3 CRC Generation

Ethernet CRC denotes four bytes of Frame-Check-Sequence appended to each packet.

CRC logic is integrated into the port and can be used to automatically generate and append CRC to a transmitted packet. One bit in the TX descriptor is used for specifying if CRC generation is required for a specific packet.



#### 12.3.2.4 TX DMA Descriptors

Figure 40 depicts the format of TX DMA descriptors. The following set of restrictions apply to TX descriptors:

- Descriptor length is 4LW and it must be 4LW aligned (i.e. Descriptor Address[3:0]=0000).
- Descriptors may reside anywhere is CPU address space except for NULL address (0x0000000), which is used to indicate end of descriptor chain.
- Last descriptor in the linked chain must have a NULL value in its NextDescriptorPointer field.
- TX buffers associated with TX descriptors are limited to 64K bytes and can reside anywhere in memory. However, buffers with a payload smaller than 8 bytes must be aligned to 64-bit boundary. Figure 41 illustrates possible alignments for 5 byte payload.

#### Figure 40: Ethernet TX Descriptor

|            |                                 |  |  |  |  |  | 2<br>4 |  |   |  |   |     |    |     |     |    |     |    |  |  | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|---------------------------------|--|--|--|--|--|--------|--|---|--|---|-----|----|-----|-----|----|-----|----|--|--|--------|---|---|---|---|---|---|---|---|---|---|
|            |                                 |  |  |  |  |  |        |  |   |  | С | orr | ım | an  | d / | St | atı | IS |  |  |        |   |   |   |   |   |   |   |   |   |   |
| Byte Count |                                 |  |  |  |  |  |        |  |   |  | l | Re  | se | rve | ed  |    |     |    |  |  |        |   |   |   |   |   |   |   |   |   |   |
|            | Buffer Pointer                  |  |  |  |  |  |        |  |   |  |   |     |    |     |     |    |     |    |  |  |        |   |   |   |   |   |   |   |   |   |   |
|            | Next Descriptor Pointer 0 0 0 0 |  |  |  |  |  |        |  | 0 |  |   |     |    |     |     |    |     |    |  |  |        |   |   |   |   |   |   |   |   |   |   |

#### Figure 41: Ethernet TX Buffer Alignment Restrictions (5 byte payload)



Table 273 through Table 276 provide detailed information about the TX descriptor.

| Bits  | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | 0       | Ownership bit<br>When set to '1', the buffer is "owned" by the device.<br>When set to '0', the buffer is owned by the CPU. Buffers owned by the CPU are not pro-<br>cessed by the DMA.                                                                                                                                                                                                                    |
| 30    | АМ      | Auto Mode<br>When set, the DMA does not clear the Ownership bit at the end of buffer processing.                                                                                                                                                                                                                                                                                                          |
| 29:24 |         | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 23    | EI      | Enable Interrupt<br>The device generates a maskable TxBuffer interrupt upon closing the descriptor.<br><b>NOTE:</b> In order to limit the number of interrupts and prevent an interrupt per buffer situ-<br>ation, the user should set this bit only in descriptors associated with LAST buff-<br>ers. If this is done, TxBuffer interrupt will be set only when transmission of a<br>frame is completed. |
| 22    | GC      | Generate CRC<br>When set, CRC is generated and appended to this packet.<br><b>NOTE:</b> Valid only if L (bit 16) is set.                                                                                                                                                                                                                                                                                  |
| 21:19 |         | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 18    | Ρ       | Padding<br>When this bit is set, zero bytes are appended to the packet if the packet is smaller than<br>60 bytes. Use this feature to prevent transmission of fragments.<br><b>NOTE:</b> Valid only if L (bit 16) is set.                                                                                                                                                                                 |
| 17    | F       | First<br>Indicates first buffer of a packet.                                                                                                                                                                                                                                                                                                                                                              |
| 16    | L       | Last<br>Indicates last buffer of a packet.                                                                                                                                                                                                                                                                                                                                                                |
| 15    | ES      | Error Summary<br>ES = LC or UR or RL<br>Set by the device to indicate an error event that occured during packet the packet.<br><b>NOTE:</b> Valid only if L (bit 16) is set.                                                                                                                                                                                                                              |
| 14    |         | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 13:10 | RC[3:0] | Retransmit Count. Indicates actual number of retransmits for this packet.<br>RC is valid only if L (bit 16) is set.                                                                                                                                                                                                                                                                                       |
| 9     | COL     | Collision<br>When set, indicates that at least one collision event occured during transmission of the<br>packet.<br><b>NOTE:</b> Valid only if L (bit 16) is set.                                                                                                                                                                                                                                         |

# Table 273: Ethernet TX Descriptor - Command/Status word



| Bits | Name | Description                                                                                                                                                                                                          |
|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | RL   | Retransmit Limit (Excessive Collision) error<br>Indicates that retransmit count reached the limit specified in the DMA configuration regis-<br>ter, see Table 296).<br><b>NOTE:</b> Valid only if L (bit 16) is set. |
| 7    |      | Reserved.                                                                                                                                                                                                            |
| 6    | UR   | Under-Run error<br>Indicates that part of the packet's data was not available while transmission was in<br>progress, probably due to memory access delays).<br><b>NOTE:</b> Valid only if L (bit 16) is set.         |
| 5    | LC   | Late Collision error<br>Collision occurred outside the collision window (i.e. more than 512 bits were transmitted<br>before collision assertion).<br><b>NOTE:</b> Valid only if L (bit 16) is set.                   |
| 4:0  |      | Reserved                                                                                                                                                                                                             |

Table 273: Ethernet TX Descriptor - Command/Status word (Continued)

## Table 274: Ethernet TX Descriptor - Byte Count

| Bits  | Name          | Description                                                                                  |
|-------|---------------|----------------------------------------------------------------------------------------------|
| 31:16 | Byte<br>Count | Number of bytes to be transmitted from associated buffer. This is the payload size in bytes. |
| 15:0  |               | Reserved.                                                                                    |

#### Table 275: Ethernet TX Descriptor - Buffer Pointer

| Bits | Name              | Description                                                                                                                                                                                                  |
|------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Buffer<br>Pointer | 32-bit pointer to the beginning of the buffer associated with this descriptor.<br><b>NOTE:</b> The alignment restrictions for buffers that have Byte-Count smaller than 8 bytes (see Figure 41 on page 259). |

#### Table 276: Ethernet TX Descriptor - Next Descriptor Pointer

| Bits | Name                          | Description                                                                                                                                                                                             |
|------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Next<br>Descriptor<br>Pointer | 32-bit pointer that points to the beginning of next descriptor. Bits [3:0] must be set to 0. DMA operation is stopped when a NULL (all zero) value in the Next Descriptor Pointer field is encountered. |



#### 12.3.2.5 TX DMA Pointer Registers

The TX DMA employs a single 32-bit pointer register per queue: TxCDP.

TxCDP - TX DMA Current Descriptor Pointer.

TxCDP is a 32-bit register used to point to the current descriptor of a transmit packet. The CPU must initialize this register before enabling DMA operation. The value used for initialization should be the address of the first descriptor to use.

#### 12.3.2.6 TX DMA Notes

Transmit DMA process is packet oriented. The transmit DMA does not close the last descriptor of a packet, until the packet has been fully transmitted. When closing the last descriptor, the DMA writes packet transmission status to the Command/Status word and resets the ownership bit. A TxBuffer maskable interrupt is generated if the EI bit in the last descriptor is set.

Transmit DMA stops processing a TX queue whenever a descriptor with a NULL value in the Next Descriptor Pointer field is reached or when a CPU owned descriptor is fetched. When that happens, a Tx\_End maskable interrupt is generated. In order to restart the queue, the CPU should issue a Start\_Tx command by writing '1' to the Start\_Tx bit in the DMA command register. <sup>1</sup>

The transmit DMA does not expect a NULL Next Descriptor Pointer or a CPU owned descriptor in the middle of a packet. When that happens, the DMA aborts transmission and stops queue processing. A TX\_Resource\_Error maskable interrupt is generated. In order to restart the queue, the CPU should issue a Start Tx command.

A transmit underrun occurs when the DMA can not access the memory fast enough and packet data is not transferred to the FIFO before the FIFO gets empty. In this case, the DMA aborts transmission and closes the last descriptor with a UR bit set in the status word. Also, a Tx\_Underrun maskable interrupt is generated. Transmit process continues with the next packet.

In order to stop DMA operation before the DMA reaches the end of descriptor chain, the CPU should issue a STOP command by writing '1' to the Stop\_Tx bit in the DMA command register. The DMA stops queue processing as soon as the current packet transmission is completed and its last descriptor returned to CPU ownership. In addition, a Tx\_End maskable interrupt is generated. In order to restart this queue, the CPU should issue a Start Tx command.

**NOTE:** Most of the terms used to denote either DMA commands (Start\_Tx and Stop\_Tx) or interrupts (TxBuffer, Tx\_End, TX\_Resource\_Error) actually reflect multiple terms (one per queue). For example, the GT-96100A provides two Start\_Tx commands. There is a separate Start\_Tx\_High command, associated with the high priority queue, and a Start\_Tx\_low command that is related to the low priority queue. The same applies to the other commands and interrupts listed above.

<sup>1.</sup> When the DMA stops due to NULL descriptor pointer, the CPU has to write TxCDP before issuing a Start\_Tx command. Otherwise, TxCDP remains NULL and the DMA can not restart queue processing.



#### 12.3.3 Receive Operation

In order to initialize a receive operation, the CPU must do the following:

- 1. Prepare a chained list of descriptors and packet buffers.
- **NOTE:** The RxDMA supports four priority queues. If the user wants to take advantage of this capability, a separate list of descriptors and buffers should be prepared for each of the priority queues.
  - 2. Write the pointer to the first descriptor to the DMA's first and current descriptor registers (RxFDP, RxCDP) associated with the priority queue to be started. If multiple priority queues are needed, the user has to initialize TxFDP and TxCDP for each queue.
  - 3. Initialize and enable the Ethernet port by writing to the port's configuration and command registers.
  - 4. Initialize and enable the DMA channel by writing to the DMA's configuration and command registers.

After completing these steps, the port starts waiting for a receive frame to arrive at the MII interface. When this occurs, receive data is packed and transferred to the RxFiFO. At the same time, address filtering test is done in order to decide if the packet is destined to this port. If the packet passes address filtering check, a decision is made regarding the destination queue to which this packet should be transferred. When this is done, actual data transfer to memory takes place.

NOTE: Packets which fail address filtering are dropped and not transferred to memory.

For packets that span more than one buffer in memory, the DMA will fetch new descriptors as necessary. However, the first descriptor pointer will not be changed until packet reception is done.

When reception is completed, status is written to the first longword of the first descriptor, and the Next Descriptor's address is written to both first and current descriptor pointer registers. This process is repeated for each received packet.

**NOTES:** The RxCDP and RxFDP point to the same descriptor whenever the DMA is ready for receiving a new packet. RxFDP is not modified during packet reception and points to the first descriptor. Only after the packet had been fully received and status information was written to the first LW of the first descriptor, will the ownership bit be reset (i.e. descriptor returned to CPU ownership).

Ownership of any descriptor other than the first is returned to CPU upon completion of data transfer to the buffer pointed by that descriptor. This means that the first descriptor of a packet is the last descriptor to return to CPU ownership (per packet).

#### 12.3.3.1 RX DMA Descriptors

Figure 42 shows the format of RX DMA descriptors.

The following set of restrictions apply to RX descriptors:

- Descriptor length is 4LW and it must be 4LW aligned (i.e. Descriptor\_Address[3:0]=0000).
- Descriptors reside anywhere in the CPU address space except NULL address, which is used to indicate end of descriptor chain.
- RX buffers associated with RX descriptors are limited to 64K bytes and must be 64-bit aligned. Minimum size for RX buffers is 8 bytes.



#### Figure 42: Ethernet RX DMA Descriptor

|                           | 2 2 2 2 2 2 2 2 2 1<br>7 6 5 4 3 2 1 0 9 | 876 | 54 | 3210 | 987654 | 3 2 | 2 1 |   | 0 |  |
|---------------------------|------------------------------------------|-----|----|------|--------|-----|-----|---|---|--|
|                           | Command / Status                         |     |    |      |        |     |     |   |   |  |
|                           | Buffer Size <b>0 0</b> Byte Count        |     |    |      |        |     |     |   |   |  |
|                           | Buffer Pointer 0                         |     |    |      |        |     |     |   |   |  |
| Next Descriptor Pointer 0 |                                          |     |    |      |        |     | 0   | 0 | 0 |  |

#### Table 277: Ethernet RX Descriptor - Command/Status word

| Bits | Name | Description                                                                                                                                                                                                                                                                                                                                  |
|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | CE   | CRC Error<br>Received CRC does not match calculated CRC for the received packet.<br><b>NOTE:</b> Valid only if F (bit 17) is set.                                                                                                                                                                                                            |
| 3:1  |      | Reserved.                                                                                                                                                                                                                                                                                                                                    |
| 4    | COL  | Collision<br>Collision was sensed during packet reception.<br><b>NOTE:</b> In normal operation mode collided packets are automatically discarded by the<br>port (being shorter than 64 bytes). Collided packets are accepted only when<br>PBF is set in the Port Configuration register (see Table 288).<br>Valid only if F (bit 17) is set. |
| 5    | LC   | Reserved.                                                                                                                                                                                                                                                                                                                                    |
| 6    | OR   | Overrun Error<br>Indicates that the RX DMA was unable to transfer data from RxFiFO to memory fast<br>enough, causing data overrun in the FIFO.<br><b>NOTE:</b> Valid only if F (bit 17) is set.                                                                                                                                              |
| 7    | MFL  | Max Frame Length Error<br>Indicates that a frame longer than MAX_FRAME_LEN was received. The maximum<br>frame length is programmable (see Table 289).<br><b>NOTE:</b> Valid only if F (bit 17) is set.                                                                                                                                       |
| 8    | SF   | Short Frame Error<br>Indicates that a frame shorter than 64 bytes was received.<br>In normal operation mode short packets are automatically discarded by the port. Short<br>packets are accepted only when PBF is set in the Port Configuration register (see Table<br>288).<br><b>NOTE:</b> Valid only if F (bit 17) is set.                |
| 10:9 |      | Reserved.                                                                                                                                                                                                                                                                                                                                    |



| Bits  | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11    | FT   | <ul> <li>Frame Type <ul> <li>1 - 802.3</li> <li>0 - Ethernet</li> </ul> </li> <li>Set to '1' when the Type/Length field in the received packet has a value not bigger than 1500 (decimal).</li> <li>NOTE: Valid only if F (bit 17) is set.</li> </ul>                                                                                                                                                                                                                  |
| 12    | М    | <ul> <li>Missed Frame <ul> <li>0 - Match</li> <li>1 - Miss</li> </ul> </li> <li>Set to indicate that this packet's destination address is not found in the address table. This bit may be set if HDM or PM are set in the Port Configuration register (see Table 288).</li> <li>Also, set to receive broadcast packets regardless of the HDM or PM settings in the Port Configuration register.</li> <li>NOTE: This bit is valid only if F (bit 17) is set.</li> </ul> |
| 13    | HE   | <ul> <li>Hash Table Expired</li> <li>Set to indicate that hash process was not completed in time. This means there is no definite answer as to whether this packet's address is in the hash table or not.</li> <li>Also, set when there is no room in the table for this address.</li> <li><b>NOTE:</b> Valid only if F (bit 17) is set.</li> </ul>                                                                                                                    |
| 14    | IGMP | Set to indicate that this packet has been identified as an IGMP packet.<br><b>NOTE:</b> Valid only if F (bit 17) is set.                                                                                                                                                                                                                                                                                                                                               |
| 15    | ES   | Error Summary<br>ES = CE or COL or LC or OR or MFL or SF<br><b>NOTE:</b> Valid only if F (bit 17) is set.                                                                                                                                                                                                                                                                                                                                                              |
| 16    | L    | Last<br>Indicates last buffer of a packet.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17    | F    | First<br>Indicates first buffer of a packet.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 22:18 |      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 23    | EI   | <ul> <li>Enable Interrupt</li> <li>The device generates a maskable interrupt upon closing the descriptor.</li> <li><b>NOTE:</b> In order to limit the number of interrupts and prevent an interrupt per buffer situation, the user should set the EI bits in all the Rx descriptors and set RIFB bit in the DMA Configuration register (see Table 296). The RxBuffer interrupt is set only on frame (rather than buffer) boundaries.</li> </ul>                        |
| 29:24 |      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 30    | AM   | Auto Mode<br>When set, the DMA does not clear the Ownership bit at the end of buffer processing.                                                                                                                                                                                                                                                                                                                                                                       |

Table 277: Ethernet RX Descriptor - Command/Status word (Continued)

| Bits | Name | Description                                                                                                          |
|------|------|----------------------------------------------------------------------------------------------------------------------|
| 31   | 0    | Ownership bit.<br>When set to '1', the buffer is "owned" by the device. When set to '0', the buffer is owned by CPU. |

#### Table 277: Ethernet RX Descriptor - Command/Status word (Continued)

#### Table 278: Ethernet RX Descriptor - Buffer Size / Byte Count

| Bits  | Name           | Description                                                                                                                                                                                                          |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | Byte<br>Count  | When the descriptor is closed this field is written by the device with a value indicating number of bytes actually written by the DMA into the buffer.                                                               |
| 31:16 | Buffer<br>Size | Buffer Size in Bytes<br>When number of bytes written to this buffer is equal to Buffer Size value, the DMA closes<br>the descriptor and moves to the next descriptor.<br><b>NOTE:</b> Bits [18:16] must be set to 0. |

# Table 279: Ethernet RX Descriptor - Buffer Pointer

| Bits | Name              | Description                                                                                                                                        |
|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Buffer<br>Pointer | 32-bit Pointer to The Beginning of the Buffer Associated with The Descriptor RX buffers have to be 64-bit aligned, so bits [2:0] must be set to 0. |

#### Table 280: Ethernet RX Descriptor - Next Descriptor Pointer

| Bits | Name                          | Description                                                                                                                                                                                              |
|------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Next<br>Descriptor<br>Pointer | 32-bit Next Descriptor Pointer to the Beginning of Next Descriptor<br>Bits [3:0] must be set to 0.<br>DMA operation is stopped when a NULL value in the Next Descriptor Pointer field is<br>encountered. |



#### 12.3.3.2 RX DMA Pointer Registers

The RX DMA employs two 32-bit pointer registers per queue: RxFDP and RxCDP.

• RxFDP - RX DMA First Descriptor Pointer.

RxFDP is a 32-bit register used to point to the first descriptor of a receive packet. The CPU must initialize this register before enabling DMA operation. The value used for initialization should be the address of the first descriptor to use.

• RxCDP - RX DMA Current Descriptor Pointer.

RxCDP is a 32-bit register used to point to the current descriptor of a receive packet. The CPU must initialize this register before enabling DMA operation. The value used for initialization should be the same as the value used for initializing RxFDP (i.e. address of first descriptor to use).

#### 12.3.3.3 Type of Service Queueing

The Type of Service queuing algorithm is based on the decoding of the DSCP field from the IP header. The DSCP field is located in the 6-MSB bits of the second byte in the IP header (See Figure 43). This field indexes the 64 IPT Table entries, which reside in the GT-96100A Ethernet register space. The 2-bit priority output of this table is referred to in the algorithm as **tos\_priority**.

The **tos\_priority** is valid only if the tos2prio enable bit 21 in the Ethernet Port Configuration Extend register, referred to in the algorithm as **tos2prio\_en**, is set.

If a VLAN tag exists in the packet, the VLAN priority tag is decoded from the 3-MSB bits of the 2<sup>nd</sup> word in the VLAN tag. This field is the index to the 8 entries in the VPT Table, which reside in the GT-96100A Ethernet register space. The 2-bit priority output of this table is referred to in the algorithm as **vlan\_priority**.

The GT-96100A can decode BPDU and IGMP protocol packets. These packets are referred to in the algorithm as **frame\_bpdu** and **frame\_igmp** respectively. Protocol detection is controlled by the SPAN and IGMP bits in the Ethernet Port Configuration Extend register, referred to in the algorithm as **bpdu\_captue** and **igmp\_capture** respectively.

BPDU and IGMP protocol packets are sent to the highest value queue unless protocol detection is turned off.

The PRIOrx Override bit in the Ethernet Port Configuration Extend register, referred to in the algorithm as **overide\_priority**, takes precedence over **tos\_priority** or **vlan\_priority**. If this bit is set, ALL packets (except **frame\_bpdu** and **frame\_igmp**) are sent to the **default\_priority** queue. The algorithm notation for the PRIOrx 2-bit field in the Ethernet Port Configuration Extend register is **default\_priority**.

The packet type is checked after checking the source address, VLAN tag (if it exists), and LLC-SNAP (if it exists). The packet type is compared to 0x8100, referred to in the algorithm as **vlan\_type**, or to 0x800, referred to in the algorithm as **ip\_type**. If **vlan\_type** or **ip\_type** with VALID **tos\_priority**, or both, are found on the packet, the packet is referred to in the algorithm as **frame\_tagged**.

Broadcast packets, which are referred to in the algorithm as **frame\_broadcast** and are not marked as **frame\_tagged** are also sent to the **default\_priority** queue.

If the packet is marked as **frame\_tagged**, the GT-96100A sends the packet to the **tos\_priority** queue or **vlan\_priority** queue. If both **tos\_priority** and **vlan\_priority** are extracted from the packet, the GT-96100A sends the packet to the higher value queue.

If both **tos\_priority** and **vlan\_priority** are missing from the packet, the GT-96100A uses the priority value found in the matched Hash Table entry. The Hash Table entry match, referred to in the algorithm as **da\_found**, occurs when the destination address matches the entry's address and the entry is valid.

The 2-bit priority value, referred to in the algorithm as **ht\_priority**, is located on bits 52:51 of the Hash Table entry. The address to be compared is located on bits 50:3 of the Hash Table entry. The validity of the entry is stated in bits 2:0.

When the Hash Table entry does not return a priority value, the packet is sent to the **default\_priority** queue.



Figure 43: Type of Service Queueing Algorithm



#### 12.3.3.4 RX DMA notes

The Receive DMA process is packet oriented. The DMA does not close the first descriptor of a packet, until the last descriptor of the packet is closed. When closing the first descriptor, the DMA writes status to the Command/ Status word and resets the ownership bit. A RxBuffer maskable interrupt is generated if the EI bit in the first descriptor is set.

The receive DMA never expects a NULL next descriptor pointer or a CPU owned descriptor during normal operation. It is assumed that whenever the receive DMA needs a buffer, a buffer is ready for it. If this is not the case, the RxDMA engine stops serving the current priority queue and a Rx\_resource\_error maskable interrupt is generated. To resume operation of the stopped queue, the following must be performed:

- 1. Read the RxCDP associated with the stopped queue.
- 2. If RxCDP is not NULL, it means that the error is due to a CPU owned descriptor. In this case, flip the ownership bit of the descriptor pointed by RxCDP.
- 3. If RxCDP is NULL, it means that the error is due to a NULL descriptor pointer. In this case, re-initialize the queue by writing a valid pointer to both RxCDP and RxFDP.

Stopping RX DMA operation is possible using the RX\_ABORT command (see Table 297).

# 12.3.4 Ethernet Address Recognition

The following chapter describes the Hash algorithm and Hash table data structure. The CPU must build this table for the GT-96100A before enabling the Ethernet port.

#### 12.3.4.1 Hash Table Structure

The GT-96100A Hash table is a data structure prepared by the CPU and resides in the system DRAM. Its location is identified by a 32 bit pointer stored in the GT-96100A EHTP internal register (addresses 0x84828 and 0x88828). The Hash table must be octet-byte aligned. The lowest three bits of the EHTP register are hard wired to '0'.

There are two possible sizes for the Hash table. Table size is selected by the HS bit in the Ethernet Configuration Register (PCR, address 0x84800 and 0x88800).

- 8K address table. 256KByte of DRAM required (4 x 64KByte banks)
- 1/2K address table. 16KByte of DRAM required (4 x 4KByte banks)

A multiple of 4 banks are used in order to reduce the number of addresses that are mapped to the same table entry.

**NOTE:** The user must initialize the Hash table before enabling the Ethernet Controller.

Each Address entry is a two word data field (64 bits) as shown below:



#### Figure 44: Ethernet Hash Table Entry



The following table describes the Hash table entry fields.

| Table | 281: | Hash   | Table | Entrv    | Fields  |
|-------|------|--------|-------|----------|---------|
| 10010 |      | 114011 | IUNIO | <u> </u> | 1 10140 |

| Bit   | Command                 | Usage                                                                                                                               |
|-------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Valid                   | Indicates Valid Entry                                                                                                               |
| 1     | Skip                    | Skip empty entry in a chain                                                                                                         |
| 2     | Receive/Discard (RD)    | 0 - Discard packet upon match<br>1 - Receive packet upon match                                                                      |
| 6:3   | Ethernet Address[3:0]   | Mapped to Ethernet MAC address[43:40].                                                                                              |
| 11:7  | Ethernet Address[7:4]   | Mapped to Ethernet MAC address[47:44].                                                                                              |
| 14:11 | Ethernet Address[11:8]  | Mapped to Ethernet MAC address[35:32].                                                                                              |
| 18:15 | Ethernet Address[15:12] | Mapped to Ethernet MAC address[39:36].                                                                                              |
| 22:19 | Ethernet Address[19:16] | Mapped to Ethernet MAC address[27:24].                                                                                              |
| 26:23 | Ethernet Address[23:20] | Mapped to Ethernet MAC address[31:28].                                                                                              |
| 30:27 | Ethernet Address[27:24] | Mapped to Ethernet MAC address[19:16].                                                                                              |
| 34:31 | Ethernet Address[31:28] | Mapped to Ethernet MAC address[23:20].                                                                                              |
| 38:35 | Ethernet Address[35:32] | Mapped to Ethernet MAC address[11:8].                                                                                               |
| 42:39 | Ethernet Address[39:36] | Mapped to Ethernet MAC address[15:12].                                                                                              |
| 46:43 | Ethernet Address[43:40] | Mapped to Ethernet MAC address[3:0].                                                                                                |
| 50:47 | Ethernet Address[47:44] | Mapped to Ethernet MAC address[7:4].                                                                                                |
| 52:51 | Priority                | The priority queue of a packet sent to this<br>Ethernet address, in case there are no other priority signals (i.e. ToS or<br>VLAN). |
| 63:53 | Reserved                | Fill With '0'                                                                                                                       |



## 12.3.4.2 Hash Modes

There are two Hash functions in the GT-96100A; Hash Mode 1 and Hash Mode 0.

#### 12.3.4.3 Hash Mode 0

In Hash mode 0, the Hash entry address is calculated in the following manner:

hashResult[14:0] = hashFunc0(ethernetADD[47:0])

- hashResult is the 15 bits Hash entry address.
- ethernetADD is a 48 bit number, which is derived from the Ethernet MAC address, by nibble swapping in every byte; i.e. MAC address of 0x123456789abc translates to ethernetADD of 0x21436587a9cb.
- inverse every nibble; i.e. ethernetADD of 0x21436587a9cb translates to 0x482c6a1e59d

hashFunc0 calculates the hashResult in the following manner:

- hashResult[14:9] = ethernetADD[7:2]
- hashResult[8:0]= ethernetADD[14:8,1,0] XOR ethernetADD[23:15] XOR ethernetADD[32:24]

#### 12.3.4.4 Hash Mode 1

In Hash mode 1, the Hash entry address is calculated in the following manner:

hashResult[14:0] = hashFunc1(ethernetADD[47:0])

- hashResult is the 15 bits Hash entry address.
- ethernetADD is a 48 bit number, which is derived from the Ethernet MAC address, by nibble swapping in every byte (i.e MAC address of 0x123456789abc translates to ethernetADD of 0x21436587a9cb).
- inverse every nibble; i.e. ethernetADD of 0x21436587a9cb translates to 0x482c6a1e59d

hashFunc1 calculates the hashResult in the following manner:

- hashResult[14:9] = ethernetADD[0:5]
- hashResult[8:0]= ethernetADD[6:14] XOR ethernetADD[15:23] XOR ethernetADD[24:32]

#### 12.3.4.5 Hash Entry

For each Ethernet address, the Hash table entry address is the lower 13 bits of the hashResult for the 8KByte address table, or the lower 9 bits for the 0.5KByte address table. The entry is an offset from the address base and is octet-byte aligned. The address entry is therefore:

- 8K Address Table: tblEntryAdd = EHTP + {hashResult[14:0],000}
- 1/2K Address Table:tblEntryAdd = EHTP + {hashResult[10:0],000}

#### 12.3.4.6 Hash Table Numbers

#### 12.3.4.7 Table Filling

When preparing the Hash table data structure, the CPU must first (typically at boot time) initialize the Hash table memory to '0'.

The table filling algorithm is described below. The hopNumber should be selected and initialized before entering this routine. The Hash table hopNumber (Number of Hops) is 12. After 12 tries to identify an address, the GT-96100A passes the address to the CPU and sets the HE (Hash Expired) bit in the descriptor status field. Therefore, the hopNumber is the number of times the CPU will attempt to write a newly learned Ethernet address into the Hash table.



- Calculate tblEntryAdd according to mode of operation (Hash Mode 1 or Hash Mode 0).
- Check that tblEntry is empty (Valid Bit is "0").
- If the tblEntry is empty, Write the hashEntry (Valid, Skip and RD bits and Ethernet Address).
- If the tblEntry is occupied (i.e. Valid bit is 1 and Skip bit is 0), move to tblEntry+1.
- If less than hopNumber tries, Repeat to Step c.

If after hopNumber failed tries, the CPU has been unable to located a free table entry. The CPU can then:

- Defragment the table.
- Create a new Hash table using the alternate Hash Mode, which may redistribute the addresses more evenly in the table.

In cases where more than one address is mapped to the same table entry, an address chain is created. In this case, when the CPU needs to erase an address that is part of an address chain, it cannot clear its Valid bit since this would cut the chain. Instead, the CPU should set the Skip bit to '1'. This is shown in Table 45.

#### Figure 45: Address Chain



In case A where Add1-6 has the same Hash function, and thus start with the same tblEntry, the CPU allocates them in the table by increasing tblEntry by one entry each time. Add1 is the first address to be written into the table and Add6 is the last.

When the CPU is required to remove Add2 from the table, it cannot clear its valid bit since that would break the chain from Add1 to Add3. Instead, it sets Add2's Skip bit to '1' (denoted as ). It is also recommended that the CPU defragments the table from time to time.

#### 12.3.4.8 Address Recognition Process

The following terms are used when referring to the address recognition process.

- Match Address is found in the table
- Miss Address is not found in the table
- **Hit** Address is in the table and RD bit is 1 (receive), or address is not in table and HDM (Hash Default Mode) is 1 (receive).
- Occupied Entry A valid Hash table entry that is occupied by another address, or an entry that has its Skip bit set,
- **Promiscuous Mode** When enabled, all packets are passed to the CPU. The GT-96100A still executes the Hash process reporting to the CPU, regardless whether the address is in the Hash table or not.

The GT-96100A address recognition process is described below, and is illustrated by Figure 46 on page 274.

The process starts with the GT-96100A fetching the address from the calculated table entry.



- If Occupied Entry is encountered, the GT-96100A proceeds to the next Hash table entry.
- After hopNumber failed tries, the GT-96100A passes the packet to the CPU and marks it by setting the HE bit in the descriptor. The same process is used in case the Discard Window is over, or the frame ends before the GT-96100A accomplishes the Hash process (which happens in rare situations when the GT-96100A cannot gain enough access to the DRAM).
- When the GT-96100A finds the address in the table there is a Match.
- When the GT-96100A encounters an empty entry, there is a Miss, meaning that the address is not in the table.
- In case of a Match, and if the RD bit is set, then there is a Hit. The GT-96100A marks the packet by setting the M bit of the receive descriptor.
- In case of a Miss, and if the HDM bit is set, then there is also a Hit. The GT-96100A marks the packet by setting the M bit of the receive descriptor.
- If there was no Hit, then the packet should be discarded. However, packets will pass if Promiscuous Mode is enabled.



Figure 46: Address Filtering Process





The GT-96100A uses the HE (Hash Expired) and M (Match) bits in the descriptor for reporting the packet filtering status. Table 282 describes the various reports and summarizes their meaning.

| HE | м | Condition                                                                                                                                                              |
|----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0  | 0 | Hash Table No Hit<br>The address was not found in the Hash table, but Promiscuous Mode is<br>enabled                                                                   |
| 0  | 1 | Hash Table Hit<br>Either by an address found in the Hash table and RD bit set<br>OR by an address that was not found in the Hash table, in case that<br>HDM bit is set |
| 1  | 0 | Hash Table Expired<br>The hopNumber expired before the address was found in the Hash table                                                                             |
| 1  | 1 | UnUsed                                                                                                                                                                 |

Table 282: Packet Filtering Status

# 12.4 Ethernet Port

#### 12.4.1 Network Interface

The Ethernet port interfaces directly to a MII (Media Independent Interface) PHY compliant with the IEEE standard (please refer to IEEE 802.3u Fast Ethernet standard for detailed interface and timing information). The MII port has the following characteristics:

- Capable of supporting both 10 Mbps and 100 Mbps data rates in half or full duplex modes.
- Data and delimiters are synchronous to clock references.
- Provides independent 4-bit wide transmit and receive paths.
- Uses TTL signal levels.
- Provides a simple management interface (common to all ports).
- Capable of driving a limited length of shielded cable.

The port incorporates all the required digital circuitry to interface with a 100BaseTX, 100BaseT4, and 100BaseFX MII PHYs.

## 12.4.1.1 10/100 MII/RMII Compatible Interface

The port's MAC (Media Access Control) logic supports connection to a 10Mbps or 100Mbps network.

The MII interface consists of a separate nibble-wide stream for both transmit and receive data. Data transfers are clocked by the 25 MHz transmit and receive clocks in 100 Mbps operation, or by 2.5 MHz transmit and receive clocks in 10 Mbps operation. The clock inputs are driven by the PHY, which controls the clock rate according to the network connection speed.

The RMII interface consists of a separate 2bit-wide stream for both transmit and receive data. Data transfers are clocked by the 50 MHz clock in both 100 Mbps and 10 Mbps operation. The clock input is driven by an external source.



#### 12.4.1.2 Media Access Control (MAC)

The MAC logic performs all of the functions of the 802.3 protocol such as frame formatting, frame stripping, collision handling, deferral to link traffic, etc. It also ensures that any outgoing packet complies with the 802.3 specification in terms of preamble structure - 56 preamble bits are transmitted before Start of Frame Delimiter (SFD).

The MAC operates in half duplex or full duplex modes. In half duplex mode, the MAC's transmit logic checks that there is no competitor for the network media before transmission.

In addition to waiting for idle before transmitting, the port handles collisions in a predetermined way. If two nodes attempt to transmit at the same time, the signals collide and the data on the line is garbled. The port listens while it is transmitting, and can detect a collision. If a collision is detected, 'JAM' pattern is transmitted and retransmission is delayed for a random time period determined by the Backoff algorithm. In full-duplex mode, the port transmits unconditionally.

#### 12.4.1.3 Auto-Negotiation for Duplex Mode

The port's duplex operation mode (either half or full duplex) can be auto-negotiated or set by the CPU.

In order to enable auto-negotiation for duplex, the CPU must set the Port\_Configuration\_Extend<DPLXen> bit. When auto-negotiation for duplex is enabled, the port decodes the duplex mode from the values of the PHY's Auto-Negotiation Advertisement register and Auto-Negotiation Link Partner Ability register at the end of the Auto-Negotiation process. Once the duplex mode is resolved, Port\_Status<Duplex> bit is updated accordingly.

In order to resolve the duplex mode, the following operations are continuously performed:

- 1. Read the PHY's Auto-Negotiation Complete status as reported by the PHY bit 1.5 (Register 1, bit 5). If this bit is '0' switch to Half-Duplex mode and continue to read PHY register bit 1.5. Continue to step 2 when PHY bit 1.5 is '1', indicating that Auto-Negotiation is complete.
- **NOTE:** Steps 2 through 6 are performed once for every transition of PHY bit 1.5 from '0' to '1'. Once PHY bit 1.5 remains '1' and PHY registers 4 and 5 have already been read, the port will continue to read PHY register 1, and monitor PHY bit 1.5. However, if after Rst\* deassertion, the PHY bit 1.5 is already read as '1', steps 2 to 6 are performed at least once in order to update the port's duplex mode.

PHY bit 1.2 (Link Status) is read and latched during this same register read operation, regardless of the Auto-Negotiation status.

- 2. Read the Auto-Negotiation Advertisement register, PHY register 4. Continue to step 3.
- 3. Read the Auto-Negotiation Link Partner Ability register, PHY register 5. Continue to step 4.
- 4. Resolve the highest common ability of the two link partners in the following manner (according to the 802.3u Priority Resolution clause 28B.3):

if (bit 4.8 AND bit 5.8) == '1' then ability is 100BASE-TX Full Duplex

else if (bit 4.9 AND bit 5.9) == '1' then ability is 100BASE-T4 Half Duplex

else if (bit 4.7 AND bit 5.7) == '1' then ability is 100BASE-TX Half Duplex

else if (bit 4.6 AND bit 5.6) == '1' then ability is 10BASE-T Full Duplex

else ability is 10BASE-T Half Duplex;

Continue to step 5.



5. Resolve the duplex mode of the two link partners in the following manner:

```
if ((ability == "100BASE-TX Full Duplex") or (ability == "10BASE-T Full Duplex")) then
duplex mode = FULL DUPLEX
else
duplex mode = HALF DUPLEX;
```

Continue to step 6.

6. Update the Port\_Status register by writing the correct duplex mode bit. Continue with step 1.

#### 12.4.1.4 Auto-Negotiation for Flow Control

Flow control mode (either enabled or disabled) can be auto-negotiated or set by the CPU. In order to enable auto-negotiation for flow-control, the CPU should set Port\_Configuration\_Extend<FCTLen> bit.

If Port\_Configuration\_Extend<FCTLen>=1, then auto-negotiation is initiated in the following cases:

- After RESET.
- After link fail (phy register 1 bit 2).
- **NOTE:** The user may force the port to implement Flow-control by disabling auto-negotiation for flow-control and programming Port\_Configuration\_Extend<FCTL>=1.

Auto-negotiation for flow-control is done in two stages:

- Setting Phy advertise word to support Flow Control. This is done by writing Phy register 4 in order to set advertise bit 10 (phy-reg4 bit 10 - Enable FC). The flow of such a cycle is:
  - Read Phy register 1. If link\_status=1 and was 0 in the last cycle continue.
  - Read Phy register 4.
  - Write Phy register 4 with bit 10 set.
- 2. Reading Phy Flow-Control status and determine result. This is done by constantly reading PHY's register 4 and register 5 in order to determine if Flow-control is supported or not. Only if both link partners support FC (registers 4.10 and 5.10 are both SET), Port\_Status<FCTL> is set to '1', and the port will send PAUSE packets when instructed to do so by the CPU. Otherwise, Port\_Status<FCTL> is set to '0', indicating that the support for 802.3x flow-control is

#### 12.4.1.5 Backoff Algorithm Options

disabled.

The port implements the truncated exponential Backoff algorithm defined by the 802.3 standard. Aggressiveness of the Backoff algorithm used is controlled by Serial Parameters Register<Limit4> bit.

Limit4 function controls the number of consecutive packet collisions that will occur before the collision counter is reset.

When Limit4 feature is disabled, the port resets its collision counter after 16 consecutive retransmit trials and restarts the Backoff algorithm. Retransmission is done using the data already stored in the FIFO.

When Limit4 feature is enabled, the port will reset its collision counter and restart the Backoff algorithm after 4 consecutive transmit trials. This makes the port more aggressive in getting hold of the media following a collision. This may result better overall throughput in standardized tests.



# 12.4.1.6 Data Blinder

The data blinder field (DataBlind in the Serial\_Parameters register) sets the period of time during which the port does not sense the wire before transmission (inhibit time). The default value is 32 bit times.

# 12.4.1.7 Inter Packet Gap (IPG)

IPG is the minimum idle time between transmission of any two successive packets from the same port. The default (from the standard) is 9.6uS for 10Mbps Ethernet and 960nsec for 100-Mbps Fast Ethernet. Note that the IPG can be made smaller or larger than standard definition by programming the Serial\_Parameters register.

## 12.4.1.8 10/100 Mbps MII Transmission

When the port has a frame ready for transmission, it samples link activity indicators. If the CrS signal is inactive (no activity on the link), and the Inter-packet gap (IPG) timer had expired, frame transmission begins. The data is transmitted via pins TxD[3:0] of the transmitting port, clocked on the rising edge of TxClk. The signal TxEn is asserted at this same time. In the case of collision, the PHY asserts the CoL signal causing the port to stop transmitting the frame and append a jam pattern to the transmitted bit stream. At the end of a collided transmission, the port will back off and attempt to retransmit once the Backoff counter expires. Per the IEEE 802.3 specification, the clock to output delay must be a minimum of 0ns and a maximum of 25ns as shown in Figure 48.

## 12.4.1.9 10/100 Mbps RMII Transmission

The port starts transmission when it has a frame ready, and Inter-packet gap (IPG) timer has expired.

If in half\_duplex mode, it also samples CRS\_DV indicator for no activity. The data is transmitted via pins TXD[1:0] of the transmitting port, clocked on the rising edge of REF\_CLK and the signal TX\_EN is asserted.

In half\_duplex mode, in the case of collision (TX\_EN asserted with CRS\_DV), the port stops transmitting the frame and appends a jam pattern to the transmitted bit stream. At the end of a collided transmission, the port backs off and attempts to retransmit once the Backoff counter expires. As the REF\_CLK frequency is 10 times the data rate in 10 Mbps, the value on TXD[1:0] shall be valid so that it may be sampled every 10th cycle. For the RMII, transmission of each octet shall be done a di-bit at a time as per the order described in the Figure 47.

## 12.4.1.10 10/100 Mbps RMII Reception

Frame reception starts with the assertion of CRS\_DV by the PHY. The port begins sampling incoming data on pins RxD[1:0] on the rising edge of REF\_CLK. Reception ends when CRS\_DV is deasserted by the PHY. The last di-bit sampled by the port is the data present on RxD[1:0] on the last REF\_CLK rising edge in which CRS\_DV is still asserted. CRS\_DV is continuously asserted during reception. If an error is detected while CRS\_DV is asserted, the decoded data is replaced in the receiving stream with "01" until the end of carrier activity. By replacing the data in the remainder of the frame, the CRC check is guaranteed to reject the packet as an error. When no reception takes place, CRS\_DV should remain de-asserted. As the REF\_CLK frequency is 10 times the data rate in 10 Mbps, the value of each octet shall be valid so that it may be sampled every 10th cycle. For the RMII, reception of each octet shall be done a di-bit at a time as per the order described in Figure 47.



The RMII transmission and reception of each octet is described in Figure 47.

#### Figure 47: RMII Di-Bit Stream



#### Figure 48: MII Transmit Signal Timing



## 12.4.1.11 10/100 Mbps MII Reception

Frame reception starts with the assertion of CrS (while the port is not transmitting) by the PHY.

Once RxDV is asserted, the port begins sampling incoming data on pins RxD[3:0] on the rising edge of RxClk. Reception ends when RxDV is deasserted by the PHY. The last nibble sampled by the port is the nibble present on RxD[3:0] on the last RxClk rising edge in which RxDV is still asserted. During reception RxDV is continuously asserted. If, while RxDV is asserted, RxEr is asserted, it designates current packet as corrupted. When no reception takes place, RxDV should remain deasserted. The input setup time should be a minimum of 10ns and the input hold time must be a minimum of 10ns and shown in Figure 49.



Figure 49: MII Receive Signal Timing



## 12.4.1.12 10/100 Mbps Full-Duplex Operation

When operating in Full-duplex mode the port can transmit and receive frames simultaneously.

In full-duplex mode, the CrS signal is associated with received frames only and has no effect on transmitted frames. The Col signal is ignored while in Full-duplex mode. Transmission starts when TxEn goes active. Transmission starts regardless of the state of CrS. Reception starts when the CrS signal is asserted indicating traffic on the receive port of the PHY.

#### 12.4.1.13 Back Pressure

The port implements a back pressure algorithm, which is only for use when the port is operating in half duplex mode. It is enabled through Port\_Command<FJ> bit.

While in backpressure mode, the port transmits a JAM pattern for a programmable period of time (JAM\_LENGTH). The IPG between two consecutive JAM patterns (or between the last transmit and the first JAM) is also a programmable value (JAM\_IPG). The values are set in Serial\_Parameters register.

#### 12.4.1.14 Flow Control

IEEE 802.3x flow control is enabled while in full-duplex mode. Activating this mode is done by setting the Port\_Configuration\_Extend<FCTL> bit or by enabling auto-negotiation for Flow-Control, see Section 12.4.1.4 "Auto-Negotiation for Flow Control" on page 277.

The port supports 802.3x flow-control (PAUSE packets, in the standard term), if it is operating in full-duplex and if Port\_Configuration\_Extend<FCTL>=1.

When the port receives a PAUSE packet, it does not transmit a new packet for a period of time specified in this PAUSE packet.

A received packet is recognized as flow control PAUSE, if it was received without errors and is either of the following:

- DA = 01-80-C2-00-00-01 and type=88-08 and MAC\_Control\_Opcode=01
- DA = (The port address) and type=88-08 and MAC\_Control\_Opcode=01. The 48-bit port address is in the registers Source\_Address\_Low, Source\_Address\_High. This address is also used as source address for PAUSE packets that the port generates (to DA=01-80-C2-00-00-01)

PAUSE packets are sent by the port when instructed to do so by the CPU. This is done by setting Port\_Command<FJ> bit.



# 12.4.2 MII Serial Management Interface (SMI)

The Ethernet unit has an integrated MII Serial Management Interface (SMI) logic for controlling MII compliant PHYs. This interface consists of two signals: serial data (MDIO); and, clock (MDC).

These signals enable control and status parameters to be passed between the PHYs and the port logic (or CPU). Multiple PHY devices can be controlled using this simple 2-pin interface.

Typically, the SMI unit continuously queries the PHY devices for their link status, without the need for CPU intervention. The PHY addresses for the link query operation are programmable per port in the PHY\_Address register.

A CPU can write/read to/from all PHY addresses/registers by writing and reading to/from the SMI control register. The SMI allows the CPU to directly control a MII compatible PHY device via the SMI control register. This enables the driver software to program the PHY into specific operation mode such as Full Duplex, Loopback, Power Down, 10/100 speed selection as well as control of the PHY device's Auto-Negotiation function, if it exists. The CPU writes commands to the SMI register and the SMI unit performs the actual data transfer via MDIO, which is a bi-directional data pin. These serial data transfers are clocked by the MDC clock output.

#### 12.4.2.1 MII Management Frame Structure

The GT-96100A's SMI cycles support the MII management frame structure.

Frames transmitted on the MII management interface have a structure that is shown in Table 283 and the order of bit transmission is from left to right.

|       | PRE | ST | ОР | PhyAd | RegAd | ТА | Data   | IDLE |
|-------|-----|----|----|-------|-------|----|--------|------|
| READ  | 11  | 01 | 10 | AAAAA | RRRRR | Z0 | DD(16) | Z    |
| WRITE | 11  | 01 | 01 | AAAAA | RRRRR | 10 | DD(16) | Z    |

#### Table 283: MII Management Frame Format

The format of the bit transmission's parts is as follows:

#### Table 284: Bit Transmission Parts

| Part                     | Description                                                                                                                                                                                                                                           |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRE (Preamble)           | At the beginning of each transaction, the port sends a sequence of 32 contiguous logic one bits on MDIO with 32 corresponding cycles on MDC to provide the PHY with a pattern that it can use to establish synchronization.                           |
| ST (Start of Frame)      | A Start of Frame pattern of 01.                                                                                                                                                                                                                       |
| OP (Operation Code)      | 10 - Read; 01 - Write.                                                                                                                                                                                                                                |
| PhyAd (PHY Address)      | A 5 bit address of the PHY device (32 possible addresses). The first PHY address bit transmitted by the port is the MSB of the address.                                                                                                               |
| RegAd (Register Address) | A 5 bit address of the PHY register (32 possible registers in each PHY). The first register address bit transmitted by the port is the MSB of the address. The port always queries the PHY device for status of the link by reading register 1 bit 2. |

| Part             | Description                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TA (Turn Around) | The turnaround time is a 2 bit time spacing between the Register Address field<br>and the Data field of the SMI frame to avoid contention during a read transac-<br>tion. During a Read transaction the PHY should not drive MDIO in the first bit<br>time and drive '0' in the second bit time. During a write transaction, the port<br>drives a '10' pattern to fill the TA time. |
| Data (Data)      | The data field is 16 bits long. The PHY drives the data field during Read trans-<br>actions. The port drives the data field during write transactions. The first data<br>bit transmitted and received shall be bit 15 of the PHY register being accessed.                                                                                                                           |
| IDLE (Idle)      | The IDLE condition on MDIO is a high impedance state. The MDIO driver is disabled and the PHY should pull-up the MDIO line to a logic one.                                                                                                                                                                                                                                          |

#### Table 284: Bit Transmission Parts

# 12.4.3 SMI Timing Requirements

When the MDIO signal is driven by the PHY, it is sampled synchronously with respect to the rising edge of MDC. Per IEEE 802.3 specification, the MDC to output delay must be a minimum of 0ns and a maximum of 300ns as shown in Figure 10. Further, when the MDIO signal is driven by the port, it has a minimum of 10ns setup time and minimum of 10ns hold time as shown in Figure 50 and Figure 51.

#### Figure 50: MDIO Output Delay



Figure 51: MDIO Setup and Hold Time





## 12.4.3.1 Link Detection and Link Detection Bypass (ForceLinkPass)

Typically, the port continuously queries the PHY devices for their link status without CPU intervention.

The PHY addresses used for the link query are determined by the PHY\_Address register and are programmable for each port. The port alternately reads register 1 from the PHYs and updates the internal link bits according to the value of bit 2 of register 1. In the case of "link down" (i.e. bit 2 is '0'), that port will enter link test fail state.

In this state, all of the port's logic is reset. The port exits from link test fail state only when the "link is up" (i.e. bit 2 of register 1 is read from the port's PHY as '1').

There is an option to disable the link detection mechanism by forcing the link state of a specific port. This is done by setting Port\_Configuration\_Extend<FLP> bit.

# 12.5 Internal Control Registers

| Description                                                                      | Offset   | Page Numbers |
|----------------------------------------------------------------------------------|----------|--------------|
| Ethernet PHY Address Register (EPAR)                                             | 0x080800 | page 285     |
| Ethernet SMI Register (ESMIR)                                                    | 0x080810 | page 286     |
| Ethernet0                                                                        |          |              |
| Ethernet0 Port Configuration Register (E0PCR)                                    | 0x084800 | page 286     |
| Ethernet0 Port Configuration Extend Register (E0PCXR)                            | 0x084808 | page 288     |
| Ethernet0 Port Command Register (E0PCMR)                                         | 0x084810 | page 291     |
| Ethernet0 Port Status Register (E0PSR)                                           | 0x084818 | page 291     |
| Ethernet0 Serial Parameters Register (E0SPR)                                     | 0x084820 | page 292     |
| Ethernet0 Hash Table Pointer Register (E0HTPR)                                   | 0x084828 | page 293     |
| Ethernet0 Flow Control Source Address Low (E0FCSAL)                              | 0x084830 | page 293     |
| Ethernet0 Flow Control Source Address High (E0FCSAH)                             | 0x084838 | page 294     |
| Ethernet0 SDMA Configuration Register (E0SDCR)                                   | 0x084840 | page 294     |
| Ethernet0 SDMA Command Register (E0SDCMR)                                        | 0x084848 | page 295     |
| Ethernet0 Interrupt Cause Register (E1ICR)                                       | 0x084850 | page 296     |
| Ethernet0 Interrupt Mask Register (E0IMR)                                        | 0x084858 | page 299     |
| Ethernet0 IP Differentiated Services CodePoint to Priority0<br>low (E0DSCP2P0L)  | 0x84860  | page 299     |
| Ethernet0 IP Differentiated Services CodePoint to Priority0<br>high (E0DSCP2P0H) | 0x84864  | page 299     |

#### Table 285: Ethernet Unit Register Map



#### Table 285: Ethernet Unit Register Map (Continued)

| Description                                                                     | Offset                 | Page Numbers |
|---------------------------------------------------------------------------------|------------------------|--------------|
| Ethernet0 (Continued)                                                           |                        |              |
| Ethernet0 IP Differentiated Services CodePoint to Priority1<br>low (E0DSCP2P1L) | 0x84868                | page 299     |
| Ethernet0 IP Differentiated Services CodePoint to Priority1 high (E0DSCP2P1H)   | 0x8486c                | page 299     |
| Ethernet0 VLAN Priority Tag to Priority (E0VPT2P)                               | 0x84870                | page 299     |
| Ethernet0 First Rx Descriptor Pointer 0 (E0FRDP0)                               | 0x084880               | page 263     |
| Ethernet0 First Rx Descriptor Pointer 1 (E0FRDP1)                               | 0x084884               |              |
| Ethernet0 First Rx Descriptor Pointer 2 (E0FRDP2)                               | 0x084888               |              |
| Ethernet0 First Rx Descriptor Pointer 3 (E0FRDP3)                               | 0x08488C               |              |
| Ethernet0 Current Rx Descriptor Pointer 0 (E0CRDP0)                             | 0x0848A0               |              |
| Ethernet0 Current Rx Descriptor Pointer 1 (E0CRDP1)                             | 0x0848A4               |              |
| Ethernet0 Current Rx Descriptor Pointer 2 (E0CRDP2)                             | 0x0848A8               |              |
| Ethernet0 Current Rx Descriptor Pointer 3 (E0CRDP3)                             | 0x0848AC               |              |
| Ethernet0 Current Tx Descriptor Pointer 0 (E0CTDP0)                             | 0x0848E0               | page 255     |
| Ethernet0 Current Tx Descriptor Pointer 1 (E0CTDP1)                             | 0x0848E4               |              |
| Ethernet0 MIB Counters                                                          | 0x085800 -<br>0x0858FF | page 302     |
| Ethernet1                                                                       |                        |              |
| Ethernet1 Port Configuration Register (E1PCR)                                   | 0x088800               | page 286     |
| Ethernet1 Port Configuration Extend Register (E1PCXR)                           | 0x088808               | page 288     |
| Ethernet1 Port Command Register (E1PCMR)                                        | 0x088810               | page 291     |
| Ethernet1 Port Status Register (E1PSR)                                          | 0x088818               | page 291     |
| Ethernet1 Serial Parameters Register (E1SPR)                                    | 0x088820               | page 292     |
| Ethernet1 Hash Table Pointer Register (E1HTPR)                                  | 0x088828               | page 293     |
| Ethernet1 Flow Control Source Address Low (E1FCSAL)                             | 0x088830               | page 293     |
| Ethernet1 Flow Control Source Address High (E1FCSAH)                            | 0x088838               | page 294     |
| Ethernet1 SDMA Configuration Register (E1SDCR)                                  | 0x088840               | page 294     |
| Ethernet1 SDMA Command Register (E1SDCMR)                                       | 0x088848               | page 295     |
| Ethernet1 Interrupt Cause Register (E1ICR)                                      | 0x088850               | page 296     |
| Ethernet1 Interrupt Mask Register (E1IMR)                                       | 0x088858               | page 299     |





| Description                                                                     | Offset                 | Page Numbers |  |  |  |  |  |
|---------------------------------------------------------------------------------|------------------------|--------------|--|--|--|--|--|
| Ethernet1 (Continued)                                                           |                        |              |  |  |  |  |  |
| Ethernet IP Differentiated Services CodePoint to Priority0 low (E0DSCP2P0L)     | 0x88860                | page 299     |  |  |  |  |  |
| Ethernet IP Differentiated Services CodePoint to Priority0<br>high (E0DSCP2P0H) | 0x88864                | page 299     |  |  |  |  |  |
| Ethernet IP Differentiated Services CodePoint to Priority0 low (E0DSCP2P1L)     | 0x88868                | page 299     |  |  |  |  |  |
| Ethernet IP Differentiated Services CodePoint to Priority0<br>high (E0DSCP2P1H) | 0x8886c                | page 299     |  |  |  |  |  |
| Ethernet1 VLAN Priority Tag to Priority (E0VPT2P)                               | 0x88870                | page 299     |  |  |  |  |  |
| Ethernet1 First Rx Descriptor Pointer 0 (E1FRDP0)                               | 0x088880               | page 264     |  |  |  |  |  |
| Ethernet1 First Rx Descriptor Pointer 1 (E1FRDP1)                               | 0x088884               | page 266     |  |  |  |  |  |
| Ethernet1 First Rx Descriptor Pointer 2 (E1FRDP2)                               | 0x088888               | page 266     |  |  |  |  |  |
| Ethernet1 First Rx Descriptor Pointer 3 (E1FRDP3)                               | 0x08888C               | page 266     |  |  |  |  |  |
| Ethernet1 Current Rx Descriptor Pointer 0 (E1CRDP0)                             | 0x0888A0               |              |  |  |  |  |  |
| Ethernet1 Current Rx Descriptor Pointer 1 (E1CRDP1)                             | 0x0888A4               |              |  |  |  |  |  |
| Ethernet1 Current Rx Descriptor Pointer 2 (E1CRDP2)                             | 0x0888A8               |              |  |  |  |  |  |
| Ethernet1 Current Rx Descriptor Pointer 3 (E1CRDP3)                             | 0x0888AC               |              |  |  |  |  |  |
| Ethernet1 Current Tx Descriptor Pointer 0 (E1CTDP0)                             | 0x0888E0               | page 260     |  |  |  |  |  |
| Ethernet1 Current Tx Descriptor Pointer 1 (E1CTDP1)                             | 0x0888E4               | page 261     |  |  |  |  |  |
| Ethernet1 MIB Counters                                                          | 0x089800 -<br>0x0898FF | page 302     |  |  |  |  |  |

# Table 286: PHY Address Register, Offset: 0x080800

| Bits | Field Name | Function                       | Initial Value |
|------|------------|--------------------------------|---------------|
| 4:0  | PhyAD0     | PHY device address for port 0. | 00100         |
| 9:5  | PhyAD1     | PHY device address for port 1. | 00101         |

| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 15:0  | Data       | <ul> <li>SMI READ operation<br/>Two transactions are required: (1) write to the SMI<br/>register with OpCode = 1, PhyAd, RegAd with the<br/>Data being any value; (2) read from the SMI regis-<br/>ter. When reading back the SMI register, the Data is<br/>the addressed Phy register contents if the Read-<br/>Valid bit (#27) is 1. The Data remains undefined as<br/>long as ReadValid is 0.</li> <li>SMI WRITE operation<br/>One transaction is required. Write to the SMI regis-<br/>ter with OpCode = 0, PhyAd, RegAd with the Data<br/>to be written to the addressed Phy register.</li> </ul> | 0             |
| 20:16 | PhyAd      | PHY Device Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0             |
| 25:21 | RegAd      | PHY Device Register Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0             |
| 26    | OpCode     | 0 - Write<br>1 - Read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1             |
| 27    | ReadValid  | 1 - indicates that the Read operation has been completed for<br>the addressed RegAd register, and the data is valid on the<br>Data field.                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0             |
| 28    | Busy       | 1 - indicates that an operation is in progress and that CPU must not write to the SMI register at this time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0             |
| 31:29 | N/A        | These bits must be written as 0 for any write to the SMI reg-<br>ister.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0             |

#### Table 287: SMI Register (SMIR), Offset: 0x080810

# Table 288: Port Configuration Register (PCR), Offset: 0x084800 for Ethernet\_0; 0x088800 for Ethernet\_1

| Bits | Field Name | Function                                                                                                                                                                                                                                                    | Initial Value |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | РМ         | Promiscuous mode<br>0 - Normal mode. Frames are received only if destination<br>address is found in hash table.<br>1 - Promiscuous mode. Frames are received regardless of<br>their destination address. Errored frames are discarded<br>unless PBF is set. | 0             |



| Bits | Field Name | Function                                                                                                                                                                                                                                                                                                    | Initial Value |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1    | RBM        | Reject Broadcast Mode<br>0 - Receive Broadcast address.<br>1 - Reject Frames with broadcast address. Overridden by<br>promiscuous mode.                                                                                                                                                                     | 0             |
| 2    | PBF        | Pass Bad Frames<br>0 - Normal mode.<br>1 - Pass bad Frames. The Ethernet receiver will pass to CPU<br>errored frames, which are normally rejected, like fragments<br>and collided packets. Frames are passed only if they pass<br>address filtering successfully.                                           | 0             |
| 6:3  | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                   | 0             |
| 7    | EN         | Enable<br>0 - Disabled.<br>1 - Enable. Ethernet port is ready to transmit/receive.                                                                                                                                                                                                                          | 0             |
| 9:8  | LPBK       | Loop Back Mode<br>00 - Normal mode.<br>01 - Internal Loopback mode. TX data is looped back to the<br>RX lines. No transition is seen on the interface pins.<br>10 - External Loopback mode. TX data is looped back to the<br>RX lines and also transmitted out to the MII interface pins.<br>11 - Reserved. | 0             |
| 10   | FC         | Force Collision<br>0 - Normal mode.<br>1 - Force Collision on any TX frame. For RXM test (in Loop-<br>back mode).                                                                                                                                                                                           | 0             |
| 11   |            | Reserved.                                                                                                                                                                                                                                                                                                   | 0             |
| 12   | HS         | Hash Size<br>0 - 8K address filtering (256KB of memory space required).<br>1 - 1/2K address filtering (16KB of memory space required).                                                                                                                                                                      | 0             |
| 13   | НМ         | Hash Mode<br>0 - Hash Function 0.<br>1 - Hash Function 1.                                                                                                                                                                                                                                                   | 0             |
| 14   | HDM        | Hash Default Mode<br>0 - Discard addresses <b>not found</b> in address table.<br>1 - Pass addresses <b>not found</b> in address table.                                                                                                                                                                      | 0             |

| Table 288: Port Configuration Register (PCR),                        |
|----------------------------------------------------------------------|
| Offset: 0x084800 for Ethernet_0; 0x088800 for Ethernet_1 (Continued) |

#### Bits **Field Name** Function **Initial Value** 15 HD 0 Duplex Mode 0 - Half Duplex. 1 - Full Duplex. NOTE: Valid only when Auto-Negotiation for duplex mode is disabled. 27:16 Reserved 30:28 0x6 ISL Enabled 0x0 ISL Disabled NOTE: When ISL is enabled, bit 31 must set to 0. 0 31 ACCS Accelerate Slot Time 0 - Normal mode. 1 - Reserved.

#### Table 288: Port Configuration Register (PCR), Offset: 0x084800 for Ethernet\_0; 0x088800 for Ethernet\_1 (Continued)

#### Table 289: Port Configuration Extend Register (PCXR), Offset: 0x084808 for Ethernet\_0; 0x088808 for Ethernet\_1

| Bits | Field Name | Function                                                                                                                                                                                                                                                                                                                                                   | Initial Value |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | IGMP       | IGMP packets capture enable.<br>0 - IGMP packets are treated as normal Multicast packets.<br>1 - IGMP packets on IPv4/IPv6 over Ethernet/802.3 are<br>trapped and sent to high priority RX queue.                                                                                                                                                          | 0             |
| 1    | SPAN       | <ul> <li>Spanning Tree packets capture enable.</li> <li>0 - BPDU (Bridge Protocol Data Unit) packets are treated as normal Multicast packets.</li> <li>1 - BPDU packets are trapped and sent to high priority RX queue.</li> </ul>                                                                                                                         | 0             |
| 2    | PAR        | <ul> <li>Partition enable.</li> <li>When more than 61 collisions occur while transmitting, the port enters Partition mode. It waits for the first good packet from the wire, and then goes back to Normal mode. Under Partition mode it continues transmitting, but it does not receive.</li> <li>0 - Normal mode.</li> <li>1 - Partition mode.</li> </ul> | 0             |



| Bits | Field Name          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Initial Value |
|------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 5:3  | PRIOtx              | <ul> <li>Priority weight in the round-robin between high and low priority TX queues:</li> <li>000 - 1 pkt transmitted from HIGH, 1 pkt from LOW.</li> <li>001 - 2 pkt transmitted from HIGH, 1 pkt from LOW.</li> <li>010 - 4 pkt transmitted from HIGH, 1 pkt from LOW.</li> <li>011 - 6 pkt transmitted from HIGH, 1 pkt from LOW.</li> <li>100 - 8 pkt transmitted from HIGH, 1 pkt from LOW.</li> <li>101 - 10 pkt transmitted from HIGH, 1 pkt from LOW.</li> <li>110 - 12 pkt transmitted from HIGH, 1 pkt from LOW.</li> <li>111 - All pkt transmitted from HIGH, 0 pkt from LOW.</li> <li>111 - All pkt transmitted from HIGH, 0 pkt from LOW.</li> <li>111 HIGH queue is emptied before finishing the count, the count will be reset until next first HIGH comes in.</li> </ul> | 0             |
| 7:6  | PRIOrx              | Default priority for packets received on this port:<br>00 - Lowest priority.<br>11 - Highest priority.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0             |
| 8    | PRIOrx_<br>Override | Override priority for packets received on this port:<br>0 - Do not override.<br>1 - Override with <priorx> field.</priorx>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0             |
| 9    | DPLXen              | Enable auto-negotiation for duplex mode:<br>0 - Enable.<br>1 - Disable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0             |
| 10   | FCTLen              | <ul> <li>Enable auto-negotiation for 802.3x flow-control:</li> <li>0 - Enable.</li> <li>NOTE: When enabled, 1 is written (through SMI access) to PHY's register 4 bit 10 to advertise flow-control capability.</li> <li>1 - Disable.</li> <li>NOTE: Only enable flow control after the PHY address is set by the CPU. When changing the PHY address the flow control auto-negotiation must be disabled.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                       | 1             |
| 11   | FLP                 | Force Link Pass<br>0 - Force Link Pass.<br>1 - Do NOT Force Link pass.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1             |
| 12   | FCTL                | <ul> <li>Flow-Control Mode</li> <li>0 - Enable IEEE 802.3x flow-control.</li> <li>1 - Disable IEEE 802.3x flow-control.</li> <li><b>NOTE:</b> Valid only when auto negotiation for flow control is disabled.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0             |
| 13   | Reserved            | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0             |

# Table 289: Port Configuration Extend Register (PCXR), Offset: 0x084808 for Ethernet\_0; 0x088808 for Ethernet\_1 (Continued)

| Bits  | Field Name | Function                                                                                                                                                                                                          | Initial Value |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 15:14 | MFL        | Max Frame Length. Maximum packet allowed for reception<br>(including CRC):<br>00 - 1518 bytes<br>01 - 1536 bytes<br>10 - 2048 bytes<br>11 - 64K bytes                                                             | 0             |
| 16    | MIBcIrMode | MIB counters clear Mode. Setting this bit causes the counters to reset when the CPU performs a counter read operation. In order to reset all MIB counters, the CPU should set this bit and read all the counters. | 0             |
| 17    | MIBctrMode | Reserved.                                                                                                                                                                                                         | 0             |
| 18    | Speed      | Port Speed<br>0 - 10Mbit/Sec.<br>1 - 100Mbit/sec.<br><b>NOTE:</b> Valid only if SpeedEn bit is set.                                                                                                               | 0             |
| 19    | SpeedEn    | Enable Auto-negotiation for Speed<br>0 - Enable.<br>1 - Disable.                                                                                                                                                  | 0             |
| 20    | RMIIen     | RMII enable<br>0-Port MII1 functions as MII port 1<br>1-Port MII1 functions as RMII port 0 and RMII port 1                                                                                                        | 0             |
| 21    | DSCPen     | DSCP enable<br>0-IP DSCP field decoding is disabled<br>1-IP DSCP field decoding is enabled                                                                                                                        | 0             |
| 27:22 | Reserved   | Reserved.                                                                                                                                                                                                         | 0             |
| 31:28 | Test       | These bits must be set to 0 for proper operation of the Ether-<br>net port.                                                                                                                                       | 0             |

# Table 289: Port Configuration Extend Register (PCXR), Offset: 0x084808 for Ethernet\_0; 0x088808 for Ethernet\_1 (Continued)



| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Initial Value |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 14:0  | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0             |
| 15    | FJ         | Force Jam / Flow Control.<br>When in halfduplex, the CPU uses this bit to force collisions<br>on the Ethernet segment. When the CPU recognizes that it<br>is going to run out of receive buffers, it can force the trans-<br>mitter to send jam frames, forcing collisions on the wire. The<br>CPU must clear the FJ bit when more resources are avail-<br>able in order to allow transmission on the Ethernet segment.<br>When in full-duplex and flow-control is enabled, this bit<br>causes the port's transmitter to send flow-control PAUSE<br>packets. The CPU should reset this bit when more resources<br>are available. | 0             |
| 31:16 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0             |

#### Table 290: Port Command Register (PCMR), Offset: 0x084810 for Ethernet\_0; 0x088810 for Ethernet\_1

#### Table 291: Port Status Register (PSR), Offset: 0x084818 for Ethernet\_0; 0x088818 for Ethernet\_1

| Bits | Field Name | Function                                                                                                                    | Initial Value |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | Speed      | Indicates port speed.<br>0 - 10Mbit/s.<br>1 - 100Mbit/s.<br>This bit is read-only.                                          | 0             |
| 1    | Duplex     | Indicates port duplex mode.<br>0 - Half duplex.<br>1 - Full duplex.<br>This bit is read-only.                               | 0             |
| 2    | Fctl       | Indicates Flow-control mode.<br>0 - Flow-control mode enabled.<br>1 - Flow-control mode disabled.<br>This bit is read-only. | 0             |
| 3    | Link       | Indicates link status.<br>0 - Link is down.<br>1 - Link is up.<br>This bit is read-only.                                    | 0             |

| Bits | Field Name | Function                                                                                                                                                                                                                                                                                                                          | Initial Value |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 4    | Pause      | Indicates that the port is in flow-control disabled state. This<br>bit is set when an IEEE 802.3x flow-control PAUSE (XOFF)<br>packet is received (assuming that flow-control is enabled and<br>the port is in full-duplex mode).<br>Reset when XON is received, or when the XOFF timer has<br>expired.<br>This bit is read-only. | 0             |
| 5    | TxLow      | <ul> <li>Tx Low priority status. Indicates the status of the low priority transmit queue:</li> <li>0 - Stopped.</li> <li>1 - Running.</li> <li>This bit is read-only.</li> </ul>                                                                                                                                                  | 0             |
| 6    | TxHigh     | <ul><li>Tx High priority status. Indicates the status of the high priority transmit queue:</li><li>0 - Stopped.</li><li>1 - Running.</li><li>This bit is read-only.</li></ul>                                                                                                                                                     | 0             |
| 7    | TXinProg   | TX in Progress. Indicates that the port's transmitter is in an active transmission state.<br>This bit is read-only.                                                                                                                                                                                                               | 0             |
| 31:8 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                         | 0             |

#### Table 291: Port Status Register (PSR), Offset: 0x084818 for Ethernet\_0; 0x088818 for Ethernet\_1 (Continued)

#### Table 292: Serial Parameters Register (SPR), Offset: 0x084820 for Ethernet\_0; 0x088820 for Ethernet\_1

| Bits | Field Name          | Function                                                                                                                                                          | Initial Value          |
|------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| 1:0  | JAM_LENGTH          | Two bits to determine the JAM Length (in Backpressure) as<br>follows:<br>00 = 12K bit-times.<br>01 = 24K bit-times.<br>10 = 32K bit-times.<br>11 = 48K bit-times. | 11 (48K bit time)      |
| 6:2  | JAM_IPG             | Five bits to determine the JAM IPG. The step is four bit-times.<br>The JAM IPG varies between 4 bit time to 124.                                                  | 01000 (32 bit<br>time) |
| 11:7 | IPG_JAM_TO_<br>DATA | Five bits to determine the IPG JAM to DATA. The step is four bit-times. The value may vary between 4 bit time to 124.                                             | 10000 (64 bit<br>time) |



| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Initial Value          |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| 16:12 | IPG_DATA   | Inter-Packet Gap (IPG): The step is 4 bit-times. The value<br>may vary between 12 bit time to 124.<br><b>NOTE:</b> These bits may be changed only when all Ethernet<br>port is disabled.                                                                                                                                                                                                                                                                                                                                                                               | 11000 (96 bit<br>time) |
| 21:17 | Data_Blind | Data Blinder<br>The number of nibbles from the beginning of the IPG, in<br>which the IPG counter is restarted when detecting a carrier<br>activity. Following this value, the port enters the Data Blinder<br>zone and does not reset the IPG counter. This ensures fair<br>access to the medium.<br>Value should be written in hexadecimal format.<br>The default is 0x19 (64 bit time -2/3 of the default IPG). The<br>step is 4bit (nibble) time. Valid range is 0xc to 0x1f.<br><b>NOTE:</b> These bits may be changed only when the Ethernet<br>port is disabled. | 11001 (64 bit<br>time) |
| 22    | Limit4     | The number of consecutive packet collisions that will occur<br>before the collision counter is reset.<br>0- The port resets its collision counter after 16 consecutive<br>retransmit trials and restarts the Backoff algorithm.<br>1- The port will reset its collision counter and restart the<br>Backoff algorithm after 4 consecutive transmit trials.                                                                                                                                                                                                              | 0                      |
| 31:23 | Reserved   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                      |

#### Table 292: Serial Parameters Register (SPR), Offset: 0x084820 for Ethernet\_0; 0x088820 for Ethernet\_1 (Continued)

#### Table 293: Hash Table Pointer Register (HTPR), Offset: 0x084828 for Ethernet\_0; 0x088828 for Ethernet\_1

| Bits | Field Name | Function                                                             | Initial Value |
|------|------------|----------------------------------------------------------------------|---------------|
| 31:0 | HTP        | 32-bit pointer to the address table. Bits [2:0] must be set to zero. | 0x0           |

#### Table 294: Flow Control Source Address Low (FCSAL), Offset: 0x084830 for Ethernet\_0; 0x088830 for Ethernet\_1

| Bits | Field Name | Function                                                                                                                   | Initial Value |
|------|------------|----------------------------------------------------------------------------------------------------------------------------|---------------|
| 15:0 | SA[15:0]   | Source Address<br>The least significant bits of the source address for the port.<br>This address is used for Flow Control. | 0             |



# Table 295: Flow Control Source Address High (FCSAH), Offset: 0x084838 for Ethernet\_0; 0x088838 for Ethernet\_1

| Bits | Field Name | Function                                                                                                                  | Initial Value |
|------|------------|---------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | SA[47:16]  | Source Address<br>The most significant bits of the source address for the port.<br>This address is used for Flow Control. | 0             |

## Table 296: SDMA Configuration Register (SDCR), Offset: 0x084840 for Ethernet\_0; 0x088840 for Ethernet\_1

| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                   | Initial Value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1:0   | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                  | 0             |
| 5:2   | RC         | Retransmit Count<br>Sets the maximum number of retransmits per packet. After<br>executing retransmit for RC times, the TX SDMA closes the<br>descriptor with a Retransmit Limit error indication and pro-<br>cesses the next packet.<br>When RC is set to 0, number of retransmits in unlimited. In<br>this case, retransmit process is terminated only if CPU<br>issues an Abort command. | 1111          |
| 6     | BLMR       | <ul> <li>Big/Little endian Receive Mode</li> <li>The DMA supports big or little endian configurations per channel. The BLMR bit only affects data transfer to memory.</li> <li>0 - Big endian.</li> <li>1 - Little endian.</li> </ul>                                                                                                                                                      | 1             |
| 7     | BLMT       | <ul> <li>Big/Little endian Transmit Mode</li> <li>The DMA supports big or little endian configurations per channel. The BLMT bit only affects data transfer from memory.</li> <li>0 - Big endian.</li> <li>1 - Little endian.</li> </ul>                                                                                                                                                   | 1             |
| 8     | POVR       | PCI Override<br>When set, causes the SDMA to direct all its accesses in<br>PCI_0 direction and overrides normal address decoding<br>process.                                                                                                                                                                                                                                               | 0             |
| 9     | RIFB       | Receive Interrupt on Frame Boundaries<br>When set, the SDMA Rx generates interrupts only on frame<br>boundaries (i.e. after writing the frame status to the descrip-<br>tor).                                                                                                                                                                                                              | 0             |
| 11:10 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                  | 0             |



| Bits  | Field Name | Function                                           | Initial Value |
|-------|------------|----------------------------------------------------|---------------|
| 13:12 | BSZ        | Burst Size                                         | 0             |
|       |            | Sets the maximum burst size for SDMA transactions: |               |
|       |            | 00 - Burst is limited to 1 64bit words.            |               |
|       |            | 01 - Burst is limited to 2 64bit words.            |               |
|       |            | 10 - Burst is limited to 4 64bit words.            |               |
|       |            | 11 - Burst is limited to 8 64bit words.            |               |
| 31:14 | Reserved   | Reserved.                                          | 0             |

#### Table 296: SDMA Configuration Register (SDCR), Offset: 0x084840 for Ethernet\_0; 0x088840 for Ethernet\_1 (Continued)

#### Table 297: SDMA Command Register (SDCMR), Offset: 0x084848 for Ethernet\_0; 0x088848 for Ethernet\_1

| Bits | Field Name | Function                                                                                                                                                                                                                                                                                                                                         | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 6:0  | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                        | 0             |
| 7    | ERD        | Enable RX DMA.<br>Set to '1' by the CPU to cause the SDMA to start a receive<br>process.<br>Cleared when the CPU issues an Abort Receive command.                                                                                                                                                                                                | 0             |
| 14:8 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                        | 0             |
| 15   | AR         | Abort Receive<br>Set to '1' by the CPU to abort a receive SDMA operation.<br>When the AR bit is set, the SDMA aborts its current opera-<br>tion and moves to IDLE. No descriptor is closed.<br>AR bit is cleared upon entering IDLE.<br>After setting AR bit, the CPU should poll it in order to verify<br>that the abort sequence is completed. | 0             |
| 16   | STDH       | Stop TX High<br>Set to '1' by the CPU to stop the transmission process from<br>the high priority queue at the end of the current frame. An<br>interrupt is generated when the stop command has been<br>executed.<br>Writing '1' to STDH resets TXDH bit.<br>Writing '0' to this bit has no effect.                                               | 0             |
| 17   | STDL       | Stop TX Low<br>Set to '1' by the CPU in order to stop the transmission pro-<br>cess from the low priority queue at the end of the current<br>frame. An interrupt is generated when the stop command<br>has been executed.<br>Writing '1' to STDL resets TXDL bit.<br>Writing '0' to this bit has no effect.                                      | 0             |



| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                              | Initial Value |  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--|
| 22:18 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                             | 0             |  |
| 23    | TXDH       | Start Tx High<br>Set to '1' by the CPU in order to cause the SDMA to fetch<br>the first descriptor and start a transmit process from the high<br>priority Tx queue.<br>Writing '1' to TXDH resets STDH bit.<br>Writing '0' to this bit has no effect.                                                                                 | 0             |  |
| 24    | TXDL       | Start Tx Low<br>Set to '1' by the CPU to cause the SDMA to fetch the first<br>descriptor and start a transmit process from the low priority<br>Tx queue.<br>Writing '1' to TXDL resets STDL bit.<br>Writing '0' to this bit has no effect.                                                                                            | 0             |  |
| 30:25 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                             | 0             |  |
| 31    | AT         | Abort Transmit<br>Set to '1' by the CPU to abort a transmit DMA operation.<br>When the AT bit is set, the SDMA aborts its current opera-<br>tion and moves to IDLE. No descriptor is closed.<br>Cleared upon entering IDLE.<br>After setting AT bit, the CPU must poll it in order to verify<br>that the abort sequence is completed. | 0             |  |

#### Table 297: SDMA Command Register (SDCMR), Offset: 0x084848 for Ethernet\_0; 0x088848 for Ethernet\_1 (Continued)

## Table 298: Interrupt Cause Register (ICR), Offset: 0x084850 for Ethernet\_0; 0x088850 for Ethernet\_1

| Bits | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | RxBuffer   | <ul> <li>Rx Buffer Return</li> <li>Indicates a Rx buffer returned to CPU ownership or that the port finished reception of a Rx frame in either priority queues.</li> <li><b>NOTE:</b> In order to get a Rx Buffer return per priority queue, use bit 19:16. This bit is set upon closing any Rx descriptor which has its El bit set. In order to limit the interrupts to frame (rather than buffer) boundaries, the user should set SDCR<rifb> bit. When RIFB is set, an interrupt will be generated only upon closing the first descriptor of a received packet if this descriptor has it El bit set.</rifb></li> </ul> | 0             |
| 1    | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0             |



| Bits | Field Name   | Function                                                                                                                                                                                                                                                                                                                                                                                           | Initial Value |
|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 2    | TxBufferHigh | <ul> <li>Tx Buffer for High priority Queue</li> <li>Indicates a Tx buffer returned to CPU ownership or that the port finished transmission of a Tx frame.</li> <li><b>NOTE:</b> This bit is set upon closing any Tx descriptor which has its EI bit set. In order to limit the interrupts to frame (rather than buffer) boundaries, the user should set EI only in the last descriptor.</li> </ul> | 0             |
| 3    | TxBufferLow  | <ul> <li>Tx Buffer for Low Priority Queue</li> <li>Indicates a Tx buffer returned to CPU ownership or that the port finished transmission of a Tx frame.</li> <li><b>NOTE:</b> This bit is set upon closing any Tx descriptor which has its El bit set. In order to limit the interrupts to frame (rather than buffer) boundaries, the user should set El only in the last descriptor.</li> </ul>  | 0             |
| 5:4  | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                          | 0             |
| 6    | TxEndHigh    | Tx End for High Priority Queue<br>Indicates that the Tx DMA stopped processing the high prior-<br>ity queue after stop command, or that it reached the end of<br>the high priority descriptor chain.                                                                                                                                                                                               | 0             |
| 7    | TxEndLow     | Tx End for Low Priority Queue<br>Indicates that the Tx DMA stopped processing the low prior-<br>ity queue after stop command, or that it reached the end of<br>the low priority descriptor chain.                                                                                                                                                                                                  | 0             |
| 8    | RxError      | Rx Resource Error<br>Indicates a Rx resource error event in either priority queues.<br><b>NOTE:</b> In order to get a Rx Resource Error Indication per<br>priority queue, use bit 23:20. event                                                                                                                                                                                                     | 0             |
| 9    | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                          | 0             |
| 10   | TxErrorHigh  | Tx Resource Error for High Priority Queue<br>Indicates a Tx resource error event during packet transmis-<br>sion from the high priority queue.                                                                                                                                                                                                                                                     | 0             |
| 11   | TxErrorLow   | Tx Resource Error for Low Priority Queue<br>Indicates a Tx resource error event during packet transmis-<br>sion from the low priority queue.                                                                                                                                                                                                                                                       | 0             |
| 12   | RxOVR        | Rx Overrun<br>Indicates an overrun event that occured during reception of a<br>packet.                                                                                                                                                                                                                                                                                                             | 0             |
| 13   | TxUdr        | Tx Underrun<br>Indicates an underrun event that occured during transmis-<br>sion of packet from either queue.                                                                                                                                                                                                                                                                                      | 0             |

# Table 298: Interrupt Cause Register (ICR), Offset: 0x084850 for Ethernet\_0; 0x088850 for Ethernet\_1 (Continued)

| Table 298: Interrupt Cause Register (ICR), Offset: 0x084850 for |  |
|-----------------------------------------------------------------|--|
| Ethernet_0; 0x088850 for Ethernet_1 (Continued)                 |  |

| Bits  | Field Name            | Function                                                                                                                                                                                     | Initial Value |
|-------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 16    | RxBuffer-<br>Queue[0] | Rx Buffer Return in Priority Queue[0], Indicates a Rx buffer<br>returned to CPU ownership or that the port completed recep-<br>tion of a Rx frame in a receive priority queue[0]             | 0             |
| 17    | RxBuffer-<br>Queue[1] | Rx Buffer Return in Priority Queue[1], Indicates a Rx buffer returned to CPU ownership or that the port completed reception of a Rx frame in a receive priority queue[1]                     | 0             |
| 18    | RxBuffer-<br>Queue[2] | Rx Buffer Return in Priority Queue[2], Indicates a Rx buffer<br>returned to CPU ownership or that the port completed recep-<br>tion of a Rx frame in a receive priority queue[2]             | 0             |
| 19    | RxBuffer-<br>Queue[3] | Rx Buffer Return in Priority Queue[3], Indicates a Rx buffer<br>returned to CPU ownership or that the port completed recep-<br>tion of a Rx frame in a receive priority queue[3]             | 0             |
| 20    | RxError-<br>Queue[0]  | Rx Resource Error in Priority Queue[0], Indicates a Rx resource error event in receive priority queue[0]                                                                                     | 0             |
| 21    | RxError-<br>Queue[1]  | Rx Resource Error in Priority Queue[1], Indicates a Rx resource error event in receive priority queue[1]                                                                                     | 0             |
| 22    | RxError-<br>Queue[2]  | Rx Resource Error in Priority Queue[2], Indicates a Rx resource error event in receive priority queue[2]                                                                                     | 0             |
| 23    | RxError-<br>Queue[3]  | Rx Resource Error in Priority Queue[3], Indicates a Rx resource error event in receive priority queue[3]                                                                                     | 0             |
| 27:24 | Reserved              | Reserved.                                                                                                                                                                                    | 0             |
| 28    | MIIPhySTC             | MII PHY Status Change<br>Indicates a status change reported by the PHY connected to<br>this port.<br>Set when the MII management interface block identifies a<br>change in PHY's register 1. | 0             |
| 29    | SMIdone               | SMI Command Done<br>Indicates the SMI completed a MII management command<br>(either read or write) that was initiated by the CPU writing to<br>the SMI register.                             | 0             |
| 30    | Reserved              | Reserved.                                                                                                                                                                                    | 0             |
| 31    | EtherIntSum           | Ethernet Interrupt Summary<br>This bit is a logical OR of the (unmasked) bits [30:4] in the<br>Interrupt Cause register.                                                                     | 0             |



#### Table 299: Interrupt Mask Register (IMR), Offset: 0x084858 for Ethernet\_0; 0x088858 for Ethernet\_1

| Bits | Field Name | Function                                | Initial Value |
|------|------------|-----------------------------------------|---------------|
| 31:0 | Various    | Mask bits for Interrupt Cause register. | 0x0           |

#### Table 300: IP Differentiated Services CodePoint to Priority0 low (DSCP2P0L)

| Bits | Field Name    | Function                                     | Initial Value |
|------|---------------|----------------------------------------------|---------------|
| 31:0 | Priority0 low | The LSB priority bit for DSCP[31:0] entries. | 0x0           |

#### Table 301: IP Differentiated Services CodePoint to Priority0 high (DSCP2P0H)

| Bits | Field Name     | Function                                                     | Initial Value |
|------|----------------|--------------------------------------------------------------|---------------|
| 31:0 | Priority0 high | These bits are the LSB priority bit for DSCP[63:32] entries. | 0x0           |

#### Table 302: IP Differentiated Services CodePoint to Priority1 low (DSCP2P1L)

| Bits | Field Name    | Function                                                    | Initial Value |
|------|---------------|-------------------------------------------------------------|---------------|
| 31:0 | Priority1 low | These bits are the MSB priority bit for DSCP[31:0] entries. | 0x0           |

#### Table 303: IP Differentiated Services CodePoint to Priority1 high (DSCP2P1H)

| Bits | Field Name     | Function                                                     | Initial Value |
|------|----------------|--------------------------------------------------------------|---------------|
| 31:0 | Priority1 high | These bits are the MSB priority bit for DSCP[63:32] entries. | 0x0           |

#### Table 304: VLAN Priority Tag to Priority (VPT2P)

| Bits                    | Field Name | Function                                                            | Initial Value |
|-------------------------|------------|---------------------------------------------------------------------|---------------|
| Initial<br>Value<br>7:0 | Priority0  | These bits are the LSB priority bit for VLAN Priority[7:0] entries. | Охсс          |
| 15:8                    | Priority1  | These bits are the MSB priority bit for VLAN Priority[7:0] entries. | 0xf0          |
| 31:16                   |            | Reserved.                                                           | 0x0           |

# 12.5.1 Defining a priority queue to the IP DSCP or VLAN Entry

To define a priority queue to the IP DSCP or VLAN entry, the entry's priority 0 and priority 1 bits must be defined.

Table 305 and Table 306 describe the writing of IP DSCP and VLAN entries respectively for a few set examples. Table 307 describes three example cases for mixed priority queueing.

| IP DSCP Value | Priority MSB bit | Priority LSB bit |
|---------------|------------------|------------------|
| 0             | DSCP2P1L[0]      | DSCP2P0L[0]      |
| 16            | DSCP2P1L[16]     | DSCP2P0L[16]     |
| 31            | DSCP2P1L[31]     | DSCP2P0L[31]     |
| 32            | DSCP2P1H[0]      | DSCP2P0H[0]      |
| 48            | DSCP2P1H[16]     | DSCP2P0H[16]     |
| 63            | DSCP2P1H[31]     | DSCP2P0H[31]     |

 Table 305: Writing IP DSCP Priority Example

#### Table 306: Writing VLAN Priority Example

| VLAN Priority Value | Priority MSB bit | Priority LSB bit |
|---------------------|------------------|------------------|
| 0                   | VPT2P[8]         | VPT2P[0]         |
| 4                   | VPT2P[12]        | VPT2P[4]         |
| 7                   | VPT2P[15]        | VPT2P[7]         |



| Case | IPDSCP                                                                                                                                                  | All Others                   | VLAN Tag Packets                                                                           |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--------------------------------------------------------------------------------------------|
| A    | 0x0 and 0x3f (63) directed to pri-<br>ority queue 3                                                                                                     | directed to priority queue 0 | ignored                                                                                    |
| В    | <0x20 (32) directed to priority queue 2                                                                                                                 | directed to priority queue 1 | directed to priority queue 3                                                               |
| С    | 0x1f (31) and 0x20 (32) directed<br>to priority queue 3<br>0x0 and 0x3f (63)directed to pri-<br>ority queue 0<0x1f (31) directed<br>to priority queue 1 | directed to priority queue 2 | >3 and IP DSCP ≠ 0x1f or<br>0x20 directed to priority<br>queue 2<br>other tags are ignored |

Table 308: Writing IP DSCP and VLAN Priority Register mapping Example

| Register  | Case A     | Case B     | Case C     |
|-----------|------------|------------|------------|
| DSCPC2P0L | 0x0000001  | 0x0000000  | 0xFFFFFFE  |
| DSCP2P0H  | 0x80000000 | 0xFFFFFFF  | 0x0000001  |
| DSCP2P1L  | 0x0000001  | 0xFFFFFFF  | 0x8000000  |
| DSCP2P1H  | 0x8000000  | 0x0000000  | 0x7FFFFFF  |
| VPT2P     | 0x0000001  | 0x0000FFFF | 0x0000F000 |

# 12.6 Ethernet MIB Counters

The Ethernet unit includes a set of counters that are used to count events occurring on the segment to which the port is connected to. All counters are 32 bit wide.

The CPU must read all the MIB counters during initialization in order to reset the counters to '0'. The counters will only be reset to '0' if MIBclrMode bit in the Port\_Configuration\_Extend register is set to '0' (default). If MIBclrMode bit is '1', reading the MIB counters will have no effect on their value.

**NOTE:** Table 309 lists definitions of terms used in the counter descriptions.

Table 309: Terms Used in MIB Counters Descriptions

| Term                | Definition                                                                  |
|---------------------|-----------------------------------------------------------------------------|
| Packet Data Section | All data bytes in the packet following the SFD until the end of the packet. |
| Packet Data Length  | The number of data bytes in the packet data section.                        |
| Data Octet          | A single byte from the packet data section.                                 |
| Nibble              | 4 bits (half byte) of a data octet.                                         |
| Misaligned Packet   | A packet with an odd number of nibbles.                                     |

| Term                 | Definition                                                                                                      |
|----------------------|-----------------------------------------------------------------------------------------------------------------|
| Received Good Packet | A received packet which is well formed.                                                                         |
| Received Bad Packet  | A received packet which has an error such as bad CRC, Rx Error Event, Invalid size (too short or too long).     |
| Transmitted Packet   | Any transmitted packet (not including collision fragments).                                                     |
| Collision Event      | Any collision event that is indicated by assertion of MII_COL signal within the col-<br>lision window interval. |
| Late Collision Event | Any collision event that is indicated by assertion of MII_COL signal outside the collision window interval.     |
| Rx Error Event       | An error event that is indicated by assertion of MII_RX_ERR signal.                                             |
| Dropped Packet       | A received packet which is dropped by the port due to lack of resources (e.g. no Rx buffers available).         |
| MIBctrMode           | MIBctrMode bit in the Port Configuration Extend register.                                                       |
| MaxFrameSize         | 1518, 1536, 2 K or 64Kbytes depending on the setting in the Port Configuration Extend register.                 |

## Table 309: Terms Used in MIB Counters Descriptions (Continued)

| Address<br>for Port 0 | Address<br>for Port 1 | Counter<br>Name | Function                                                                                                                  | lnitial<br>Value |
|-----------------------|-----------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------|------------------|
| 0x085800              | 0x089800              | Bytes Received  | This counter increments once for every data octet of good packets (Unicast + Multicast + Broadcast) received by the port. | -                |
| 0x085804              | 0x089804              | Bytes Sent      | This counter increments once for every data octet of transmitted packets sent by the port.                                | -                |
| 0x085808              | 0x089808              | Frames Received | This counter increments once for every good packet (Unicast + Multicast + Broadcast) received by the port.                | -                |
| 0x08580C              | 0x08980C              | Frames Sent     | This counter increments once for every transmitted packet sent by the port.                                               | -                |



| Address<br>for Port 0 | Address<br>for Port 1 | Counter<br>Name              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | lnitial<br>Value |
|-----------------------|-----------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0x085810              | 0x089810              | Total Bytes<br>Received      | This counter increments once for every<br>data octet of all received packets. This<br>includes data octets of BAD packets,<br>which might be automatically rejected<br>by the port (e.g fragments). This<br>counter reflects all the data octets<br>received from the line.<br><b>NOTE:</b> A nibble is NOT counted as a<br>whole byte.                                                                                                                                                       | -                |
| 0x085814              | 0x089814              | Total Frames<br>Received     | This counter increments once for every received packet. This includes BAD packets. This counter reflects all packets received from the line.                                                                                                                                                                                                                                                                                                                                                  | -                |
| 0x085818              | 0x089818              | Broadcast<br>Frames Received | This counter increments once for every good broadcast packet received.                                                                                                                                                                                                                                                                                                                                                                                                                        | -                |
| 0x08581C              | 0x08981C              | Multicast Frames<br>Received | This counter increments once for every good Multicast packet received.<br>This counter does not count Broadcast packets.                                                                                                                                                                                                                                                                                                                                                                      | -                |
| 0x085820              | 0x089820              | CRC Error                    | <ul> <li>This counter increments once for every received packet which meets all the following conditions (i.e. logical AND of the following conditions): <ul> <li>Packet data length is between 64 and MaxFrameSize bytes inclusive (i.e. valid packet data length per IEEE std).</li> <li>Packet has invalid CRC.</li> <li>Collision Event has not been detected.</li> <li>Late Collision Event has not been detected.</li> <li>Rx Error Event has not been detected.</li> </ul> </li> </ul> | -                |

| Address<br>for Port 0 | Address<br>for Port 1 | Counter<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | lnitial<br>Value |
|-----------------------|-----------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0x085824              | 0x089824              | Oversize Frames | <ul> <li>This counter increments once for every received packet which meets all the following conditions (i.e. logical AND of the following conditions): <ul> <li>Packet data length is greater than MaxFrameSize.</li> <li>Packet has valid CRC.</li> <li>Rx Error Event has not been detected.</li> </ul> </li> </ul>                                                                                                                                                             | -                |
| 0x085828              | 0x089828              | Fragments       | <ul> <li>This counter increments once for every received packet which meets all the following conditions (i.e. logical AND of the following conditions): <ul> <li>Packet data length is less than 64 bytes -OR- packet without SFD and is less than 64 bytes in length.</li> <li>Collision Event has not been detected.</li> <li>Late Collision Event has not been detected.</li> <li>Rx Error Event has not been detected.</li> <li>Packet has INVALID CRC.</li> </ul> </li> </ul> | -                |
| 0x08582c              | 0x08982c              | Jabber          | <ul> <li>This counter increments once for every received packet which meets all the following conditions (i.e. logical AND of the following conditions): <ul> <li>Packet data length is greater than MaxFrameSize.</li> <li>Packet has invalid CRC.</li> <li>Rx Error Event has not been detected.</li> </ul> </li> </ul>                                                                                                                                                           | -                |
| 0x085830              | 0x089830              | Collision       | <ul> <li>This counter increments once for every received packet which meets both of the following conditions (i.e. logical AND of the following conditions):</li> <li>Collision Event has been detected.</li> <li>Rx Error Event has not been detected.</li> </ul>                                                                                                                                                                                                                  | -                |



| Address<br>for Port 0 | Address<br>for Port 1 | Counter<br>Name                       | Function                                                                                                                                                                                                                                                                            | Initial<br>Value |
|-----------------------|-----------------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0x085834              | 0x089834              | Late Collision                        | <ul> <li>This counter increments once for every received packet which meets both of the following conditions (i.e. logical AND of the following conditions): <ul> <li>Late Collision Event has been detected.</li> <li>Rx Error Event has not been detected.</li> </ul> </li> </ul> | -                |
| 0x085838              | 0x089838              | Frames 64 Bytes                       | This counter increments once for every received and transmitted packet with size of 64 bytes. This counter does not count BAD received packets.                                                                                                                                     | -                |
| 0x08583c              | 0x08983c              | Frames 65-127<br>Bytes                | This counter increments once for every received and transmitted packet with size of 65 to 127 bytes. This counter does not count BAD received packets.                                                                                                                              | -                |
| 0x085840              | 0x089840              | Frames 128-255<br>Bytes               | This counter increments once for every received and transmitted packet with size of 128 to 255 bytes. This counter does not count BAD received packets.                                                                                                                             | -                |
| 0x085844              | 0x089844              | Frames 256-511<br>Bytes               | This counter increments once for every received and transmitted packet with size of 256-511 bytes. This counter does not count BAD received packets.                                                                                                                                | -                |
| 0x085848              | 0x089848              | Frames 512-1023<br>Bytes              | This counter increments once for every received and transmitted packet with size of 512-1023 bytes. This counter does not count BAD received packets.                                                                                                                               | -                |
| 0x08584c              | 0x08984c              | Frames 1024-<br>MaxFrameSize<br>Bytes | This counter increments once for every received and transmitted packet with size of 1024 to MaxFrameSize bytes. This counter does not count BAD received packets.                                                                                                                   | -                |
| 0x085850              | 0x089850              | Rx Error                              | This counter increments once for every<br>received packet in which the Rx Error<br>Event has been detected. When a Rx<br>Error event occurs, the following<br>counters do not increment: CRC Error,<br>Oversize Frames, Fragments, Jabbers,<br>Collision and Late Collision.        | -                |
| 0x085854              | 0x089854              | Dropped Frames                        | Reserved.                                                                                                                                                                                                                                                                           | -                |

| Address<br>for Port 0 | Address<br>for Port 1 | Counter<br>Name         | Function                                                                                                                                                                                                                                                                                                                                                                                                            | lnitial<br>Value |
|-----------------------|-----------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0x085858              | 0x089858              | Out Multicast<br>Frames | The number of Multicast frames sent<br>by the port.<br>This counter does not count Broadcast<br>packets.                                                                                                                                                                                                                                                                                                            | -                |
| 0x08585C              | 0x08985C              | Out Broadcast<br>Frames | The number of Broadcast frames sent by the port.                                                                                                                                                                                                                                                                                                                                                                    | -                |
|                       |                       | Out Unicast<br>Frames   | Calculated from: <ul> <li>"Frames Sent"</li> <li>"Out Multicast Frames"</li> <li>"Out Broadcast Frames"</li> </ul>                                                                                                                                                                                                                                                                                                  |                  |
| 0x085860              | 0x089860              | Undersize<br>Frames     | <ul> <li>This counter increments once for every received packet which meets all the following conditions (i.e. logical AND of the following conditions): <ul> <li>Packet data length is less than 64 bytes.</li> <li>Collision Event has not been detected.</li> <li>Late Collision Event has not been detected.</li> <li>Rx Error Event has not been detected.</li> <li>Packet has valid CRC.</li> </ul></li></ul> | -                |



# 13. SERIAL DMA (SDMA)

# 13.1 Overview

There are 16 SDMA channels on the GT-96100A that are dedicated for moving data between the serial communications channels (MPSCs) and memory buffers. Each SDMA channel consists of a DMA engine for receiving and one for transmitting.

The 16 SDMA channels are logically divided in two identical groups. Each group consists of 8 SDMA channels - one SDMA channel per MPSC. In both groups SDMA channel 0 is allocated to data transfer from/to MPSC0, SDMA1 is tied to MPSC1 and so on. Each MPSC can be programmed to use a specific SDMA channel from one of the groups, making it possible to split the serial data flow into two logical streams. These streams can be assigned a different priority tag at the CIU level.

Each SDMA channel has two dedicated FIFOs for data buffering (for a total of 32 FIFOs). All FIFOs are 256 bytes deep.

For receive operations, the MPSC moves received data into the dedicated FIFO of the corresponding SDMA. Then, using descriptors set up by the user, the SDMA moves the data into memory buffers. For transmit operations, the SDMA uses descriptors set up by the user to move data out of buffers into the dedicated FIFO. The MPSC moves the data down to the serial communications link.

The SDMA channel descriptors use a chained data structure. They work without CPU interference after appropriate initialization. SDMA channels can be programed to generate interrupts on buffer or frame boundaries.

When enabled, he receive SDMAs run freely and expect to find a valid descriptor, when one is required. When a receive SDMA channel accesses an invalid descriptor, the receive SDMA process halts with a resource error status indication.

When enabled, the transmit SDMAs run freely until the end of the descriptor chain is reached. When a transmit SDMA accesses an invalid descriptor and the last descriptor was not marked as an end of frame descriptor, the transmit SDMA process halts with resource error status indication.

The SDMAs in each group arbitrate for accessing the descriptors and buffers. A standard round-robin scheme is used for arbitration within the group. The arbitration between the groups is done at the CIU level, which supports a programmable, weighted round-robin algorithm.

SDMA buffers and descriptor reside either in SDRAM space or in PCI space. Address decoding is automatic and does not require user intervention. However, the user may choose to override the address decoding and force one (or more) of the SDMAs to direct all its accesses to the PCI.



+0

# **13.2 SDMA Descriptors**

All SDMA data transfers are done via a chained link of descriptors. The following rules must be followed when using the GT-96100A SDMA descriptors:

- Descriptor length is 4LW and it must be 4LW aligned (i.e. Descriptor\_Address[3:0]=0000).
- Descriptors may reside anywhere in CPU address space except NULL address, which is used to indicate end of descriptor chain.
- In normal mode (HDLC and Transparent) RX buffers associated with RX descriptors must be 64-bit aligned. Minimum size for RX buffers is 8 bytes. In low latency, or byte, mode (BISYNC, UART, and Transparent) RX buffers have no alignment restrictions.
- Tx buffers associated with TX descriptors can start in any byte location.
- SDMA RX and TX buffers are limited to 64Kbytes.

#### Figure 52: SDMA Descriptor Format

#### **Rx Descriptor**

| Command / Status             |                                 |  |  |  |  |
|------------------------------|---------------------------------|--|--|--|--|
| Buffer Size 0 0 0 Byte Count |                                 |  |  |  |  |
| Buffer Pointer 000           |                                 |  |  |  |  |
| Next D                       | Next Descriptor Pointer 0 0 0 0 |  |  |  |  |

#### **Tx Descriptor**

| Byte Count Shadow Byte Count    |          |                |  |
|---------------------------------|----------|----------------|--|
| Buffer Pointer                  |          |                |  |
| Next Descriptor Pointer 0 0 0 0 |          |                |  |
|                                 | Buffer I | Buffer Pointer |  |

= Reserved

= Any Value in Byte Mode

 
 Table 311: SDMA Descriptor - Command/Status word
 \_\_\_\_

| Bits  | Field Name          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|-------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:0  | Command/Sta-<br>tus | <ul> <li>Contains commands bits that instruct the SDMA how to process a buffer and sta tus bits that the SDMA updates upon closing a descriptor. The CPU uses the sta tus bits to evaluate the buffer status. Except for bits 31, 30, 23, 17, and 16, the definition of the bits vary depending on which mode is being used. See: <ul> <li>Section 14.5.2 "SDMAx Command/Status Field for HDLC Mode" on page 338.</li> <li>Section 14.6.3 "SDMAx Command/Status Field for BISYNC Mode" or page 350.</li> <li>Section 14.7.2 "SDMAx Command/Status Field for UART Mode" on page 362.</li> <li>Section 14.8.1 "SDMAx Command/Status Field for Transparent Mode" on page 374.</li> </ul> </li> </ul> |  |  |
| 31    | 0                   | Owner Bit<br>When set to'1', the buffer can be processed by the GT-96100A.<br>When set to '0', the buffer can be processed by the CPU. An SDMA process will<br>halt when a descriptor with owner bit set to '0' is fetched.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 30    | AM                  | Auto Mode<br>When set, the SDMA won't clear the Owner bit of the descriptor at the end of<br>buffer processing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 29:24 | Reserved            | Determined by the mode selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 23    | EI                  | <ul> <li>Enable Interrupt</li> <li>The GT-96100A generates a maskable interrupt when closing descriptor with EI bit set.</li> <li><b>NOTE:</b> If the RIFB bit is set in the SDMA configuration register, a Rx interrupt is generated only if this is the last descriptor associated with a received frame. In this case, EI bit setting is masked for intermediate descriptors.</li> </ul>                                                                                                                                                                                                                                                                                                       |  |  |
| 22:18 |                     | Determined by the mode selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 17    | F                   | First Bit<br>Indicates first buffer of a frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 16    | L                   | Last Bit<br>Indicates last buffer of a frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 15:0  |                     | Determined by the mode selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |

| Bits  | Field Name  | Function                                                                                                                                                                                                                                                                                                                         |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Buffer Size | The buffer size field is valid only in receive descriptors and is reserved in transmit descriptors. The field is written by the CPU and read by the GT-96100A. When the buffer byte counter of a SDMA receive channel reaches the buffer size value, the SDMA will close the buffer descriptor and will move to the next buffer. |
|       |             | Buffer Size must be a multiple of 8 when the MPSC is programmed to work in nor-<br>mal mode (HDLC and Transparent). Buffer Size can be arbitrary when working in<br>low bandwidth mode (BISYNC, UART, and Transparent).                                                                                                          |
| 15:0  | Byte Count  | The number of bytes that were actually written by the SDMA into the buffer. This number is never greater than Buffer Size. The CPU must initialize the Byte Count field with 0x0000.                                                                                                                                             |

### Table 312: SDMA Descriptor - Buffer Size, Byte Count (Rx Descriptor)

### Table 313: SDMA Descriptor - Byte Count, Shadow Byte Count (Tx Descriptor)

| Bits  | Field Name           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|-------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:16 | Byte Count           | Byte count is the number of bytes to be transmitted.<br>Zero byte counters are not supported with retransmission. Do not use zero byte<br>buffers with LAP-D protocol.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 15:0  | Shadow Byte<br>Count | The CPU must initialize this field with a value identical to the Byte Count field. The GT-96100A subtracts the number of bytes actually transmitted from this parameter.<br>Usually the GT-96100A writes '0' in this field when closing a descriptor. However, when the transmit SDMA halts due to a transmit error, this number can be used to determine the number of bytes that were fetched into the GT-96100A.<br>Setting both the Byte Count and Shadow Byte Count to '0' will cause the SDMA to close the descriptor and move to the next descriptor, if both or neither of the F and L bits are set. Setting Byte Count and Buffer Size to '0' in transmit descriptors with one of the F or L bits set will lead to unpredictable behavior. |  |

#### Table 314: SDMA Descriptor - Buffer Pointer

| Bits | Field Name     | Function                                                                                                                                     |
|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Buffer Pointer | 32-bit pointer to the beginning of the buffer associated with the descriptor. The buffer can reside anywhere in memory or PCI address space. |



| Bits | Field Name                 | Function                                                                                                                                                                                                                                                                 |
|------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Next Descriptor<br>Pointer | 32-bit Next Descriptor pointer to the beginning of the next descriptor in the chain. A descriptor can reside anywhere in memory or PCI space. Bits [3:0] must be set to'0'.<br>DMA operation is stopped when a NULL value in the Next Descriptor Pointer is encountered. |

 Table 315: SDMA Descriptor - Next Descriptor Pointer

# **13.3 SDMA Configuration Register (SDC)**

Each SDMA has a dedicated configuration register (SDCx). The SDC must be initialized before enabling the SDMA channel.

#### Figure 53: SDMAx Configuration Register (SDCx)

|  | BSZ | RIFB | POVR | BLMT | BLMR | RC |  | SFM | RFT |
|--|-----|------|------|------|------|----|--|-----|-----|
|--|-----|------|------|------|------|----|--|-----|-----|

| Bits | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Initial Value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 0    | RFT        | <ul> <li>Receive FIFO Threshold</li> <li>0 - 8 bytes</li> <li>1 - Half FIFO (128 bytes)</li> <li>NOTES: When working with an 8-bit data path, the threshold is always one byte regardless of the RFT value. It is recommended that RFT bit be set to '0' in this case.</li> <li>When RFT is set to '0', the SDMA will not burst. It will transfer one word (64 bits) on each transfer.</li> </ul>                                                                                                                                                                                                                                          | 0             |
| 1    | SFM        | <ul> <li>Single Frame Mode <ul> <li>0 - Multi frame mode. The GT-96100A will read as many frames as needed into the FIFO in order to keep the transmit FIFO full. The FIFO can handle more than one frame at a time.</li> <li>1 - Single frame mode. The first descriptor will not be fetched before the current frame's last descriptor is closed.</li> </ul> </li> <li>NOTES: The SFM bit must be set to '1' for HDLC Collision mode, BISYNC and UART protocols.</li> <li>When the SFM bit is set to '0', CTS Lost cannot be reported in the correct descriptor/frame. In LAN HDLC mode SFM must be set for proper operation.</li> </ul> | 0             |
| 5:2  | RC         | Retransmit Count<br>In collision modes (LAP-D), after executing a backoff proce-<br>dure RC times, the Tx SDMA will close the buffer with a<br>Retransmit Limit (RL) error, a maskable interrupt will be gen-<br>erated, and the SDMA will go to OFF state. A new Transmit<br>Demand command should be issued in order to start a new<br>transmission process.<br>When RC field is 0000, the GT-96100A will try to retransmit<br>forever. The CPU needs to issue an abort command in order<br>to stop the retransmit process.                                                                                                              | 1111          |
| 6    | BLMR       | <ul> <li>Rx Big Little/Endian Receive Mode</li> <li>The GT-96100A supports big or little endian configuration per channel for maximum system flexibility. The BLMR bit only affects data movements.</li> <li>0 - Big endian convention.</li> <li>1 - Little endian convention</li> </ul>                                                                                                                                                                                                                                                                                                                                                   | 1             |

## Table 316: SDMA Configuration Register (SDCx), Offset: 0x000900



| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                   | Initial Value |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 7     | BLMT       | <ul> <li>Tx Big/Little Endian Transmit Mode</li> <li>The GT-96100A supports big or little endian configuration per channel for maximum system flexibility. The BLMT bit only affects data movements.<sup>1</sup></li> <li>0 - Big endian convention.</li> <li>1 - Little endian convention.</li> </ul>     | 1             |
| 8     | POVR       | PCI Override<br>When set, causes the SDMA to direct all its accesses in<br>PCI_0 direction, overriding normal address decoding pro-<br>cess.                                                                                                                                                               | 0             |
| 9     | RIFB       | Receive Interrupt on Frame Boundaries<br>When set, the SDMA Rx generates interrupts only on frame<br>boundaries (i.e. after writing the frame status to the descrip-<br>tor).                                                                                                                              | 0             |
| 11:10 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                  | 0             |
| 13:12 | BSZ        | <ul> <li>Burst Size</li> <li>Sets the maximum burst size for SDMA transactions: <ul> <li>00 - Burst is limited to 1 64bit words.</li> <li>01 - Burst is limited to 2 64bit words.</li> <li>10 - Burst is limited to 4 64bit words.</li> <li>11 - Burst is limited to 8 64bit words.</li> </ul> </li> </ul> | 0             |
| 31:14 |            | Reserved.                                                                                                                                                                                                                                                                                                  | 0             |

Table 316: SDMA Configuration Register (SDCx), Offset: 0x000900 (Continued)

1. The user can define the SDMA descriptors as big or little endian through the CIU Configuration register.

# 13.4 SDMA Command Register (SDCMx)

Each SDMA has a dedicated SDMA Command Register (SDCMx) register to control its DMA process.

Figure 54: SDMA Command Register (SDCMx)

| 3 3 2 2 2 2 2 2 2<br>1 0 9 8 7 6 5 4 |     | 1 1 1 1 1 1 1 1<br>6 5 4 3 2 1 0 9 8 | 76543210 |
|--------------------------------------|-----|--------------------------------------|----------|
| AT                                   | TXD | AR                                   | ERD      |

| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Initial Value |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 6:0   | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0             |
| 7     | ERD        | Enable Rx DMA<br>When set to '1', the Rx SDMA will fetch the 1st descriptor and<br>will be ready for a receive frame. The GT-96100A clears ERD<br>when the GT-96100A receive SDMA has a resource error or<br>when the CPU issues an abort command.                                                                                                                                                                                                                                          | 0             |
| 14:8  | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0             |
| 15    | AR         | Abort Receive<br>The CPU sets the AR bit when it needs to abort a receive<br>SDMA channel operation. When the AR bit is set, the SDMA<br>aborts its operation and goes to IDLE state. No descriptor is<br>closed. The GT-96100A clears both the AR and ERD bits<br>when entering IDLE state. The CPU must poll bit 15. When it<br>is '0', the GT-96100A has completed the abort sequence.<br>After an abort the CPU should write the 1st descriptor<br>address and then set ERD bit to '1'. | 0             |
| 16    | STD        | Stop Tx<br>The SDMA stops transmission at the end of frame (i.e. at the<br>end of buffer with L bit set to '1'). After transmitting the last<br>buffer, the transmit SDMA goes to IDLE state. The GT-<br>96100A clears the TXD bit when entering IDLE state. After<br>the SDMA stops, the CPU must write the first descriptor<br>address and than set the TXD bit to '1'. The GT-96100A sig-<br>nals the CPU with interrupt when the stop procedure is<br>accomplished.                     | 0             |
| 22:17 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0             |
| 23    | TXD        | Tx Demand<br>When this bit is set to '1', the Tx DMA will fetch the first<br>descriptor and will start the transmission process. The GT-<br>96100A clears TXD when it successfully ends an SDMA<br>transmit process. It also clears TXD when a resource error<br>occurs, when the transmit process is halted due to channel<br>error (i.e. CTS# lost), or when the CPU issues an abort com-<br>mand.                                                                                        | 0             |
| 30:24 | Reserved   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0             |

## Table 317: SDMA Command Register (SDCMx), Offset: 0x000908

| Bits | Field Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Initial Value |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31   | AT         | Abort Transmit<br>The CPU sets the AT bit to '1' when it needs to abort a trans-<br>mit SDMA channel operation. When the AT bit is set, the<br>SDMA aborts its operation and goes to IDLE state. No<br>descriptor is closed. The GT-96100A clears both the AT and<br>TXD bits when entering IDLE state.<br>The CPU must poll bit 31. When it is '0', the GT-96100A has<br>completed the abort sequence. After an abort, the CPU must<br>write the first descriptor address and than set TXD bit to '1'. | 0             |

Table 317: SDMA Command Register (SDCMx), Offset: 0x000908 (Continued)

# 13.5 SDMA Group Configuration Register

Use this register to assign a specific SDMA channel from one of the SDMA groups to handle the data stream associated with the corresponding MPSC.

**NOTE:** MPSC's receive and transmit data flows does not have to be assigned to the same SDMA group. For example, there is no problem with assigning MPSC0 transmit to SDMA channel 0 of group 0, while MPSC0 receive flow is handled by SDMA channel 0 of group 1. Moreover, for certain asymmetric protocols, like ADSL, the bandwidth requirements for Rx and Tx are different, and splitting the data streams between the SDMA groups may be critical for controlling bandwidth allocation.

| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                     | Initial Value |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 7:0   | RxSG[7:0]  | <ul> <li>Rx Group</li> <li>These bits are used to assign one of the SDMA groups to the RX data of each MPSC. RxSG[0] controls MPSC0, RxSG[1] controls MPSC1 and so on.</li> <li>0 - Receive data from the MPSC is handled by SDMA group 0.</li> <li>1 - Receive data from the MPSC is handled by SDMA group 1.</li> </ul>    | 0             |
| 15:8  | TxSG[7:0]  | <ul> <li>Tx SDMA Group</li> <li>These bits are used to assign one of the SDMA groups to the TX data of each MPSC. TxSG[0] controls MPSC0, TxSG[1] controls MPSC1 and so on.</li> <li>0 - Transmit data to the MPSC is handled by SDMA group 0.</li> <li>1 - Transmit data to the MPSC is handled by SDMA group 1.</li> </ul> | 0             |
| 31:16 | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                    | 0             |

Table 318: SDMA Group Register (SGC), Offset: 0x101AF0



# **13.6 SDMA Descriptor Pointer Registers**

Each SDMA channel has three 32-bit registers that reside in a special descriptor's Dual Port memory located in the internal address space of the GT-96100A.

#### Figure 55: SDMA Descriptor Pointer Registers

SDMAx Current Receive Descriptor Pointer (SCRDPx)

SDMAx First Transmit Descriptor Pointer (SFTDPx)

# 13.6.1 SDMA Current Receive Descriptor Pointer (SCRDP)

SCRDPx points to the current receive descriptor in memory. The CPU must write this register with the first descriptor address before enabling the SDMA receive channel. When a SDMA receive channel is enabled it will fetch the first descriptor pointed to by SCRDPx as part of its SDMA starting procedure.

## 13.6.2 SDMA Current Transmit Descriptor Pointer (SCTDP)

SCTDPx points to the current transmit descriptor in memory. The CPU must write this register with the first descriptor address before enabling the SDMA transmit channel. When a SDMA transmit channel is enabled it will fetch the first descriptor pointed to by SCRDPx as part of its SDMA starting procedure.

# 13.6.3 SDMA First Transmit Descriptor Pointer (SFTDP)

SFTDPx points to the first descriptor in a transmit frame. The CPU must write this register with the first descriptor address before enabling the SDMA transmit channel. The SDMA transmit controller uses the SFTDP when it needs to restart a transmission after collision (HDLC mode only). The GT-96100A updates the content of SFTDP each time it fetches a descriptor with the F (first) bit set to '1'.

**NOTE:** The CPU must write the same value to both SCTDP and SFTDP before enabling the corresponding SDMA transmit channel.

# 13.7 Transmit SDMA

## 13.7.1 Transmit SDMA Definitions

- SOF (Start Of Frame descriptor): Descriptor with F (First) bit set to '1'.
- EOF (End Of Frame descriptor): Descriptor with L (Last) bit set to '1'.

F and L bits are set by the CPU before releasing a descriptor to the GT-96100A for transmission.



A frame starts with a SOF descriptor and ends with a EOF descriptor. A frame can consist of one buffer or split over many buffers. If a frame is stored in one buffer, the associated descriptor will have both the F and L bits set to '1'. In a non-frame oriented protocol (e.g. BISYNC or UART), it is recommended that both F and L bits be set to '1' for each buffer.

# 13.7.2 Transmit SDMA Flow

The following steps are executed during a normal transmit SDMA process:

- 1. Before enabling a SDMA Tx channel the CPU must prepare a valid descriptor with the owner bit set to '1'.
- 2. The CPU must then write the first descriptor address to both SCTDP and SFTDP registers.
- 3. The CPU issues a Transmit Demand command. The SDMA controller will then fetch the first descriptor and will start the SDMA process.
- 4. When buffer transmission is completed, the SDMA will close the buffer descriptor by setting the correct transmit status and writing '0' in the Owner Bit, returning the buffer to the CPU.

# 13.7.3 Retransmit in HDLC (LAP-D) mode

When working in collision mode (see MPSC section), the GT-96100A retransmits if collision occurs before the SDMA fetches the 3rd descriptor. If the frame consists of more than two buffers, the user must assure that there is enough data in the first two buffers to compensate for this behavior. The GT-96100A can buffer up to 256 bytes in its internal Tx FIFO. This should be considered when preparing a LAP-D transmit frame.

# 13.7.4 Transmit SDMA Notes

The transmit SDMA process is frame oriented.

The Transmit SDMA does not clear the frame's first descriptor ownership bit until the last descriptor associated with this frame is closed. The transmit SDMA then writes '0' to the first descriptor Owner bit and generate an interrupt if the EI bit of the first descriptor is set.

The transmit SDMA stops the DMA process whenever it reaches a descriptor with NULL (0x00000000) value in the NextDescriptorPointer (NDP) field or when it fetches a descriptor with Owner Bit set to '0'.

When the transmit SDMA controller encouters a NULL NDP value or a Not-Owned descriptor with it's First field bit set, after the last descriptor of a frame, the transmit idles. The TxD bit is cleared and the transmit SDMA controller return to IDLE state.

When the transmit SDMA controller encouter a NULL NDP value, or a Not-Owned descriptor with it's First field bit set, in the middle of a frame or a Not-Owned descriptor with it's First field bit reset, after the last descriptor of a frame, the transmit aborts. The TxD bit is cleared, a Tx RESOURCE ERROR maskable interrupt is generated and the transmit SDMA controller return to IDLE state.

When the transmit SDMA controller encouters a Not-Owned descriptor with it's First field bit reset, in the middle of a frame, the transmit stops. The TxD bit is not cleared and the transmit SDMA controller waits for an Abort transmit command. In such cases, the SDMA controller clears the TxD bit before returning to IDLE state.

In normal operation, the transmit SDMA never expects to find a NULL NextDescriptorPointer or Not-Owned descriptor in the middle of a frame. When this occurs, the transmit SDMA controller aborts, the TxD bit is cleared and a Tx RESOURCE ERROR maskable interrupt is generated.



**NOTE:** In collision mode, if a collision occurs exactly one clock cycle after a resource error, the GT-96100A ignores the resource error and retransmit the frame.

When the CPU needs to interfere with the transmit process without corrupting the ongoing transmit process, it can issue a STOP command by writing '1' to the STD bit in the SDMA command register. The transmit SDMA controller stops after completing the transmission of the active frame.

When issuing an STD command TXD is reset to '0' upon entering IDLE state. The CPU can then issue a new Transmit Demand command to restart the SDMA process.

# 13.8 Receive SDMA

### 13.8.1 Receive SDMA Definitions

Table 319: SDMA Definitions

| Term | Definition                                                             |
|------|------------------------------------------------------------------------|
| SOF  | Start Of Frame descriptor<br>Descriptor with F (First) bit set to '1'. |
| EOF  | End Of Frame descriptor<br>Descriptor with L (Last) bit set to '1'.    |

F and L bits are set by the CPU before releasing a descriptor to the GT-96100A.

A frame starts with an SOF descriptor and ends with an EOF descriptor. A frame can be contained in one buffer or split over many buffers. If a frame is stored in one buffer, the associated descriptor will have both F and L bits set to '1'.

# 13.8.2 Receive SDMA Flow

The following steps are executed during a normal transmit SDMA process:

- 1. Before enabling a SDMA Rx channel the CPU must prepare a valid descriptor with the owner bit set to '1'.
- 2. The CPU must then write the descriptor address to the SCRDP register before enabling the receive SDMA channel.
- 3. The CPU writes '1' to the ERD bit in the SDCM register, enabling the receive SDMA channel.
- 4. Normally the receive SDMA controller will then run continuously, processing received data from the MPSC.

**NOTES:** The receive SDMA controller never expects to encounter a descriptor with owner bit set to '0' or a NULL value (0x00000000) in the NDP field. If this occurs, the receive SDMA aborts and a maskable Rx RESOURCE ERROR interrupt is generated.

Use the receive abort command for the CPU to stop the receive SDMA. It is the CPU's responsibility to properly restart the descriptor chain.



# 13.9 SDMA Interrupt and Mask register (SDI and SDM)

Each SDMA channel has two maskable interrupt sources. One is for Resource Error events and the other one is for descriptor closed events.

# 13.9.1 Resource Error Interrupt

When a receive SDMA encounters a NULL descriptor pointer or a not owned descriptor, a Resource Error interrupt is generated. A Resource Error interrupt is generated whenever a transmit SDMA encounters a NULL descriptor pointer or a not-owned descriptor in a middle of a frame.

**NOTE:** When the GT-96100A encounters a descriptor with Owner bit set to 0, it still expects to find that all the other fields of the descriptor are legitimate. A descriptor with Owner bit set to 0, with non-legitimate fields (such as Start Of Frame descriptor with F (First) bit not set to '1') can lead to unpredictable behavior.

## 13.9.2 Descriptor/Frame Closed Interrupt

When a SDMA channel closes a descriptor with the EI (Enable Interrupt) bit set to '1', a Descriptor Closed interrupt is generated.

**NOTES:**In case the RIFB bit is set in the SDMA configuration register, an interrupt is generated by the Rx channel only on receive frame boundaries.

The correct operation of the frame level interrupt requires all Rx descriptors to have their EI bit set.

# 13.10 SDMA in Auto Mode

The CPU can set bit 30 in the command/status field of transmit or receive descriptors directing the GT-96100A to work in Auto Mode.

When working with an Auto Mode descriptor, the GT-96100A SDMA works as usual except that it does not clear the Ownership bit when closing the descriptor. The CPU can use this for example to cause the GT-96100A to transmit endlessly (until CPU intervention).





Figure 56: Using Auto Mode to Create Idle Loop

# 13.11 SDMA Registers

Table 320: SDMA Group 0 Register Map

| Description                                      | Offset                                | Page Number                                      |
|--------------------------------------------------|---------------------------------------|--------------------------------------------------|
| SDMA Group Configuration Register                | 0x101AF0                              | page 315                                         |
| Channel0                                         |                                       |                                                  |
| Channel0 Configuration Register (S0DC0)          | 0x000 <b>9</b> 00                     | page 312                                         |
| Channel0 Command Register (S0DCM0)               | 0x000 <b>9</b> 08                     | page 314                                         |
| Channel0 Rx Descriptor                           | 0x008 <b>9</b> 00 - 0x008 <b>9</b> 0F | Not to be accessed dur-<br>ing normal operation. |
| Channel0 Current Rx Descriptor Pointer (S0CRDP0) | 0x008 <b>9</b> 10                     | page 316                                         |
| Channel0 Tx Descriptor                           | 0x00C <b>9</b> 00 - 0x00C <b>9</b> 0F | Not to be accessed dur-<br>ing normal operation. |
| Channel0 Current Tx Descriptor Pointer (S0CTDP0) | 0x00C <b>9</b> 10                     | page 316                                         |
| Channel0 First Tx Descriptor Pointer (S0FTDP0)   | 0x00C <b>9</b> 14                     | page 316                                         |



| Description                                      | Offset                                | Page Number                                                                 |  |
|--------------------------------------------------|---------------------------------------|-----------------------------------------------------------------------------|--|
| Channel1                                         |                                       |                                                                             |  |
| Channel1 Configuration Register (S0DC1)          | 0x010 <b>9</b> 00                     | For a description of the                                                    |  |
| Channel1 Command Register (S0DCM1)               | 0x010 <b>9</b> 08                     | Channel1 registers, see<br>the descriptions for the<br>Channel 0 registers. |  |
| Channel1 Rx Descriptor                           | 0x018 <b>9</b> 00 - 0x018 <b>9</b> 0F |                                                                             |  |
| Channel1 Current Rx Descriptor Pointer (S0CRDP1) | 0x018 <b>9</b> 10                     |                                                                             |  |
| Channel1 Tx Descriptor                           | 0x01C <b>9</b> 00 - 0x01C <b>9</b> 0F |                                                                             |  |
| Channel1 Current Tx Descriptor Pointer (S0CTDP1) | 0x01C <b>9</b> 10                     |                                                                             |  |
| Channel1 First Tx Descriptor Pointer (S0FTDP1)   | 0x01C <b>9</b> 14                     |                                                                             |  |
| Channel2                                         | ·                                     |                                                                             |  |
| Channel2 Configuration Register (S0DC2)          | 0x020 <b>9</b> 00                     | For a description of the                                                    |  |
| Channel2 Command Register (S0DCM2)               | 0x020 <b>9</b> 08                     | Channel2 registers, see the descriptions for the                            |  |
| Channel2 Rx Descriptor                           | 0x028 <b>9</b> 00 - 0x028 <b>9</b> 0F | Channel 0 registers.                                                        |  |
| Channel2 Current Rx Descriptor Pointer (S0CRDP2) | 0x028 <b>9</b> 10                     |                                                                             |  |
| Channel2 Tx Descriptor                           | 0x02C <b>9</b> 00 - 0x02C <b>9</b> 0F |                                                                             |  |
| Channel2 Current Tx Descriptor Pointer (S0CTDP2) | 0x02C <b>9</b> 10                     | -                                                                           |  |
| Channel2 First Tx Descriptor Pointer (S0FTDP2)   | 0x02C <b>9</b> 14                     |                                                                             |  |
| Channel3                                         |                                       |                                                                             |  |
| Channel3 Configuration Register (S0DC3)          | 0x030 <b>9</b> 00                     | For a description of the                                                    |  |
| Channel3 Command Register (S0DCM3)               | 0x030 <b>9</b> 08                     | Channel3 registers, see<br>the descriptions for the<br>Channel 0 registers. |  |
| Channel3 Rx Descriptor                           | 0x038 <b>9</b> 00 - 0x038 <b>9</b> 0F |                                                                             |  |
| Channel3 Current Rx Descriptor Pointer (S0CRDP3) | 0x038 <b>9</b> 10                     |                                                                             |  |
| Channel3 Tx Descriptor                           | 0x03C <b>9</b> 00 - 0x03C <b>9</b> 0F |                                                                             |  |
| Channel3 Current Tx Descriptor Pointer (S0CTDP3) | 0x03C <b>9</b> 10                     |                                                                             |  |
| Channel3 First Tx Descriptor Pointer (S0FTDP3)   | 0x03C <b>9</b> 14                     |                                                                             |  |

## Table 320: SDMA Group 0 Register Map (Continued)

| Description                                      | Offset                                | Page Number                                                                     |  |
|--------------------------------------------------|---------------------------------------|---------------------------------------------------------------------------------|--|
| Channel4                                         |                                       |                                                                                 |  |
| Channel4 Configuration Register (S0DC4)          | 0x040 <b>9</b> 00                     | For a description of the<br>Channel4 registers, see<br>the descriptions for the |  |
| Channel4 Command Register (S0DCM4)               | 0x040 <b>9</b> 08                     |                                                                                 |  |
| Channel4 Rx Descriptor                           | 0x048 <b>9</b> 00 - 0x048 <b>9</b> 0F | Channel 0 registers.                                                            |  |
| Channel4 Current Rx Descriptor Pointer (S0CRDP4) | 0x048 <b>9</b> 10                     |                                                                                 |  |
| Channel4 Tx Descriptor                           | 0x04C <b>9</b> 00 - 0x04C <b>9</b> 0F |                                                                                 |  |
| Channel4 Current Tx Descriptor Pointer (S0CTDP4) | 0x04C <b>9</b> 10                     |                                                                                 |  |
| Channel4 First Tx Descriptor Pointer (S0FTDP4)   | 0x04C <b>9</b> 14                     |                                                                                 |  |
| Channel5                                         |                                       |                                                                                 |  |
| Channel5 Configuration Register (S0DC5)          | 0x050 <b>9</b> 00                     | For a description of the                                                        |  |
| Channel5 Command Register (S0DCM5)               | 0x050 <b>9</b> 08                     | Channel5 registers, see<br>the descriptions for the<br>Channel 0 registers.     |  |
| Channel5 Rx Descriptor                           | 0x058 <b>9</b> 00 - 0x058 <b>9</b> 0F |                                                                                 |  |
| Channel5 Current Rx Descriptor Pointer (S0CRDP5) | 0x058 <b>9</b> 10                     |                                                                                 |  |
| Channel5 Tx Descriptor                           | 0x05C <b>9</b> 00 - 0x05C <b>9</b> 0F |                                                                                 |  |
| Channel5 Current Tx Descriptor Pointer (S0CTDP5) | 0x05C <b>9</b> 10                     | -                                                                               |  |
| Channel5 First Tx Descriptor Pointer (S0FTDP5)   | 0x05C <b>9</b> 14                     |                                                                                 |  |
| Channel6                                         |                                       |                                                                                 |  |
| Channel6 Configuration Register (S0DC6)          | 0x060 <b>9</b> 00                     | For a description of the                                                        |  |
| Channel6 Command Register (S0DCM6)               | 0x060 <b>9</b> 08                     | Channel6 registers, see<br>the descriptions for the<br>Channel 0 registers.     |  |
| Channel6 Rx Descriptor                           | 0x068 <b>9</b> 00 - 0x068 <b>9</b> 0F |                                                                                 |  |
| Channel6 Current Rx Descriptor Pointer (S0CRDP6) | 0x068 <b>9</b> 10                     |                                                                                 |  |
| Channel6 Tx Descriptor                           | 0x06C <b>9</b> 00 - 0x06C <b>9</b> 0F |                                                                                 |  |
| Channel6 Current Tx Descriptor Pointer (S0CTDP6) | 0x06C <b>9</b> 10                     |                                                                                 |  |
| Channel6 First Tx Descriptor Pointer (S0FTDP6)   | 0x06C <b>9</b> 14                     |                                                                                 |  |

## Table 320: SDMA Group 0 Register Map (Continued)



| Table 320: SDMA | Group 0 Regis | ter Map (Continued) |  |
|-----------------|---------------|---------------------|--|
|                 | Oloup v Regis | ter map (continueu) |  |

| Description                                      | Offset                                | Page Number                                      |
|--------------------------------------------------|---------------------------------------|--------------------------------------------------|
| Channel7                                         |                                       |                                                  |
| Channel7 Configuration Register (S0DC7)          | 0x070 <b>9</b> 00                     | For a description of the                         |
| Channel7 Command Register (S0DCM7)               | 0x070 <b>9</b> 08                     | Channel7 registers, see the descriptions for the |
| Channel7 Rx Descriptor                           | 0x078 <b>9</b> 00 - 0x078 <b>9</b> 0F | Channel 0 registers.                             |
| Channel7 Current Rx Descriptor Pointer (S0CRDP7) | 0x078 <b>9</b> 10                     |                                                  |
| Channel7 Tx Descriptor                           | 0x07C <b>9</b> 00 - 0x07C <b>9</b> 0F |                                                  |
| Channel7 Current Tx Descriptor Pointer (S0CTDP7) | 0x07C <b>9</b> 10                     |                                                  |
| Channel7 First Tx Descriptor Pointer (S0FTDP7)   | 0x07C <b>9</b> 14                     |                                                  |

### Table 321: SDMA Group 1 Register Map

| Description                                      | Offset                                | Page Number                                      |
|--------------------------------------------------|---------------------------------------|--------------------------------------------------|
| Channel0                                         |                                       |                                                  |
| Channel0 Configuration Register (S1DC0)          | 0x100 <b>9</b> 00                     | page 312                                         |
| Channel0 Command Register (S1DCM0)               | 0x100 <b>9</b> 08                     | page 314                                         |
| Channel0 Rx Descriptor                           | 0x108 <b>9</b> 00 - 0x108 <b>9</b> 0F | Not to be accessed dur-<br>ing normal operation. |
| Channel0 Current Rx Descriptor Pointer (S1CRDP0) | 0x108 <b>9</b> 10                     | page 316                                         |
| Channel0 Tx Descriptor                           | 0x10C <b>9</b> 00 - 0x10C <b>9</b> 0F | Not to be accessed dur-<br>ing normal operation. |
| Channel0 Current Tx Descriptor Pointer (S1CTDP0) | 0x10C <b>9</b> 10                     | page 316                                         |
| Channel0 First Tx Descriptor Pointer (S1FTDP0)   | 0x10C <b>9</b> 14                     | page 316                                         |
| Channel1                                         |                                       |                                                  |
| Channel1 Configuration Register (S1DC1)          | 0x110 <b>9</b> 00                     | For a description of the                         |
| Channel1 Command Register (S1DCM1)               | 0x110 <b>9</b> 08                     | Channel1 registers, see the descriptions for the |
| Channel1 Rx Descriptor                           | 0x118 <b>9</b> 00 - 0x118 <b>9</b> 0F | Channel 0 registers.                             |
| Channel1 Current Rx Descriptor Pointer (S1CRDP1) | 0x118 <b>9</b> 10                     |                                                  |
| Channel1 Tx Descriptor                           | 0x11C <b>9</b> 00 - 0x11C <b>9</b> 0F |                                                  |
| Channel1 Current Tx Descriptor Pointer (S1CTDP1) | 0x11C <b>9</b> 10                     |                                                  |
| Channel1 First Tx Descriptor Pointer (S1FTDP1)   | 0x11C <b>9</b> 14                     |                                                  |

| Description                                      | Offset                                | Page Number                                                                                             |  |
|--------------------------------------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------|--|
| Channel2                                         |                                       |                                                                                                         |  |
| Channel2 Configuration Register (S1DC2)          | 0x120 <b>9</b> 00                     | For a description of the<br>Channel2 registers, see<br>the descriptions for the                         |  |
| Channel2 Command Register (S1DCM2)               | 0x120 <b>9</b> 08                     |                                                                                                         |  |
| Channel2 Rx Descriptor                           | 0x128 <b>9</b> 00 - 0x128 <b>9</b> 0F | Channel 0 registers.                                                                                    |  |
| Channel2 Current Rx Descriptor Pointer (S1CRDP2) | 0x128 <b>9</b> 10                     |                                                                                                         |  |
| Channel2 Tx Descriptor                           | 0x12C <b>9</b> 00 - 0x12C <b>9</b> 0F |                                                                                                         |  |
| Channel2 Current Tx Descriptor Pointer (S1CTDP2) | 0x12C <b>9</b> 10                     |                                                                                                         |  |
| Channel2 First Tx Descriptor Pointer (S1FTDP2)   | 0x12C <b>9</b> 14                     |                                                                                                         |  |
| Channel3                                         | ·                                     |                                                                                                         |  |
| Channel3 Configuration Register (S1DC3)          | 0x130 <b>9</b> 00                     | For a description of the<br>Channel3 registers, see<br>the descriptions for the<br>Channel 0 registers. |  |
| Channel3 Command Register (S1DCM3)               | 0x130 <b>9</b> 08                     |                                                                                                         |  |
| Channel3 Rx Descriptor                           | 0x138 <b>9</b> 00 - 0x138 <b>9</b> 0F |                                                                                                         |  |
| Channel3 Current Rx Descriptor Pointer (S1CRDP3) | 0x138 <b>9</b> 10                     |                                                                                                         |  |
| Channel3 Tx Descriptor                           | 0x13C <b>9</b> 00 - 0x13C <b>9</b> 0F |                                                                                                         |  |
| Channel3 Current Tx Descriptor Pointer (S1CTDP3) | 0x13C <b>9</b> 10                     | -                                                                                                       |  |
| Channel3 First Tx Descriptor Pointer (S1FTDP3)   | 0x13C <b>9</b> 14                     |                                                                                                         |  |
| Channel4                                         |                                       |                                                                                                         |  |
| Channel4 Configuration Register (S1DC4)          | 0x140 <b>9</b> 00                     | For a description of the                                                                                |  |
| Channel4 Command Register (S1DCM4)               | 0x140 <b>9</b> 08                     | Channel4 registers, see<br>the descriptions for the<br>Channel 0 registers.                             |  |
| Channel4 Rx Descriptor                           | 0x148 <b>9</b> 00 - 0x148 <b>9</b> 0F |                                                                                                         |  |
| Channel4 Current Rx Descriptor Pointer (S1CRDP4) | 0x148 <b>9</b> 10                     |                                                                                                         |  |
| Channel4 Tx Descriptor                           | 0x14C <b>9</b> 00 - 0x14C <b>9</b> 0F |                                                                                                         |  |
| Channel4 Current Tx Descriptor Pointer (S1CTDP4) | 0x14C <b>9</b> 10                     | ]                                                                                                       |  |
| Channel4 First Tx Descriptor Pointer (S1FTDP4)   | 0x14C <b>9</b> 14                     |                                                                                                         |  |

## Table 321: SDMA Group 1 Register Map (Continued)



| Description                                      | Offset                                | Page Number                                                                 |  |  |
|--------------------------------------------------|---------------------------------------|-----------------------------------------------------------------------------|--|--|
| Channel5                                         |                                       |                                                                             |  |  |
| Channel5 Configuration Register (S1DC5)          | 0x150 <b>9</b> 00                     | For a description of the                                                    |  |  |
| Channel5 Command Register (S1DCM5)               | 0x150 <b>9</b> 08                     | Channel5 registers, see<br>the descriptions for the<br>Channel 0 registers. |  |  |
| Channel5 Rx Descriptor                           | 0x158 <b>9</b> 00 - 0x158 <b>9</b> 0F |                                                                             |  |  |
| Channel5 Current Rx Descriptor Pointer (S1CRDP5) | 0x158 <b>9</b> 10                     |                                                                             |  |  |
| Channel5 Tx Descriptor                           | 0x15C <b>9</b> 00 - 0x15C <b>9</b> 0F |                                                                             |  |  |
| Channel5 Current Tx Descriptor Pointer (S1CTDP5) | 0x15C <b>9</b> 10                     |                                                                             |  |  |
| Channel5 First Tx Descriptor Pointer (S1FTDP5)   | 0x15C <b>9</b> 14                     |                                                                             |  |  |
| Channel6                                         |                                       |                                                                             |  |  |
| Channel6 Configuration Register (S1DC6)          | 0x160 <b>9</b> 00                     | For a description of the                                                    |  |  |
| Channel6 Command Register (S1DCM6)               | 0x160 <b>9</b> 08                     | Channel6 registers, see the descriptions for the                            |  |  |
| Channel6 Rx Descriptor                           | 0x168 <b>9</b> 00 - 0x168 <b>9</b> 0F | Channel 0 registers.                                                        |  |  |
| Channel6 Current Rx Descriptor Pointer (S1CRDP6) | 0x168 <b>9</b> 10                     |                                                                             |  |  |
| Channel6 Tx Descriptor                           | 0x16C <b>9</b> 00 - 0x16C <b>9</b> 0F |                                                                             |  |  |
| Channel6 Current Tx Descriptor Pointer (S1CTDP6) | 0x16C <b>9</b> 10                     |                                                                             |  |  |
| Channel6 First Tx Descriptor Pointer (S1FTDP6)   | 0x16C <b>9</b> 14                     |                                                                             |  |  |
| Channel7                                         |                                       |                                                                             |  |  |
| Channel7 Configuration Register (S1DC7)          | 0x170 <b>9</b> 00                     | For a description of the                                                    |  |  |
| Channel7 Command Register (S1DCM7)               | 0x170 <b>9</b> 08                     | Channel7 registers, see the descriptions for the                            |  |  |
| Channel7 Rx Descriptor                           | 0x178 <b>9</b> 00 - 0x178 <b>9</b> 0F | Channel 0 registers.                                                        |  |  |
| Channel7 Current Rx Descriptor Pointer (S1CRDP7) | 0x178 <b>9</b> 10                     |                                                                             |  |  |
| Channel7 Tx Descriptor                           | 0x17C <b>9</b> 00 - 0x17C <b>9</b> 0F |                                                                             |  |  |
| Channel7 Current Tx Descriptor Pointer (S1CTDP7) | 0x17C <b>9</b> 10                     |                                                                             |  |  |
| Channel7 First Tx Descriptor Pointer (S1FTDP7)   | 0x17C <b>9</b> 14                     |                                                                             |  |  |

### Table 321: SDMA Group 1 Register Map (Continued)





### 14. MULTI PROTOCOL SERIAL CONTROLLER (MPSC)

The GT-96100A includes eight MPSCs that support:

- Bit oriented protocols (e.g. HDLC)
- Byte oriented protocols (e.g. BISYNC)
- Transparent protocols
- The UART (Start/Stop) mode.

All eight MPSCs can operate simultaneously. Four MPSCs can operate up to a guaranteed bit rate of 55Mbps while the remaining MPSCs can work up to guaranteed bit rate of 2Mbps (in NRZ/NRZI).

All eight MPSCs can be routed out via serial interface ports which implement interfaces like EIA-232 and V.34.

Alternatively, the MPSCs can be connected to the GT-96100A's FlexTDMs. A FlexTDM can also be used to connect the various MPSCs to a PCM highway bus or any other time slot assigner bus. See Section 15. "FlexTDM Units (FTDM)" on page 379 for a description of the FlexTDM.

### 14.1 DPLL

Each MPSC has a dedicated transmit and receive digital phase lock loop (DPLL).

The transmit DPLL encodes the transmit bit stream to the selected code and monitors the transmit clock for glitches. If a clock glitch is detected and the Glitch Detect Enable (GDE) bit in the Main Configuration register (MMCR) is set to '1', a maskable interrupt is generated.

The receive DPLL decodes the incoming bit stream according to the selected mode. If a code violation is detected (for example, no transition in Manchester code) the DE (Decoding Error) in the receive descriptor is set. The receive DPLL also performs clock recovery from the incoming bit stream and monitors the receive clock for glitches. If a clock glitch is detected and the Glitch Detect Enable (GDE) bit in the Main Configuration register (MMCR) is set to '1', a maskable interrupt is generated.



### 14.1.1 Data Encoding/Decoding

Figure 57 shows the data encoding and decoding schemes The GT-96100A DPLL supports.





### 14.1.2 DPLL Clock Source

Each received DPLL uses the MPSC receive clock input and each transmit DPLL uses the MPSC transmit clock input as its source clock.

**NOTE:** The GT-96100A DPLLs can accept a clock source of up to 83MHz. This allows the GT-96100A to have a bit rate of up to 5MHz using a 16X clock rate scheme.



### 14.1.3 Receive DPLL Clock Recovery

When a MPSC is programmed to work in Asynchronous mode, sampling rate on the DPLL Rx clock is configurable between 8, 16, 32, which means that the user should supply the MPSC with a clock source that is 8x, 16x, 32x of the bit rate, respectively. The clock source for the MPSC's RX can be the SCLK associated with that MPSC or one of the internal BRG's outputs. Selection of the MPSC's RX input clock is done using the RCRR register (see chapter 20, "physical signal routing" in the data sheet).

When not synchronized, the DPLL hunts for a start bit or edge. In UART mode, the DPLL hunts for start bit. In HDLC BISYNC and Transparent mode, the DPLL hunts for an edge. If hunting for a start bit (UART), the DPLL hunts for a falling edge, assuming it to be the beginning of a start bit. It then samples RxD at the middle of the bit, calculated from the falling edge of the start bit (8 ticks in x16 mode), to see that it is still '0'. If not, it is considered noise. A modulo 16 counter (for a 16x over-sampling rate) generates the receive clock RCLK.

In HDLC, BISYNC, and Transparent modes, the DPLL tries to lock itself on the transitions of the receive bit stream. When synchronization is achieved, the DPLL continuously monitors for rising and falling edges as defined in the MPSC Main Configuration Register (MMCR). When detecting an edge, the edge-compare logic gives the counter shift\_left or shift\_right commands to maintain lock on the received data.

### 14.2 MPSCx Main Configuration Register (MMCRx)

Each MPSC has an MPSC Main Configuration Register (MMCRx). The MMCRx is a 64 bit register used to configure common MPSC features. It is protocol independent. The MMCRx consists of two 32 bits registers, MMCRHx and MMCRLx, as shown below.



#### Figure 58: MPSC Main Configuration Register (MMCRx)

Unless otherwise specified:

- '1' means set
- '0' means not set
- '0' is the default value after reset.



### 14.2.1 MPSCx Main Configuration Register Low (MMCRLx)

 Table 322: MPSCx Main Configuration Register Low (MMCRLx), Offset: 0x000A00, 0x008A00, 0x010A00, 0x018A00, 0x020A00, 0x028A00, 0x030A00, 0x038A00

(where x is the port number 0 to 7)

| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | lnitial<br>Value |
|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 2:0  | MODE          | Mode<br>000 -HDLC (default)<br>001 -Reserved<br>010 -Reserved<br>011 -Reserved<br>100 -UART<br>101 -BISYNC<br>110 -Reserved<br>111 -Reserved                                                                                                                                                                                                                                                                                                                                | 0                |
| 3    | ТТХ           | Transparent Transmitter<br>0 - Normal Mode. (default)<br>1 - Transparent Mode. (Transparent Mode overrides the program mode in<br>MODE bits.)                                                                                                                                                                                                                                                                                                                               | 0                |
| 4    | TRX           | Transparent Receiver<br>0 - Normal Mode (default)<br>1 - Transparent Mode. (Transparent Mode overrides the program mode in<br>MODE bits.)                                                                                                                                                                                                                                                                                                                                   | 0                |
| 5    |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                |
| 6    | ET            | <ul> <li>Enable Transmit</li> <li>0 - Disabled. The Tx channel is in Low Power Mode.</li> <li>1 - Enable. The Tx controller is ready for data. When the SDMA has data to transmit it loads the data to the Tx controller, that will transmit the data in the selected protocol.</li> </ul>                                                                                                                                                                                  | 0                |
| 7    | ER            | Enable Receive<br>0 - Disabled. The Rx channel is in Low Power Mode.<br>1 - Enable. The Rx controller is ready to receive data.                                                                                                                                                                                                                                                                                                                                             | 0                |
| 9:8  | LPBK          | Loop Back (for diagnostic) mode<br>00 -Normal Operation, no loopback (Default)<br>01 -Loopback<br>10 -Echo<br>11 -Loop Back + Echo<br>In loopback mode, which is only for diagnostic purposes, the transmitted data<br>on TxD is fed into RxD. In this mode, the same clock source should be used<br>for both Rx and TX.<br>Echo mode re-transmits received data on RxD (with one clock delay) on TxD.<br>If CD* is asserted, the receiver also receives the incoming data. | 00               |

## Table 322: MPSCx Main Configuration Register Low (MMCRLx), Offset: 0x000A00, 0x008A00,<br/>0x010A00, 0x018A00, 0x020A00, 0x028A00, 0x030A00, 0x038A00<br/>(where x is the port number 0 to 7) (Continued)

| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Initial<br>Value |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 10   | NLM           | <ul> <li>Null Modem</li> <li>0 - Normal operation. The MPSC uses the CD* and CTS* inputs to control the data flow</li> <li>1 - Null Modem. The MPSC CD* and RTS* internal signals are always asserted. The external pin status can be still read from the Event Register.</li> <li>NOTE: For information about the behavior of the Event Register in different modes, see: <ul> <li>Section "The ESR register holds information on the transmit/ receive channel condition." on page 345.</li> <li>Section 14.6.5.6 "CHR10 - BISYNC Event Status Register (ESR)" on page 360.</li> <li>Section 14.7.5.7 "CHR10 - UART Event Status Register (ESR)" on page 371.</li> <li>Section 14.8.2.3 "CHR10 - Transparent Event Status Register (ESR)" on page 378.</li> </ul> </li> </ul> | 0                |
| 11   |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                |
| 12   | TSYN          | <ul> <li>Transmitter Synchronize to Receiver</li> <li>Setting this bit synchronizes the transmitter to receiver byte boundaries. This is particularly important in the X.21 protocol.</li> <li>0 - No synchronization assumed.</li> <li>1 - Transmit bit stream is synchronized to the receive bit stream. This bit affects only a transparent transmitter. Transmitter will start transmission nx8 bit period after the receive data arrives. If CTS* is already asserted, the transparent transmitter will start transmit 8 clocks after the receiver starts to receive data.</li> <li>NOTE: Only this bit when transmit and receive clocks are equal and TCDV and RCDV are set to '00'.</li> </ul>                                                                           | 0                |
| 13   |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                |



## Table 322: MPSCx Main Configuration Register Low (MMCRLx), Offset: 0x000A00, 0x008A00,<br/>0x010A00, 0x018A00, 0x020A00, 0x028A00, 0x030A00, 0x038A00<br/>(where x is the port number 0 to 7) (Continued)

| Dite  | Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Initial |
|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| Bits  | Name  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Value   |
| 15:14 | TSNS  | Transmit Sense.<br>Defines the number of bit times the internal sense signal will stay active after<br>last transition on the RXD line occurs. It is useful for AppleTalk protocol to<br>avoid the spurious CD* change interrupt that would otherwise occur during<br>the frame synchronization sequence that precedes the opening flag. The<br>delay is a function of RCDV (clock divider) setting.<br>00 (RCDV = 0) - Infinite (Carrier Sense is always active - default)<br>00 (RCDV $\neq$ 0) - Infinite (Carrier Sense is always active - default)<br>01 (RCDV $\neq$ 0) - 14 bit times<br>01 (RCDV $\neq$ 0) - 6.5 bit times<br>10 (RCDV $\neq$ 0) - 4 bit times (normal AppleTalk)<br>10 (RCDV $\neq$ 0) - 2.5 bit times (normal AppleTalk)<br>11 (RCDV $\neq$ 0) - 1 bit times | 0       |
| 16    | TIDL  | Transmit Idles<br>0 - TxD is encoded during data transmission (including preamble and flags/<br>sync patterns). TxD is in MARK during idle. (Default.)<br>1 - TxD is encoded all the time, even when idles are transmitted. Table 323.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0       |
| 17    | RTSM  | RTS* Mode<br>This bit may be changed on the fly.<br>0 - Send IDLE between frames. RTS* is negated between frames. IDLE pat-<br>tern is defined by the protocol and TIDL bit.<br>1- Send flags/syncs between frames according to the protocol. RTS* is<br>always asserted. Refer to Table 323.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0       |
| 18    |       | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0       |
| 19    | CTSS  | CTS* Sampling Mode<br>0 - Asynchronous CTS*. CTS* is synchronized inside the GT-96100A. Trans-<br>mission starts after synchronization is achieved with a few cycles delay to the<br>external CTS*. (Default)<br>1 - Synchronous CTS*. CTS* is synchronized to the Rx clock. This mode is<br>recommended when connecting an MPSC to a FlexTDM.<br><b>NOTE:</b> Synchronous CTS* must be used for ISDN D channels.                                                                                                                                                                                                                                                                                                                                                                      | 0       |
| 20    | CDS   | CD* Sampling mode<br>0 - Asynchronous CD*. CD* is synchronized internally in the GT-96100A and<br>then data is received. (Default)<br>1 - Synchronous CD*. CD* is synchronized to the Rx clock. This mode is rec-<br>ommended when connecting an MPSC to a Flex-TDM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0       |

## Table 322: MPSCx Main Configuration Register Low (MMCRLx), Offset: 0x000A00, 0x008A00,<br/>0x010A00, 0x018A00, 0x020A00, 0x028A00, 0x030A00, 0x038A00<br/>(where x is the port number 0 to 7) (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                        | Initial<br>Value |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 21    | CTSM          | CTS* Operating Mode<br>0 - Normal mode. (Envelop Mode). CTS* should envelop the frame. Deasser-<br>tion of CTS* during transmission will cause a CTS lost error.<br>1- Pulse Mode. Once CTS* is sampled low, synchronization has been<br>achieved. Further transitions of CTS* have no effect. CTS* synchronization<br>will be lost when RTS* is deasserted.                                    | 0                |
| 22    | CDM           | <ul> <li>CD* Operating Mode</li> <li>0- Normal mode. (Envelop Mode). CD* should envelop the frame. Deassertion of CD* during reception will cause a CD lost error.</li> <li>1- Pulse Mode. Once CD* is sampled low, synchronization has been achieved. Further transitions of CD* have no effect.</li> </ul>                                                                                    | 0                |
| 25:23 | CRCM          | CRC Mode<br>000 - CRC16-CCITT (HDLC based protocols, e.g. X.25) (Default)<br>001 - CRC-16 (BISYNC)<br>010 - CRC32-CCITT (HDLC based protocols, e.g. LAP-D. Identical to the<br>Ethernet CRC)<br>011 - Reserved<br>1XX- Reserved                                                                                                                                                                 | 010              |
| 27:26 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       | 0                |
| 28    | TRVD          | Transmit Reverse Data<br>0 - Normal Mode. (Default)<br>1 - Reverse Data Mode. MSB is shifted out first.                                                                                                                                                                                                                                                                                         | 0                |
| 29    | RRVD          | Receive Reverse Data<br>0 - Normal Mode. (Default)<br>1 - Reverse Data Mode. MSB is shifted in first.                                                                                                                                                                                                                                                                                           | 0                |
| 30    |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       | 0                |
| 31    | GDE           | <ul> <li>Glitch Detect Enable</li> <li>0 - Normal mode. No glitch detect. (Default)</li> <li>1 - When glitch is detect, a maskable interrupt is generated.</li> <li>When this bit is set the MPSC looks for glitches in the external receive and transmit clocks.</li> <li>NOTE: The GT-96100A tries to clean the input clocks by receiving them via a Schmitt trigger input buffer.</li> </ul> | 0                |



| RTSM/TIDL | TxD               | RTS* | TxD          | RTS* |
|-----------|-------------------|------|--------------|------|
| 00        | '1' Not Encoded   | 1    | Data Encoded | 0    |
| 01        | '1' Encoded       | 1    | Data Encoded | 0    |
| 10        | Flags/Not Encoded | 0    | Data Encoded | 0    |
| 11        | Flags/Encoded     | 0    | Data Encoded | 0    |

### The following table summarizes the relationship between the TIDL and RTSM Table 323: TIDL/RTSM Relationship

### 14.2.2 MPSCx Main Configuration Register High (MMCRHx)

### Table 324: MPSCx Main Configuration Register High (MMCRHx), Offset: 0x000A04, 0x008A04, 0x010A04, 0x018A04, 0x020A04, 0x028A04, 0x030A04,0x038A04

(where x is the port number 0 to 7)

| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                             | Initial<br>Value |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0    | TCI           | Transmit Clock Invert<br>0 - Normal operation - Data is shifted out on the falling edge. (Default.)<br>1 -The internal transmit clock is inverted by the MPSC before it is used. This<br>allows the MPSC to clock data out half a cycle earlier on the rising edge of<br>the clock.                                                  | 0                |
| 1    | TINV          | Transmit bit stream inversion<br>0 - No invert.<br>1 - Invert the data before it is sent to the DPLL. Setting TINV to '1' generates<br>FM1 from FM0, NRZI mark from NRZI space, etc. It also inverts the bit<br>stream in NRZ mode.                                                                                                  | 0                |
| 4:2  | TPL           | Transmit Preamble Length<br>Determines the number of preamble bytes the transmitter sends before it<br>starts to transmit data. The send pattern is defined by the TPPT bits.<br>000 - No Preamble (Default)<br>001 - 1 byte<br>010 - 2 bytes<br>011 - 4 bytes<br>100 - 6 bytes<br>101 - 8 bytes<br>110 - 16 bytes<br>111 - Reserved | 0                |
| 8:5  | TPPT          | Transmit Preamble Pattern<br>Defines a character sent as a preamble sequence. Two TPPT characters<br>form a preamble byte. The number of preamble bytes sent is defined by the<br>TPL field. The receiving DPLL uses the preamble pattern to lock on the<br>receiving signal.                                                        | 0                |

# Table 324: MPSCx Main Configuration Register High (MMCRHx), Offset: 0x000A04, 0x008A04,<br/>0x010A04, 0x018A04, 0x020A04, 0x028A04, 0x030A04,0x038A04<br/>(where x is the port number 0 to 7) (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                      | Initial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 10:9  | TCDV          | Transmit Clock Divider<br>Defines the transmit clock divider. The transmit bit rate is the rate of the clock<br>entering the MPSC Tx machine (from external pin or a BRG) divided by the<br>TCDV field. For FM0, FM1, Manchester, and Differential Manchester, one of<br>the 8x, 16x, or 32x options must be set.<br>00 - 1x clock mode (Default. For NRZ and NRZI only.)<br>01 - 8x clock mode<br>10 - 16x clock mode<br>11 - 32x clock mode | 0                |
| 13:11 | TDEC          | Transmit Encoder<br>Specifies the encoding method for the dedicated Tx channel DPLL.<br>000 - NRZ (default)<br>001 - NRZI (mark, can be set to Space by setting TINV bit)<br>010 - FM0 (can be set to FM1 by setting the TINV bit)<br>011 - Reserved<br>100 - Manchester<br>101 - Reserved<br>110 - Differential Manchester<br>111 - Reserved                                                                                                 | 0                |
| 15:14 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                |
| 16    | RINV          | <ul> <li>Receive Bit Stream Inversion.</li> <li>0 - No invert.</li> <li>1 - Inverts the data before it is sent from the DPLL to the MPSC data path.</li> <li>Setting RINV to '1' decodes FM1 and NRZI mark when the RENC field is programed to FM0 and NRZI space etc. It also inverts the received bit stream in NRZ mode.</li> </ul>                                                                                                        | 0                |
| 20:17 | GDW           | Clock Glitch Width<br>When the GDE bit is set, the MPSC will consider Tx/Rx clock pulses that are<br>narrower than GDW system clocks as a glitch.                                                                                                                                                                                                                                                                                             | 0                |
| 21    |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                |



## Table 324: MPSCx Main Configuration Register High (MMCRHx), Offset: 0x000A04, 0x008A04,<br/>0x010A04, 0x018A04, 0x020A04, 0x028A04, 0x030A04,0x038A04<br/>(where x is the port number 0 to 7) (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Initial<br>Value |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 22    | RDW           | <ul> <li>Receive Data Width</li> <li>0 - Normal mode. The MPSC data path is 16 bits wide. Upon receiving 16 bits, the data is transferred into the SDMA FIFOs. Buffers must be 64-bit word aligned. DMA bursts are enabled.</li> <li><b>NOTE:</b> Normal Mode must be used for HDLC based protocols.</li> <li>1 - Low latency operation. Data is transferred to the FIFOs after 8 bits are received. Logical FIFO width is one byte.</li> <li><b>NOTE:</b> This mode allows byte aligned buffers. This mode must be chosen for BISYNC and UART modes. DMA bursts are disabled. The SDMA writes one byte per DRAM access. Setting RDW also bypasses the receive FIFO threshold. The SDMA arbitrates for DMA access as soon as the FIFO has one byte in it.</li> </ul> | 0                |
| 24:23 | RSYL          | Receive Sync Length (BISYNC and Transparent Modes)<br>00 - External sync (CD* assertion)<br>01 - 4-bit sync<br>10 - 8-bit sync (MonoSYNC)<br>11 - 16-bit sync (BISYNC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                |
| 26:25 | RCDV          | Receive Clock Divider<br>Defines the receive clock divider. The receive bit rate is the rate of the clock<br>entering the MPSC Rx machine (from external pin or a BRG) divided by the<br>RCDV field. For FM0, FM1, Manchester, and Differential Manchester, one of<br>the 8x, 16x, or 32x options must be set.<br>00 - 1x clock mode (Default. For NRZ and NRZI only.)<br>01 - 8x clock mode<br>10 - 16x clock mode<br>11 - 32x clock mode                                                                                                                                                                                                                                                                                                                           | 0                |
| 29:27 | RENC          | Receive Encoder<br>Specifies the encoding method for the dedicated Rx channel DPLL.<br>000 - NRZ (default)<br>001 - NRZI (Mark, can be set to Space by setting RINV bit)<br>010 - FM0 (can be set to FM1 by setting the RINV bit)<br>011 - Reserved<br>100 - Manchester<br>101 - Reserved<br>110 - Differential Manchester<br>111 - Reserved                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                |



# Table 324: MPSCx Main Configuration Register High (MMCRHx), Offset: 0x000A04, 0x008A04,<br/>0x010A04, 0x018A04, 0x020A04, 0x028A04, 0x030A04,0x038A04<br/>(where x is the port number 0 to 7) (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                     | lnitial<br>Value |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 31:30 | SEDG          | Synchronization Clock Edge<br>The clock edge used by the DPLL for adjusting the receive sample point due<br>to drift in the receive signal.<br>00 - Both rising and falling edges. (Default.)<br>01 - Rising edge<br>10 - Falling edge<br>11 - No adjustment | 0                |



### 14.3 MPSCx Protocol Configuration Registers (MPCRx)

Each MPSC has a dedicated Protocol Configuration Register (MPCRx).

The MPCRx registers are located at base+08 relative to the corresponding MPSC Main Configuration Register (MMCRx). The functionality of the MPCRx is protocol dependent. Detailed descriptions of the MPCRs are given in the following protocol sections.

### 14.4 Channel Registers (CHxRx)

Each MPSC and the ethernet controller has ten dedicated Channel Registers (CHxRx) to program the MPSC or ethernet controller.

The CHxRx registers are located at base+0xC0 through base+0x30 relative to the corresponding MPSC Main Configuration Register (MMCRx). The functionality of the CHxRx is protocol dependent. Detailed descriptions of the CHRs are given in the following protocol sections.

### 14.5 HDLC Mode

### 14.5.1 HDLC Receive/Transmit Operation

In HDLC mode, an MPSC performs the following protocol functions:

- Flag generation and stripping
- Bit stuffing and stripping
- Address recognition (up to 16 bit addresses)
- CRC generation and checking
- Line condition monitoring
- LocalTalk preamble generation
- LocalTalk trailing abort generation

#### Figure 59: Typical HDLC Frame

| FLAG   | ADDRESS      | CONTROL   | INFORMATION        | CRC        | FLAG   |
|--------|--------------|-----------|--------------------|------------|--------|
| 8 Bits | 8/16/8N Bits | 8/16 Bits | 8N Bits (Optional) | 16/32 Bits | 8 Bits |

#### Figure 60: Typical LocalTalk Frame

| PPulse   | FLAG   | FLAG       | Des ADD   | Src ADD      | LLAP Type | Length       | Data         | CRC     | FLAG   | Abort     |
|----------|--------|------------|-----------|--------------|-----------|--------------|--------------|---------|--------|-----------|
| > 3 Bits | 8 Bits | 8 Bits     | 8bits     | 8bits        | 8 Bits    | 10 Bits      | 0 -598 Bytes | 16 Bits | 8 Bits | 12-18 Bit |
|          | At lea | ast the pr | eamble bi | it is not de | ecoded.   | 6 Reserved E | lits         |         |        |           |



### 14.5.2 SDMAx Command/Status Field for HDLC Mode

When an MPSC is in HDLC mode, the Command/Status field in the corresponding SDMAx descriptor has the following format:

| Bit   | Rx - Function                                                                              | Tx - Function                                              |
|-------|--------------------------------------------------------------------------------------------|------------------------------------------------------------|
| 0     | CE - CRC Error                                                                             | Reserved                                                   |
| 1     | CDL - CD Loss                                                                              | CTSL - CTS Loss                                            |
| 2     | DE - Decoding Error                                                                        | Reserved                                                   |
| 3     | NO - Non Octet Frame                                                                       | D-deferred. Transmission was deferred due to busy channel. |
| 4     | ABR - Abort Sequence/Residue[0]                                                            | Reserved                                                   |
| 5     | Residue[1]                                                                                 | Reserved                                                   |
| 6     | OR - Data Overrun/Residue[2]                                                               | UR - Data Underrun                                         |
| 7     | MFL - Max Frame Length Err                                                                 | Reserved                                                   |
| 8     | SF - Short Frame                                                                           | RL - Retransmit Limit Error                                |
| 9     | Reserved                                                                                   | COL - Collision Occurred                                   |
| 13:10 | Reserved                                                                                   | RC-Retransmit Count (LAN HDLC mode only)                   |
| 14    | Reserved                                                                                   | Reserved                                                   |
| 15    | ES - Error Summary<br>ES = CE    CDL    DE    NO    ABR    OR    MFL<br>   SF <sup>1</sup> | Error Summary<br>ES = CTSL    UR    RL <sup>1</sup>        |
| 16    | L - last                                                                                   | L - Last                                                   |
| 17    | F - First                                                                                  | F - First                                                  |
| 21:18 | Reserved                                                                                   | Reserved                                                   |
| 22    | Reserved                                                                                   | GC - Generate CRC                                          |
| 23    | EI - Enable Interrupt                                                                      | EI - Enable Interrupt                                      |
| 29:24 | Reserved                                                                                   | Reserved                                                   |
| 30    | AM - Auto Mode                                                                             | AM - Auto Mode                                             |
| 31    | O -Owner                                                                                   | O - Owner                                                  |

Table 325: SDMAx Command/Status Field for HDLC Mode

1. "||" means logical OR.



### 14.5.3 MPSCx Protocol Configuration Register (MPCRx) for HDLC

#### Figure 61: MPSCx Protocol Configuration Register (MPCRx) for HDLC

|           | 3 3 2 2 2 2 2 2 2 2 2 2 2 1 1 1 1<br>1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 |     |       |
|-----------|----------------------------------------------------------------------|-----|-------|
| Base + 08 |                                                                      | NOF | MPCRX |

#### Table 326: MPSCx Protocol Configuration Register (MPCRx) for HDLC, Offset: 0x000A08, 0x008A08, 0x010A08, 0x018A08, 0x020A08, 0x028A08, 0x030A08, 0x038A08 (where x is the port number 0 to 7)

| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | lnitial<br>Value |
|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1:0  |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                |
| 2    | LCT           | <ul> <li>Local Talk</li> <li>When set, the following LocalTalk support is added to the HDLC controller: <ul> <li>Two abort sequences will be generated at the end of frame following its closing flag.</li> <li>A preamble will be generated. No encoding will be done for the last preamble bit</li> </ul> </li> <li>When working with LocalTalk, the FM0 Encoding Scheme should be set by writing '010' to RENC and TDEC in the MMCRx. The user should also set TPPT to 0xF and TPL to '1' (one byte preamble). The last preamble bit is not decoded. This must be done for LocalTalk RTS frames. Setting TPL to '0' leads to a frame without preamble. This can be used with LocalTalk data frames. Setting TPL to other values leads to unpredictable results.</li> </ul>                                                                                                                                          | 0                |
| 3    |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                |
| 4    | ССМ           | <ul> <li>CRC Compliance Mode.</li> <li>In HDLC, the TX side uses bit stuffing to prevent a data/CRC pattern from looking like an HDLC control flag. The CCM tells the Rx side how to handle frames that were received with mistakes in bit stuffing, when they occur immediately before the end flag. This is a borderline condition that may or may not present a problem in actual systems.</li> <li>0 - Compatible Mode. If the Rx side receives a frame that is missing a stuffed bit that is supposed to be immediately before the End Flag, then mark in the descriptor that the frame has a good CRC, and pass the good CRC along to the buffer.</li> <li>1 - Compliance Mode. If the Rx side receives a frame that is missing a stuffed bit that is supposed to immediately proceed the End Flag, then mark in the descriptor that the frame has a bad CRC, and pass the errored CRC to the buffer.</li> </ul> |                  |
| 5    |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                |

## Table 326: MPSCx Protocol Configuration Register (MPCRx) for HDLC, Offset: 0x000A08,<br/>0x008A08, 0x010A08, 0x018A08, 0x020A08, 0x028A08, 0x030A08, 0x038A08<br/>(where x is the port number 0 to 7) (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                     | Initial<br>Value |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 6     | DRT           | Disable Rx on Tx<br>When DRT is set to '1' the Rx path is closed during Tx. This is useful in mul-<br>tidrop configurations when a user doesn't want to receive its own frames.                                                                                                                                                              | 0                |
| 8:7   |               | Reserved.                                                                                                                                                                                                                                                                                                                                    | 0                |
| 9     | CLM           | Collision Mode.<br>When set to '1', the MPSC transceiver tries to retransmit a frame after a CTS lost. This mode allows automatic collision resolution for an ISDN LAP-D type channel.                                                                                                                                                       | 0                |
| 11:10 |               | Reserved.                                                                                                                                                                                                                                                                                                                                    | 0                |
| 15:12 | NOF           | Number of Flags<br>Specifies the number of flags transmitted between consecutive frames.<br>Setting NOF to '0' specifies shared flag mode. In shared flag mode, the clos-<br>ing flag of a frame is used as the opening flag of the following frame. This<br>setting also puts the receiver in back-to-back mode.<br>The default value is 1. | 1                |
| 31:16 |               | Reserved.                                                                                                                                                                                                                                                                                                                                    | 0                |



### 14.5.4 Channel Registers (CHxRx) for HDLC Mode



#### Figure 62: Channel Registers (CHxRx) for HDLC



Unless otherwise specified:

- '1' means set.
- '0' means not set.
- '0' is the default value after reset.

### Table 327: CHxR1 - Sync/Abort Register (SYNR), Offset: 0x000A0C, 0x008A0C, 0x010A0C, 0x018A0C, 0x020A0C, 0x028A0C, 0x030A0C, 0x038A0C (where x is channel 0 to 7)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                       | Initial<br>Value |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 7:0   | SYNC          | Holds the synchronization pattern for the receive machine and opening/<br>closing flag/sync-pattern for the transmit machine.<br>This is an HDLC Abort Pattern so no additional programing is needed for<br>the HDLC protocol. | 7E               |
| 15:8  |               | Reserved                                                                                                                                                                                                                       | 0                |
| 23:16 | Abort         | The abort pattern is transmitted upon receiving an abort command or when an UnderRun event occurs.<br>This is an HDLC Abort Pattern so no additional programing is needed for the HDLC protocol.                               | FE               |
| 31:24 |               | Reserved                                                                                                                                                                                                                       | 0                |

### Table 328: CHxR2 - Command Register (CR), Offset: 0x000A10, 0x008A10, 0x010A10, 0x018A10, 0x020A10, 0x028A10, 0x030A10, 0x038A10 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                        | Resetv<br>Value |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 6:0   |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                       | 0               |
| 7     | A             | Abort Transmission<br>Abort transmission immediately and go to IDLE. The descriptor is not<br>closed or incremented.<br><b>NOTE:</b> Command is not synchronized to byte.                                                                                                                                                                                                                                                       | 0               |
| 22:8  |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                       | 0               |
| 23    | A             | Abort Reception<br>Abort receive immediately and go to IDLE. The descriptor is not closed or<br>incremented. The processor must issue enter hunt command after abort<br>command in order to enable reception. The bit is cleared upon entering<br>IDLE state.<br>After executing an Abort Reception, the CPU must disable the Tx SDMA<br>channel. The CPU then needs to execute a normal initialization process to<br>the MPSC. | 0               |
| 30:24 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                       | 0               |



| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                         | Resetv<br>Value |
|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 31   | EH            | Enter Hunt<br>Upon receiving the Enter Hunt command, the receive machine moves to<br>HUNT state and continuously searches for an opening flag. If enter hunt<br>mode command is issued during frame reception, the current descriptor is<br>closed with CRC error <sup>1</sup> . The EH bit is cleared upon entering Hunt state. | 0               |
| N/A  | TD            | Transmit Demand<br>Fetch a descriptor and start transmission.<br>Issued through the SDMAx Command Register.                                                                                                                                                                                                                      |                 |
| N/A  | Stop          | Stop<br>Complete frame transmission and stop. (Go to IDLE).<br>Issued through the SDMAx Command Register.                                                                                                                                                                                                                        |                 |

### Table 328: CHxR2 - Command Register (CR), Offset: 0x000A10, 0x008A10, 0x010A10, 0x018A10, 0x020A10, 0x028A10, 0x030A10, 0x038A10 (where x is channel 0 and 7)

1. The reception process for this purpose begins after proper address recognition is allowed. Before achieving an address match, the receiver goes to Enter Hunt state without closing the descriptor.

**NOTES:**The ET bit in the Main Configuration Register must be set to '1' before issuing the following Transmit Demand, Stop Transmission, or Abort Transmission commands.

The ER bit in the Main Configuration Register must be set to '1' before issuing the Enter Hunt or Abort Reception commands.

When the ET or ER bits are deasserted, the MPSCx transmit/receive channel is in low power mode (NO CLOCK). Issuing one of the above commands in this state will lead to unpredictable results.

## Table 329: CHxR3 - Maximum Frame Length Register (MFLR), Offset: 0x000A14, 0x008A14, 0x010A14, 0x018A14, 0x020A14, 0x028A14, 0x030A14, 0x038A14 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                      | lnitial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 15:0  | FLBR          | Frame Length Buffer Register<br>Holds the maximum allowed frame length. When a frame exceeds the num-<br>ber written in the FLBR, the remainder of the frame is discarded. The HDLC<br>controller waits for a closing flag and then returns the frame status with bit 7<br>(MFLE) set to '1'. | 0xFFFF           |
| 31:16 |               | Reserved.                                                                                                                                                                                                                                                                                     | 0                |

### Table 330: CHxR4 - Address Filtering Register (ADFR), Offset: 0x000A18, 0x008A18, 0x010A18,<br/>0x018A18, 0x020A18, 0x028A18, 0x030A18, 0x038A18 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                         | Initial<br>Value |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 15:0  | BCE           | <ul> <li>Bit Comparison Enable Bits</li> <li>Setting '1' in one of the BCE bits enables the address comparison for this bit: <ul> <li>For 16-bit LAP-D like address recognition, write 0xFFFF in ADFR.</li> <li>For 8-bit HDLC/LAP-B like address recognition, write 0x00FF in ADFR.</li> <li>For reception of a predefined address group, write '0' to the appropriate bits to disable address comparison on these bits.</li> </ul> </li> </ul> | 0                |
| 28:16 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0                |
| 29    | Ν             | Null Enable<br>Enables the reception of HDLC NULL address (0x0000 or 0x00 depending<br>on the BCE setting)                                                                                                                                                                                                                                                                                                                                       | 0                |
| 30    |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0                |
| 31    | В             | Broadcast Enable<br>Enables the reception of HDLC broadcast address (0xFFFF or 0xFF,<br>depending on the BCE setting).                                                                                                                                                                                                                                                                                                                           | 0                |

### Table 331: CHxR5 - Short Frame Register (SHFR), Offset: 0x000A1C, 0x008A1C, 0x010A1C,<br/>0x018A1C, 0x020A1C, 0x028A1C, 0x030A1C, 0x038A1C (where x is channel 0 and 7)

| Bits | Field<br>Name | Function                                                                                                                                       | lnitial<br>Value |
|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 2:0  | SHFR          | Short Frame Register<br>Setting SHFR to '1' enables the Short Frame Error report. Short Frames<br>are frames with byte count less than 3+SHFR. | 0                |
| 31:3 |               | Reserved.                                                                                                                                      | 0                |

### Table 332: CHxR6 - Address 1 and 2 Register (ADLR), Offset: 0x000A20, 0x008A20, 0x010A20, 0x018A20, 0x020A20, 0x028A20, 0x030A20, 0x038A20 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Function                                                                        | Reset<br>Value |
|-------|---------------|---------------------------------------------------------------------------------|----------------|
| 15:0  | AD1           | Address 1<br>A 16-bit address that can be used for receive address recognition. | 0              |
| 31:16 | AD2           | Address 2<br>A 16-bit address used for receive address recognition.             | 0              |



### Table 333: CHxR7 - Address 3 and 4 Register (ADHR), Offset: 0x000A24, 0x008A24, 0x010A24, 0x018A24, 0x020A24, 0x028A24, 0x030A24, 0x038A24 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Function                                                                        | Reset<br>Value |
|-------|---------------|---------------------------------------------------------------------------------|----------------|
| 15:0  | AD3           | Address 3<br>A 16-bit address that can be used for receive address recognition. | 0              |
| 31:16 | AD4           | Address 4<br>A 16-bit address that can be used for receive address recognition. | 0              |

### Table 334: CHxR8 - Reserved, Offset: 0x000A28, 0x008A28, 0x010A28, 0x018A28, 0x020A28, 0x020A28, 0x028A28, 0x030A28, 0x038A28 (where x is channel 0 and 7)

| Bits | Field<br>Name | Function                                                                | lnitial<br>Value |
|------|---------------|-------------------------------------------------------------------------|------------------|
| 31:0 |               | Reserved.<br><b>NOTE:</b> Do not access this register in the HDLC mode. | 0                |
|      |               |                                                                         |                  |

### Table 335: CHxR9 - Reserved, Offset: 0x000A2C, 0x008A2C, 0x010A2C, 0x018A2C, 0x020A2C, 0x028A2C, 0x030A2C, 0x038A2C (where x is channel 0 and 7)

| Bits | Field<br>Name | Function                                                                | Reset<br>Value |
|------|---------------|-------------------------------------------------------------------------|----------------|
| 31:0 |               | Reserved.<br><b>NOTE:</b> Do not access this register in the HDLC mode. | 0              |
|      |               |                                                                         |                |

The ESR register holds information on the transmit/receive channel condition.

CHR10 can be read by the CPU for channel condition resolution. Some changes in the channel condition can generate maskable interrupts, as shown below.

### Table 336: CHxR10 - Event Status Register (ESR), Offset: 0x000A30, 0x008A30, 0x010A30, 0x018A30, 0x020A30, 0x028A30, 0x030A30, 0x038A30 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Function                                                                                          | Initial<br>Value |
|-------|---------------|---------------------------------------------------------------------------------------------------|------------------|
| 0     | CTS           | Clear To Send Signal<br>An interrupt is generated when this signal is deasserted during transmit. | 0                |
| 1     | CD            | Carrier Detect Signal<br>An interrupt is generated when this signal is deasserted during receive. | 0                |
| 2     |               | Reserved.                                                                                         | 0                |
| 3     | TIDLE         | Tx in IDLE state.<br>An interrupt is generated upon entering IDLE state.                          | 0                |
| 4     |               | Reserved.                                                                                         | 0                |
| 5     | RHS           | Rx in HUNT state.                                                                                 | 0                |
| 10:6  |               | Reserved.                                                                                         | 0                |
| 11    | RLIDL         | 1 = Rx IDLE Line                                                                                  | 0                |
| 12    | DPCS          | 1 = DPLL Carrier Sense.                                                                           | 0                |
| 13    | RRF           | 1 = Rx Receiving Flags.                                                                           | 0                |
| 31:14 |               | Reserved.                                                                                         | 0                |



### 14.6 BISYNC Mode

The GT-96100A BISYNC controller was designed to reduce CPU overhead by executing most of the protocol requirements for BISYNC/MonoSYNC mode without CPU interference.

When Auto Transparent mode is enabled, the GT-96100A automatically switches to the transparent receive mode upon receiving a DLE STX sequence.

Other features are controlled by programming the bank of control registers.

#### Figure 63: Typical BISYNC/MonoSYNC Frames

|      | MOI   | NOSY   | 'NC    |       |         |             |                  |     |
|------|-------|--------|--------|-------|---------|-------------|------------------|-----|
|      | SYN   |        | DATA   |       |         |             |                  |     |
| BISY | NC Te | xt Wi  | h Hea  | der   |         |             |                  |     |
| SYN  | SYN   | SOH    | HEA    | DER   | STX     | TEXT        | ETX<br>or<br>ETB | BCC |
|      |       |        | BISY   | NC Te | ext Wit | hout Header |                  |     |
|      |       |        | SYN    | SYN   | STX     | TEXT        | ETX<br>or<br>ETB | BCC |
| BIS  | YNC 1 | Fransp | parent |       |         |             |                  |     |
| SYN  | N SYN | N DLE  | E STX  | ĸ     |         | TEXT DLE    | ETX<br>or<br>ETB | BCC |

### 14.6.1 BISYNC Transmit Operation

In BISYNC mode an MPSC handles the following protocol functions:

- Leading SYNC character transmission before a buffer with F bit set.
- Optional 32-bit transmission before the SYNC transmission.
- DLE transmission before a buffer with the TD bit set.
- BCC generation:
  - BCC (CRC-16, VRC/LRC and VRC/CRC-16) is calculated.
  - Buffers with BCE set to '0' are excluded from BCC calculation.
  - CRC reset is controlled from the RC bit in Tx descriptor.
  - The calculation of BCC is sent or discarded according to the GC bit in the Tx descriptor.
  - Automatic stuffing of DLE when transmitting a transparent buffer (buffer with TR bit set).
- SYNC transmission if underrun occurs.

BISYNC transmission is descriptor chain oriented. Transmission starts when the CPU issues a Transmit Demand command and continues until the channel's SDMA reaches a NULL pointer or a 'not owned' descriptor.

•



### 14.6.2 BISYNC Receive Operation

There are two major operating modes in the BISYNC receiver.

#### Table 337: BISYNC Receiver Operating Modes

| Mode                  | Function                                                                                                                                                                   |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Normal Mode           | The CPU must monitor each received byte and manage each BISYNC opera-<br>tion (e.g., moving into transparent mode) manually.                                               |
| Auto Transparent Mode | The GT-96100A handles transparent mode automatically.<br>This mode reduces the CPU burden since it can monitor the incoming data<br>buffer-by-buffer and not byte-by-byte. |

### 14.6.2.1 BISYNC Normal Receive Mode

In Normal Mode, the BISYNC receiver handles the following protocol functions:

- BISYNC, MonoSYNC, NibbleSYNC or External SYNC synchronization.
- Auto SYNC stripping in text mode.
- Auto DLE-SYNC stripping in transparent text mode.
- Auto SYNC stripping after receiving DLE ITB in transparent mode.
- Automatic exit of transparent mode after receiving DLE-ETX/ETB (if RTR bit in the MPCRx was cleared).
- Marking of buffers that contain transparent data by setting the TB bit in the descriptor.
- BCC generation:
  - BCC (CRC-16, VRC/LRC and VRC/CRC-16) is calculated.
  - In transparent text mode, CRC-16 always overrides the VRC.
  - SYNC (DLE-SYNC) is not included in the BCC calculation.
- Buffer closing at the reception of ETX, ETB, ITB and ENQ.
- Maintaining SYNC (stay in text mode) after ITB.
- Protocol correctness checking:
  - Test for '1' padding at the end of block reception. (The CPU should ignore a padding error reported after ITB, and can use it when testing for proper NAK or EOT.)
  - Test for DLE-CTL after receiving DLE-ITB in transparent text mode. If another sequence arrives (except SYNCs), buffer is closed with DLE error.



### 14.6.2.2 BISYNC Auto Transparent Receive Mode

In Auto Transparent Mode, the BISYNC receiver handles the following protocol functions:

- BISYNC, MonoSYNC, NibbleSYNC, or External SYNC synchronization.
- Auto SYNC stripping in text mode.
- Auto DLE-SYNC stripping in transparent text mode.
- Auto SYNC stripping after receiving DLE ITB in transparent mode.
- Automatic switch to transparent mode after receiving DLE-STX.
- Automatic exit of transparent mode after receiving DLE-ETX/ETB.
- Marking of buffers that contain transparent data by setting the TB bit in the descriptor.
- BCC generation:
  - BCC (CRC-16, VRC/LRC and VRC/CRC-16) is calculated.
  - In transparent text mode, CRC-16 always overrides the VRC.
  - SYNC (DLE-SYNC) is not included in the BCC calculation.
  - Opening STX/SOH (DLE-STX) are discarded from BCC calculations.
- Buffer closing at the reception of ETX, ETB, ITB, and ENQ.
- Maintaining SYNC (stay in text mode) after ITB.
- Buffer closing after SYN-SYN-DLE-CHAR (when char is not STX).
- Protocol correctness checking:
  - Test for '1' padding at the end of block reception. (The CPU should ignore a padding error reported after ITB, and can use it when testing for proper NAK or EOT.)
  - Test for DLE-CTL (CTL is a control character with B or H set) after receiving DLE-ITB in transparent text mode. If another sequence arrives (except SYNCs), buffer is closed with a DLE error.

The BISYNC receive process is block oriented. A block starts after a buffer was closed due to control character reception, overrun, protocol error, parity error, or line error (i.e. CD deassertion).

The first descriptor in a block is marked with F bit set to '1'. The last descriptor in block is marked with L bit set to '1'. The last descriptor also includes the actual status report for the block. Intermediate descriptors can be recognized by having both F and L bit set to '0'.



### 14.6.3 SDMAx Command/Status Field for BISYNC Mode

When an MPSC is in BISYNC mode the Command/Status field in the corresponding SDMAx descriptor has the following format:

| Bits | Rx - Function                                                                                                                                   | Tx - Function                                                                                                                                                           |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | CE - CRC/LRC Error                                                                                                                              | Reserved                                                                                                                                                                |
| 1    | CDL - CD Loss                                                                                                                                   | CTSL - CTS Loss                                                                                                                                                         |
| 2    | DE - Decoding Error                                                                                                                             | Reserved                                                                                                                                                                |
| 3    | DLE - DLE Error. While in transparent mode,<br>this indicates a DLE was received and the fol-<br>lowing byte was not a valid control character. | Reserved                                                                                                                                                                |
| 4    | PR - Parity Error. Last byte in buffer has parity error.                                                                                        | Reserved                                                                                                                                                                |
| 5    | Reserved                                                                                                                                        | Reserved                                                                                                                                                                |
| 6    | OR - Data Overrun                                                                                                                               | Reserved                                                                                                                                                                |
| 8:7  | Reserved                                                                                                                                        | Reserved                                                                                                                                                                |
| 9    | PDR - Pad Report. This is set if there were no four consecutive '1's after the block reception.                                                 | Reserved                                                                                                                                                                |
| 10   | Reserved                                                                                                                                        | Reserved                                                                                                                                                                |
| 11   | TB - Transparent Buffer. Buffer contains transparent data.                                                                                      | Reserved                                                                                                                                                                |
| 12   | Reserved                                                                                                                                        | Reserved                                                                                                                                                                |
| 13   | C - Last bytes in buffer is a user defined control character.                                                                                   | Reserved                                                                                                                                                                |
| 14   | B - Last bytes in buffer are BCC.                                                                                                               | Reserved                                                                                                                                                                |
| 15   | ES - Error Summary<br>ES = CDL    DE    DLE    PR    OR                                                                                         | ES - Error Summary<br>ES = CTSL                                                                                                                                         |
| 16   | L - Last                                                                                                                                        | L - Last<br><b>NOTE:</b> Transmit Bit 22 is used only if L bit is<br>set to '1'. If L bit is set to '0', no BCC is<br>sent at the end of this buffer transmis-<br>sion. |
| 17   | F - First                                                                                                                                       | F - First                                                                                                                                                               |

Table 338: SDMAx Command/Status Field for BISYNC Mode



| Bits  | Rx - Function         | Tx - Function                                                                                                                                                                                             |
|-------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18    | Reserved              | <ul> <li>TR - Transparent mode.</li> <li>0 - Normal mode. SYNC will be sent in case of underrun</li> <li>1 - Transparent Mode. DLE-SYNC will be sent in case of underrun. CRC-16 will be used.</li> </ul> |
| 19    | Reserved              | TD - Transmit DLE before transmitting the buffer. This bit is valid only for transparent buffers. The preceding DLE is not included in the BCC calculations.                                              |
| 20    | Reserved              | <ul> <li>BCE - BCC Enable</li> <li>0 - Buffer must be excluded from BCC calculations</li> <li>1 - Buffer must be included in BCC calculation</li> </ul>                                                   |
| 21    | Reserved              | RC - Reset BCC<br>• 0 - BCC/LRC is accumulated.<br>• 1 - BCC/LRC is reset.                                                                                                                                |
| 22    | Reserved              | GC - Generate BCC/LRC.                                                                                                                                                                                    |
| 23    | EI - Enable Interrupt | EI - Enable Interrupt                                                                                                                                                                                     |
| 29:24 | Reserved              | Reserved                                                                                                                                                                                                  |
| 30    | AM - Auto Mode        | AM - Auto Mode                                                                                                                                                                                            |
| 31    | O - Owner             | O - Owner                                                                                                                                                                                                 |

Table 338: SDMAx Command/Status Field for BISYNC Mode (Continued)

### 14.6.4 MPSCx Protocol Configuration Register (MPCRx) for BISYNC





## Table 339: MPSCx Protocol Configuration Register (MPCRx) for BISYNC, Offset: 0x000A08,<br/>0x008A08, 0x010A08, 0x018A08, 0x020A08, 0x028A08, 0x030A08, 0x038A08<br/>(where x is the port number 0 to 7)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Initial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1:0   |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0                |
| 2     | ATM           | <ul> <li>Auto Transparent Mode</li> <li>0 - Normal Mode.</li> <li>1 - Receiver switches to transparent mode after receiving DLE-STX and exits transparent mode upon receiving a DLE-ETB or DLE-ETX sequence. When switching to transparent mode, new buffers are opened for transparent data. When the ATR bit is set to '1' the following characters should be programed into CTL1-8: <ul> <li>CTL3 - STX</li> <li>CTL4 - SOH</li> </ul> </li> <li>NOTE: When entering transparent mode either automatically or by issuing an RTR command, the Receiver will strip automatically leading DLEs. The TB bit in the descriptor will be set to signal the software that the buffer contains transparent data.</li> </ul> | 0                |
| 5:3   |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0                |
| 6     | DRT           | Disable Rx on Tx<br>When DRT is set to '1' the Rx path is closed during Tx. This is useful in a<br>multidrop configuration when a user doesn't want to receive its own frames.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0                |
| 9:7   |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0                |
| 10    | TRP           | Trailing Pad<br>When set, the BISYNC transmitter sends a PAD character (0xFF) at the<br>end of each outgoing frame (i.e. after a buffer with L bit set.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                |
| 12:11 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 10               |
| 13    | RTR           | <ul> <li>Receive Transparent Mode</li> <li>0 - The receiver is placed in normal mode with sync stripping and control character recognition operative.</li> <li>1 - The receiver is placed in transparent mode. Syncs DLEs and control characters are recognized only after leading DLE characters. CRC16 is calculated even in VRC/LRC mode while in transparent mode.</li> <li><b>NOTE:</b> When entering transparent mode either automatically or by issuing an RTR command, the receiver automatically strips leading DLEs. The TB bit in the descriptor is set to signal the software that the buffer contains transparent data.</li> </ul>                                                                       | 0                |



## Table 339: MPSCx Protocol Configuration Register (MPCRx) for BISYNC, Offset: 0x000A08,<br/>0x008A08, 0x010A08, 0x018A08, 0x020A08, 0x028A08, 0x030A08, 0x038A08<br/>(where x is the port number 0 to 7) (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Initial<br>Value |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 14    | RDB           | Receive Discard From BCC<br>When this bit is set, the received byte is not included in the BCC. The soft-<br>ware must set this bit within the byte time window that starts when the char-<br>acter is in the Rx machine internal buffer. (The software can use the<br>BISYNC interrupts for proper synchronization.) This bit is used in software<br>to control BISYNC. The GT-96100A clears the RDBCC bit after discarding<br>the required byte from BCC. | 0                |
| 15    | TSM           | <ul> <li>Tx SYNC Mode</li> <li>0 - Two SYNC characters are transmitted.</li> <li>1 - 32 SYNC characters are transmitted.</li> <li><b>NOTE:</b> The Tx machine sends at least two bytes even in MonoSYNC or NibbleSYNC modes.</li> </ul>                                                                                                                                                                                                                     | 0                |
| 31:16 |               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                |

### 14.6.5 Channel Registers (CHxRx) for BISYNC Mode



#### Figure 65: Channel Registers (CHxRx) for BISYNC



Unless otherwise specified:

- '1' means set
- '0' means unset.
- '0' is the default value after reset.

### 14.6.5.1 CHR1 - SYNC/DLE Register (SDR)

CHR1[7:0] holds the SYNC character and CHR1[23:16] holds the DLE character for the channel. After reset it holds the value of 7E in the SYNC field and FE in the DLE field. The user must write the appropriate values before enabling the Rx/Tx machines.

If bit 15 is set, the BISYNC receive machine discards the SYNC patterns received in a middle of a message.

**NOTE:** This usually happens when the transmitter experiences underrun.

If bit [15] is '0' the SYNC characters is transferred to the receive buffer.

If bit 31 is '1', the first DLE received in transparent mode is discarded. If bit 31 is '0', the BISYNC receiver is not discard DLE in transparent mode.

A BISYNC transmitter always stuffs the leading DLE before transmitting the DLE that is part of a transparent buffer (transmit descriptor with TR bit set). In order to send DLE ETX, for example, the CPU must either prepare a buffer that contains DLE ETX and set TR='0', or prepare a buffer with ETX and program the transmitter to send a leading DLE by setting the TD bit in the descriptor.

A BISYNC transmitter always transmits SYNC-SYNC at the beginning of a frame. This is true in MonoSYNC and NibbleSYNC modes.

When a BISYNC transmitter experiences underrun it transmits continuous SYNC patterns in text mode or DLE-SYNC in transparent mode. The BISYNC transmitter exits this state upon receiving new data or when the CPU issues a Stop or Abort command.

The receiver SYNC length is programmable. The actual length is determined according to the value of the RSYL bits in the MMCRx. If the RSYL bits equal #00b, the synchronization is done externally and the receiver will start receiving when CD\* is asserted.

In NibbleSync mode, bits [7:4] are used by the receiver for sync recognition. Bits [3:0] should return the SYNC pattern in order to assure proper SYNC transmission.



### 14.6.5.2 CHR2 - Command Register (CR)

### Table 340: CHxR2 - Command Register (CR), Offset: 0x000A10, 0x008A10, 0x010A10, 0x018A10, 0x020A10, 0x028A10, 0x030A10, 0x038A10 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                         | Initial<br>Value |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0     | TEL           | <ul> <li>Tx Enable Longitudinal Redundancy Check</li> <li>0 - LRC is disabled.</li> <li>1 - LRC is enabled. (TEL default value is 0 and the CPU must write "1" to it in order to enable LRC). When set, TEL overrides the CRC mode that was programed in the CRCM field in the MMCRx.</li> </ul> | 0                |
| 1     | TEV           | <ul> <li>Tx Enable Vertical Redundancy Check (Parity Bit)</li> <li>0 - VRC is disabled.</li> <li>1 - VRC is enabled. (TEV default value is '0' and the CPU must write '1' to it in order to enable VRC).</li> </ul>                                                                              | 0                |
| 3:2   | ТРМ           | Transmit Parity Mode<br>00 - Odd<br>01 - Low (always "0")<br>10 - Even<br>11 - High (always "1")                                                                                                                                                                                                 | 0                |
| 4     | TLRM          | Transmit Longitudinal Redundancy Mode<br>0 - Odd<br>1 - Even                                                                                                                                                                                                                                     | 1                |
| 6:5   |               | Reserved.                                                                                                                                                                                                                                                                                        | 0                |
| 7     | A             | Abort Transmission<br>Abort transmission immediately and go to IDLE. The descriptor is not<br>closed or incremented.<br><b>NOTE:</b> Command is not synchronized to byte.                                                                                                                        | 0                |
| 15:8  |               | Reserved.                                                                                                                                                                                                                                                                                        | 0                |
| 16    | REL           | <ul> <li>Rx Enable Longitudinal Redundancy Check.</li> <li>0 - LRC is disabled.</li> <li>1 - LRC is enabled. This is the normal mode for BISYNC. When set, REL overrides the CRC mode that was programed in the CRCM field in the MMCRx.</li> </ul>                                              | 0                |
| 17    | REV           | Rx Enable Vertical Redundancy Check (parity bit).<br>0 - VRC (parity) is disabled.<br>1 - VRC is enabled. This is the normal mode for BISYNC.                                                                                                                                                    | 0                |
| 19:18 | RPM           | Receive Parity Mode<br>00 - Odd<br>01 - Low (always '0')<br>10 - Even<br>11 - High (always '1')                                                                                                                                                                                                  | 0                |

| Table 340: CHxR2 - Command Register (CR), Offset: 0x000A10, 0x008A10, 0x010A10, |
|---------------------------------------------------------------------------------|
| 0x018A10, 0x020A10, 0x028A10, 0x030A10, 0x038A10 (where x is channel 0 and 7)   |

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                        | Initial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 20    | RLRM          | Receive Longitudinal Redundancy Mode<br>0 - Odd<br>1 - Even                                                                                                                                                                                                                                                                                                     | 1                |
| 22:21 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                       | 0                |
| 23    | A             | Abort Reception<br>Abort receive immediately and go to IDLE. The descriptor is not closed or<br>incremented. The processor must issue an enter hunt command after an<br>abort command to enable reception.<br>The A bit is cleared upon entering IDLE state.                                                                                                    | 0                |
| 24    |               | Reserved.                                                                                                                                                                                                                                                                                                                                                       | 0                |
| 25    | CRD           | Close Rx Descriptor<br>When the CPU issues a CRD command the current receive descriptor is<br>closed and the following received data is SDMA'd into a new buffer. If there<br>is no active receive in process, no action takes place.                                                                                                                           | 0                |
| 28:26 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                       | 0                |
| 29    | RBC           | Reset BCC<br>The CPU issues an RBC command in order to manually reset the CRC-<br>LRC/VRC generator. The BCC calculation starts with the next byte. The<br>GT-96100A clears the RBC bit after resetting BCC.                                                                                                                                                    | 0                |
| 30    |               | Reserved.                                                                                                                                                                                                                                                                                                                                                       | 0                |
| 31    | EH            | Enter Hunt<br>Upon receiving an enter hunt command, the receive machine will move to a<br>hunt state and will continuously search for an opening SYNC or external<br>SYNC. If an enter hunt mode command is issued during frame reception,<br>the current descriptor will be closed with a CRC error.<br>The EH bit will be cleared upon entering a hunt state. | 0                |
| NA    | TD            | Transmit Demand<br>Fetch a descriptor and start transmission.<br>Issued through the SDMAx Command Register.                                                                                                                                                                                                                                                     |                  |
| NA    | Stop          | Stop Transmission<br>Complete frame transmission and stop. (Go to IDLE).<br>Issued through the SDMAs Command Register.                                                                                                                                                                                                                                          |                  |



The ET bit in the Main Configuration Register must be set to '1' before issuing any of the following commands:

- Transmit Demand.
- Stop Transmission.
- Abort Transmission.

The ER bit in the Main Configuration Register must be set to '1' before issuing any of the following commands:

- Enter Hunt
- Reset BCC
- Close Rx Descriptor
- Abort Reception.

When the ET or ER bits are deasserted, the MPSCx transmit/receive channel is in low power mode (NO CLOCK).

NOTE: Issuing one of the above commands in this state will lead to unpredictable results.

Setting TEL='0', TEV='1' and CRCM='001', or setting REL='0', REV='1' and CRCM='001', will set the BISYNC transmitter/receiver to work in VRC+CRC16 mode. The calculated parity bit is considered part of the data that the CRC-16 checks.

When a BISYNC transmitter transmits a transparent buffer, it automatically switches to the CRC that was programmed in the CRCM field in MMCRx. When a receiver enters transparent mode, it automatically switches to the CRC that was programed in CRCM field in MMCRx. In both cases, CRCM must be programed to '001' in order to meet the BISYNC CRC-16 specifications.

### 14.6.5.3 CHR4 - Control Filtering Register (CFR)

Bits 7:0 of the CFR register are the Bit Comparison Enable bits. Setting '1' in one of the BCE bits enables the control comparison for this bit

### 14.6.5.4 CHR5-8 - BISYNC Control Character Registers

Figure 66 shows a BISYNC control register format.

The CHAR field holds the pattern for the control character while bits 8-15 are used to control the GT-96100A behavior when the control character is recognized.

#### Figure 66: BISYNC Control Character Register Format

111111 5432109876543210 V вн I ЦКБС СНАР

| Bits | Field<br>Name | Function                                                                                                                                                                       | Initial<br>Value |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 7:0  | CHAR          | The Control Character To Sync On<br><b>NOTE:</b> Bit 7 must be programmed according to the parity method in use.<br>See Table 340.                                             | 0                |
| 8    |               | Reserved.                                                                                                                                                                      | 0                |
| 9    | SOH           | SOH Character<br>0 - Normal Mode.<br>1 - SOH character. In Auto Transparent mode the characters following SOH<br>including STX are part of the BCC calculations.               | 0                |
| 10   | STX           | STX Character<br>0 - Normal character.<br>1 - STX character. In Auto Transparent mode, an STX character is expected<br>after the first DLE in order to enter transparent mode. | 0                |
| 11   | ITT           | Ignore While Receiving in Text Mode<br>0 - Normal control character.<br>1 - Ignore this character after entering text mode (i.e. after receiving SYN-<br>SYN-STX/SOH).         | 0                |
| 12   | I             | Interrupt<br>0 - No interrupt.<br>1 - Generate interrupt upon receiving this CHAR.                                                                                             | 0                |
| 13   | Н             | Hunt<br>0 - Close buffer and maintain SYNC.<br>1 - Close buffer and move to HUNT state.                                                                                        | 0                |
| 14   | В             | BCC Next<br>0 - Close buffer.<br>1 - BCC is next. Receive BCC and than close buffer.                                                                                           | 0                |
| 15   | V             | Valid.<br>0 - Entry is not valid.<br>1 - Entry is valid.                                                                                                                       | 0                |

### Table 341: BISYNC Control Character Register Format

The BISYNC Control Character programming recommendations for Auto Transparent Mode and CPU Controlled Operation are shown in the following tables.



| Control Character | v | В | н | I | ІТТ | ѕтх | SOH |
|-------------------|---|---|---|---|-----|-----|-----|
| STX <sup>1</sup>  | 1 | 0 | 0 | х | 1   | 1   | 0   |
| SOH <sup>2</sup>  | 1 | 0 | 0 | х | 1   | 0   | 1   |
| ETX               | 1 | 1 | 1 | х | 0   | 0   | 0   |
| ITB               | 1 | 1 | 0 | х | 0   | 0   | 0   |
| ETB               | 1 | 1 | 1 | х | 0   | 0   | 0   |
| ENQ               | 1 | 0 | 1 | х | 0   | 0   | 0   |
| EOT               | 1 | 0 | 1 | х | 1   | 0   | 0   |
| NACK              | 1 | 0 | 1 | х | 1   | 0   | 0   |

### Table 342: Auto Transparent Programming

1. CTL3 must be use to hold STX

2. CTL4 must be use to hold SOH

| Control Character | v | В | н | 1 | ІТТ | STX | SOH |
|-------------------|---|---|---|---|-----|-----|-----|
| ETX               | 1 | 1 | 1 | х | 0   | 0   | 0   |
| ITB               | 1 | 1 | 0 | х | 0   | 0   | 0   |
| ETB               | 1 | 1 | 1 | х | 0   | 0   | 0   |
| ENQ               | 1 | 0 | 1 | х | 0   | 0   | 0   |
| EOT               | 1 | 0 | 1 | х | 1   | 0   | 0   |
| NACK              | 1 | 0 | 1 | х | 1   | 0   | 0   |
| Other Entry       |   |   |   |   |     |     |     |
| Other Entry       |   |   |   |   |     |     |     |

### Table 343: CPU Controlled Operation

### 14.6.5.5 CHR9 - Reserved

This register is reserved.

Do not access this register in the BISYNC mode.

#### 14.6.5.6 CHR10 - BISYNC Event Status Register (ESR)

The ESR register holds information on the transmit/receive channel condition.

CHR10 can be read by the CPU for channel condition resolution. Some changes in the channel condition can generate maskable interrupts, as shown below.

#### Table 344: CHxR10 - BISYNC Event Status Register (ESR), Offset: 0x000A30, 0x008A30, 0x010A30, 0x018A30, 0x020A30, 0x028A30, 0x030A30, 0x038A30 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CTS           | Clear To Send Signal <sup>1</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1     | CD            | Carrier Detect Signal <sup>2</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2     |               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3     | TIDLE         | Tx in Idle State <sup>3</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 5     | RHS           | Rx in HUNT state                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10:6  |               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11    | RLIDL         | 1 = Rx IDLE Line <sup>4</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 12    | DPCS          | 1 = DPLL Carrier Sense                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:13 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23:16 | RCRn          | Received Control Character n<br>When the BISYNC receiver recognizes a control character it sets the corresponding<br>RCRn bit. Bit 16 (RCR1) corresponds to CTL1. Bit 23 (RCR8) corresponds to CTL8.<br>RCRn bits are cleared by writing '1' to the bit. RCRn is set if the corresponding control<br>character arrives, and both its Valid bit and Interrupt bit are also set (e.g., bit 16 will be<br>set if CTL1 arrives, and both CTL1's "V" bit is set, and CTL1's "I" bit is also set.) |

1. Interrupt is generated when signal is deasserted during transmit

2. Interrupt is generated when signal is deasserted during receive

- 3. Interrupt is generated upon entering IDLE state
- 4. Interrupt is generated upon change in line status

**NOTE:** PERR will be set in transparent mode during SYN stripping when a non DLE or SYN character is received. This is a protocol violation. The receiver moves to hunt mode and a maskable interrupt is generated. The received character is discarded.



## 14.7 UART Mode

## 14.7.1 UART Receive/Transmit Operation

In UART mode an MPSC performs the following protocol functions:

- Start/Stop bit framing.
- Programmable data lengths (5-8 bits).
- Synchronous and asynchronous support.
- Message oriented data support.
- Parity detection and generation.
- Frame error, noise error, break, and idle detection.
- Support for HDLC over asynchronous control-octet transparency protocol.
- Multidrop operation with address recognition of up to two different addresses.

Figure 67 shows a typical UART frame format. A frame with a start bit is followed by 5-8 data bits. The address and parity bits are optional.

#### Figure 67: Typical UART Frame



At the end of a frame there are 1-2 stop bits before the transmitter can start to transmit the next frame. If there is nothing to transmit, a continuous '1' is transmitted. This indicates that the line is idle.

The GT-96100A's UART samples each bit three times near its central point to define the bit value. A new start bit can be recognized only after the last stop bit sample is received. For example, at a 16x clock rate, the receiver can receive a start bit after a 9/16 bit time long stop bit.

When in UART mode, the RDW bit in the MMCRx should be set to configure the MPSCx data path to 8 bits.

A UART transceiver can work in Asynchronous or Isochronous modes.

#### 14.7.1.1 Asynchronous Mode

In Asynchronous mode, the DPLL encoding must be set to RNZ and the clock sampling rate is set to 8x, 16x, or 32x of the data rate. The DPLL is synchronized by the falling edge of the start bit. If no error occurs, it maintains synchronization until the last bit in a frame is received.



Each bit is sampled three times around it's middle point. The bit value is determined by a majority vote. This feature helps to filter out noise from received data.

## 14.7.1.2 Isochronous Mode

In Isochronous mode, the DPLL sampling rate will be 1x the data rate. The receive data must be synchronized to the receive clock.

## 14.7.2 SDMAx Command/Status Field for UART Mode

When an MPSC is in UART mode the Command/Status field in the corresponding SDMAx descriptor has the following format:

| Bit | Rx - Function                                                                                                                                                           | Tx - Function                   |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| 0   | PE - Parity Error. Last byte in buffer has parity error.                                                                                                                | Reserved                        |
| 1   | CDL - CD Loss                                                                                                                                                           | CTSL - CTS Loss                 |
| 2   | Reserved                                                                                                                                                                | Reserved                        |
| 3   | FE - Framing Error                                                                                                                                                      | Reserved                        |
| 5:4 | Reserved                                                                                                                                                                | Reserved                        |
| 6   | OR - Data Overrun                                                                                                                                                       | Reserved                        |
| 8:7 | Reserved                                                                                                                                                                | Reserved                        |
| 9   | BR - Break Received while receiving data into this buffer                                                                                                               | Reserved                        |
| 10  | <ul> <li>MI - Max Idle. Buffer was closed due to<br/>Max_Idle timer expiration.</li> <li>NOTE: When this bit is set, the status of bit 0<br/>is disregarded.</li> </ul> | Reserved                        |
| 11  | A - Address. First byte in the buffer is an address. (Valid only in multidrop mode, '0' in point to point mode.)                                                        | Reserved                        |
| 12  | AM - Address match. This bit will be set to '1'<br>when a match occurred even if the V bit of the<br>address is disabled.                                               | Reserved                        |
| 13  | CT - The last byte in the buffer was precede by a transparency control octet.                                                                                           | Reserved                        |
| 14  | C - The last byte in a buffer is a user define control character.                                                                                                       | Reserved                        |
| 15  | ES - Error Summary<br>ES = PE    CDL    FE    OR                                                                                                                        | ES - Error Summary<br>ES = CTSL |
| 16  | L - Last                                                                                                                                                                | L- Last                         |

Table 345: SDMAx Command/Status Field for UART Mode

| Bit   | Rx - Function         | Tx - Function                                                                                                                         |
|-------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 17    | F - First             | F - First                                                                                                                             |
| 18    | Reserved              | P - Preamble. When set, the UART will send an IDLE preamble before buffer data. If data length is 0, only preamble IDLE will be send. |
| 19    | Reserved              | A - Address. When set, buffer content will be sent with address bit on. Valid only in multidrop mode.                                 |
| 20    | Reserved              | NS - No Stop Bit. When set, data will be sent without stop bit.                                                                       |
| 22:21 | Reserved              | Reserved                                                                                                                              |
| 23    | EI - Enable Interrupt | EI - Enable Interrupt                                                                                                                 |
| 29:24 | Reserved              | Reserved                                                                                                                              |
| 30    | AM - Auto Mode        | AM - Auto Mode                                                                                                                        |
| 31    | O - Owner             | O - Owner                                                                                                                             |

Table 345: SDMAx Command/Status Field for UART Mode (Continued)

## 14.7.3 MPSCx Protocol Configuration Register (MPCRx) for UART Mode

### Figure 68: MPSCx Protocol Configuration Register (MPCRx) for UART Mode

| 3 3 2 2 2 2 2 2 2 2 2 2 2 1 | 1 1 1 1 1 1 1 1 1   |
|-----------------------------|---------------------|
| 1 0 9 8 7 6 5 4 3 2 1 0 9   | 8765432109876543210 |

Base + 08

SBL SBL SBL SBL SBL SBL SBL SBL SBL

MPCR

# Table 346: MPSCx Protocol Configuration Register (MPCRx) for UART Mode, Offset: 0x000A08,<br/>0x008A08, 0x010A08, 0x018A08, 0x020A08, 0x028A08, 0x030A08, 0x038A08<br/>(where x is the port number 0 to 7)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | lnitial<br>Value |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 5:0   |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                |
| 6     | DRT           | Disable Rx on Tx. When DRT is set to '1' the Rx path is closed during Tx.<br>This is useful in multidrop configurations when a user doesn't want to<br>receive its own frames                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0                |
| 7     | ISO           | Isochronous Mode<br>0 - Asynchronous Mode. Start and stop bits are expected. RENC in the<br>MMCRx should be programmed to NRZ and RCDV should be programmed<br>to x8, x16 or x32 mode. (x16 is recommended for most applications).<br>1 - Isochronous Mode. The receive bit stream is assumed to be synchro-<br>nous to the receive clock. RCDV should be programmed to x1 mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |
| 8     | RZS           | <ul> <li>Receive Zero Stop Bit</li> <li>0 - Normal Mode. At least one stop bit is expected.</li> <li>1 - Zero Stop Bit. The receiver continues reception when a stop bit is missing. If a '0' is received when stop bit is expected, this bit is considered a start bit. The FE (Framing Error) bit is set and the next bit to be received is considered to be data.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                |
| 9     | FRZ           | <ul> <li>Freeze Tx</li> <li>0 - Restart Tx after freeze (normal operation). Transmission continues from the place it stopped.</li> <li>1 - Freeze Tx at the end of the current character.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                |
| 11:10 | UM            | <ul> <li>UART Mode</li> <li>00 - Normal Mode. Multidrop is disabled and IDLE line wake up is selected.<br/>A UART receiver wakes up after entering hunt mode upon receiving an<br/>IDLE character (all one character).</li> <li>01 - Multi Drop Mode. In multidrop mode, there is an additional Address/<br/>Data bit in each character. Upon receiving an address character, the UART<br/>receiver compares it to two 8-bit addresses stored in it's channel registers.<br/>If a match occurs, the receiver transfers the address and the following char-<br/>acters into a new buffer. If there is a no match, the character is discarded<br/>and the receiver is set to the hunt mode. If none of the addresses is valid (V<br/>bit in both address register is set to '0'), there is always a match and all the<br/>characters are transferred into the DRAM. Addresses are always be placed<br/>in a new buffer (Regardless of the V bit). The receiver receives characters<br/>until a new address is received, an abort character is received, an enter<br/>hunt command is issued, or until max idle counter expiration. Upon max<br/>idle counter expiration, the receiver is set to the hunt mode.</li> <li>10 - Reserved.</li> <li>11 - Reserved.</li> </ul> | 0                |



| Table 346: MPSCx Protocol Configuration Register (MPCRx) for UART Mode, Offset: 0x000A08, |
|-------------------------------------------------------------------------------------------|
| 0x008A08, 0x010A08, 0x018A08, 0x020A08, 0x028A08, 0x030A08, 0x038A08                      |
| (where x is the port number 0 to 7) (Continued)                                           |

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                           | Initial<br>Value |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 13:12 | CL            | Character Length<br>00 - 5 data bits<br>01 - 6 data bits<br>10 - 7 data bits<br>11 - 8 data bits                                                                                                                                                                                                                                                                                                   | 01               |
| 14    | SBL           | Stop Bit Length<br>0 - One stop bit<br>1 - Two stop bits                                                                                                                                                                                                                                                                                                                                           | 0                |
| 15    | FLC           | <ul> <li>Flow Control</li> <li>0 - Normal Mode. The CTSM bit in the MMCRx determines the CTS* pin behavior.</li> <li>1 - Asynchronous Mode. When CTS* is negative, transmission stops at the end of the current character. When CTS* is asserted again the transmission starts from the place it stopped. No CTS* lost is reported. Line is IDLE (MARK) during CTS* deassertion period.</li> </ul> | 0                |
| 31:16 |               | Reserved                                                                                                                                                                                                                                                                                                                                                                                           | 0                |

**NOTE:** When CD\* is deasserted during frame reception UART behavior is different for multidrop and normal modes. In normal mode the UART hunts for an IDLE character (hunting starts when CD\* is asserted again) before receiving valid start bit. In this mode, transmitting from a GT-96100A model to another should be with the 'P' bit in the buffer descriptor set. In multidrop mode, the UART receiver hunts for a start bit as soon as CD\* is asserted again.

## 14.7.4 UART Stop Bit Reception and Framing Error

The UART receiver always expects to find a stop bit at the end of a character. If no stop bit is detected, the Framing Error (FE) bit is set in the receive descriptor. After a framing error, the reception process is controlled by the RZS and UM bits in the UART MPCRx. The various options are summarized in the table bellow.

| UM | RZS | Operation                                                                                                                                    | Break<br>Recognition |
|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| 00 | 0   | Go to hunt after missing a stop bit. The receiver is enabled after receiving a new IDLE char.                                                | Single Break         |
| 00 | 1   | The receiver tries to synchronize itself. The missing stop bit is considered as the following start bit and the reception process continues. | Two Break Sequence   |

 Table 347: UART Stop Bit Reception and Framing Error

| υм | RZS | Operation                                                                                                                                    | Break<br>Recognition |
|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| 01 | 0   | Goes to hunt after missing stop bit. The receiver is enabled after receiving new address character.                                          | Single Break         |
| 01 | 1   | The receiver tries to synchronize itself. The missing stop bit is considered as the following start bit and the reception process continues. | Two Break Sequence   |

### Table 347: UART Stop Bit Reception and Framing Error (Continued)



## 14.7.5 Channel Registers (CHxRx) for UART Mode

The MPSCx Channel Registers (CHxRx) are protocol dependent.

Figure 69 shows the CHxRx format in UART mode.





Unless otherwise specified:

- '1' means set.
- '0' means unset.
- '0' is the default value after reset.

## 14.7.5.1 CHR1 - UART Break/Stuff Register (UBSR)

The UART Break/Stuff register has two fields: Break Count (BRK)(CHR1[23:16]) and Control Stuff Character (TCS) (CHR1[7:0]).

With the BRK field, the UART transmitter will starts to transmit break characters after receiving an abort command. The number for the break character to send is programmed into the BRK field.

For example, when BRK equals '0', no break character is transmitted. When BRK equals '1', one break character is transmitted.

A break character is a character with all '0's including it's stop bit.

Upon issuing a TCS command, the transmitter sends a TCS character after the current transmitting character. This allows a transmitter to bypass the normal pipeline when a special control character must be send (e.g. XON/ XOFF).

Upon receiving a break character, the UART stops the reception process and moves to the hunt state. In a point to point configuration, the receiver is hunting for a new IDLE character. In a multidrop configuration, the receiver hunts for a new address character.

When the UART is in RZS=0 mode after receiving a break sequence, the descriptor is closed with BR bit (bit 9) set. In addition, a "break descriptor" also has the FE bit (bit 3) set and, if in odd parity, the PE bit (bit 0) is also set.

When the UART in RZS=1 mode, two consecutive break sequences are needed for proper break recognition. The first break character is not recognized. Instead, the UART receiver closes the descriptor with the FE bit (bit 3) set and, if in odd parity, the PE bit (bit 0) will also be set. The second break will be recognized as a break and a descriptor will be closed with the BR bit (bit 9) set. In addition, a "break descriptor" will also have the FE bit (bit 3) set and, if in odd parity, the PE bit (bit 0) will also be set.

|       | 0x018A10, 0x020A10, 0x028A10, 0x030A10, 0x038A10 (where x is channel 0 and 7) |                                                                                                                                                                                                                                                                                                                                                                 |                  |  |
|-------|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--|
| Bits  | Field<br>Name                                                                 | Function                                                                                                                                                                                                                                                                                                                                                        | Initial<br>Value |  |
| 0     |                                                                               | Reserved.                                                                                                                                                                                                                                                                                                                                                       | 0                |  |
| 1     | TEV                                                                           | Tx Enable Vertical Redundancy Check<br>0 - VRC (parity) is disabled.<br>1 - VRC is enabled.                                                                                                                                                                                                                                                                     | 0                |  |
| 3:2   | ТРМ                                                                           | Transmit Parity Mode<br>00 - Odd<br>01 - Low (always 0)<br>10 - Even<br>11 - High (always 1)                                                                                                                                                                                                                                                                    | 0                |  |
| 6:4   |                                                                               | Reserved.                                                                                                                                                                                                                                                                                                                                                       | 0                |  |
| 7     | A                                                                             | Transmit Abort<br>Aborts the transmission immediately (on byte boundaries) and goes to<br>IDLE. The descriptor is not closed or incremented.<br>After receiving an abort command, the GT-96100A halts the transmit pro-<br>cess and starts sending a break sequence according to the BRK field in<br>CHR1.<br><b>NOTE:</b> Command is not synchronized to byte. | 0                |  |
| 8     |                                                                               | Reserved.                                                                                                                                                                                                                                                                                                                                                       | 0                |  |
| 9     | TCS                                                                           | Transmit TCS Character.<br>The TCS character is transmitted after the current transmitted character.<br>The transmitter then continues with the normal Tx sequence.<br>The TCS command can be used to send out of band characters such as<br>XOFF and XON.                                                                                                      | 0                |  |
| 16:10 |                                                                               | Reserved.                                                                                                                                                                                                                                                                                                                                                       | 0                |  |
| 17    | REV                                                                           | Rx Enable Vertical Redundancy Check<br>0 - VRC (parity) is disabled.<br>1 - VRC is enabled.                                                                                                                                                                                                                                                                     | 0                |  |

## 14.7.5.2 CHR2 - Command Register (CR)

Table 348: CHxR2 - Command Register (CR), Offset: 0x000A10, 0x008A10, 0x010A10, 0x018A10, 0x020A10, 0x028A10, 0x030A10, 0x038A10 (where x is channel 0 and 7)



| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                               | Initial<br>Value |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 19:18 | RPM           | Receive Parity Mode.<br>00 - Odd<br>01 - Low (always '0')<br>10 - Even<br>11 - High (always '1')                                                                                                                                                                                                                                       | 0                |
| 22:20 |               | Reserved.                                                                                                                                                                                                                                                                                                                              | 0                |
| 23    | A             | Receive Abort<br>Abort receive immediately and go to IDLE. The descriptor is not closed or<br>incremented. The processor must issue a enter hunt command after an<br>abort command in order to enable reception.<br>The A bit is cleared upon entering IDLE state.                                                                     | 0                |
| 24    |               | Reserved.                                                                                                                                                                                                                                                                                                                              | 0                |
| 25    | CRD           | Close Rx Descriptor<br>When the CPU issues a CRD command the current receive descriptor is<br>closed and subsequent received data is DMA'd into a new buffer. If there is<br>no active receive process, no action takes place. The GT-96100A clears the<br>CRD bit upon closing the buffer status. <sup>1</sup>                        | 0                |
| 30:26 |               | Reserved.                                                                                                                                                                                                                                                                                                                              | 0                |
| 31    | EH            | Enter Hunt<br>Upon receiving an enter hunt command, the receive machine moves to a<br>hunt state and continuously searches for an opening character. An opening<br>character is considered an IDLE char in point to point mode (UM=00) or a<br>matched address in multidrop mode.<br>The EH bit is cleared upon entering a hunt state. | 0                |
| N/A   | TD            | Transmit Demand<br>Fetch a descriptor and start transmission.<br>Issued through the SDMAx Command Register.                                                                                                                                                                                                                            |                  |
| N/A   | Stop          | Stop<br>Complete frame transmission and stop. (Go to IDLE).<br>Issued through the SDMAx Command Register.                                                                                                                                                                                                                              |                  |

## Table 348: CHxR2 - Command Register (CR), Offset: 0x000A10, 0x008A10, 0x010A10, 0x018A10, 0x020A10, 0x028A10, 0x030A10, 0x038A10 (where x is channel 0 and 7)

1. Usually, it takes a few cycles from the time the CRD bit is closed until the SDMAx actually closes the buffer. The SDMAx generates a maskable interrupt when closing a buffer if programed to do so.



The ET bit in the Main Configuration Register must be set to '1' before issuing any of the following commands:

- Transmit Demand
- Stop Transmission
- Transmit TCS Character
- Abort Transmission

The ER bit in the Main Configuration Register must be set to '1' before issuing any of the following commands:

- Enter Hunt
- Close Rx Descriptor
- Abort Reception

When the ET or ER bits are deasserted, the MPSCx transmit/receive channel is in low power mode (NO CLOCK).

**NOTE:** Issuing one of the above commands in this state leads to unpredictable results.

The CRCM in the MMCR must be set to 011 for LRC/VRC mode.

### 14.7.5.3 CHR3 - Max Idle Register (MIR)

This 16-bit value (CHR3[15:0]) defines the number of IDLE characters the receiver waits before it closes a descriptor and a maskable interrupt is generated.

When set to '0', the counter is disabled.

The counter is preloaded every time a non-IDLE character is received.

## 14.7.5.4 CHR4 - Control Filtering Register (CFR)

Bits 7:0 of the CFR register are the Bit Comparison Enable bits.

Setting a '1' in one of the BCE bits enables the control comparison for this bit.

#### 14.7.5.5 CHR5-8 - UART Control Character Registers

Figure 70 shows a UART control register format.

The CHAR field holds the pattern for the control character while bits 8-15 are used to control the GT-96100A's behavior when the control character is recognized.

#### Figure 70: UART Control Character Register Format

| 111111   |          |
|----------|----------|
| 54321098 | 76543210 |
| VROLU    | CHAR     |



| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                            | Reset<br>Value |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | CHAR          | The control character to sync on.                                                                                                                                                                                                                                                                                                                                                   | 0              |
| 11:8 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                           | 0              |
| 12   | INT           | Interrupt<br>0 - No interrupt.<br>1 - Generate interrupt upon receiving this CHAR.                                                                                                                                                                                                                                                                                                  | 0              |
| 13   | со            | Control Octet (ISO 3309 Control Octet)<br>Upon receiving a control octet, the control octet is discarded and the 6th bit<br>(i.e. bit 5 in CHR5) of the following octet is complemented. The current<br>buffer is closed with the CO bit asserted.<br><b>NOTE:</b> When the CO bit is set, the CHAR field must be programmed with<br>'10111110' in order to be ISO-3309 compatible. | 0              |
| 14   | R             | Reject<br>0 - Receive character and close the buffer.<br>1 - Reject character. The character is discarded, the buffer is closed and a<br>maskable interrupt is generated.                                                                                                                                                                                                           | 0              |
| 15   | V             | Valid.<br>0 - Entry is not valid.<br>1 - Entry is valid.                                                                                                                                                                                                                                                                                                                            | 0              |

Table 349: UART Control Character Register Format

## 14.7.5.6 CHR9 - Address Register (ADR)

CHR9 holds the UART addresses for multidrop operation. The GT-96100A UART supports up to 2 addresses.

Upon receiving an address, the UART transfers the previous frame status to the SDMA. This causes the SDMA to close the previous frame descriptor and to locate the address in a new buffer.

There are two modes for address recognition operation. The first mode, setting of '1', allows the address and following characters to be transferred to the SDMA only if there is a match. The second mode, setting of '0', allows all frames to be passed to the SDMA. The CPU can use the AM bit in the last frame descriptor to check if a match occurred.

## 14.7.5.7 CHR10 - UART Event Status Register (ESR)

The ESR register holds information on the transmit/receive channel condition. CHR10 can be read by the CPU for channel condition resolution.

Some changes in the channel condition can generate maskable interrupts, as shown in Table 350.



## Table 350: CHR10 - UART Event Status Register (ESR), Offset: 0x000A30, 0x008A30, 0x010A30, 0x018A30, 0x020A30, 0x028A30, 0x030A30, 0x038A30 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Event                                                                                                                                                                                                                                            |  |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0     | CTS           | Clear To Send Signal <sup>1</sup>                                                                                                                                                                                                                |  |
| 1     | CD            | Carrier Detect Signal <sup>2</sup>                                                                                                                                                                                                               |  |
| 2     |               | Reserved.                                                                                                                                                                                                                                        |  |
| 3     | TIDLE         | Tx in Idle State <sup>3</sup>                                                                                                                                                                                                                    |  |
| 4     |               | Reserved.                                                                                                                                                                                                                                        |  |
| 5     | RHS           | Rx in HUNT State                                                                                                                                                                                                                                 |  |
| 6     |               | Reserved.                                                                                                                                                                                                                                        |  |
| 7     | RLS           | Rx Line Status                                                                                                                                                                                                                                   |  |
| 10:8  |               | Reserved.                                                                                                                                                                                                                                        |  |
| 11    | RLIDL         | 1 = Rx IDLE Line <sup>c</sup>                                                                                                                                                                                                                    |  |
| 15:12 |               | Reserved.                                                                                                                                                                                                                                        |  |
| 23:16 | RCRn          | Received Control Char n<br>When the UART receiver recognizes a control character it sets the corresponding RCRn<br>bit. (bit 16 (RCR1) corresponds to CTL1 bit 23 (RCR8) corresponds to CTL8). RCRn<br>bits are cleared by write a 1 to the bit. |  |

1. Interrupt is generated when signal is deasserted during transmit.

2. Interrupt is generated when signal is deasserted during receive.

3. Interrupt is generated upon entering IDLE state.

## 14.8 Transparent Protocol

In transparent mode, the GT-96100A does not perform any protocol dependent data processing.

However, it gives the processor hardware assistance for bit reception, using the GT-96100A's powerful SDMA engines, and some assistance in synchronization, interrupt generation, and frame construction. The CPU also uses the built-in CRC engine for CRC generation and checking. In any case, CRC bits are transferred into memory for CPU use.

In transparent mode, the channel is fully configured from the MMCRx and no mode is defined by the channel registers.

A transparent channel is synchronous. If it is not serviced on time, underrun and overrun errors can occur.



The receiver can use external sync using the CD\* input or synchronize itself on a SYNC sequence according to the RSYL bits in the MMCRx.



## 14.8.1 SDMAx Command/Status Field for Transparent Mode

When an MPSC is in Transparent mode the Command/Status field in the corresponding SDMAx descriptor has the following format:

| Bit   | Rx - Function                                    | Tx - Function                         |
|-------|--------------------------------------------------|---------------------------------------|
| 0     | CE - CRC/LRC Error                               | Reserved.                             |
| 1     | CDL - CD Loss                                    | CTSL - CTS Loss                       |
| 2     | DE - Decoding Error                              | Reserved.                             |
| 3     | Reserved.                                        | Reserved.                             |
| 4     | Reserved.                                        | Reserved.                             |
| 5     | Reserved.                                        | Reserved.                             |
| 6     | OR - Data Overrun                                | UR - Data Underrun                    |
| 14:7  | Reserved.                                        | Reserved.                             |
| 15    | ES - Error Summary<br>ES = CE    CDL    DE    OR | ES - Error Summary<br>ES = CTSL    UR |
| 16    | L - Last                                         | L - Last                              |
| 17    | F - First                                        | F - First                             |
| 21:18 | Reserved.                                        | Reserved.                             |
| 22    | Reserved.                                        | GC - Generate BCC/LRC.                |
| 23    | EI - Enable Interrupt                            | EI - Enable Interrupt                 |
| 29:24 | Reserved.                                        | Reserved.                             |
| 30    | AM - Auto Mode                                   | AM - Auto Mode                        |
| 31    | O - Owner                                        | O - Owner                             |

Table 351: SDMAx Command/Status Field for Transparent Mode



## 14.8.2 Channel Registers (CHxRx) for Transparent Mode



#### Figure 71: Channel Registers (CHxRx) for Transparent Mode

Unless otherwise specified:

- '1' means set.
- '0' means unset.
- '0' is the default value after reset.

#### 14.8.2.1 CHR1 - SYNC Register (SYNR)

The SYNC Register holds the synchronization for the channel receiver. After reset it holds the value of 7E in the SYNC field. The user should right the appropriate values before enabling the Rx/Tx machines.

There are two basic synchronization options for a transparent channel: Transparent Mode Synchronization and Transmitter Synchronization. The Transparent Mode Synchronization has two synchronization options, selected by setting RSYL[24:23] in the MMCRx.

The Transparent Mode Synchronization has two synchronization options. They are also selected by setting the RSYL [24:23] bits in the MMCRx.

**NOTE:** For more information about setting RSYL[24:23], see Table 324.

| Synchronization Option   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External Synchronization | (RSYL = '00')<br>The receiver starts to receive data whenever CD* is asserted and<br>stops receiving data when CD* is deasserted (if CDM=0) or when the<br>CPU issues an Enter Hunt Command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Sync Hunt                | <ul> <li>RSYL = '01', '10', or '11' (nibble, byte or two bytes sync)</li> <li>The receiver hunts for the sync pattern, as defined by RSYL.</li> <li>When the synch pattern is recognized, the receiver starts to receive data. The receive process stops when CD* is deasserted and CDM=0 or when the CPU issues an enter hunt command.</li> <li>If bit 15 is set, there is no transfer of the SYNC characters to the receiver. The syncs are stripped until the first data character is received, and are not calculated in the packet CRC. If bit 15 is reset, sync characters that appear after the sync pattern is recognized are regarded as data.</li> <li>On the transmitter side, in sync hunt mode, two sync characters are always sent at the beginning of a frame.</li> <li><b>NOTE:</b> When RSYL equals 01, the Sync pattern is defined by bits [7:4] of the Sync Register.</li> </ul> |

### Table 352: Transparent Mode Synchronization Options

There are two mode of transmit synchronization in transparent mode. They are selected by setting TSYN[12} in the MMCRx, see Table 322.

| Synchronization Option | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TSYN = 0               | Synchronization is achieved whenever CTS* is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| TSYN=1                 | Synchronization is achieved after receiver synchronization and CTS* is asserted. The transmitter always starts to transmit on the receive byte boundaries. In external synchronization, when CTS* is asserted, the transmitter starts to transmit 8 bits after CD* assertion. In sync hunt mode, when CTS* is asserted, the transmitter starts to transmit 8 bits after sync recognition. If CTS* is deasserted after the receiver gains synchronization, the transmitter waits to the byte boundary before it starts to transmit. |

### Table 353: Transmitter Mode Synchronization Options



## 14.8.2.2 CHR2 - Command Register (CR)

## Table 354: CHxR2 - Command Register (CR), Offset: 0x000A10, 0x008A10, 0x010A10, 0x018A10, 0x020A10, 0x028A10, 0x030A10, 0x038A10 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                             | Initial Value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 6:0   | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                            | 0             |
| 7     | A             | Abort Transmission<br>Aborts the transmission immediately (on byte boundaries) and goes<br>to IDLE. The descriptor is not closed or incremented.<br><b>NOTE:</b> Command is not synchronized to byte.                                                                                                                                                | 0             |
| 22:8  | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                            | 0             |
| 23    | A             | Abort Reception<br>Abort receive immediately and go to IDLE. The descriptor is not<br>closed or incremented. The processor must issue an enter hunt<br>command after an abort command in order to enable reception.<br>The A bit is cleared upon entering IDLE state.                                                                                | 0             |
| 24    | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                            | 0             |
| 25    | CRD           | Close Rx Descriptor<br>When the CPU issues a CRD command the current receive<br>descriptor is closed and the following received data is SDMA'd into<br>a new buffer. If there is no active receive in progress, no action<br>takes place.                                                                                                            | 0             |
| 30:26 | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                            | 0             |
| 31    | EH            | Enter Hunt<br>Upon receiving an enter hunt command, the receive machine<br>moves to a hunt state and continuously searches for an opening<br>sync or an external sync. If the enter hunt command is received<br>during a frame reception, the current descriptor is closed with a<br>CRC error.<br>The EH bit is cleared upon entering a hunt state. | 0             |
| N/A   | TD            | Transmit Demand<br>Fetch a descriptor and start transmission.<br>Issued at SDMAx Command Register.                                                                                                                                                                                                                                                   |               |
| N/A   | Stop          | Stop<br>Complete frame transmission and stop. (Go to IDLE).<br>Issued at SDMAx Command Register.                                                                                                                                                                                                                                                     |               |

The ET bit in the Main Configuration Register must be set to '1' before issuing any of the following commands:

- Transmit Demand
- Stop Transmission
- Abort Transmission



The ER bit in the Main Configuration Register must be set to '1' before issuing any of the following commands:

- Enter Hunt
- Close Rx Descriptor •
- Abort Reception •

When the ET or ER bits are deasserted, the MPSCx transmit/receive channel is in low power mode (NO CLOCK).

NOTE: Issuing one of the above commands in this state leads to unpredictable results.

#### 14.8.2.3 CHR10 - Transparent Event Status Register (ESR)

The ESR register holds information on the transmit/receive channel condition. CHR10 can be read by the CPU for channel condition resolution. Some changes in the channel condition can generate maskable interrupts, as shown Table 355.

#### Table 355: CHR10 - Transparent Event Status Register (ESR), Offset: 0x000A30, 0x008A30, 0x010A30, 0x018A30, 0x020A30, 0x028A30, 0x030A30, 0x038A30 (where x is channel 0 and 7)

| Bits  | Field<br>Name | Event                                                                                                                                                                                                                                                       |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CTS           | Clear To Send Signal <sup>1</sup>                                                                                                                                                                                                                           |
| 1     | CD            | Carrier Detect Signal <sup>2</sup>                                                                                                                                                                                                                          |
| 2     |               | Reserved.                                                                                                                                                                                                                                                   |
| 3     | TIDLE         | Tx in Idle State <sup>3</sup>                                                                                                                                                                                                                               |
| 4     |               | Reserved.                                                                                                                                                                                                                                                   |
| 5     | RHS           | Rx in HUNT state                                                                                                                                                                                                                                            |
| 11:6  |               | Reserved.                                                                                                                                                                                                                                                   |
| 12    | DPCS          | 1 = DPLL Carrier Sense                                                                                                                                                                                                                                      |
| 15:13 |               | Reserved.                                                                                                                                                                                                                                                   |
| 23:16 | RCRn          | Received Control Character n<br>When the transparent receiver recognizes a control character it sets the corresponded<br>RCRn bit (bit 16 (RCR1) corresponds to CTL1 bit 23 (RCR8) correspond to CTL8).<br>RCRn bits are cleared by writing '1' to the bit. |

Interrupt is generated when signal is deasserted during transmit
 Interrupt is generated when signal is deasserted during receive
 Interrupt is generated upon entering IDLE state



## 15. FLEXTDM UNITS (FTDM)

There are four FlexTDM units (also called time slot assigners) in the GT-96100A. Each unit is capable of supporting IOM-1/2 (GCI), PCM highway, T1/CEPT lines, as well as other proprietary time slot assigned buses.

The time slot assignment is configured by programming an internal dual port RAM (DPRAM). This DPRAM supports static and dynamic configurations. The DPRAM based design provides the flexibility to program the FlexTDM to any of the common time slot buses (i.e. GCI, PCM) or to a proprietary bus.

The FlexTDM unit consists of a transmit and a receive section. Each has a dedicated 256 entry dual port RAM. Figure 72 shows a block diagram of a FlexTDM unit.







## 15.1 FlexTDM Architecture

The FlexTDM architecture is based on two dual-port RAM (DPRAM) arrays. one RAM array is for receiving and one is for transmitting. The frame structure of a time slot assigned bus is configured by programming this DPRAM.

The FlexTDM incorporates two auxiliary channels: AUXA and AUXB. These channels are customized for the IOM Monitor and C/I channels.

The eight MPSCs and two auxiliary channels are time multiplexed on the TxD and RxD lines using two dedicated muxes. The mux select lines are controlled through DPRAM programming. A MPSC connected to a FlexTDM gets it's receive and transmit signals from the FlexTDM. The actual bit rate of the MPSC is defined by the FlexTDM programming and the time slots that are assigned to this MPSC.

The FlexTDM supports independent transmit and receive clocks and frame syncs. Either 1x or 2x input clocks are allowed (the 2x clock is required for IOM bus interface). Selection of clock edges (rising/falling) for frame sync and data is supported as well.

## 15.2 FlexTDM DPRAM

The FlexTDM DPRAM is a 256x27 dual port RAM array that controls the FlexTDM behavior. The DPRAM can be configured dynamically during FlexTDM operation.

Table 356 shows the FlexTDM DPRAM field assignments.

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                             | Reset<br>Value |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 26    | FTINT         | FlexTDM Interrupt<br>An interrupt is generated if FTINT bit is set in the current entry and reset in<br>the last TDM entry that was executed.                                                                                                                                                                                                                        | X              |
| 25    | L             | Last Entry in Frame<br>The TDM read pointer returns to entry 0 or entry 128 (address 0 or 128 of<br>the TDM DPRAM) after reading this entry. Control of which entry is executed<br>next - either 0 or 128 - is done through R2HALF and T2HALF bits in TCR<br>(see Section 15.4 "FlexTDM Configuration Register (TCR)" on page 384).                                  | x              |
| 24:23 | RPT           | Number of times entry is repeated before moving to the next entry.<br>The FlexTDM repeats execution of this entry according to the value pro-<br>grammed in RPT. <sup>1</sup><br>00 - Entry not repeated (i.e. it is executed once).<br>01 - Entry repeated once.<br>10 - Entry repeated twice.<br>11 - Entry repeated three times (i.e. it is executed four times). | Х              |
| 22:21 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                            | х              |

 Table 356: Flex TDM DPRAM Entry



| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset<br>Value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 20:19 | STRB          | This field controls the TDSTRB output of the TDM.<br>00 - 0<br>01 - Z (tri-state)<br>10 - Toggle (strobe state is inverted every cycle this entry is executed)<br>11 - 1<br><b>NOTE:</b> The FlexTDM provides a single external strobe signal, which is<br>shared between the receive and transmit sections. The strobe pin<br>is driven according to the logical OR of the internally generated<br>strobe signals. For example, if transmit strobe is Z and receive<br>strobe is 0, external strobe will be 0. If transmit strobe is 1 and<br>receive strobe is 0, external strobe will be 1. | X              |
| 18    | В             | Byte<br>Defines byte/bit resolution for this entry.<br>0 - Bit.<br>Data width associated with this entry is 1 bit.<br>1 - Byte.<br>Data width associated with this entry is 1 byte (8 bits).<br><b>NOTE:</b> When B=1, indicating byte resolution, the DPRAM entry is exe-<br>cuted 8 times (once for each bit in the byte). <sup>1</sup>                                                                                                                                                                                                                                                      | X              |
| 17:13 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | х              |
| 12:8  | СН            | Channel Select<br>Controls which of the serial controllers is assigned to the current data group.<br>00000 - MPSC0<br>00001 - MPSC1<br>00010 - MPSC2<br>00011 - MPSC3<br>00100 - MPSC4<br>00101 - MPSC5<br>00110 - MPSC6<br>00111 - MPSC7<br>11110 - AUXA<br>11111 - AUXB<br><b>NOTE:</b> CH values not listed above are reserved and are not to be used.                                                                                                                                                                                                                                      | X              |

### Table 356: Flex TDM DPRAM Entry (Continued)

## Table 356: Flex TDM DPRAM Entry (Continued)

| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset<br>Value |
|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | MASK          | <ul> <li>Mask pattern for the current data.</li> <li>Definition of this field is dependent on B (byte/bit) setting.</li> <li>B=1 (byte mode)</li> <li>In byte mode each bit in the MASK field defines the mask for the corresponding bit in the data.</li> <li>1 - TDM transmit data is driven out, receive data is processed normally.</li> <li>0 - TDM transmit data is not driven out (transmit output is tristated), receive data is ignored.</li> <li>B=0 (bit mode)</li> <li>In bit mode only bits 5:0 are valid. Bits 7:6 must be set to '0'.</li> <li>Bits 1:0 define the mask for the current bit: <ul> <li>00 - Z</li> <li>Transmit output is tri-state. Receive data is ignored.</li> <li>01 - 0</li> <li>Transmit output is forced low. Receive data is ignored.</li> <li>10 - D</li> <li>Transmit data driven out. Receive data is ignored.</li> <li>10 - D</li> <li>Transmit data driven out. Receive data is ignored.</li> <li>11 - 1 (transmit output is forced high, receive data is ignored)</li> </ul> </li> <li>Bit 2 serves as the D channel bit. Setting this bit to '1' marks this time slot as a D channel time slot. This bit identifies the MPSC to which the TDM must assert or de-assert the internal CTS signal based on the recent sampled value of the Dgrant is sampled low, CTS is asserted.</li> <li>If Dgrant is sampled low, CTS is deasserted.</li> <li>If Dgrant is deasserted while a D channel stops transmission (due to CT S lost) and initiates a collision resolution procedure.</li> <li>Bit 3 - Dgrant/Dreq</li> <li>In a received frame, this bit serves as the Dgrant bit. An IOM (GCI) PHY uses this bit to signal the GT-96100A that it has access to the D channel. In a transmit frame, it serves as the Dreq. Piof100A drives the Dreq bit to '0' when sending data on the D channel. When not sending data on the D channel. Dreq is driven according to the value programmed in MASK[1:0] bits.</li> <li>Bit 4 identifies the current bit as the IOM-2 MX bit. The GT-96100A recognizes an inactive-to-active transition of received MX bit as an indication that valid</li></ul> | X              |



- 1. The total number of times that a DPRAM entry is actually repeated is set by both the RPT (bits 24:23) and B (bit 18) fields. The range is 1 (B=0, RPT=00) to 32 (B=1, RPT=11).
- **NOTES:**When the FlexTDM is disabled, the CPU accesses the DPRAM for both reads and writes. When the FlexTDM is enabled, the FlexTDM DPRAM is write only.

After reset the dual port RAM entries are undefined. Users must explicitly program the required entries in order to ensure correct and consistent system operation.

## 15.3 FlexTDM Programing Modes

After enabling the FlexTDM, there are two ways the user can dynamically program the DPRAM: Single Array Mode and Split Array Mode.

In Single Array Mode, the FlexTDM read pointer ALWAYS returns to entry 0 after receiving a SYNC or reading the last entry (entry with L bit set). The entire range of 256 entries is available for programing a TDM frame. The user can dynamically make changes in the DPRAM but precautions must be made not to write to the same address from which the FlexTDM is reading. This can be done by checking the read pointer before accessing the DPRAM array.

In Split Array mode, the TDM frame is limited to 128 DPRAM entries. The user programs the FlexTDM frame in entries 0-127 and enables the FlexTDM. When a change in programming is needed, the user first programs the new frame in entries 128-255 and than sets the R2HALF (read as "Return To Half") bit in the TCR. When the next SYNC or last entry occurs, the FlexTDM starts processing the frame as programmed in entries 128-255. The user can then re-program entries 0-127. This process of switching between one half of the DPRAM and the other half simplifies on-the-fly DPRAM changes.

**NOTE:** If a frame structure is changed (e.g. a change in frame length) while the FlexTDM is enabled, the FlexTDM can lose synchronization. This can lead to a CD lost error and a CTS lost error for all channels that are connected to the FlexTDM.



## 15.4 FlexTDM Configuration Register (TCR)

## Table 357: FlexTDMx Configuration Register (TCR), Offset: 0x008B08, 0x018B08, 0x028B08, 0x028B08, 0x038B08 (where x is FlexTDM 0 to 3)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                | Reset<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 6:0   |               | Reserved                                                                                                                                                                                                                                                                                                                                |                |
| 7     | TDDCHG        | TDM Delay for D_Channel Grant,<br>0-low priority<br>1-high priority                                                                                                                                                                                                                                                                     | 1              |
| 10:8  | TDTT          | TDM Delay for Transparent Transmit<br>TDTT must be set to '101' for proper operation.                                                                                                                                                                                                                                                   | 101            |
| 13:11 | TDTR          | TDM Delay for Transparent Receive<br>TDTR must be set to '100' for proper operation.                                                                                                                                                                                                                                                    | 100            |
| 14    | ТТМ           | TDM Transparent Mode<br>TTM must be set to '0' for proper operation.                                                                                                                                                                                                                                                                    | 0              |
| 15    | RR2HALF       | Receive Return to Half.<br>This bit is used for dynamic programming of the TDM receive frame.<br>0 - Return to 0.<br>After sync or last, the FlexTDM receive read pointer returns to entry 0 in<br>the Rx DPRAM.<br>1 - Return to 128.<br>After Sync or Last, the FlexTDM receive read pointer returns to entry 128<br>in the Rx DPRAM. | 0              |
| 16    | TR2HALF       | Transmit Return to Half<br>Used for dynamic programming of the TDM transmit frame.<br>0 - Return to 0.<br>After sync or last, the FlexTDM transmit read pointer returns to entry 0 in<br>the Tx DPRAM.<br>1 - Return to 128.<br>After sync or last, the FlexTDM transmit read pointer returns to entry 128<br>in the Tx DPRAM.          | 0              |
| 19:17 | ТМ            | TDM Mode<br>000 - PCM<br>001 - Reserved<br>010 - IOM1<br>011 - Reserved<br>100 - IOM2-TE<br>101 - Reserved<br>110 - IOM2-LC<br>111 - Reserved                                                                                                                                                                                           | 0              |

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                 | Reset<br>Value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 20    | SE            | Sync Edge (for TRSYNC and TTSYNC)<br>0 - Sync signals are sampled on falling edge of the clock.<br>1 - Sync signals are sampled on rising edge of the clock.                                                                                                                             | 0              |
| 21    | DE            | <ul> <li>Driving Edge.</li> <li>0 - Transmit data is sent on rising edge, receive data is sampled on falling edge of the clock.</li> <li>1 - Transmit data is sent on falling edge, receive data is sampled on rising edge of the clock.</li> </ul>                                      | 0              |
| 22    | STZ           | Set Tx to Zero<br>When set, the TDM transmit output (TTXD) is forced to zero until a serial<br>clock is available. (IOM-2 mode)                                                                                                                                                          | 0              |
| 23    | CRT           | Common Receive and Transmit pins<br>0 - Separate receive and transmit pins.<br>1 - Common receive and transmit pins.<br>The transmit section of the FlexTDM uses the FlexTDM's Rx clock and<br>Rx sync signals. In this mode, TTCLK and TTSYNC pins are used as<br>general purpose pins. | 0              |
| 24    | CLKDV         | Divide CLK by Two<br>0 - normal (1x) clock mode<br>1 - double (2x) clock mode<br>Input clock is twice the bit clock. (IOM-2 mode)                                                                                                                                                        | 0              |
| 26:25 | TSD           | <ul> <li>Transmit Sync Delay</li> <li>Specifies the delay (in number of bits) between transmit sync and the first bit of the transmit frame.</li> <li>00 - No bit delay (IOM-2 mode).</li> <li>01 - 1-bit delay</li> <li>10 - 2-bit delay</li> <li>11 - 3-bit delay</li> </ul>           | 0              |
| 28:27 | RSD           | Receive Sync Delay<br>Specifies the delay (in number of bits) between receive sync and the first<br>bit of the receive frame.<br>00 - No bit delay (IOM-2 mode)<br>01 - 1-bit delay<br>10 - 2-bit delay<br>11 - 3-bit delay                                                              | 0              |

## Table 357: FlexTDMx Configuration Register (TCR), Offset: 0x008B08, 0x018B08, 0x028B08,0x038B08 (where x is FlexTDM 0 to 3) (Continued)



| Table 357: FlexTDMx Configuration Register (TCR), Offset: 0x008B08, 0x018B08, 0x028B08, |
|-----------------------------------------------------------------------------------------|
| 0x038B08 (where x is FlexTDM 0 to 3) (Continued)                                        |

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset<br>Value |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 30:29 | TDIAG         | <ul> <li>TDM Diagnostic</li> <li>00 - Normal Operation</li> <li>The received input is connected to the FlexTDM receive pin (TRXD) and transmit output is connected to the FlexTDM transmit pin (TTXD).</li> <li>01 - Echo</li> <li>TDM receive input is echoed on TDM output with one clock delay. The received bit stream is processed normally according to DPRAM programming.</li> <li>10 - Loopback</li> <li>Transmit data is driven on TDM output, as in normal operation, and is also connected internally to the TDM receive line. The received bit stream is processed normally according to DPRAM programming.</li> <li>11 - Internal Loopback (transmit output is inactive)</li> <li>TDM transmit output is internally connected to the TDM receive input. This mode is useful for TDM loopback testing without affecting the external lines.</li> <li><b>NOTE:</b> Proper operation of the echo and loopback modes requires that an identical clock is supplied to the TDM's transmit and receive sections. If a TDM entry in the DPRAM is in byte mode (bit 18,'B' is set to 1) and configured for a MPSC channel in Transparent mode, bits 6 and 7 must never be masked simultaneously. For example, a MASK (bits 7:0 of the TDM entry) of 0b00xx xxxx (where x means 'don't care'), DPRAM entry for MPSC channel in Transparent mode is not allowed in byte mode.</li> </ul> | 0              |
| 31    | TEN           | Enable FlexTDM<br>0 - FlexTDM disabled.<br>Transmit output is Z.<br>1 - FlexTDM enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0              |

## 15.5 FlexTDM Synchronization

After enable, the FlexTDM needs to receive one received sync to achieve synchronization. Until synchronization is achieved, the FlexTDM transmit and receive paths are disabled.

After gaining synchronization, the FlexTDM always predicts when the next sync is expected. If the sync signal is not asserted when expected, the FlexTDM executes a synchronization lost procedure and a maskable interrupt is generated. All the MPSCs that are connected to the FlexTDM experience a CD loss and a CTS loss and all the transmit and receive processes are halted until synchronization is gained again.



## 15.6 IOM (GCI) Mode

The GCI bus, also known as the IOM-2 bus, is a super set of an older bus known as IOM-1.

While IOM-1 is well suited for NT applications, it lacks the LAPD D channel collision resolution support which is crucial for TE implementation where multiple accesses to the D channel are allowed. The GT-96100A's FlexTDM supports both the IOM-1 and IOM-2 frame structures. Figure 73 depicts various IOM frame structures.

| Figure 73: Typical IOM Structures |
|-----------------------------------|
|-----------------------------------|

. . . . . .

| DCL 512kHz         |                            |                        |                         |       |
|--------------------|----------------------------|------------------------|-------------------------|-------|
| FSC                |                            |                        |                         |       |
| IOM1               | B1                         | B2 MONI                | TOR D1 D2 C/I           | MR MX |
| DCL 1536kHz<br>FSC |                            |                        |                         |       |
| IOM2-TE            | Channel 0                  | Channel 1              | Channel 2               |       |
| DCL 4096Hz         |                            |                        |                         |       |
| FSC                |                            |                        |                         | J     |
| IOM2- LC           | Channel0 Channel1 Channel2 | Channel3 Channel4 Char | nnel5 Channel6 Channel7 | ]     |

## 15.6.1 IOM-1 Frames

An IOM-1 frame is constructed from two 8-bit B channels, one 2-bit D channel, a monitor channel, and a C/I channel.

The monitor channel is used to transfer data between the CPU and an ISDN PHY device. This channel is also used for PHY chip programing and layer-2 message transferring. The MR and MX bits are used to control the data transfers on the monitor channel.

The C/I channel is used to transfer layer-1 messages between the CPU and the PHY chip.

In IOM-1 mode no D channel control is supported and the D channel is assumed to be always granted. This mode can be used when interfacing PHY chips such as the Siemens PEB-2081 and PEB-2086.



## 15.6.2 IOM-2-TE Frames

An IOM-2-TE frame consists of three IOM channels (channels 0,1,2).

The C/I channel of the third sub-frame (i.e. IOM channel 2) is used for TIC bus applications. The TIC bus is used by the PHY device to grant D channel access. Usually, bit 4 of C/I channel 2 is used as the D channel request/ grant bit. However, this is programmable in the GT-96100A and it is possible to specify any desired bit as the request/grant bit.

The GT-96100A fully supports IOM-2-TE frames. In IOM-2-TE mode, the GT-96100A handles the D channel REQ/GNT protocol by itself. The GT-96100A accesses the D channel only when the received Dgrant bit is asserted low. The GT-96100A drives the Dreq bit to '0' when sending data over the D channel. Otherwise, it drives the value programed in MASK[1:0] bits (see Table 356 for more information).

## 15.6.3 IOM-2-LC Frames

The IOM-2 line card frame is used to connect up to eight ISDN devices on the same card. An IOM-2-LC frame consists of eight IOM channels.

The GT-96100A can be programmed to access any one of the IOM channels. The monitor and C/I channels refer to the selected IOM channel. However, other MPSCs can be used to access other time slots in the IOM-2-LC frame.

## 15.7 PCM Highway Mode

This is a free programming mode where each MPSC can be connected to any time slot in the programed frame.

## 15.8 Data Rate Adoption

Since it is capable of accessing each bit of the serial TDM stream separately, the FlexTDM supports data rate adoption.

The FlexTDM DPRAM allows programmable routing of each bit (or byte) in the data to any of the MPSCs and supports masking of bits which are to be ignored. The clock pulse associated with a masked bit is "stolen" from the MPSC (or AUX channel). Thus, the serial controller is clocked at an effective rate that is appropriate for the logical data stream.

## 15.9 FlexTDM Auxiliary Channels A and B

The auxiliary channels were designed to support the IOM-2 monitor and C/I channels. These are simple channels accessible by reading and writing 8 bit registers.

## 15.9.1 Auxiliary Channel A

Auxiliary channel A is used to access the monitor channel. The GT-96100A uses the IOM MX and MR bits for interfacing to this channel.

#### Figure 74: Auxiliary Channel A Control Registers



The CPU writes new data to the ATA register and sets the V bit (bit 15) to 1. The GT-96100A loads the data into the channel A transmit shift register and clears the V bit. The auxiliary channel A transmitter will constantly transmit the contents of the ATA to the monitor channel when enabled. A maskable interrupt will be generated when the MR bit in the receive frame changes from '1' to '0', indicating the PHY chip had received the transmitted byte.

When the transmit FlexTDM loses synchronization (i.e. when the SYNC signal is asserted not where expected), the auxiliary channel A transmitter flushes its shift register and stops its transmit process. The transmit process restarts when the FlexTDM regains synchronization.

The channel A receiver writes new data to the ARA register and sets the V bit. The GT-96100A clears the V bit when the CPU reads the ARA register. The auxiliary channel A receiver generates an interrupt whenever the MX bit in the received IOM frame changes from '1' to '0', indicating that there is new data in the ARA register.

When the receive FlexTDM loses synchronization, the auxiliary channel A receiver flushes it's shift register and stop its receive process. The receive process restarts when the FlexTDM regains synchronization. The ARA contents are not affected by synchronization lost.

Table 358 illustrates a typical monitor channel handshaking process.



| Monitor<br>Channel | MX<br>Outgoing<br>Frame | MR<br>Incoming<br>Frame | Interrupt | MX<br>Incoming<br>Frame | MR<br>Outgoing<br>Frame | Interrupt |
|--------------------|-------------------------|-------------------------|-----------|-------------------------|-------------------------|-----------|
| FF                 | 1                       | 1                       |           | 1                       | 1                       |           |
| FF                 | 1                       | 1                       |           | 1                       | 1                       |           |
| 1st Byte           | 0                       | 1                       |           | 0                       | 1                       | Rx        |
| 1st Byte           | 0                       | 0                       | Тх        | 0                       | 0                       |           |
| 2nd Byte           | 1                       | 0                       |           | 1                       | 0                       |           |
| 2nd Byte           | 0                       | 0                       |           | 0                       | 0                       | Rx        |
| 2nd Byte           | 0                       | 1                       |           | 0                       | 1                       |           |
| 2nd Byte           | 0                       | 0                       | Тх        | 0                       | 0                       |           |
| FF                 | 1                       | 0                       |           | 1                       | 0                       |           |
| FF                 | 1                       | 0                       |           | 1                       | 0                       |           |
| FF                 | 1                       | 1                       |           | 1                       | 1                       |           |
| FF                 | 1                       | 1                       |           | 1                       | 1                       |           |
| FF                 | 1                       | 1                       |           | 1                       | 1                       |           |
| FF                 | 1                       | 1                       |           | 1                       | 1                       |           |

#### Table 358: Monitor Channel Handshaking Process

## 15.9.2 Auxiliary Channel B

Channel B is used to interface to the 32Kbps C/I channel. The C/I channel is used to transfer 4-bit layer-1 commands between the CPU and the PHY chip. A command is considered valid after it is received twice (i.e. after receiving 8 bits).

#### Figure 75: Channel B Control Register



The CPU loads ATB with the data it wants to transmit and sets the V bit to 1. Auxiliary channel B transmitter loads the new data into its internal shift register, clears the V bit and generates a maskable interrupt. The data is transmitted constantly until new data is loaded.



**NOTE:** The C/I channel messages are 4 bits wide. The message must be duplicated to create an 8-bit word, which is written to the 8-bit ATB register.

When the transmit FlexTDM loses synchronization (i.e. when the SYNC signal is asserted not where expected), the auxiliary channel B transmitter flushes its shift register and stop its transmit process. The transmit process restarts when the FlexTDM regains synchronization.

The auxiliary channel B receiver generates an interrupt after it loads into ARB register a *new* C/I command. A new command is recognized when it is different from the previous loaded command. The channel receiver sets the V bit whenever it loads data into the ARB register. The CPU clears the V bit when it reads ARB.

When the receive FlexTDM loses synchronization, the auxiliary channel B receiver flushes its shift register and stops its receive process. The receive process restarts when the FlexTDM regains synchronization. The ARB contents are not affected by synchronization lost.

**NOTES:**The GT-96100A sets the V bit whenever it loads data, even if no new command was received. However, the GT-96100A interrupts the CPU only when new command was received.

When the FlexTDM loses synchronization (i.e., when SYNC is not asserted where expected), the V bit is cleared, even if new data has been loaded into ATB register. This prevents the new data from being transmitted. The driver software must rewrite the data to the ATB register when there is loss of synchronization (Loss of synchronization can be recognized using an interrupt or by polling).

## 15.10 IOM Programing

Table 359, Table 360 and Table 361 provide the recommended DPRAM programming for the IOM bus. If IOM mode is selected, the programming recommendations must be followed for the appropriate collision resolution process.

**NOTE:** In these tables, B channels mask bits are set to '1'. However, the CPU must complete layer-2 negotiations before granting a MPSC access to one of the B channels.

| Entry<br>Number | L | RPT | STRB | в | СН    | MASK     | Comments                                                                          |
|-----------------|---|-----|------|---|-------|----------|-----------------------------------------------------------------------------------|
| 0               | 0 | 00  | хх   | 1 | 00000 | 11111111 | B channel 0 to MPSC0 (1 byte).                                                    |
| 1               | 0 | 00  | хх   | 1 | 00001 | 11111111 | B channel 1 to MPSC1 (1 byte).                                                    |
| 2               | 0 | 00  | хх   | 1 | 11110 | 11111111 | Monitor to AUXA (1 byte).                                                         |
| 3               | 0 | 01  | хх   | 0 | 00010 | 00000110 | D channel to MPSC2 (2 bits).<br><b>NOTE:</b> The MASK setting for D channel data. |
| 4               | 0 | 11  | хх   | 0 | 11111 | 00000010 | C/I to AUXB (4 bits).                                                             |

| Table 3 | 59: IOM-1 | Progra | nming |
|---------|-----------|--------|-------|
|---------|-----------|--------|-------|

| Entry<br>Number | L | RPT | STRB | в | СН    | MASK                       | Comments                                                                                                                       |
|-----------------|---|-----|------|---|-------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 5               | 0 | 00  | хх   | 0 | 11110 | 00010001<br>or<br>00010011 | Receive: MX bit to AUXA (1bit).<br>Transmit: force 0 or 1 on MR using<br>MASK[1:0] (1bit).                                     |
| 6               | 1 | 00  | xx   | 0 | 11110 | 00100001<br>or<br>00100011 | Receive: MR bit to AUXA (1bit).<br>Transmit: force 0 or 1 on MX using<br>MASK[1:0] (1bit).<br>L indicates last entry in frame. |

## Table 359: IOM-1 Programming (Continued)

## Table 360: IOM2-TE Programming

| Entry |   | DDT | 0.7.0.0 |   |       | MAOK                    | O a man a más                                                                                                    |
|-------|---|-----|---------|---|-------|-------------------------|------------------------------------------------------------------------------------------------------------------|
| No    | L | RPT | STRB    | В | СН    | MASK                    | Comments                                                                                                         |
| 0     | 0 | 00  | хх      | 1 | 00000 | 11111111                | B channel 0 (in IOM channel 0)<br>to MPSC0 (1 byte).                                                             |
| 1     | 0 | 00  | хх      | 1 | 00001 | 11111111                | B channel 1 (in IOM channel 0)<br>to MPSC1 (1 byte).                                                             |
| 2     | 0 | 00  | хх      | 1 | 11110 | 11111111                | Monitor (in IOM channel 0) to AUXA (1 byte).                                                                     |
| 3     | 0 | 01  | хх      | 0 | 00010 | 00000110                | D channel (in IOM channel 0) to<br>MPSC2 (2 bits). Note the MASK<br>setting for D channel data.                  |
| 4     | 0 | 11  | хх      | 0 | 11111 | 0000010                 | C/I (in IOM channel 0) to AUXB (4 bits).                                                                         |
| 5     | 0 | 00  | хх      | 0 | 11110 | 00010001 or<br>00010011 | Receive: MX bit (in IOM channel<br>0) to AUXA (1bit).<br>Transmit: force 0 or 1 on MR<br>using MASK[1:0] (1bit). |
| 6     | 0 | 00  | хх      | 0 | 11110 | 00100001 or<br>00100011 | Receive: MR bit (in IOM channel<br>0) to AUXA (1bit).<br>Transmit: force 0 or 1 on MX<br>using MASK[1:0] (1bit). |
| 7     | 0 | 11  | хх      | 1 | 11110 | 0000000                 | Skip IOM channel 1 (4 bytes).                                                                                    |
| 8     | 0 | 10  | хх      | 1 | 11110 | 0000000                 | Skip part of IOM channel 2 (3 bytes).                                                                            |
| 9     | 0 | 01  | xx      | 0 | 11110 | 0000000                 | Skip more (2 bits).                                                                                              |
| 10    | 0 | 00  | хх      | 0 | 11110 | 00001000                | D-grant/D-req bit in C/I channel<br>of IOM channel 2 (1 bit).                                                    |



| Entry<br>No | L | RPT | STRB | в | СН    | MASK    | Comments                                                                      |
|-------------|---|-----|------|---|-------|---------|-------------------------------------------------------------------------------|
| 11          | 0 | 11  | хх   | 0 | 11110 | 0000000 | Skip (4 bits).                                                                |
| 12          | 1 | 00  | хх   | 0 | 11110 | 0000000 | Skip to end of frame (1 bit).<br>L is set to indicate last entry in<br>frame. |

Table 360: IOM2-TE Programming (Continued)

### Table 361: IOM2-LC (connected to channel 3) GCI

| Entry |   |     |      |   |       |                         |                                                                                                                  |
|-------|---|-----|------|---|-------|-------------------------|------------------------------------------------------------------------------------------------------------------|
| No    | L | RPT | STRB | В | СН    | MASK                    | Comments                                                                                                         |
| 0     | 0 | 11  | хх   | 1 | 11110 | 0000000                 | Skip IOM channel 0 (4 bytes).                                                                                    |
| 1     | 0 | 11  | хх   | 1 | 11110 | 0000000                 | Skip IOM channel 1 (4 bytes).                                                                                    |
| 2     | 0 | 11  | хх   | 1 | 11110 | 0000000                 | Skip IOM channel 2 (4 bytes).                                                                                    |
| 3     | 0 | 00  | хх   | 1 | 00000 | 11111111                | B channel 0 (in IOM channel 3)<br>to MPSC0 (1 byte).                                                             |
| 4     | 0 | 00  | хх   | 1 | 00001 | 11111111                | B channel 1 (in IOM channel 3)<br>to MPSC1 (1 byte).                                                             |
| 5     | 0 | 00  | хх   | 1 | 11110 | 11111111                | Monitor (in IOM channel 3) to AUXA (1 byte).                                                                     |
| 6     | 0 | 01  | хх   | 0 | 00010 | 00000110                | D channel (in IOM channel 3) to<br>MPSC2 (2 bits).<br><b>NOTE:</b> The MASK setting for<br>D channel data.       |
| 7     | 0 | 11  | хх   | 0 | 11111 | 0000010                 | C/I (in IOM channel 3) to AUXB (4 bits).                                                                         |
| 8     | 0 | 00  | xx   | 0 | 11110 | 00010001 or<br>00010011 | Receive: MX bit (in IOM channel<br>3) to AUXA (1bit).<br>Transmit: force 0 or 1 on MR<br>using MASK[1:0] (1bit). |
| 9     | 0 | 00  | хх   | 0 | 11110 | 00100010 or<br>00100011 | Receive: MR bit (in IOM channel<br>3) to AUXA (1bit).<br>Transmit: force 0 or 1 on MX<br>using MASK[1:0] (1bit). |
| 10    | 0 | 11  | хх   | 1 | 11110 | 0000000                 | Skip IOM channel 4 (4 bytes).                                                                                    |
| 11    | 0 | 11  | хх   | 1 | 11110 | 0000000                 | Skip IOM channel 5 (4 bytes).                                                                                    |



| Entry<br>No | L | RPT | STRB | в | СН    | MASK    | Comments                                                                      |
|-------------|---|-----|------|---|-------|---------|-------------------------------------------------------------------------------|
| 12          | 0 | 11  | хх   | 1 | 11110 | 0000000 | Skip IOM channel 6 (4 bytes).                                                 |
| 13          | 1 | 11  | хх   | 1 | 11110 | 0000000 | Skip IOM channel 7 (4 bytes).<br>L is set to indicate last entry in<br>frame. |

 Table 361: IOM2-LC (connected to channel 3) GCI (Continued)

## 15.11 FlexTDM Registers

## Table 362: FlexTDM Register Map

| Description                                      | Offset                                | Page<br>Number |
|--------------------------------------------------|---------------------------------------|----------------|
| FlexTDM0                                         |                                       | •              |
| FlexTDM0 Transmit Dual Port RAM (TDPR0), block 0 | 0x000 <b>B</b> 00 - 0x000 <b>B</b> FF |                |
| FlexTDM0 Transmit Dual Port RAM (TDPR0), block 1 | 0x001 <b>B</b> 00 - 0x001 <b>B</b> FF |                |
| FlexTDM0 Transmit Dual Port RAM (TDPR0), block 2 | 0x002 <b>B</b> 00 - 0x002 <b>B</b> FF |                |
| FlexTDM0 Transmit Dual Port RAM (TDPR0), block 3 | 0x003 <b>B</b> 00 - 0x003 <b>B</b> FF |                |
| FlexTDM0 Receive Dual Port RAM (RDPR0), block 0  | 0x004 <b>B</b> 00 - 0x004 <b>B</b> FF |                |
| FlexTDM0 Receive Dual Port RAM (RDPR0), block 1  | 0x005 <b>B</b> 00 - 0x005 <b>B</b> FF |                |
| FlexTDM0 Receive Dual Port RAM (RDPR0), block 2  | 0x006 <b>B</b> 00 - 0x006 <b>B</b> FF |                |
| FlexTDM0 Receive Dual Port RAM (RDPR0), block 3  | 0x007 <b>B</b> 00 - 0x007 <b>B</b> FF |                |
| FlexTDM0 Transmit Read Pointer (TRP0)            | 0x008 <b>B</b> 00                     |                |
| FlexTDM0 Receive Read Pointer (TRP0)             | 0x008 <b>B</b> 04                     |                |
| FlexTDM0 Configuration Register (TCR0)           | 0x008 <b>B</b> 08                     | page 384       |
| FlexTDM0 AUX ChannelA TX Register (ATA0)         | 0x008 <b>B</b> 0C                     |                |
| FlexTDM0 AUX ChannelA RX Register (ARA0)         | 0x008 <b>B</b> 10                     |                |
| FlexTDM0 AUX ChannelB TX Register (ATB0)         | 0x008 <b>B</b> 14                     |                |
| FlexTDM0 AUX ChannelB RX Register (ARB0)         | 0x008 <b>B</b> 18                     |                |
| FlexTDM1                                         |                                       |                |
| FlexTDM1 Transmit Dual Port RAM (TDPR1), block 0 | 0x010 <b>B</b> 00 - 0x010 <b>B</b> FF |                |
| FlexTDM1 Transmit Dual Port RAM (TDPR1), block 1 | 0x011 <b>B</b> 00 - 0x011 <b>B</b> FF |                |
| FlexTDM1 Transmit Dual Port RAM (TDPR1), block 2 | 0x012 <b>B</b> 00 - 0x012 <b>B</b> FF |                |
| FlexTDM1 (Continued)                             |                                       |                |



| Description                                      | Offset                                | Page<br>Number |
|--------------------------------------------------|---------------------------------------|----------------|
| FlexTDM1 Transmit Dual Port RAM (TDPR1), block 3 | 0x013 <b>B</b> 00 - 0x013 <b>B</b> FF |                |
| FlexTDM1 Receive Dual Port RAM (RDPR1), block 0  | 0x014 <b>B</b> 00 - 0x014 <b>B</b> FF |                |
| FlexTDM1 Receive Dual Port RAM (RDPR1), block 1  | 0x015 <b>B</b> 00 - 0x015 <b>B</b> FF |                |
| FlexTDM1 Receive Dual Port RAM (RDPR1), block 2  | 0x016 <b>B</b> 00 - 0x016 <b>B</b> FF |                |
| FlexTDM1 Receive Dual Port RAM (RDPR1), block 3  | 0x017 <b>B</b> 00 - 0x017 <b>B</b> FF |                |
| FlexTDM1 Transmit Read Pointer (TRP1)            | 0x018 <b>B</b> 00                     |                |
| FlexTDM1 Receive Read Pointer (TRP1)             | 0x018 <b>B</b> 04                     |                |
| FlexTDM1 Configuration Register (TCR1)           | 0x018 <b>B</b> 08                     | page 384       |
| FlexTDM1 AUX ChannelA TX Register (ATA1)         | 0x018 <b>B</b> 0C                     |                |
| FlexTDM1 AUX ChannelA RX Register (ARA1)         | 0x018 <b>B</b> 10                     |                |
| FlexTDM1 AUX ChannelB TX Register (ATB1)         | 0x018 <b>B</b> 14                     |                |
| FlexTDM1 AUX ChannelB RX Register (ARB1)         | 0x018 <b>B</b> 18                     |                |
| FlexTDM2                                         |                                       |                |
| FlexTDM2 Transmit Dual Port RAM (TDPR2), block 0 | 0x020 <b>B</b> 00 - 0x020 <b>B</b> FF |                |
| FlexTDM2 Transmit Dual Port RAM (TDPR2), block 1 | 0x021 <b>B</b> 00 - 0x021 <b>B</b> FF |                |
| FlexTDM2 Transmit Dual Port RAM (TDPR2), block 2 | 0x022 <b>B</b> 00 - 0x022 <b>B</b> FF |                |
| FlexTDM2 Transmit Dual Port RAM (TDPR2), block 3 | 0x023 <b>B</b> 00 - 0x023 <b>B</b> FF |                |
| FlexTDM2 Receive Dual Port RAM (RDPR2), block 0  | 0x024 <b>B</b> 00 - 0x024 <b>B</b> FF |                |
| FlexTDM2 Receive Dual Port RAM (RDPR2), block 1  | 0x025 <b>B</b> 00 - 0x025 <b>B</b> FF |                |
| FlexTDM2 Receive Dual Port RAM (RDPR2), block 2  | 0x026 <b>B</b> 00 - 0x026 <b>B</b> FF |                |
| FlexTDM2 Receive Dual Port RAM (RDPR2), block 3  | 0x027 <b>B</b> 00 - 0x027 <b>B</b> FF |                |
| FlexTDM2 Transmit Read Pointer (TRP2)            | 0x028 <b>B</b> 00                     |                |
| FlexTDM2 Receive Read Pointer (TRP2)             | 0x028 <b>B</b> 04                     |                |
| FlexTDM2 Configuration Register (TCR2)           | 0x028 <b>B</b> 08                     | page 384       |
| FlexTDM2 AUX ChannelA TX Register (ATA2)         | 0x028 <b>B</b> 0C                     |                |
| FlexTDM2 AUX ChannelA RX Register (ARA2)         | 0x028 <b>B</b> 10                     |                |
| FlexTDM2 AUX ChannelB TX Register (ATB2)         | 0x028 <b>B</b> 14                     |                |
| FlexTDM2 AUX ChannelB RX Register (ARB2)         | 0x028 <b>B</b> 18                     |                |
| FlexTDM3                                         |                                       |                |
| FlexTDM3 Transmit Dual Port RAM (TDPR3), block 0 | 0x030 <b>B</b> 00 - 0x030 <b>B</b> FF |                |



### Table 362: FlexTDM Register Map (Continued)

| Description                                      | Offset                                | Page<br>Number |
|--------------------------------------------------|---------------------------------------|----------------|
| FlexTDM3 Transmit Dual Port RAM (TDPR3), block 1 | 0x031 <b>B</b> 00 - 0x031 <b>B</b> FF |                |
| FlexTDM3 Transmit Dual Port RAM (TDPR3), block 2 | 0x032 <b>B</b> 00 - 0x032 <b>B</b> FF |                |
| FlexTDM3 Transmit Dual Port RAM (TDPR3), block 3 | 0x033 <b>B</b> 00 - 0x033 <b>B</b> FF |                |
| FlexTDM3 Receive Dual Port RAM (RDPR3), block 0  | 0x034 <b>B</b> 00 - 0x034 <b>B</b> FF |                |
| FlexTDM3 Receive Dual Port RAM (RDPR3), block 1  | 0x035 <b>B</b> 00 - 0x035 <b>B</b> FF |                |
| FlexTDM3 Receive Dual Port RAM (RDPR3), block 2  | 0x036 <b>B</b> 00 - 0x036 <b>B</b> FF |                |
| FlexTDM3 Receive Dual Port RAM (RDPR3), block 3  | 0x037 <b>B</b> 00 - 0x037 <b>B</b> FF |                |
| FlexTDM3 Transmit Read Pointer (TRP3)            | 0x038 <b>B</b> 00                     |                |
| FlexTDM3 Receive Read Pointer (TRP3)             | 0x038 <b>B</b> 04                     |                |
| FlexTDM3 Configuration Register (TCR3)           | 0x038 <b>B</b> 08                     | page 384       |
| FlexTDM3 AUX ChannelA TX Register (ATA3)         | 0x038 <b>B</b> 0C                     |                |
| FlexTDM3 AUX ChannelA RX Register (ARA3)         | 0x038 <b>B</b> 10                     |                |
| FlexTDM3 AUX ChannelB TX Register (ATB3)         | 0x038 <b>B</b> 14                     |                |
| FlexTDM3 AUX ChannelB RX Register (ARB3)         | 0x038 <b>B</b> 18                     |                |



# 16. BAUD RATE GENERATORS (BRGS)

There are eight baud rate generators (BRGs) in the GT-96100A. Figure 76 shows a BRG block diagram.



#### Figure 76: Baud Rate Generator Block Diagram

### 16.1 BRG Inputs and Outputs

There are 19 clock inputs to the baud rate generators (BRGs). Two general purpose pins can be programmed to function as clock inputs for the BRGs: GPP[0] and GPP[1]. Additionally, each of the serial input clocks can be used as a BRG clock. Finally, the TCLK, which is the system parallel clock, is also an option.

When a BRG is enabled, it loads the Count Down Value (CDV), from the BRG configuration register, into its count down counter. When the counter expires (i.e. reaches zero), the BRG clock output, BCLK, is toggled and the counter reloads.

# 16.2 BRG Baud Tuning

A baud tuning mechanism can be used to adjust the generated clock rate to the receive clock rate.

When baud tuning is enabled, the baud tuning mechanism monitors for a start bit, i.e. High-to-Low transition. When a start bit is found, the baud tuning machine measures the bit length by counting up until the next Low-to-High transition. The count-up value of the BRG is then loaded into the Count Up Value (CUV) register and a maskable interrupt is generated signaling the CPU that the bit length value is available. The CPU reads the value from the CUV and adjusts the CDV to the requested value.

The CUV can be used to adjust the CDV, in the BRG configuration register, to the requested value.



# 16.3 BRG Registers

### Table 363: BRG Registers Map

| Register Name                      | Offset            | Page                                               |
|------------------------------------|-------------------|----------------------------------------------------|
| BRG0                               |                   |                                                    |
| BRG0 Configuration Register (BCR0) | 0x102 <b>A</b> 00 | page 399                                           |
| BRG0 Baud Tuning Register (BTR0)   | 0x102 <b>A</b> 04 | page 400                                           |
| BRG1                               |                   |                                                    |
| BRG1 Configuration Register (BCR1) | 0x102 <b>A</b> 08 | For a description of the BRG1 regis-               |
| BRG1 Baud Tuning Register (BTR1)   | 0x102 <b>A</b> 0C | ters, see the descriptions for the BRG0 registers. |
| BRG2                               |                   |                                                    |
| BRG2 Configuration Register (BCR2) | 0x102 <b>A</b> 10 | For a description of the BRG2 regis-               |
| BRG2 Baud Tuning Register (BTR2)   | 0x102 <b>A</b> 14 | ters, see the descriptions for the BRG0 registers. |
| BRG3                               |                   |                                                    |
| BRG3 Configuration Register (BCR3) | 0x102 <b>A</b> 18 | For a description of the BRG3 regis-               |
| BRG3 Baud Tuning Register (BTR3)   | 0x102 <b>A</b> 1C | ters, see the descriptions for the BRG0 registers. |
| BRG4                               |                   |                                                    |
| BRG4 Configuration Register (BCR4) | 0x102 <b>A</b> 20 | For a description of the BRG4 regis-               |
| BRG4 Baud Tuning Register (BTR4)   | 0x102 <b>A</b> 24 | ters, see the descriptions for the BRG0 registers. |
| BRG5                               |                   |                                                    |
| BRG5 Configuration Register (BCR5) | 0x102 <b>A</b> 28 | For a description of the BRG5 regis-               |
| BRG5 Baud Tuning Register (BTR5)   | 0x102 <b>A</b> 2C | ters, see the descriptions for the BRG0 registers. |
| BRG6                               |                   |                                                    |
| BRG6 Configuration Register (BCR6) | 0x102 <b>A</b> 30 | For a description of the BRG6 regis-               |
| BRG6 Baud Tuning Register (BTR6)   | 0x102 <b>A</b> 34 | ters, see the descriptions for the BRG0 registers. |
| BRG7                               |                   |                                                    |
| BRG7 Configuration Register (BCR7) | 0x102 <b>A</b> 38 | For a description of the BRG7 regis-               |
| BRG7 Baud Tuning Register (BTR7)   | 0x102 <b>A</b> 3C | ters, see the descriptions for the BRG0 registers. |





| Bits  | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset<br>Value |
|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 15:0  | CDV  | Count Down Value.<br>The user programs the CDV field to define the baud rate that the BRG generates. CDV is loaded into the BRG counter every time it reaches 0. The actual baud rate is:<br>$BaudRate = \frac{InputClockRate}{(CDV+1) \times 2}$                                                                                                                                                                                                                                                                                                                                                                                     |                |
|       |      | When CDV is 0x0000, the generated baud rate is equal to the input clock rate.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |
| 16    | En   | Enable BRG<br>0 - Disabled. Output clock is clamped to 0.<br>1 - Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0              |
| 17    | RST  | Reset BRG<br>0 - No Op.<br>1 - Reset BRG counter to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0              |
| 22:18 | CLKS | Clock Source (input clock to the BRG)<br>00000 - BCLK0 (from GPP[0] pin)<br>00011 - BCLK1 (from GPP[1] pin)<br>00010 - SCLK0 (from PA[5] pin)<br>00011 - TSCLK0 (from PA[6] pin)<br>00100 - SCLK1 (from PB[5] pin)<br>00101 - TSCLK1 (from PE[6] pin)<br>00110 - SCLK2 (from PC[5] pin)<br>00111 - TSCLK2 (from PC[6] pin)<br>01000 - SCLK3 (from PD[5] pin)<br>01001 - TSCLK3 (from PE[5] pin)<br>01011 - TSCLK4 (from PE[6] pin)<br>01101 - SCLK5 (from PF[5] pin)<br>01101 - SCLK5 (from PF[6] pin)<br>01110 - SCLK5 (from MII0[12] pin)<br>01111 - TSCLK6 (from MII0[13] pin)<br>10000 - SCLK7 (from MII0[6] pin)<br>10010 - TCLK | 10010          |
| 24:23 |      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0              |

#### Table 364: BRGx Configuration Register (BCR) (Continued)

| Bits  | Name | Description                                                                                                                                                                                                    | Reset<br>Value |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 25    | BT   | Baud Tuning<br>0 - Disabled<br>1 - Enabled<br>Setting BT to 1 enables the baud tuning for the duration of one start bit.<br>When the Start Bit Length calculation is done, the GT-96100A clears the BT<br>bit. | 0              |
| 31:24 |      | Reserved                                                                                                                                                                                                       | 0              |

#### Table 365: BRGx Baud Tuning register (BTR)

**NOTE:** If the BRG is written for a clock source that is inactive, this register cannot be accessed, see Table 364 bits [22:18].

| Bits  | Name | Description                                           | Reset<br>Value |
|-------|------|-------------------------------------------------------|----------------|
| 15:0  | CUV  | Count Up Value <b>NOTE:</b> These bits are read only. | 0              |
| 31:16 |      | Reserved.                                             | 0              |



## **17. WATCHDOG TIMER**

The GT-96100A internal watchdog timer is a 32-bit count down counter that can be used to generate a nonmaskable interrupt or reset the system in the event of unpredictable software behavior.

After the watchdog is enabled, it is a free running counter that needs to be serviced periodically in order to prevent its expiration.

## 17.1 Watchdog Registers

Figure 77: Watchdog Register Map

| register | ••===== | 2 2 2 2 1 1 1 1 1 1 1 1 1 1<br>3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 | offset   |
|----------|---------|--------------------------------------------------------------------------------|----------|
| WDC      |         | Preset_VAL                                                                     | 0x101A80 |
| WDV      |         | NMI_VAL                                                                        | 0x101A84 |

#### Table 366: Watchdog Configuration register (WDC), Offset: 0x101A80

| Bits  | Field<br>Name | Function                                                                                                                                                                                                         | Initial<br>Value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 23:0  | Preset_VAL    | This field holds the 24 most significant bits which the watchdog counter loads each time it is enabled or serviced. After reset, this field is set to 0xFF.FFFF. The preset value is equal to {0xPreset_VAL,FF}. | 0xFF.FFFF        |
| 25:24 | CTL1          | A write sequence of '01' followed by '10' into CTL1 disables/enables the watchdog.                                                                                                                               | 00               |
| 27:26 | CTL2          | A write sequence of '01' followed by '10' to CTL2 services the watch-<br>dog timer.                                                                                                                              | 00               |
| 28    |               | Reserved.                                                                                                                                                                                                        | 0                |
| 29    | NMI           | Non-Maskable Interrupt<br>When the watchdog counter reaches a value equal to NMI_VAL, this<br>bit is asserted. This pin can be used to drive the processor's NMI*<br>pin.<br>This bit is read only.              | 1                |

| Bits | Field<br>Name | Function                                                                                                                                                          | lnitial<br>Value |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 30   | WDE           | Watchdog Expiration<br>When the watchdog counter expires, this bit is asserted. The WDE*<br>pin can be used to reset the entire system.<br>This bit is read only. | 1                |
| 31   | EN            | Enable<br>0 - Watchdog is disabled, counter is loaded with Preset_VAL. NMI<br>and WDE are set to '1'.<br>1 - Watchdog is enabled.<br>This bit is read only.       | 0                |

#### Table 366: Watchdog Configuration register (WDC), Offset: 0x101A80 (Continued)

#### Table 367: Watchdog Value register (WDV), Offset: 0x101A84

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                  | Reset<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 23:0  | NMI_VAL       | NMI_VAL are the 24 least significant bits of a 32-bit value. The upper 8 bits are always '00'.<br>When the Watchdog counter reaches a value equal to the NMI value NMI* pin is asserted. The actual NMI value is a 32-bit number equal to {0x00,NMI_VAL}. | 0x000.0000     |
| 31:24 |               | Reserved.                                                                                                                                                                                                                                                 | 0              |

## 17.2 Watchdog Operation

After reset, the watchdog is disabled.

The watchdog must be serviced periodically in order to avoid NMI or reset (WDE\*). Watchdog service is performed by writing '01' to CTL2, followed by writing '10' to CTL2. Upon watchdog service, the GT-96100A clears the NMI and WDE bits (if set) and reloads the Preset\_VAL into the watchdog counter.

A write sequence of '01' followed by '10' into CTL1 disables/enables the watchdog. The watchdog's current status can be read in bit 31 of WDC. When disabled, the GT-96100A sets the NMI and WDE bits (if clear) and reloads the Preset\_VAL into the watchdog counter.

Preset\_VAL and NMI\_VAL can be changed while the watchdog is enabled. However, Preset\_VAL will affect the watchdog only after it is loaded into the watchdog counter (e.g. after watchdog service).

If the watchdog is not serviced before the counter reaches NMI\_VAL, a non-maskable interrupt event occurs. a watchdog expiration event occurs. The NMI bit is reset, asserting low the NMI\* pin.

In order to deassert the NMI\* and/or WDE\* pins, the watchdog must be serviced, disabled or the GT-96100A must be reset. The GT-96100A holds WDE\* asserted for the duration of 16 system cycles after reset assertion.



## **18.** TIMERS/COUNTERS

There are three 24-bit wide and one 32-bit wide timer/counters on the GT-96100A. Each one can be selected to operate as a timer or as a counter.

**NOTE:** The count frequency for the timer/counters is equal to TCLk frequency

In Counter mode, the counter counts down to terminal count, stops, and issue an interrupt.

In Timer mode, the timer counts down, issues an interrupt on terminal count, and resets itself to the programmed countdown value, and begins to count down.

Reads from the counter or timer are done from the counter itself, while writes are to its register. For example, note that even though the registers are programmed to an initial value of 0 the counters read 0xffffff.

In order to reprogram a timer/counter:

- 1. Disable the timer/counter.
- 2. Load it with a new value.
- 3. Enable it as appropriate, counter or timer.
- **NOTE:** There are no external input pins for enable/disable nor are there any output timer pins on the GT-96100A.

### 18.1 Timer / Counter Registers

#### Table 368: Timer/Counter 0, Offset: 0x850

| Bits | Field Name | Function                            | Initial Value |
|------|------------|-------------------------------------|---------------|
| 31:0 | TC0Value   | The counter or timer initial value. | 0xfffffff     |

#### Table 369: Timer/Counter 1, Offset: 0x854

| Bits  | Field Name | Function                            | Initial Value |
|-------|------------|-------------------------------------|---------------|
| 23:0  | TC1Value   | The counter or timer initial value. | 0xfffff       |
| 31:24 | Reserved   | Reserved.                           | 0x0           |

#### Table 370: Timer/Counter 2, Offset: 0x858

| Bits  | Field Name | Function                            | Initial Value |
|-------|------------|-------------------------------------|---------------|
| 23:0  | TC2Value   | The counter or timer initial value. | 0xfffff       |
| 31:24 | Reserved   | Reserved.                           | 0x0           |

| Bits  | Field Name | Function                            | Initial Value |
|-------|------------|-------------------------------------|---------------|
| 23:0  | TC3Value   | The counter or timer initial value. | 0xfffff       |
| 31:24 | Reserved   | Reserved.                           | 0x0           |

### Table 371: Timer/Counter 3, Offset: 0x85c

### Table 372: Timer/Counter Control, Offset: 0x864

| Bits | Field Name | Function                                                                          | Initial Value |
|------|------------|-----------------------------------------------------------------------------------|---------------|
| 0    | EnTC0      | The timer/counter counts only when it is<br>enabled.<br>0 - Disable<br>1 - Enable | 0x0           |
| 1    | SelTC0     | Timer or Counter Selection<br>0 - Counter<br>1 - Timer                            | 0x0           |
| 2    | EnTC1      | The timer/counter counts only when it is<br>enabled.<br>0 - Disable<br>1 - Enable | 0x0           |
| 3    | SelTC1     | Timer or Counter Selection<br>0 - Counter<br>1 - Timer                            | 0x0           |
| 4    | EnTC2      | The timer/counter counts only when it is<br>enabled.<br>0 - Disable<br>1 - Enable | 0x0           |
| 5    | SelTC2     | Timer or Counter Selection<br>0 - Counter<br>1 - Timer                            | 0x0           |
| 6    | EnTC3      | The timer/counter counts only when it is<br>enabled.<br>0 - Disable<br>1 - Enable | 0x0           |
| 7    | SelTC3     | Timer or Counter Selection<br>0 - Counter<br>1 - Timer                            | 0x0           |
| 31:8 | Reserved   | Reserved.                                                                         | 0x0           |



## **19. GENERAL PURPOSE PORTS**

### 19.1 Overview

The GT-96100A supports up to 88 general purpose pins.

Most of these pins are shared (multiplexed) with the serial ports (ports A through F) and with the MII ports (MII0 and MII1). The result is that in most applications less than 88 pins can be configured as GPPs. However, the control of the ports in GT-96100A is made very flexible, providing the user with a pin level configuration capability. Thus, for example, if port A is used for serial communication but one of its pins is not needed (e.g. PA[6]), this single pin can be programmed to function as a general purpose pin, without affecting the other pins associated with the serial function.

GT-96100A also provides the capability of generating interrupts for each of the GPP pins.

## **19.2 General Purpose Control Registers**

The General Purpose registers control the behavior of the pins associated with the GPP function. There are 12 registers, which are divided into 3 groups. The groups are defined as follows:

- Group 0 includes GPP, A and B ports.
- Group 1 includes C, D, E and F ports.
- Group 2 includes MII0 and MII1 ports.

Each group of registers comprises four registers, used to configure the group pins.

| Register                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General Purpose Con-<br>figuration registers | GPC0, GPC1, and GPC2<br>These registers control the setting of the pins as either general-purpose I/O or<br>peripheral function. When a pin is configured as peripheral, it's exact functionality is<br>set according to the port's connection setting. For example, if port C is connected to<br>MPSC2, PC[0] is used as RXD2. If port C is tied to TDM0, PC[0] can be set to<br>either TRXD0 or TTXD0.                                                  |
| General Purpose Input/<br>Output registers   | <ul> <li>GPIO0, GPIO1, and GPIO2</li> <li>These registers control the direction of the pins (either input or output).</li> <li><b>NOTE:</b> GPIO registers affect pin functionality not only when the pin is configured as general purpose I/O, but also when the pin is configured as peripheral function. For example, If port C is tied to TDM0, setting PC[0] as TRXD0 (input) or TTXD0 (output) is done by programming GPIO1 accordingly.</li> </ul> |

Table 373: Control Registers

| Register                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General Purpose Data registers  | GPD0, GPD1, and GPD2<br>These registers hold the data associated with the general purpose I/O pins. These<br>registers' bits are read-only for general purpose inputs and are read-write for gen-<br>eral purpose outputs. The data read from these registers reflect the pin state, while<br>writing to these registers sets the data to be driven out (for output pins).<br>When a GPP pin is configured as input and its associated GPD bit is 0, an interrupt<br>is set. An interrupt is set regardless of the GPC state. |
| General Purpose Level registers | GPL0, GPL1, and GPL2<br>These registers define the polarity associated with pins that are configured as gen-<br>eral purpose input. For each pin defined as asserted low, the pin state is inverted<br>before being processed in the device. Thus, if a pin is externally tied to '0', but is<br>configured in the GPL register as negative polarity, the data read from the respec-<br>tive GPD bit is '1'.                                                                                                                  |

### Table 373: Control Registers (Continued)

The registers are described in the following tables.

#### Table 374: GPP Registers Map

| Description                            | Offset            | Page Number |  |  |  |  |
|----------------------------------------|-------------------|-------------|--|--|--|--|
| General Purpose Configuration          |                   |             |  |  |  |  |
| General Purpose Configuration 0 (GPC0) | 0x100 <b>A</b> 00 | page 407    |  |  |  |  |
| General Purpose Configuration 1 (GPC1) | 0x100 <b>A</b> 04 | page 409    |  |  |  |  |
| General Purpose Configuration 2 (GPC2) | 0x100 <b>A</b> 08 | page 412    |  |  |  |  |
| General Purpose Input/Output           |                   |             |  |  |  |  |
| General Purpose Input/Output 0 (GPIO0) | 0x100 <b>A</b> 20 | page 407    |  |  |  |  |
| General Purpose Input/Output 1 (GPIO1) | 0x100 <b>A</b> 24 | page 410    |  |  |  |  |
| General Purpose Input/Output 2 (GPIO2) | 0x100 <b>A</b> 28 | page 412    |  |  |  |  |
| General Purpose Data                   |                   |             |  |  |  |  |
| General Purpose Data 0 (GPD0)          | 0x100 <b>A</b> 40 | page 408    |  |  |  |  |
| General Purpose Data 1 (GPD1)          | 0x100 <b>A</b> 44 | page 410    |  |  |  |  |
| General Purpose Data 2 (GPD2)          | 0x100 <b>A</b> 48 | page 413    |  |  |  |  |
| General Purpose Level                  |                   |             |  |  |  |  |
| General Purpose Level 0 (GPL0)         | 0x100 <b>A</b> 60 | page 408    |  |  |  |  |
| General Purpose Level 1 (GPL1)         | 0x100 <b>A</b> 64 | page 411    |  |  |  |  |
| General Purpose Level 2 (GPL2)         | 0x100 <b>A</b> 68 | page 413    |  |  |  |  |



| Bits  | Field<br>Name | Function                                                                                                                                                                                                     | Initial<br>Value |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 15:0  | GPPC          | General Purpose Port Configuration<br>Each bit controls the setting of the respective pin in the GPP port.<br>0 - pin is configured as General Purpose I/O.<br>1 - pin is configured as peripheral function. | 0                |
| 22:16 | PAC           | Port A Configuration<br>Each bit controls the setting of the respective pin in port A.<br>0 - pin is configured as General Purpose I/O.<br>1 - pin is configured as peripheral function.                     | 0                |
| 23    |               | Reserved.                                                                                                                                                                                                    | 0                |
| 30:24 | PBC           | Port B Configuration<br>Each bit controls the setting of the respective pin in port B.<br>0 - pin is configured as General Purpose I/O.<br>1 - pin is configured as peripheral function.                     | 0                |
| 31    |               | Reserved.                                                                                                                                                                                                    | 0                |

Table 375: General Purpose Configuration 0 (GPC0), Offset: 0x100A00

#### Table 376: General Purpose Input/Output 0 (GPIO0), Offset: 0x100A20

| Bits  | Field<br>Name | Function                                                                                                                                                                                      | lnitial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 15:0  | GPPIO         | General Purpose Port I/O<br>Each bit controls the setting of the respective pin in the GPP port as input or<br>output.<br>0 - pin is configured as input.<br>1 - pin is configured as output. | 0                |
| 22:16 | PAIO          | Port A I/O<br>Each bit controls the setting of the respective pin in port A as input or output.<br>0 - pin is configured as input.<br>1 - pin is configured as output.                        | 0                |
| 23    |               | Reserved.                                                                                                                                                                                     | 0                |
| 30:24 | PBIO          | Port B I/O. Each bit controls the setting of the respective pin in port B as<br>input or output.<br>0 - pin is configured as input.<br>1 - pin is configured as output.                       | 0                |
| 31    |               | Reserved.                                                                                                                                                                                     | 0                |

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                            | Initial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 15:0  | GPPD          | General Purpose Port Data<br>Each bit holds the data of the respective pin in GPP port. If the pin is config-<br>ured as input, this bit is read-only and reflects the signal status at the pin. If<br>the pin is configured as output, this bit is read-write and controls the data<br>driven out. | 0                |
| 22:16 | PAD           | Port A Data<br>Each bit holds the data of the respective pin in port A. If the pin is configured<br>as input, this bit is read-only and reflects the signal status at the pin. If the<br>pin is configured as output, this bit is read-write and controls the data driven<br>out.                   | 0                |
| 23    |               | Reserved.                                                                                                                                                                                                                                                                                           | 0                |
| 30:24 | PBD           | Port B Data<br>Each bit holds the data of the respective pin in port B. If the pin is configured<br>as input, this bit is read-only and reflects the signal status at the pin. If the<br>pin is configured as output, this bit is read-write and controls the data driven<br>out.                   | 0                |
| 31    |               | Reserved.                                                                                                                                                                                                                                                                                           | 0                |

### Table 377: General Purpose Data 0 (GPD0), Offset: 0x100A40

#### Table 378: General Purpose Level 0 (GPL0), Offset: 0x100A60

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                      | Initial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 15:0  | GPPL          | <ul> <li>General Purpose Port Level</li> <li>Each bit defines the polarity of the respective pin in GPP port.</li> <li>0 - positive (normal) polarity.</li> <li>1 - negative polarity. If the pin is configured as input, it is inverted before being processed inside the device.</li> </ul> | 0                |
| 22:16 | PAL           | Port A Level<br>Each bit defines the polarity of the respective pin in port A.<br>0 - positive (normal) polarity.<br>1 - negative polarity. If the pin is configured as input, it is inverted before<br>being processed inside the device.                                                    | 0                |
| 23    |               | Reserved.                                                                                                                                                                                                                                                                                     | 0                |
| 30:24 | PBL           | Port B Level<br>Each bit defines the polarity of the respective pin in port B.<br>0 - positive (normal) polarity.<br>1 - negative polarity. If the pin is configured as input, it is inverted before<br>being processed inside the device.                                                    | 0                |



| Bits | Field<br>Name | Function  | lnitial<br>Value |
|------|---------------|-----------|------------------|
| 31   |               | Reserved. | 0                |

#### Table 378: General Purpose Level 0 (GPL0), Offset: 0x100A60 (Continued)

#### Table 379: General Purpose Configuration 1 (GPC1), Offset: 0x100A04

| Bits  | Field<br>Name | Function                                                                                                                                                                                 | lnitial<br>Value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 6:0   | PCC           | Port C Configuration<br>Each bit controls the setting of the respective pin in port C.<br>0 - pin is configured as General Purpose I/O.<br>1 - pin is configured as peripheral function. | 0                |
| 7     |               | Reserved.                                                                                                                                                                                | 0                |
| 14:8  | PDC           | Port D Configuration<br>Each bit controls the setting of the respective pin in port D.<br>0 - pin is configured as General Purpose I/O.<br>1 - pin is configured as peripheral function. | 0                |
| 15    |               | Reserved.                                                                                                                                                                                | 0                |
| 22:16 | PEC           | Port E Configuration<br>Each bit controls the setting of the respective pin in port E.<br>0 - pin is configured as General Purpose I/O.<br>1 - pin is configured as peripheral function. | 0                |
| 23    |               | Reserved.                                                                                                                                                                                | 0                |
| 30:24 | PFC           | Port F Configuration<br>Each bit controls the setting of the respective pin in port F.<br>0 - pin is configured as General Purpose I/O.<br>1 - pin is configured as peripheral function. | 0                |
| 31    |               | Reserved.                                                                                                                                                                                | 0                |

| Bits  | Field<br>Name | Function                                                                                                                                                               | lnitial<br>Value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 6:0   | PCIO          | Port C I/O<br>Each bit controls the setting of the respective pin in port C as input or output.<br>0 - pin is configured as input.<br>1 - pin is configured as output. | 0                |
| 7     |               | Reserved.                                                                                                                                                              | 0                |
| 14:8  | PDIO          | Port D I/O<br>Each bit controls the setting of the respective pin in port D as input or output.<br>0 - pin is configured as input.<br>1 - pin is configured as output. | 0                |
| 15    |               | Reserved.                                                                                                                                                              | 0                |
| 22:16 | PEIO          | Port E I/O<br>Each bit controls the setting of the respective pin in port E as input or output.<br>0 - pin is configured as input.<br>1 - pin is configured as output. | 0                |
| 23    |               | Reserved.                                                                                                                                                              | 0                |
| 30:24 | PFIO          | Port F I/O<br>Each bit controls the setting of the respective pin in port F as input or output.<br>0 - pin is configured as input.<br>1 - pin is configured as output. | 0                |
| 31    |               | Reserved.                                                                                                                                                              | 0                |

### Table 380: General Purpose Input/Output 1 (GPIO1), Offset: 0x100A24

#### Table 381: General Purpose Data 1 (GPD1), Offset: 0x100A44

| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                          | lnitial<br>Value |
|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 6:0  | PCD           | Port C Data<br>Each bit holds the data of the respective pin in port C.<br>If the pin is configured as input, this bit is read-only and reflects the signal<br>status at the pin. If the pin is configured as output, this bit is read-write and<br>controls the data driven out. | 0                |
| 7    |               | Reserved                                                                                                                                                                                                                                                                          | 0                |
| 14:8 | PDD           | Port D Data<br>Each bit holds the data of the respective pin in port D.<br>If the pin is configured as input, this bit is read-only and reflects the signal<br>status at the pin. If the pin is configured as output, this bit is read-write and<br>controls the data driven out. | 0                |



| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                          | Initial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 15    |               | Reserved                                                                                                                                                                                                                                                                          | 0                |
| 22:16 | PED           | Port E Data<br>Each bit holds the data of the respective pin in port E.<br>If the pin is configured as input, this bit is read-only and reflects the signal<br>status at the pin. If the pin is configured as output, this bit is read-write and<br>controls the data driven out. | 0                |
| 23    |               | Reserved                                                                                                                                                                                                                                                                          | 0                |
| 30:24 | PFD           | Port F Data<br>Each bit holds the data of the respective pin in port F.<br>If the pin is configured as input, this bit is read-only and reflects the signal<br>status at the pin. If the pin is configured as output, this bit is read-write and<br>controls the data driven out. | 0                |
| 31    |               | Reserved                                                                                                                                                                                                                                                                          | 0                |

#### Table 381: General Purpose Data 1 (GPD1), Offset: 0x100A44 (Continued)

#### Table 382: General Purpose Level 1 (GPL1), Offset: 0x100A64

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                      | Initial<br>Value |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 6:0   | PCL           | <ul> <li>Port C Level</li> <li>Each bit defines the polarity of the respective pin in port C.</li> <li>0 - positive (normal) polarity.</li> <li>1 - negative polarity. If the pin is configured as input, it is inverted before being processed inside the device.</li> </ul> | 0                |
| 7     |               | Reserved.                                                                                                                                                                                                                                                                     | 0                |
| 14:8  | PDL           | <ul> <li>Port D Level</li> <li>Each bit defines the polarity of the respective pin in port D.</li> <li>0 - positive (normal) polarity.</li> <li>1 - negative polarity. If the pin is configured as input, it is inverted before being processed inside the device.</li> </ul> | 0                |
| 15    |               | Reserved.                                                                                                                                                                                                                                                                     | 0                |
| 22:16 | PEL           | Port E Level<br>Each bit defines the polarity of the respective pin in port E.<br>0 - positive (normal) polarity.<br>1 - negative polarity. If the pin is configured as input, it is inverted before<br>being processed inside the device.                                    | 0                |
| 23    |               | Reserved.                                                                                                                                                                                                                                                                     | 0                |



#### Table 382: General Purpose Level 1 (GPL1), Offset: 0x100A64 (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                   | Initial<br>Value |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 30:24 | PFL           | Port F Level<br>Each bit defines the polarity of the respective pin in port F.<br>0 - positive (normal) polarity.<br>1 - negative polarity. If the pin is configured as input, it is inverted before<br>being processed inside the device. | 0                |
| 31    |               | Reserved.                                                                                                                                                                                                                                  | 0                |

#### Table 383: General Purpose Configuration 2 (GPC2), Offset: 0x100A08

| Bits  | Field<br>Name | Function                                                                                                                                                                                       | lnitial<br>Value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 14:0  | MIIOC         | Port MII0 Configuration<br>Each bit controls the setting of the respective pin in port MII0.<br>0 - pin is configured as General Purpose I/O.<br>1 - pin is configured as peripheral function. | 0                |
| 15    |               | Reserved.                                                                                                                                                                                      | 0                |
| 30:16 | MII1C         | Port MII1 Configuration<br>Each bit controls the setting of the respective pin in port MII1.<br>0 - pin is configured as General Purpose I/O.<br>1 - pin is configured as peripheral function. | 0                |
| 31    |               | Reserved.                                                                                                                                                                                      | 0                |

#### Table 384: General Purpose Input/Output 2 (GPIO2), Offset: 0x100A28

| Bits  | Field<br>Name | Function                                                                                                                                                                          | Initial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 14:0  | MIIOIO        | Port MII0 I/O<br>Each bit controls the setting of the respective pin in port MII0 as input or out-<br>put.<br>0 - pin is configured as input.<br>1 - pin is configured as output. | 0                |
| 15    |               | Reserved.                                                                                                                                                                         | 0                |
| 30:16 | MII1IO        | Port MII1 I/O<br>Each bit controls the setting of the respective pin in port MII1 as input or out-<br>put.<br>0 - pin is configured as input.<br>1 - pin is configured as output. | 0                |



| Bits | Field<br>Name | Function  | lnitial<br>Value |
|------|---------------|-----------|------------------|
| 31   |               | Reserved. | 0                |

#### Table 384: General Purpose Input/Output 2 (GPIO2), Offset: 0x100A28 (Continued)

#### Table 385: General Purpose Data 2 (GPD2), Offset: 0x100A48

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                  | lnitial<br>Value |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 14:0  | MIIOD         | Port MII0 Data<br>Each bit holds the data of the respective pin in port MII0. If the pin is config-<br>ured as input, this bit is read-only and reflects the signal status at the pin. If<br>the pin is configured as output, this bit is read-write and controls the data<br>driven out. | 0                |
| 15    |               | Reserved.                                                                                                                                                                                                                                                                                 | 0                |
| 30:16 | MII1D         | Port MII1 Data<br>Each bit holds the data of the respective pin in port MII1. If the pin is config-<br>ured as input, this bit is read-only and reflects the signal status at the pin. If<br>the pin is configured as output, this bit is read-write and controls the data<br>driven out. | 0                |
| 31    |               | Reserved.                                                                                                                                                                                                                                                                                 | 0                |

#### Table 386: General Purpose Level 2 (GPL2), Offset: 0x100A68

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                          | Initial<br>Value |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 14:0  | MIIOL         | Port MII0 Level.<br>Each bit defines the polarity of the respective pin in port MII0.<br>0 - positive (normal) polarity.<br>1 - negative polarity. If the pin is configured as input, it is inverted before<br>being processed inside the device. | 0                |
| 15    |               | Reserved.                                                                                                                                                                                                                                         | 0                |
| 30:16 | MII1L         | Port MII1 Level<br>Each bit defines the polarity of the respective pin in port MII1.<br>0 - positive (normal) polarity.<br>1 - negative polarity. If the pin is configured as input, it is inverted before<br>being processed inside the device.  | 0                |
| 31    |               | Reserved.                                                                                                                                                                                                                                         | 0                |



г

## 20. PHYSICAL SIGNAL ROUTING

# 20.1 Signal Routing

There are six serial ports on the GT-96100A's Ports A–F and the MII0 port which are used to externally route the MPSCs, FlexTDMs, and the General Purpose Interface signals.

The actual physical routing of the MPSC and TDM signals are defined in the Main Routing Register (MRR), see Table 387 .

| Bits | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                    | lnitial<br>Value |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 2:0  | MR0           | MPSC0 Routing<br>000 - Port A<br>001 - FlexTDM0<br>010 - FlexTDM1<br>011 - FlexTDM2<br>100 - FlexTDM3<br>101 - Reserved<br>110 - Reserved<br>111 - Unconnected (Default)<br>When not connected to MPSC0, Port A is connected to the PCI Arbiter or<br>used as GPP. See Section 19. "General Purpose Ports" on page 405 for<br>more details. | 111              |
| 5:3  | MR1           | MPSC1 Routing<br>000 - Port B<br>001 - FlexTDM0<br>010 - FlexTDM1<br>011 - FlexTDM2<br>100 - FlexTDM3<br>101 - Reserved<br>110 - Reserved<br>111 - Unconnected (Default)<br>When not connected to MPSC1, Port B is connected to the PCI Arbiter or<br>used as GPP. See Section 19. "General Purpose Ports" on page 405 for<br>more details. | 111              |

Table 387: MPSC Routing Register (MRR), Offset: 0X101A00



| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                         | Initial<br>Value |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 8:6   | MR2           | MPSC2 Routing<br>000 - Port C<br>001 - FlexTDM0<br>010 - FlexTDM1<br>011 - FlexTDM2<br>100 - FlexTDM3<br>101 - Reserved<br>110 - Reserved<br>111 - Unconnected (Default)<br>When not connected to MPSC2, Port C is connected to TDM0 or used as<br>GPP. See Section 19. "General Purpose Ports" on page 405 for more<br>details. | 111              |
| 11:9  | MR3           | MPSC3 Routing<br>000 - Port D<br>001 - FlexTDM0<br>010 - FlexTDM1<br>011 - FlexTDM2<br>100 - FlexTDM3<br>101 - Reserved<br>110 - Reserved<br>111 - Unconnected (Default)<br>When not connected to MPSC3, Port D is connected to TDM1 or used as<br>GPP. See Section 19. "General Purpose Ports" on page 405 for more<br>details. | 111              |
| 14:12 | MR4           | MPSC4 Routing<br>000 - Port E<br>001 - FlexTDM0<br>010 - FlexTDM1<br>011 - FlexTDM2<br>100 - FlexTDM3<br>101 - Reserved<br>110 - Reserved<br>111 - Unconnected (Default)<br>When not connected to MPSC4, Port E is connected to TDM2 or used as<br>GPP. See Section 19. "General Purpose Ports" on page 405 for more<br>details. | 111              |

#### Table 387: MPSC Routing Register (MRR), Offset: 0X101A00 (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | lnitial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 17:15 | MR5           | MPSC5 Routing<br>000 - Port F<br>001 - FlexTDM0<br>010 - FlexTDM1<br>011 - FlexTDM2<br>100 - FlexTDM3<br>101 - Reserved<br>110 - Reserved<br>111 - Unconnected (Default)<br>When not connected to MPSC5, Port F is connected to TDM3 or used as<br>GPP. See Section 19. "General Purpose Ports" on page 405 for more<br>details.                                                                                                                                                                                                                                                                                                  | 111              |
| 20:18 | MR6           | MPSC6 Routing<br>000 - Port MII0<br>001 - FlexTDM0<br>010 - FlexTDM1<br>011 - FlexTDM2<br>100 - FlexTDM3<br>101 - Reserved<br>110 - Reserved<br>111 - Unconnected (Default)<br>When not connected to MPSC6, Port MII0 is connected to Ethernet 0 or<br>used as GPP. See Section 19. "General Purpose Ports" on page 405 for<br>more details.<br><b>NOTE:</b> Proper operation of MII interface for Ethernet 0 requires that fields<br>MR6 and MR7 cannot be set to value '000'. Any other value is a<br>valid setting. The RMII interface can be used for employing both<br>MPSC6 and Ethernet 0. See Table 289 for more details. | 111              |

#### Table 387: MPSC Routing Register (MRR), Offset: 0X101A00 (Continued)



| Bits  | Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | lnitial<br>Value |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 23:21 | MR7           | MPSC7 Routing<br>000 - Port MII0<br>001 - FlexTDM0<br>010 - FlexTDM1<br>011 - FlexTDM2<br>100 - FlexTDM3<br>101 - Reserved<br>110 - Reserved<br>111 - Unconnected (Default)<br>When not connected to MPSC7, Port MII0 is connected to Ethernet 0 or<br>used as GPP. See Section 19. "General Purpose Ports" on page 405 for<br>more details.<br><b>NOTE:</b> Proper operation of MII interface for Ethernet 0 requires that fields<br>MR6 and MR7 cannot be set to value '000'. Any other value is a<br>valid setting. The RMII interface can be used for employing both<br>MPSC7 and Ethernet 0. See Table 289 for more details. | 111              |
| 31:24 |               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                |

#### Table 387: MPSC Routing Register (MRR), Offset: 0X101A00 (Continued)

**NOTE:** When a MPSC is connected to a FlexTDM, it's clocks come from the FlexTDM Unit regardless of the content of CRR/CRT.



# 20.2 Clock Routing

The MPSCs' receive and transmit clocks use the baud rate generators or serial clock input signals. The routing of these signals is defined in the RX Clock Routing Register (RCRR) and the TX Clock Routing Register (TCRR).

| Bits | Field<br>Name | Function                                                                                                                                                                                  | Initial<br>Value |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 3:0  | CRR0          | MPSC0 RX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK0<br>1001 to 1111 - Reserved | 0000             |
| 7:4  | CRR1          | MPSC1 RX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK1<br>1001 to 1111 - Reserved | 0000             |
| 11:8 | CRR2          | MPSC2 RX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK2<br>1001 to 1111 - Reserved | 0000             |

Table 388: RX Clock Routing Register (RCRR), Offset: 0X101A10



| Bits  | Field<br>Name | Function                                                                                                                                                                                  | lnitial<br>Value |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 15:12 | CRR3          | MPSC3 RX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK3<br>1001 to 1111 - Reserved | 0000             |
| 19:16 | CRR4          | MPSC4 RX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK4<br>1001 to 1111 - Reserved | 0000             |
| 23:20 | CRR5          | MPSC5 RX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK5<br>1001 to 1111 - Reserved | 0000             |

#### Table 388: RX Clock Routing Register (RCRR), Offset: 0X101A10 (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                  | Initial<br>Value |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 27:24 | CRR6          | MPSC6 RX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK6<br>1001 to 1111 - Reserved | 0000             |
| 31:28 | CRR7          | MPSC7 RX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK7<br>1001 to 1111 - Reserved | 0000             |

#### Table 388: RX Clock Routing Register (RCRR), Offset: 0X101A10 (Continued)

### Table 389: TX Clock Routing Register (TCRR), Offset: 0x101A20

| Bits | Field<br>Name | Function                                                                                                                                                                                                   | Initial<br>Value |
|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 3:0  | CRT0          | MPSC0 TX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK0<br>1001 - TSCLK0<br>1010 to 1111 - Reserved | 0000             |



| Bits  | Field<br>Name | Function                                                                                                                                                                                                   | lnitial<br>Value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 7:4   | CRT1          | MPSC1 TX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK1<br>1001 - TSCLK1<br>1010 to 1111 - Reserved | 0000             |
| 11:8  | CRT2          | MPSC2 TX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK2<br>1001 - TSCLK2<br>1010 to 1111 - Reserved | 0000             |
| 15:12 | CRT3          | MPSC3 TX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK3<br>1001 - TSCLK3<br>1010 to 1111 - Reserved | 0000             |

#### Table 389: TX Clock Routing Register (TCRR), Offset: 0x101A20 (Continued)

| Bits  | Field<br>Name | Function                                                                                                                                                                                                   | Initial<br>Value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 19:16 | CRT4          | MPSC4 TX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK4<br>1001 - TSCLK4<br>1010 to 1111 - Reserved | 0000             |
| 23:20 | CRT5          | MPSC5 TX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK5<br>1001 - TSCLK5<br>1010 to 1111 - Reserved | 0000             |
| 27:24 | CRT6          | MPSC6 TX Clock Routing<br>0000 - BRG0<br>0001 - BRG1<br>0010 - BRG2<br>0011 - BRG3<br>0100 - BRG4<br>0101 - BRG5<br>0110 - BRG6<br>0111 - BRG7<br>1000 - SCLK6<br>1001 - TSCLK6<br>1010 to 1111 - Reserved | 0000             |

#### Table 389: TX Clock Routing Register (TCRR), Offset: 0x101A20 (Continued)



| Fie<br>Bits Na |                                                                              | tion                                 | lnitial<br>Value |
|----------------|------------------------------------------------------------------------------|--------------------------------------|------------------|
| 31:28 CR1      | 0000 -                                                                       | 7 TX Clock Routing<br>BRG0<br>BRG1   | 0000             |
|                | 0010 -<br>0011 -<br>0100 -<br>0101 -<br>0110 -<br>0111 -<br>1000 -<br>1001 - | BRG2<br>BRG3<br>BRG4<br>BRG5<br>BRG6 |                  |

| Table 389: TX Clock Routing Regis | ster (TCRR), Offset: 0x101A20 (Continued) |
|-----------------------------------|-------------------------------------------|
| Tuble 666. TX electricating regio |                                           |



## 21. INTERRUPT CONTROLLER

The GT-96100A provides four interrupt pins that can be used for generating interrupts to the CPU:

- Interrupt0\*
- Interrupt1\*
- SerInt0\*
- SerInt1\*

The GT-96100A also integrates a programmable interrupt controller that is capable of routing each of the internal interrupt requests to one (or more) of the interrupt pins. The interrupt controller performs a logical OR of all internal interrupt events and asserts an interrupt to the CPU when at least one of the (unmasked) events is set.

The interrupt pins provided by the GT-96100A can be used in any system which supports multiple interrupt signals. If the CPU is capable of handling multiple interrupt inputs, connect the GT-96100A pins directly to the CPU. If the system requires a PCI directed interrupt, connect one of the pins to the PCI and the remaining pins to the CPU.

The two serial interrupt pins (SerInt0\*, SerInt1\*) allow separation of communication interrupts from other system events. Only events that originate within the communication unit can be routed to the serial interrupt pins.

## 21.1 Interrupt Cause Registers

There are two high-level interrupt cause registers, which serve to indicate the occurrence of certain events. One cause register (Main\_Cause register) consists of events originating in the GT-96100A's system controller logic. This register is located at offset 0x000C18.

The other cause register (High\_Cause register) consists of events originating in the PCI\_1 unit and the communication unit. This register is located at offset 0x000C1C.

**NOTE:** There is another cause register dedicated to communication events. This register (Serial\_Cause register) is located at 0x103A00.

When an interrupt event occurs, a bit in one of the cause registers is set. All bits in the cause register(s) are ORed together, and the result is driven on one of the Interrupt\* lines. The Interrupt\* causes the CPU to read the interrupt cause registers and run a service routine depending on the interrupt being serviced.

The interrupt is acknowledged by the CPU resetting bits in the cause register. The specific bit that is reset depends on the interrupt event being serviced. Reset a bit by writing '0' to this bit and '1' to all other bits.

**NOTE:** An exception to the above is the CPUInt ([25:22]) and PCIInt ([29:26]) bits, which are intended for generating PCItoCPU and CPUtoPCI interrupts. Set these bits by writing '0' from the interrupt originating side. Clear these bits by writing '0' from the interrupt destination side. For example, if one of the PCI agents needs to assert an interrupt to the CPU, it can write '0' to one of the PCIInt bits in the Main\_Cause register. Assuming that this bit is not masked, interrupt0\* will be asserted. After servicing this interrupt the CPU should clear the interrupt bit by writing zero to it.



### 21.1.1 Communication Unit Cause Registers

The GT-96100A includes 16 second level cause registers used to trap events generated within the communication unit.

Each interrupt source in the communication unit is tied to one of these second level cause registers. Each of these registers is tied to specific bits in the High\_Cause register and in the Serial\_Cause register. These bits function as summary bits, and are set when specific bits in the cause register are asserted (i.e. each summary bit is equivalent to a logical OR of some bits in one of the cause registers). These summary bits are read-only.

When an interrupt event occurs in the communication unit, a bit is set in one of the second level cause registers. This bit, if not masked, asserts one of the summary bits in the High\_Cause register and in the Serial\_Cause register. Following that, one (or more) of the interrupt lines is asserted.

The CPU recognizes an interrupt that is due to the communication unit when one of the summary bits in the High\_Cause register is set or when one of the summary bits in the Serial\_Cause register is set. Based on the specific bit set, the CPU reads the second level cause register associated with this bit in order to identify the actual interrupt event that generated the interrupt. In order to acknowledge the interrupt, the CPU must write zero to this bit in the cause register.

**NOTE:** The CPU cannot reset the summary bits directly, because these bits are read-only. A summary bit is automatically reset when the CPU resets the bits in the related second level cause register.

## 21.2 Interrupt Mask Registers

The GT-96100A provides interrupt mask registers for each of the internal cause registers. These mask registers allow masking of certain events, so that only specific events (as selected by the user) actually cause assertion of one of the interrupts.

There are two mask registers associated with Interrupt0\* and two mask registers associated with Interrupt1\*. These mask registers are used for enabling events that cause the assertion of either of these interrupts. For Interrupt0\*, these mask registers are located at 0x000C1C and at 0x000C9C. For Interrupt1\*, the mask registers are located at 0x000C24 and at 0x000C38. Programming '0' in a mask register bit disables the associated event from asserting interrupt. Programming '1' allows the interrupt event to cause interrupt signal assertion.

In addition, there is one mask register associated with each of the serial interrupt pins. For SerInt0\* the mask register is located at 0x103A80 and for SerInt1\* the mask register is located at 0x103A88.



### 21.3 Interrupt Summaries

The GT-96100A provides the following three interrupt summary bits in the main cause register:

- IntSum (bit [0] in the Main\_Cause register) is the logical OR of all interrupt bits in both the Main\_Cause and High\_Cause registers. This OR is not affected by the state of the mask bits and can be used for event polling.
- Int0\*Sum (bit [30] in the Main\_Cause register) is the logical OR of all interrupt bits in both the Main\_Cause and High\_Cause registers masked by Interrupt0\* mask registers. It serves as an indication that at least one of the (unmasked) Interrupt0\* events is set.
- Int1\*Sum (bit [31] in the Main\_Cause register) is the logical OR of all interrupt bits in both the Main\_Cause and High\_Cause registers masked by Interrupt1\* mask registers. It serves as an indication that at least one of the (unmasked) Interrupt1\* events is set.

# 21.4 Interrupt Select Registers

There are two interrupt select registers that can be used to optimize interrupt service routines. One select register is associated with Interrupt0\* (offset 0x000C70) and another register is associated with interrupt1\* (offset 0x000C74).

These select registers optimize service routines is the following manner:

- Instead of checking BOTH the Main\_Cause register and the High\_Cause register, when interrupted, the CPU has the option to read the appropriate select register.
- The select register will reflect the Cause register bits of either the Main\_Cause or the High\_Cause registers, depending on which register has active unmasked interrupt bits.
- Bit [30] of the select register indicates which of the cause registers (Main or High) is selected and bits [29:0] reflect the state of the interrupt bits of the selected cause register. For example, if bit [5] of the High\_Cause register is set (and is unmasked), and no (unmasked) bit in the Main\_Cause register is set, then bit [5] of the select register is set as well. In addition, bit [30] of the select register is set, indicating that the High\_Cause register is currently being selected.

In case both the Main\_Cause and the High\_Cause registers have interrupt bits set, the select register reflects the state of the Main\_Cause register (and bit [30] is therefore reset). However, in order to indicate that both cause registers are active, bit [31] of the select register is also set, in this case.



# 21.5 Interrupt Registers Tables

| Table 390: Interrupt Registers Map | Table 390: | Interrupt Registers I | Мар |
|------------------------------------|------------|-----------------------|-----|
|------------------------------------|------------|-----------------------|-----|

| Register Name                  | Offset   | Page Number |
|--------------------------------|----------|-------------|
| Interrupt Main Cause register  | 0x000C18 | page 428    |
| Interrupt0* Main Mask register | 0x000C18 | page 432    |
|                                | 0x000C24 |             |
| Interrupt1* Main Mask register |          | page 434    |
| Interrupt High Cause register  | 0x000C98 | page 430    |
| Interrupt0* High Mask register | 0x000C9C | page 433    |
| Interrupt1* High Mask register | 0x000CA4 | page 435    |
| Interrupt0* Select register    | 0x000C70 | page 431    |
| Interrupt1* Select register    | 0x000C74 | page 432    |
| Serial Cause register          | 0x103A00 | page 436    |
| SerInt0* Mask register         | 0x103A80 | page 438    |
| SerInt1* Mask register         | 0x103A88 | page 439    |
| Ethernet0 Cause register       | 0x084850 | page 440    |
| Ethernet0 Mask register        | 0x084858 | page 440    |
| Ethernet1 Cause register       | 0x088850 | page 441    |
| Ethernet1 Mask register        | 0x088858 | page 441    |
| SDMA Cause register            | 0x103A10 | page 441    |
| SDMA Mask register             | 0x103A90 | page 441    |
| MPSC0 Cause register           | 0x103A20 | page 444    |
| MPSC0 Mask register            | 0x103AA0 | page 444    |
| MPSC1 Cause register           | 0x103A24 | page 445    |
| MPSC1 Mask register            | 0x103AA4 | page 445    |
| MPSC2 Cause register           | 0x103A28 | page 445    |
| MPSC2 Mask register            | 0x103AA8 | page 445    |
| MPSC3 Cause register           | 0x103A2C | page 446    |
| MPSC3 Mask register            | 0x103AAC | page 446    |
| MPSC4 Cause register           | 0x103A30 | page 446    |
| MPSC4 Mask register            | 0x103AB0 | page 446    |
| MPSC5 Cause register           | 0x103A34 | page 446    |
| MPSC5 Mask register            | 0x103AB4 | page 446    |

| Register Name          | Offset   | Page Number |
|------------------------|----------|-------------|
| MPSC6 Cause register   | 0x103A38 | page 446    |
| MPSC6 Mask register    | 0x103AB8 | page 446    |
| MPSC7 Cause register   | 0x103A3C | page 446    |
| MPSC7 Mask register    | 0x103ABC | page 446    |
| FlexTDM Cause register | 0x103A40 | page 447    |
| FlexTDM Mask register  | 0x103AC0 | page 447    |
| BRG Cause register     | 0x103A48 | page 448    |
| BRG Mask register      | 0x103AC8 | page 448    |
| GPP0 Cause register    | 0x103A50 | page 448    |
| GPP0 Mask register     | 0x103AD0 | page 448    |
| GPP1 Cause register    | 0x103A54 | page 449    |
| GPP1 Mask register     | 0x103AD4 | page 449    |
| GPP2 Cause register    | 0x103A58 | page 449    |
| GPP2 Mask register     | 0x103AD8 |             |

### Table 390: Interrupt Registers Map (Continued)

#### Table 391: Interrupt Main Cause Register, Offset: 0x000C18

| Bits | Field Name | Function                                                                                                                          | lnitial<br>Value |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0    | IntSum     | Interrupt Summary<br>Logical OR of all the interrupt bits, regardless of the Mask registers'<br>values.<br>This bit is read-only. | 0                |
| 1    | MemOut     | Asserts when the CPU or PCI accesses an address out of range in the memory decoding or a burst access to 8- 16-bit devices.       | 0                |
| 2    | DMAOut     | Asserts when the DMA or Communication unit accesses an address out of range.                                                      | 0                |
| 3    | CPUOut     | Asserts when the CPU accesses an address out of range.                                                                            | 0                |
| 4    | DMA0Comp   | Asserts at completion of DMA Channel 0 transfer.                                                                                  | 0                |
| 5    | DMA1Comp   | Asserts at completion of DMA Channel 1 transfer.                                                                                  | 0                |
| 6    | DMA2Comp   | Asserts at completion of DMA Channel 2 transfer.                                                                                  | 0                |
| 7    | DMA3Comp   | Asserts at completion of DMA Channel 3 transfer.                                                                                  | 0                |
| 8    | T0Exp      | Asserts when Timer 0 expires.                                                                                                     | 0                |

| Bits  | Field Name | Function                                                                                                                                                                                                                                                                                                                                                    | Initial<br>Value |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 9     | T1Exp      | Asserts when Timer 1 expires.                                                                                                                                                                                                                                                                                                                               | 0                |
| 10    | T2Exp      | Asserts when Timer 2 expires.                                                                                                                                                                                                                                                                                                                               | 0                |
| 11    | T3Exp      | Asserts when Timer 3 expires.                                                                                                                                                                                                                                                                                                                               | 0                |
| 12    | MasRdErr0  | Asserts when the GT-96100A detects a parity error during a PCI_0 master read operation.                                                                                                                                                                                                                                                                     | 0                |
| 13    | SlvWrErr0  | Asserts when the GT-96100A detects a parity error during a PCI_0 slave write operation.                                                                                                                                                                                                                                                                     | 0                |
| 14    | MasWrErr0  | Asserts when the GT-96100A detects a parity error during a PCI_0 master write operation.                                                                                                                                                                                                                                                                    | 0                |
| 15    | SlvRdErr0  | Asserts when the GT-96100A detects a parity error during a PCI_0 slave read operation.                                                                                                                                                                                                                                                                      | 0                |
| 16    | AddrErr0   | Asserts when the GT-96100A detects a parity error on the PCI_0 address lines.                                                                                                                                                                                                                                                                               | 0                |
| 17    | MemErr     | Asserts when a memory parity error is detected.                                                                                                                                                                                                                                                                                                             | 0                |
| 18    | MasAbort0  | Asserts upon PCI_0 master abort.                                                                                                                                                                                                                                                                                                                            | 0                |
| 19    | TarAbort0  | Asserts upon PCI_0 target abort.                                                                                                                                                                                                                                                                                                                            | 0                |
| 20    | RetryCtr0  | Asserts when the PCI_0 retry counter expires.                                                                                                                                                                                                                                                                                                               | 0                |
| 21    | PMCInt0    | <ul> <li>If Power Management is enabled this bit functions as PMC0 interrupt, otherwise it functions as one of the CPUInt bits.</li> <li>PMCInt: Asserts when power state bits in PMCSR0 register are updated from PCI.</li> <li>CPUInt: Set by the CPU by writing '0' to generate an interrupt on the PCI bus. Cleared when the PCI writes '0'.</li> </ul> | 0                |
| 25:22 | CPUInt     | These bits are set by the CPU by writing '0' to generate an interrupt on the PCI bus. They are cleared when the PCI writes '0'. This requires that Interrupt1* is used as a PCI interrupt signal.                                                                                                                                                           | 0                |
| 29:26 | PCIInt     | These bits are set by the PCI by writing '0' to generate an interrupt on the CPU. They are cleared when the CPU writes '0'.                                                                                                                                                                                                                                 | 0                |
| 30    | Int0*Sum   | Interrupt Summary<br>Logical OR of all interrupt bits in the main and high Cause registers<br>masked by Interrupt0* mask registers.<br>This bit is read-only.                                                                                                                                                                                               | 0                |
| 31    | Int1*Sum   | Interrupt Summary<br>Logical OR of all interrupt bits in the main and high Cause registers<br>masked by Interrupt1* mask registers.<br>This bit is read-only.                                                                                                                                                                                               | 0                |

Table 391: Interrupt Main Cause Register, Offset: 0x000C18 (Continued)

| Table 392: | Interrupt Hi | nh Cause | Register.  | Offset: 0x000C98 | 3 |
|------------|--------------|----------|------------|------------------|---|
|            | meenapeing   | gn ouuse | riegister, |                  | , |

|      |            |                                                                                                                                                | Initia<br>I |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Bits | Field Name | Function                                                                                                                                       | Value       |
| 0    | Ether0Sum  | Ethernet port 0 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the Ethernet0_Cause reg-<br>ister.<br>This bit is read-only. | 0           |
| 1    | Ether1Sum  | Ethernet Port 1Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the Ethernet1_Cause reg-<br>ister.<br>This bit is read-only.  | 0           |
| 3:2  |            | Reserved.                                                                                                                                      | 0           |
| 4    | SdmaSum    | SDMA Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the SDMA_Cause register.<br>This bit is read-only.                      | 0           |
| 5    | MpscSum    | MPSC Interrupt Summary<br>Logical OR of all unmasked interrupt bits in all the MPSC_Cause reg-<br>isters.<br>This bit is read-only.            | 0           |
| 6    | FtdmSum    | FlexTDM Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the FTDM_Cause register.<br>This bit is read-only.                   | 0           |
| 7    | BrgSum     | Baud Rate Generators Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the BRG_Cause register.<br>This bit is read-only.       | 0           |
| 8    | GPP0Sum    | GPP0 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the GPP0_Cause register.<br>This bit is read-only.                      | 0           |
| 9    | GPP1Sum    | GPP1 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the GPP1_Cause register.<br>This bit is read-only.                      | 0           |
| 10   | GPP2Sum    | GPP2 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the GPP2_Cause register.<br>This bit is read-only.                      | 0           |
| 11   |            | Reserved.                                                                                                                                      | 0           |
| 12   | MasRdErr1  | Asserts when the GT-96100A detects a parity error during a PCI_1 master read operation.                                                        | 0           |
| 13   | SlvWrErr1  | Asserts when the GT-96100A detects a parity error during a PCI_1 slave write operation.                                                        | 0           |

| Bits  | Field Name | Function                                                                                                                                                                    | Initia<br>I<br>Value |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
|       |            |                                                                                                                                                                             | value                |
| 14    | MasWrErr1  | Asserts when the GT-96100A detects a parity error during a PCI_1 master write operation.                                                                                    | 0                    |
| 15    | SlvRdErr1  | Asserts when the GT-96100A detects a parity error during a PCI_1 slave read operation.                                                                                      | 0                    |
| 16    | AddrErr1   | Asserts when the GT-96100A detects a parity error on the PCI_1 address lines.                                                                                               | 0                    |
| 17    |            | Reserved.                                                                                                                                                                   | 0                    |
| 18    | MasAbort1  | Asserts upon PCI_1 master abort.                                                                                                                                            | 0                    |
| 19    | TarAbort1  | Asserts upon PCI_1 target abort.                                                                                                                                            | 0                    |
| 20    | RetryCtr1  | Asserts when the PCI_1 retry counter expires.                                                                                                                               | 0                    |
| 21    | PMCInt1    | If Power Management is enabled, this bit functions as PMC1 interrupt, otherwise it is reserved. PMC1 asserts when power state bits in PMCSR1 register are updated from PCI. | 0                    |
| 23:22 |            | Reserved.                                                                                                                                                                   | 0                    |
| 24    | PciArb0    | PCI_0 Arbiter Interrupt                                                                                                                                                     | 0                    |
|       |            | This bit is set when a "broken master" condition is detected by PCI_0 arbiter.                                                                                              |                      |
| 25    | PciArb1    | PCI_1 Arbiter Interrupt                                                                                                                                                     | 0                    |
|       |            | This bit is set when a "broken master" condition is detected by PCI_1 arbiter.                                                                                              |                      |
| 31:26 |            | Reserved.                                                                                                                                                                   | 0                    |

#### Table 392: Interrupt High Cause Register, Offset: 0x000C98 (Continued)

#### Table 393: Interrupt0\* Select Register, Offset: 0x000C70

| Bits | Field Name  | Function                                                                      | lnitia<br>I<br>Value |
|------|-------------|-------------------------------------------------------------------------------|----------------------|
| 29:0 | AliasedBits | Aliased to bits [29:0] of the selected Cause register.                        | 0                    |
| 30   | SelectCause | Selected Cause Register<br>0 - Main Cause Register<br>1 - High Cause Register | 0                    |
| 31   | LowAndHigh  | Interrupt is set in both Main and High Cause Registers.                       | 0                    |



### Table 394: Interrupt1\* Select Register, Offset: 0x000C74

| Bits | Field Name | Function                                 | lnitial<br>Value |
|------|------------|------------------------------------------|------------------|
| 31:0 | Various    | Same as for Interrupt0* Select register. | 0                |

#### Table 395: Interrupt0\* Main Mask Register, Offset: 0x000C1C

| Bits  | Field Name    | Function                                                                                                     | Initial<br>Value |
|-------|---------------|--------------------------------------------------------------------------------------------------------------|------------------|
| 0     |               | Reserved.                                                                                                    | 0                |
| 1     | MemOutMask    | Masks MemOut Interrupt to Interrupt0*                                                                        | 0                |
| 2     | DMAOutMask    | Masks DMAOut Interrupt to Interrupt0*                                                                        | 0                |
| 3     | CPUOutMask    | Masks CPUOut Interrupt to Interrupt0*                                                                        | 0                |
| 4     | DMA0CompMask  | Masks DMA0Comp Interrupt to Interrupt0*                                                                      | 0                |
| 5     | DMA1CompMask  | Masks DMA1Comp Interrupt to Interrupt0*                                                                      | 0                |
| 6     | DMA2CompMask  | Masks DMA2Comp Interrupt to Interrupt0*                                                                      | 0                |
| 7     | DMA3CompMask  | Masks DMA3Comp Interrupt to Interrupt0*                                                                      | 0                |
| 8     | T0ExpMask     | Masks T0Exp Interrupt to Interrupt0*                                                                         | 0                |
| 9     | T1ExpMask     | Masks T1Exp Interrupt to Interrupt0*                                                                         | 0                |
| 10    | T2ExpMask     | Masks T2Exp Interrupt to Interrupt0*                                                                         | 0                |
| 11    | T3ExpMask     | Masks T3Exp Interrupt to Interrupt0*                                                                         | 0                |
| 12    | MasRdErr0Mask | Masks MasRdErr0 Interrupt to Interrupt0*                                                                     | 0                |
| 13    | SlvWrErr0Mask | Masks SlvWrErr0 Interrupt to Interrupt0*                                                                     | 0                |
| 14    | MasWrErr0Mask | Masks MasWrErr0 Interrupt to Interrupt0*                                                                     | 0                |
| 15    | SlvRdErr0Mask | Masks SlvRdErr0 Interrupt to Interrupt0*                                                                     | 0                |
| 16    | AddrErr0Mask  | Masks AddrErr0 Interrupt to Interrupt0*                                                                      | 0                |
| 17    | MemErrMask    | Masks MemErr Interrupt to Interrupt0*                                                                        | 0                |
| 18    | MasAbort0Mask | Masks MasAbort0 Interrupt to Interrupt0*                                                                     | 0                |
| 19    | TarAbort0Mask | Masks TarAbort0 Interrupt to Interrupt0*                                                                     | 0                |
| 20    | RetryCtr0Mask | Masks RetryCtr0 Interrupt to Interrupt0*                                                                     | 0                |
| 21    | PMC0Mask      | If Power Management is enabled, masks PMC0 interrupt to Interrupt0*, otherwise it is reserved (Read Only 0). | 0                |
| 25:22 |               | Reserved.                                                                                                    | 0                |
| 29:26 | PCIIntMask    | Masks PCIInt Interrupt to Interrupt0*                                                                        | 0                |



| Bits  | Field Name | Function  | Initial<br>Value |
|-------|------------|-----------|------------------|
| 31:30 |            | Reserved. | 0                |

### Table 395: Interrupt0\* Main Mask Register, Offset: 0x000C1C (Continued)

### Table 396: Interrupt0\* High Mask Register, Offset: 0x000C9C

| Bits  | Field Name    | Function                                                                                                     | lnitial<br>Value |
|-------|---------------|--------------------------------------------------------------------------------------------------------------|------------------|
| 0     | Ether0SumMask | Masks Ether0Sum to Interrupt0*                                                                               | 0                |
| 1     | Ether1SumMask | Masks Ether1Sum to Interrupt0*                                                                               | 0                |
| 3:2   |               | Reserved.                                                                                                    | 0                |
| 4     | SdmaSumMask   | Masks SdmaSum to Interrupt0*                                                                                 | 0                |
| 5     | MpscSumMask   | Masks MpscSum to Interrupt0*                                                                                 | 0                |
| 6     | FtdmSumMask   | Masks FtdmSum to Interrupt0*                                                                                 | 0                |
| 7     | BrgSumMask    | Masks BrgSum to Interrupt0*                                                                                  | 0                |
| 8     | GPP0SumMask   | Masks GPP0Sum to Interrupt0*                                                                                 | 0                |
| 9     | GPP1SumMask   | Masks GPP1Sum to Interrupt0*                                                                                 | 0                |
| 10    | GPP2SumMask   | Masks GPP2Sum to Interrupt0*                                                                                 | 0                |
| 11    |               | Reserved.                                                                                                    | 0                |
| 12    | MasRdErr1Mask | Masks MasRdErr1 to Interrupt0*                                                                               | 0                |
| 13    | SlvWrErr1Mask | Masks SlvWrErr1 to Interrupt0*                                                                               | 0                |
| 14    | MasWrErr1Mask | Masks MasWrErr1 to Interrupt0*                                                                               | 0                |
| 15    | SlvRdErr1Mask | Masks SlvRdErr1 to Interrupt0*                                                                               | 0                |
| 16    | AddrErr1Mask  | Masks AddrErr1 to Interrupt0*                                                                                | 0                |
| 17    |               | Reserved.                                                                                                    | 0                |
| 18    | MasAbort1Mask | Masks MasAbort1 to Interrupt0*                                                                               | 0                |
| 19    | TarAbort1Mask | Masks TarAbort1 to Interrupt0*                                                                               | 0                |
| 20    | RetryCtr1Mask | Masks RetryCtr1 to Interrupt0*                                                                               | 0                |
| 21    | PMC1Mask      | If Power Management is enabled, masks PMC1 interrupt to Interrupt0*, otherwise it is reserved (Read Only 0). | 0                |
| 23:22 |               | Reserved.                                                                                                    |                  |
| 24    | PciArb0Mask   | Masks PciArb0 to Interrupt0*                                                                                 | 0                |
| 25    | PciArb1Mask   | Masks PciArb1 to Interrupt0*                                                                                 | 0                |



### Table 396: Interrupt0\* High Mask Register, Offset: 0x000C9C (Continued)

| Bits  | Field Name | Function  | lnitial<br>Value |
|-------|------------|-----------|------------------|
| 31:26 |            | Reserved. | 0                |

### Table 397: Interrupt1\* Main Mask Register, Offset: 0x000C24

| Bits  | Field Name    | Function                                                                                                                   | Initial<br>Value |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------|------------------|
| 0     |               | Reserved                                                                                                                   | 0                |
| 1     | MemOutMask    | Masks MemOut Interrupt to Interrupt1*                                                                                      | 0                |
| 2     | DMAOutMask    | Masks DMAOut Interrupt to Interrupt1*                                                                                      | 0                |
| 3     | CPUOutMask    | Masks CPUOut Interrupt to Interrupt1*                                                                                      | 0                |
| 4     | DMA0CompMask  | Masks DMA0Comp Interrupt to Interrupt1*                                                                                    | 0                |
| 5     | DMA1CompMask  | Masks DMA1Comp Interrupt to Interrupt1*                                                                                    | 0                |
| 6     | DMA2CompMask  | Masks DMA2Comp Interrupt to Interrupt1*                                                                                    | 0                |
| 7     | DMA3CompMask  | Masks DMA3Comp Interrupt to Interrupt1*                                                                                    | 0                |
| 8     | T0ExpMask     | Masks T0Exp Interrupt to Interrupt1*                                                                                       | 0                |
| 9     | T1ExpMask     | Masks T1Exp Interrupt to Interrupt1*                                                                                       | 0                |
| 10    | T2ExpMask     | Masks T2Exp Interrupt to Interrupt1*                                                                                       | 0                |
| 11    | T3ExpMask     | Masks T3Exp Interrupt to Interrupt1*                                                                                       | 0                |
| 12    | MasRdErr0Mask | Masks MasRdErr0 Interrupt to Interrupt1*                                                                                   | 0                |
| 13    | SlvWrErr0Mask | Masks SIvWrErr0 Interrupt to Interrupt1*                                                                                   | 0                |
| 14    | MasWrErr0Mask | Masks MasWrErr0 Interrupt to Interrupt1*                                                                                   | 0                |
| 15    | SlvRdErr0Mask | Masks SlvRdErr0 Interrupt to Interrupt1*                                                                                   | 0                |
| 16    | AddrErr0Mask  | Masks AddrErr0 Interrupt to Interrupt1*                                                                                    | 0                |
| 17    | MemErrMask    | Masks MemErr Interrupt to Interrupt1*                                                                                      | 0                |
| 18    | MasAbort0Mask | Masks MasAbort0 Interrupt to Interrupt1*                                                                                   | 0                |
| 19    | TarAbort0Mask | Masks TarAbort0 Interrupt to Interrupt1*                                                                                   | 0                |
| 20    | RetryCtr0Mask | Masks RetryCtr0 Interrupt to Interrupt1*                                                                                   | 0                |
| 21    | PMC0Mask      | If Power Management is enabled, masks PMC0 interrupt to<br>Interrupt1*, otherwise it masks CPUInt Interrupt to Interrupt1* | 0                |
| 25:22 | CPUInt        | Masks CPUInt Interrupt to Interrupt1*                                                                                      | 0                |
| 31:26 |               | Reserved                                                                                                                   | 0                |



| D'1-  |               | E                                                                                                             | Initial |
|-------|---------------|---------------------------------------------------------------------------------------------------------------|---------|
| Bits  | Field Name    | Function                                                                                                      | Value   |
| 0     | Ether0SumMask | Masks Ether0Sum to Interrupt1*                                                                                | 0       |
| 1     | Ether1SumMask | Masks Ether1Sum to Interrupt1*                                                                                | 0       |
| 3:2   |               | Reserved.                                                                                                     | 0       |
| 4     | SdmaSumMask   | Masks SdmaSum to Interrupt1*                                                                                  | 0       |
| 5     | MpscSumMask   | Masks MpscSum to Interrupt1*                                                                                  | 0       |
| 6     | FtdmSumMask   | Masks FtdmSum to Interrupt1*                                                                                  | 0       |
| 7     | BrgSumMask    | Masks BrgSum to Interrupt1*                                                                                   | 0       |
| 8     | GPP0SumMask   | Masks GPP0Sum to Interrupt1*                                                                                  | 0       |
| 9     | GPP1SumMask   | Masks GPP1Sum to Interrupt1*                                                                                  | 0       |
| 10    | GPP2SumMask   | Masks GPP2Sum to Interrupt1*                                                                                  | 0       |
| 11    |               | Reserved.                                                                                                     | 0       |
| 12    | MasRdErr1Mask | Masks MasRdErr1 to Interrupt1*                                                                                | 0       |
| 13    | SlvWrErr1Mask | Masks SlvWrErr1 to Interrupt1*                                                                                | 0       |
| 14    | MasWrErr1Mask | Masks MasWrErr1 to Interrupt1*                                                                                | 0       |
| 15    | SlvRdErr1Mask | Masks SlvRdErr1 to Interrupt1*                                                                                | 0       |
| 16    | AddrErr1Mask  | Masks AddrErr1 to Interrupt1*                                                                                 | 0       |
| 17    |               | Reserved.                                                                                                     | 0       |
| 18    | MasAbort1Mask | Masks MasAbort1 to Interrupt1*                                                                                | 0       |
| 19    | TarAbort1Mask | Masks TarAbort1 to Interrupt1*                                                                                | 0       |
| 20    | RetryCtr1Mask | Masks RetryCtr1 to Interrupt1*                                                                                | 0       |
| 21    | PMC1Mask      | If Power Management is enabled, masks PMC1 interrupt to Interrupt1*. Otherwise, it is reserved (Read Only 0). | 0       |
| 23:22 |               | Reserved.                                                                                                     |         |
| 24    | PciArb0Mask   | Masks PciArb0 to Interrupt1*                                                                                  | 0       |
| 25    | PciArb1Mask   | Masks PciArb1 to Interrupt1*                                                                                  | 0       |
| 31:26 |               | Reserved.                                                                                                     | 0       |

## Table 398: Interrupt1\* High Mask Register, Offset: 0x000CA4



## Table 399: Serial Cause Register, Offset: 0x103A00

|      |            |                                                                                                                                               | Initia<br>I |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Bits | Field Name | Function                                                                                                                                      | Value       |
| 0    | Ether0Sum  | Ethernet Port 0 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the Ethernet0_Cause<br>register.<br>This bit is read-only.  | 0           |
| 1    | Ether1Sum  | Ethernet Port 1Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the Ethernet1_Cause<br>register.<br>This bit is read-only.   | 0           |
| 3:2  |            | Reserved.                                                                                                                                     | 0           |
| 4    | SdmaSum    | SDMA Interrupt Summary<br>Logical OR of all unmasked bits in the SDMA_Cause register.<br>This bit is read-only.                               | 0           |
| 5    | MpscSum    | MPSC Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the MPSC_Cause regis-<br>ters.<br>This bit is read-only.               | 0           |
| 6    | FtdmSum    | FlexTDM Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the FTDM_Cause regis-<br>ter.<br>This bit is read-only.             | 0           |
| 7    | BrgSum     | Baud Rate Generators Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the BRG_Cause regis-<br>ter.<br>This bit is read-only. | 0           |
| 8    | Sdma0Sum   | SDMA0 Interrupt Summary<br>Logical OR of unmasked bits [3:0] in the SDMA_Cause register.<br>This bit is read-only.                            | 0           |
| 9    | Mpsc0Sum   | MPSC0 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the MPSC0_Cause reg-<br>ister.<br>This bit is read-only.              | 0           |
| 10   | Sdma1Sum   | SDMA1 Interrupt Summary<br>Logical OR of unmasked bits [7:4] in the SDMA_Cause register.<br>This bit is read-only.                            | 0           |

|      |            |                                                                                                                                  | Initia<br>I |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------|-------------|
| Bits | Field Name | Function                                                                                                                         | Value       |
| 11   | Mpsc1Sum   | MPSC1 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the MPSC1_Cause reg-<br>ister.<br>This bit is read-only. | 0           |
| 12   | Sdma2Sum   | SDMA2 Interrupt Summary<br>Logical OR of unmasked bits [11:8] in the SDMA_Cause register.<br>This bit is read-only.              | 0           |
| 13   | Mpsc2Sum   | MPSC2 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the MPSC2_Cause reg-<br>ister.<br>This bit is read-only. | 0           |
| 14   | Sdma3Sum   | SDMA2 Interrupt Summary<br>Logical OR of unmasked bits [15:12] in the SDMA_Cause register.<br>This bit is read-only.             | 0           |
| 15   | Mpsc3Sum   | MPSC3 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the MPSC3_Cause reg-<br>ister.<br>This bit is read-only. | 0           |
| 16   | Sdma4Sum   | SDMA4 Interrupt Summary<br>Logical OR of unmasked bits [19:16] in the SDMA_Cause register.<br>This bit is read-only.             | 0           |
| 17   | Mpsc4Sum   | MPSC4 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the MPSC4_Cause reg-<br>ister.<br>This bit is read-only. | 0           |
| 18   | Sdma5Sum   | SDMA5 Interrupt Summary<br>Logical OR of unmasked bits [23:20] in the SDMA_Cause register.<br>This bit is read-only.             | 0           |
| 19   | Mpsc5Sum   | MPSC5 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the MPSC5_Cause reg-<br>ister.<br>This bit is read-only. | 0           |
| 20   | Sdma6Sum   | SDMA6 Interrupt Summary<br>Logical OR of unmasked bits [27:24] in the SDMA_Cause register.<br>This bit is read-only.             | 0           |

### Table 399: Serial Cause Register, Offset: 0x103A00 (Continued)

### Table 399: Serial Cause Register, Offset: 0x103A00 (Continued)

|       |            |                                                                                                                                  | Initia<br>I |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------|-------------|
| Bits  | Field Name | Function                                                                                                                         | Value       |
| 21    | Mpsc6Sum   | MPSC6 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the MPSC6_Cause reg-<br>ister.<br>This bit is read-only. | 0           |
| 22    | Sdma7Sum   | SDMA7 Interrupt Summary<br>Logical OR of unmasked bits [31:28] in the SDMA_Cause register.<br>This bit is read-only.             | 0           |
| 23    | Mpsc7Sum   | MPSC7 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the MPSC7_Cause reg-<br>ister.<br>This bit is read-only. | 0           |
| 24    | GPP0Sum    | GPP0 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the GPP0_Cause regis-<br>ter.<br>This bit is read-only.   | 0           |
| 25    | GPP1Sum    | GPP1 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the GPP1_Cause regis-<br>ter.<br>This bit is read-only.   | 0           |
| 26    | GPP2Sum    | GPP2 Interrupt Summary<br>Logical OR of all unmasked interrupt bits in the GPP2_Cause regis-<br>ter.<br>This bit is read-only.   | 0           |
| 31:27 |            | Reserved.                                                                                                                        | 0           |

## Table 400: SerInt0\* Mask Register, Offset: 0x103A80

| Bits | Field Name    | Function                             | lnitial<br>Value |
|------|---------------|--------------------------------------|------------------|
| 0    | Ether0SumMask | Mask Ether0Sum interrupt to SerInt0* | 0                |
| 1    | Ether1SumMask | Mask Ether1Sum interrupt to SerInt0* | 0                |
| 3:2  |               | Reserved.                            | 0                |
| 4    | SdmaSumMask   | Mask SdmaSum interrupt to SerInt0*   | 0                |
| 5    | MpscSumMask   | Mask MpscSum interrupt to SerInt0*   | 0                |
| 6    | FtdmSumMask   | Mask FtdmSum interrupt to SerInt0*   | 0                |



| Bits  | Field Name   | Function                            | Initial<br>Value |
|-------|--------------|-------------------------------------|------------------|
| 7     | BrgSumMask   | Mask BrgSum interrupt to SerInt0*   | 0                |
| 8     | Sdma0SumMask | Mask Sdma0Sum interrupt to SerInt0* | 0                |
| 9     | Mpsc0SumMask | Mask Mpsc0Sum interrupt to SerInt0* | 0                |
| 10    | Sdma1SumMask | Mask Sdma1Sum interrupt to SerInt0* | 0                |
| 11    | Mpsc1SumMask | Mask Mpsc1Sum interrupt to SerInt0* | 0                |
| 12    | Sdma2SumMask | Mask Sdma2Sum interrupt to SerInt0* | 0                |
| 13    | Mpsc2SumMask | Mask Mpsc2Sum interrupt to SerInt0* | 0                |
| 14    | Sdma3SumMask | Mask Sdma3Sum interrupt to SerInt0* | 0                |
| 15    | Mpsc3SumMask | Mask Mpsc3Sum interrupt to SerInt0* | 0                |
| 16    | Sdma4SumMask | Mask Sdma4Sum interrupt to SerInt0* | 0                |
| 17    | Mpsc4SumMask | Mask Mpsc4Sum interrupt to SerInt0* | 0                |
| 18    | Sdma5SumMask | Mask Sdma5Sum interrupt to SerInt0* | 0                |
| 19    | Mpsc5SumMask | Mask Mpsc5Sum interrupt to SerInt0* | 0                |
| 20    | Sdma6SumMask | Mask Sdma6Sum interrupt to SerInt0* | 0                |
| 21    | Mpsc6SumMask | Mask Mpsc6Sum interrupt to SerInt0* | 0                |
| 22    | Sdma7SumMask | Mask Sdma7Sum interrupt to SerInt0* | 0                |
| 23    | Mpsc7SumMask | Mask Mpsc7Sum interrupt to SerInt0* | 0                |
| 24    | GPP0SumMask  | Mask GPP0Sum interrupt to SerInt0*  | 0                |
| 25    | GPP1SumMask  | Mask GPP1Sum interrupt to SerInt0*  | 0                |
| 26    | GPP2SumMask  | Mask GPP2Sum interrupt to SerInt0*  | 0                |
| 31:27 |              | Reserved.                           | 0                |

### Table 400: SerInt0\* Mask Register, Offset: 0x103A80 (Continued)

## Table 401: SerInt1\* Mask Register, Offset: 0x103A88

| Bits | Field Name    | Function                             | lnitial<br>Value |
|------|---------------|--------------------------------------|------------------|
| 0    | Ether0SumMask | Mask Ether0Sum interrupt to SerInt1* | 0                |
| 1    | Ether1SumMask | Mask Ether1Sum interrupt to SerInt1* | 0                |
| 3:2  |               | Reserved.                            | 0                |
| 4    | SdmaSumMask   | Mask SdmaSum interrupt to SerInt1*   | 0                |
| 5    | MpscSumMask   | Mask MpscSum interrupt to SerInt1*   | 0                |

| Bits  | Field Name   | Function                            | Initial<br>Value |
|-------|--------------|-------------------------------------|------------------|
| 6     | FtdmSumMask  | Mask FtdmSum interrupt to SerInt1*  | 0                |
| 7     | BrgSumMask   | Mask BrgSum interrupt to SerInt1*   | 0                |
| 8     | Sdma0SumMask | Mask Sdma0Sum interrupt to SerInt1* | 0                |
| 9     | Mpsc0SumMask | Mask Mpsc0Sum interrupt to SerInt1* | 0                |
| 10    | Sdma1SumMask | Mask Sdma1Sum interrupt to SerInt1* | 0                |
| 11    | Mpsc1SumMask | Mask Mpsc1Sum interrupt to SerInt1* | 0                |
| 12    | Sdma2SumMask | Mask Sdma2Sum interrupt to SerInt1* | 0                |
| 13    | Mpsc2SumMask | Mask Mpsc2Sum interrupt to SerInt1* | 0                |
| 14    | Sdma3SumMask | Mask Sdma3Sum interrupt to SerInt1* | 0                |
| 15    | Mpsc3SumMask | Mask Mpsc3Sum interrupt to SerInt1* | 0                |
| 16    | Sdma4SumMask | Mask Sdma4Sum interrupt to SerInt1* | 0                |
| 17    | Mpsc4SumMask | Mask Mpsc4Sum interrupt to SerInt1* | 0                |
| 18    | Sdma5SumMask | Mask Sdma5Sum interrupt to SerInt1* | 0                |
| 19    | Mpsc5SumMask | Mask Mpsc5Sum interrupt to SerInt1* | 0                |
| 20    | Sdma6SumMask | Mask Sdma6Sum interrupt to SerInt1* | 0                |
| 21    | Mpsc6SumMask | Mask Mpsc6Sum interrupt to SerInt1* | 0                |
| 22    | Sdma7SumMask | Mask Sdma7Sum interrupt to SerInt1* | 0                |
| 23    | Mpsc7SumMask | Mask Mpsc7Sum interrupt to SerInt1* | 0                |
| 24    | GPP0SumMask  | Mask GPP0Sum interrupt to SerInt1*  | 0                |
| 25    | GPP1SumMask  | Mask GPP1Sum interrupt to SerInt1*  | 0                |
| 26    | GPP2SumMask  | Mask GPP2Sum interrupt to SerInt1*  | 0                |
| 31:27 |              | Reserved.                           | 0                |

### Table 401: SerInt1\* Mask Register, Offset: 0x103A88 (Continued)

# Table 402: Ethernet0 Cause Register, Offset: 0x084850 andEthernet0 Mask Register, Offset: 0x084858

| Bits | Field Name   | Function                           | lnitial<br>Value |
|------|--------------|------------------------------------|------------------|
| 0    | RxBuffer     | Rx Buffer Return                   | 0                |
| 1    |              | Reserved.                          | 0                |
| 2    | TxBufferHigh | Tx Buffer for High priority queue. | 0                |



| Bits  | Field Name  | Function                                                                                                                 | Initial<br>Value |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------|------------------|
| 3     | TxBufferLow | Tx Buffer for low priority queue.                                                                                        | 0                |
| 5:4   |             | Reserved.                                                                                                                | 0                |
| 6     | TxEndHigh   | Tx End for high priority queue.                                                                                          | 0                |
| 7     | TxEndLow    | Tx End for low priority queue.                                                                                           | 0                |
| 8     | RxError     | Rx Resource Error. Indicates a Rx resource error event.                                                                  | 0                |
| 9     |             | Reserved.                                                                                                                | 0                |
| 10    | TxErrorHigh | Tx Resource Error for high priority queue.                                                                               | 0                |
| 11    | TxErrorLow  | Tx Resource Error for low priority queue.                                                                                | 0                |
| 12    | RxOVR       | Rx Overrun                                                                                                               | 0                |
| 13    | TxUdr       | Tx Underrun                                                                                                              | 0                |
| 27:14 |             | Reserved.                                                                                                                | 0                |
| 28    | MIIPhySTC   | MII PHY Status Change.                                                                                                   | 0                |
| 29    | SMIdone     | SMI Command Done                                                                                                         | 0                |
| 30    |             | Reserved.                                                                                                                | 0                |
| 31    | EtherIntSum | Ethernet Interrupt Summary<br>This bit is a logical OR of the (unmasked) bits [30:4] in the Interrupt<br>Cause register. | 0                |

# Table 402: Ethernet0 Cause Register, Offset: 0x084850 and Ethernet0 Mask Register, Offset: 0x084858 (Continued)

# Table 403: Ethernet1 Cause Register, Offset: 0x088850 andEthernet1 Mask Register, Offset: 0x088858

| Bits | Field Name | Function                              | lnitial<br>Value |
|------|------------|---------------------------------------|------------------|
| 31:0 | various    | Same as for Ethernet0 Cause register. | 0                |

# Table 404: SDMA Cause Register, Offset: 0x103A10 and SDMA Mask Register, Offset: 0x103A90

| Bits | Field Name | Function                                                                                                                                 | lnitial<br>Value |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0    | Sdma0RxBuf | SDMA Channel 0 Rx Buffer Return<br>Indicates that SDMA0 Rx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership. | 0                |

# Table 404: SDMA Cause Register, Offset: 0x103A10 and SDMA Mask Register, Offset: 0x103A90 (Continued)

| Bits | Field Name | Function                                                                                                                                                                                      | lnitial<br>Value |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1    | Sdma0RxErr | SDMA Channel 0 Rx Error<br>Indicates that a Rx resource error occurred.                                                                                                                       | 0                |
| 2    | Sdma0TxBuf | SDMA Channel 0 Tx Buffer Return<br>Indicates that SDMA0 Tx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 3    | Sdma0TxEnd | SDMA Channel 0 Tx End<br>Indicates that a Tx resource error occurred or that the Tx DMA moved<br>to IDLE after a stop command. Also set when Tx retransmit limit is<br>reached in HDLC mode.  | 0                |
| 4    | Sdma1RxBuf | SDMA Channel 1 Rx Buffer Return<br>Indicates that SDMA1 Rx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 5    | Sdma1RxErr | SDMA Channel 1 Rx Error<br>Indicates that a Rx resource error occurred.                                                                                                                       | 0                |
| 6    | Sdma1TxBuf | SDMA Channel 1 Tx Buffer Return<br>Indicates that SDMA1 Tx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 7    | Sdma1TxEnd | SDMA Channel 1 Tx End<br>Indicates that a Tx resource error occurred or that the Tx DMA moved<br>to IDLE after a stop command. Also set when Tx retransmit limit is<br>reached in HDLC mode.  | 0                |
| 8    | Sdma2RxBuf | SDMA Channel 2 Rx Buffer Return<br>Indicates that SDMA2 Rx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 9    | Sdma2RxErr | SDMA Channel 2 Rx Error<br>Indicates that a Rx resource error occurred.                                                                                                                       | 0                |
| 10   | Sdma2TxBuf | SDMA Channel 2 Tx Buffer Return<br>Indicates that SDMA2 Tx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 11   | Sdma2TxEnd | SDMA Channel 2 Tx End<br>Indicates that a Tx resource error occurred or that the Tx DMA moved<br>to IDLE after a stop command. Also, set when Tx retransmit limit is<br>reached in HDLC mode. | 0                |
| 12   | Sdma3RxBuf | SDMA Channel 3 Rx Buffer Return<br>Indicates that SDMA3 Rx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |



| Bits | Field Name | Function                                                                                                                                                                                      | Initial<br>Value |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 13   | Sdma3RxErr | SDMA Channel 3 Rx Error<br>Indicates that a Rx resource error occurred.                                                                                                                       | 0                |
| 14   | Sdma3TxBuf | SDMA Channel 3 Tx Buffer Return<br>Indicates that SDMA3 Tx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 15   | Sdma3TxEnd | SDMA Channel 3 Tx End<br>Indicates that a Tx resource Error occurred or that the Tx DMA moved<br>to IDLE after a stop command. Also, set when Tx retransmit limit is<br>reached in HDLC mode. | 0                |
| 16   | Sdma4RxBuf | SDMA Channel 4 Rx Buffer Return<br>Indicates that SDMA4 Rx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 17   | Sdma4RxErr | SDMA Channel 4 Rx Error<br>Indicates that a Rx resource error occurred.                                                                                                                       | 0                |
| 18   | Sdma4TxBuf | SDMA Channel 4 Tx Buffer Return<br>Indicates that SDMA4 Tx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 19   | Sdma4TxEnd | SDMA Channel 4 Tx End<br>Indicates that a Tx resource error occurred or that the Tx DMA moved<br>to IDLE after a stop command. Also, set when Tx retransmit limit is<br>reached in HDLC mode. | 0                |
| 20   | Sdma5RxBuf | SDMA Channel 5 Rx Buffer Return<br>Indicates that SDMA5 Rx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 21   | Sdma5RxErr | SDMA Channel 5 Rx Error<br>Indicates that a Rx resource error occurred.                                                                                                                       | 0                |
| 22   | Sdma5TxBuf | SDMA Channel 5 Tx Buffer Return<br>Indicates that SDMA5 Tx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 23   | Sdma5TxEnd | SDMA Channel 5 Tx End<br>Indicates that a Tx resource error occurred or that the Tx DMA moved<br>to IDLE after a stop command. Also, set when Tx retransmit limit is<br>reached in HDLC mode. | 0                |
| 24   | Sdma6RxBuf | SDMA Channel 6 Rx Buffer Return<br>Indicates that SDMA6 Rx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |

# Table 404: SDMA Cause Register, Offset: 0x103A10 and SDMA Mask Register, Offset: 0x103A90 (Continued)

# Table 404: SDMA Cause Register, Offset: 0x103A10 and SDMA Mask Register, Offset: 0x103A90 (Continued)

| Bits | Field Name | Function                                                                                                                                                                                      | lnitial<br>Value |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 25   | Sdma6RxErr | SDMA Channel 6 Rx Error<br>Indicates that a Rx resource error occurred.                                                                                                                       | 0                |
| 26   | Sdma6TxBuf | SDMA Channel 6 Tx Buffer Return<br>Indicates that SDMA6 Tx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 27   | Sdma6TxEnd | SDMA Channel 6 Tx End<br>Indicates that a Tx resource error occurred or that the Tx DMA moved<br>to IDLE after a stop command. Also, set when Tx retransmit limit is<br>reached in HDLC mode. | 0                |
| 28   | Sdma7RxBuf | SDMA Channel 7 Rx Buffer Return<br>Indicates that SDMA7 Rx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 29   | Sdma7RxErr | SDMA Channel 7 Rx Error<br>Indicates that a Rx resource error occurred.                                                                                                                       | 0                |
| 30   | Sdma7TxBuf | SDMA Channel 7 Tx Buffer Return<br>Indicates that SDMA7 Tx closed a descriptor and returned the associ-<br>ated buffer to CPU ownership.                                                      | 0                |
| 31   | Sdma7TxEnd | SDMA Channel 7 Tx End<br>Indicates that a Tx resource Error occurred or that the Tx DMA moved<br>to IDLE after a stop command. Also, set when Tx retransmit limit is<br>reached in HDLC mode. | 0                |

# Table 405: MPSC0 Cause Register, Offset: 0x103A20 andMPSC0 Mask Register, Offset: 0x103AA0

| Bits | Field Name | Function                                                                                                 | lnitial<br>Value |
|------|------------|----------------------------------------------------------------------------------------------------------|------------------|
| 0    | Mpsc0Rx    | MPSC0 Normal Rx Interrupt Summary<br>Logical OR of (unmasked) bits 4-7 below.<br>This bit is read only.  | 0                |
| 1    | Mpsc0RxErr | MPSC0 Rx Error Interrupt Summary<br>Logical OR of (unmasked) bits 8-11 below.<br>This bit is read only.  | 0                |
| 2    |            | Reserved.                                                                                                | 0                |
| 3    | Mpsc0TxErr | MPSC0 Tx Error Interrupt Summary<br>Logical OR of (unmasked) bits 13-15 below.<br>This bit is read only. | 0                |



| Bits  | Field Name             | Function                                                                                         | Initial<br>Value |
|-------|------------------------|--------------------------------------------------------------------------------------------------|------------------|
| 4     | Mpsc0RLSC              | MPSC0 Rx Line Status Change (from to IDLE)                                                       | 0                |
| 5     | Mpsc0RHNT              | MPSC0 Rx Entered HUNT State                                                                      | 0                |
| 6     | Mpsc0RFSC/<br>Mpsc0RCC | MPSC0 Rx Flag Status Change (HDLC mode)<br>MPSC0 Received Control Character (Bisync, Uart modes) | 0                |
| 7     | Mpsc0RCSC              | MPSC0 Rx Carrier Sense Change (DPLL decoded carriers sense)                                      | 0                |
| 8     | Mpsc0ROVR              | MPSC0 Rx Overrun                                                                                 | 0                |
| 9     | Mpsc0RCDL              | MPSC0 Rx Carrier Detect Loss                                                                     | 0                |
| 10    | Mpsc0RCKG              | MPSC0 Rx Clock Glitch                                                                            | 0                |
| 11    | MPsc0BPER              | MPSC0 Bisync Protocol Error (valid only in Bisync mode)                                          | 0                |
| 12    | Mpsc0TEIDL             | MPSC0 Tx Entered IDLE State                                                                      | 0                |
| 13    | Mpsc0TUDR              | MPSC0 Tx Underrun                                                                                | 0                |
| 14    | Mpsc0TCTSL             | MPSC0 Tx Clear To Send Loss                                                                      | 0                |
| 15    | Mpsc0TCKG              | MPSC0 Tx Clock Glitch                                                                            | 0                |
| 31:16 |                        | Reserved.                                                                                        | 0                |

# Table 405: MPSC0 Cause Register, Offset: 0x103A20 and MPSC0 Mask Register, Offset: 0x103AA0 (Continued)

#### Table 406: MPSC1 Cause Register, Offset: 0x103A24 and MPSC1 Mask Register, Offset: 0x103AA4

| Bits | Field Name | Function                          | lnitial<br>Value |
|------|------------|-----------------------------------|------------------|
| 31:0 | Various    | Same as for MPSC0 cause register. | 0                |

#### Table 407: MPSC2 Cause Register, Offset: 0x103A28 and MPSC2 Mask Register, Offset: 0x103AA8

| Bits | Field Name | Function                          | lnitial<br>Value |
|------|------------|-----------------------------------|------------------|
| 31:0 | Various    | Same as for MPSC0 cause register. | 0                |



#### Table 408: MPSC3 Cause Register, Offset: 0x103A2C and MPSC3 Mask Register, Offset: 0x103AAC

| Bits | Field Name | Function                          | lnitial<br>Value |
|------|------------|-----------------------------------|------------------|
| 31:0 | Various    | Same as for MPSC0 cause register. | 0                |

#### Table 409: MPSC4 Cause Register, Offset: 0x103A30 and MPSC4 Mask Register, Offset: 0x103AB0

| Bit | ts Field Nam | e Function                        | Initial<br>Value |
|-----|--------------|-----------------------------------|------------------|
| 31: | 0 Various    | Same as for MPSC0 cause register. | 0                |

#### Table 410: MPSC5 Cause Register, Offset: 0x103A34 and MPSC5 Mask Register, Offset: 0x103AB4

| Bits | Field Name | Function                          | Initial<br>Value |
|------|------------|-----------------------------------|------------------|
| 31:0 | Various    | Same as for MPSC0 cause register. | 0                |

#### Table 411: MPSC6 Cause Register, Offset: 0x103A38 and MPSC6 Mask Register, Offset: 0x103AB8

| Bits | Field Name | Function                          | Initial<br>Value |
|------|------------|-----------------------------------|------------------|
| 31:0 | Various    | Same as for MPSC0 cause register. | 0                |

#### Table 412: MPSC7 Cause Register, Offset: 0x103A3C and MPSC7 Mask Register, Offset: 0x103ABC

| Bits | Field Name | Function                          | Initial<br>Value |
|------|------------|-----------------------------------|------------------|
| 31:0 | Various    | Same as for MPSC0 cause register. | 0                |



| Table 413: FlexTDM Cause Register, Offset: 0x103A40 and |
|---------------------------------------------------------|
| FlexTDM Mask Register, Offset: 0x103AC0                 |

| Bits | Field Name | Function                                            | Initial<br>Value |
|------|------------|-----------------------------------------------------|------------------|
| 0    | Ftdm0RAUXA | FlexTDM0 Rx Interrupt from AUX channel A            | 0                |
| 1    | Ftdm0RAUXB | FlexTDM0 Rx Interrupt from AUX channel B            | 0                |
| 2    | Ftdm0Rint  | FlexTDM0 Rx Interrupt (programmed in dual port ram) | 0                |
| 3    | Ftdm0RSL   | FlexTDM0 Rx Synchronization Loss                    | 0                |
| 4    | Ftdm0TAUXA | FlexTDM0 Tx Interrupt from AUX channel A            | 0                |
| 5    | Ftdm0TAUXB | FlexTDM0 Tx Interrupt from AUX channel B            | 0                |
| 6    | Ftdm0Tint  | FlexTDM0 Tx Interrupt (programmed in dual port ram) | 0                |
| 7    | Ftdm0TSL   | FlexTDM0 Tx Synchronization Loss                    | 0                |
| 8    | Ftdm1RAUXA | FlexTDM1 Rx Interrupt from AUX channel A            | 0                |
| 9    | Ftdm1RAUXB | FlexTDM1 Rx Interrupt from AUX channel B            | 0                |
| 10   | Ftdm1Rint  | FlexTDM1 Rx Interrupt (programmed in dual port ram) | 0                |
| 11   | Ftdm1RSL   | FlexTDM1 Rx Synchronization Loss                    | 0                |
| 12   | Ftdm1TAUXA | FlexTDM1 Tx Interrupt from AUX channel A            | 0                |
| 13   | Ftdm1TAUXB | FlexTDM1 Tx Interrupt from AUX channel B            | 0                |
| 14   | Ftdm1Tint  | FlexTDM1 Tx Interrupt (programmed in dual port ram) | 0                |
| 15   | Ftdm1TSL   | FlexTDM1 Tx Synchronization Loss                    | 0                |
| 16   | Ftdm2RAUXA | FlexTDM2 Rx Interrupt from AUX channel A            | 0                |
| 17   | Ftdm2RAUXB | FlexTDM2 Rx Interrupt from AUX channel B            | 0                |
| 18   | Ftdm2Rint  | FlexTDM2 Rx Interrupt (programmed in dual port ram) | 0                |
| 19   | Ftdm2RSL   | FlexTDM2 Rx Synchronization Loss                    | 0                |
| 20   | Ftdm2TAUXA | FlexTDM2 Tx Interrupt from AUX channel A            | 0                |
| 21   | Ftdm2TAUXB | FlexTDM2 Tx Interrupt from AUX channel B            | 0                |
| 22   | Ftdm2Tint  | FlexTDM2 Tx Interrupt (programmed in dual port ram) | 0                |
| 23   | Ftdm2TSL   | FlexTDM2 Tx Synchronization Loss                    | 0                |
| 24   | Ftdm3RAUXA | FlexTDM3 Rx Interrupt from AUX channel A            | 0                |
| 25   | Ftdm3RAUXB | FlexTDM3 Rx Interrupt from AUX channel B            | 0                |
| 26   | Ftdm3Rint  | FlexTDM3 Rx Interrupt (programmed in dual port ram) | 0                |
| 27   | Ftdm3RSL   | FlexTDM3 Rx Synchronization Loss                    | 0                |
| 28   | Ftdm3TAUXA | FlexTDM3 Tx Interrupt from AUX channel A            | 0                |



#### Table 413: FlexTDM Cause Register, Offset: 0x103A40 and FlexTDM Mask Register, Offset: 0x103AC0 (Continued)

| Bits | Field Name | Function                                            | lnitial<br>Value |
|------|------------|-----------------------------------------------------|------------------|
| 29   | Ftdm3TAUXB | FlexTDM3 Tx Interrupt from AUX channel B            | 0                |
| 30   | Ftdm3Tint  | FlexTDM3 Tx Interrupt (programmed in dual port ram) | 0                |
| 31   | Ftdm3TSL   | FlexTDM3 Tx Synchronization Loss                    | 0                |

# Table 414: BRG Cause Register, Offset: 0x103A48 andBRG Mask Register, Offset: 0x103AC8

| Bits  | Field Name | Function                | Initial<br>Value |
|-------|------------|-------------------------|------------------|
| 0     | BTR0       | Baud Tuning 0 interrupt | 0                |
| 1     | BTR1       | Baud Tuning 1 interrupt | 0                |
| 2     | BTR2       | Baud Tuning 2 interrupt | 0                |
| 3     | BTR3       | Baud Tuning 3 interrupt | 0                |
| 4     | BTR4       | Baud Tuning 4 interrupt | 0                |
| 5     | BTR5       | Baud Tuning 5 interrupt | 0                |
| 6     | BTR6       | Baud Tuning 6 interrupt | 0                |
| 7     | BTR7       | Baud Tuning 7 interrupt | 0                |
| 31:24 |            | Reserved.               | 0                |

#### Table 415: GPP0 Cause Register, Offset: 0x103A50 and GPP0 Mask Register, Offset: 0x103AD0

| Bits | Field Name  | Function                                                                                                                                                                                                                                    | lnitial<br>Value |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 31:0 | GPInt[31:0] | General Purpose Interrupt Bits<br>A bit in this cause register is set when the value latched in the GPD<br>register bit is '0'.<br><b>NOTE:</b> Interrupts also occur when the associated GPC pin is con-<br>figured as a functional input. | 0                |



# Table 416: GPP1 Cause Register, Offset: 0x103A54 andGPP1 Mask Register, Offset: 0x103AD4

| Bits | Field<br>Name | Function                                                                                                                                                                                                                                    | Initial<br>Value |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 31:0 | GPInt[63:32]  | General Purpose Interrupt Bits<br>A bit in this cause register is set when the value latched in the GPD<br>register bit is '0'.<br><b>NOTE:</b> Interrupts also occur when the associated GPC pin is con-<br>figured as a functional input. | 0                |

# Table 417: GPP2 Cause Register, Offset: 0x103A58 andGPP2 Mask Register, Offset: 0x103AD8

| Bits | Field Name   | Function                                                                                                                                                                                                                                    | lnitial<br>Value |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 31:0 | GPInt[95:64] | General Purpose Interrupt Bits<br>A bit in this cause register is set when the value latched in the GPD<br>register bit is '0'.<br><b>NOTE:</b> Interrupts also occur when the associated GPC pin is con-<br>figured as a functional input. | 0                |

### Table 418: SErr0\* Mask, PCI\_0 Events Offset: 0xc28

| Bits | Field Name | Function                                                                                                                                 | Initial<br>Value |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0    | AddrErr0   | Mask bit.<br>When this bit is set and the GT-96100A detects a parity error on<br>PCI_0 address lines, SErr0* is asserted.                | 0x0              |
| 1    | MasWrErr0  | Mask bit.<br>When this bit is set and the GT-96100A detects a parity error during<br>a PCI_0 master write operation, SErr0* is asserted. | 0x0              |
| 2    | MasRdErr0  | Mask bit.<br>When this bit is set and the GT-96100A detects a parity error during<br>a PCI_0 master read operation, SErr0* is asserted.  | 0x0              |
| 3    | MemErr     | Mask bit.<br>When this bit is set and a memory parity error has been detected,<br>SErr0* is asserted.                                    | 0x0              |
| 4    | MasAbor0t  | Mask bit.<br>When this bit is set and the GT-96100A performs a PCI_0 master<br>abort, SErr0* is asserted.                                | 0x0              |

| Bits | Field Name | Function                                                                                                 | lnitial<br>Value |
|------|------------|----------------------------------------------------------------------------------------------------------|------------------|
| 5    | TarAbort0  | Mask bit.<br>When this bit is set and the GT-96100A detects a PCI_0 target abort,<br>SErr0* is asserted. | 0x0              |
| 31:6 | Reserved   |                                                                                                          | 0x0              |

# Table 418: SErr0\* Mask, PCI\_0 Events Offset: 0xc28 (Continued)



| Bits | Field Name | Function                                                                                                                                 | lnitial<br>Value |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0    | AddrErr1   | Mask bit.<br>When this bit is set and the GT-96100A detects a parity error on the<br>PCI_1 address lines, SErr1* is asserted.            | 0x0              |
| 1    | MasWrErr1  | Mask bit.<br>When this bit is set and the GT-96100A detects a parity error during<br>a PCI_1 master write operation, SErr1* is asserted. | 0x0              |
| 2    | MasRdErr1  | Mask bit.<br>When this bit is set and the GT-96100A detects a parity error during<br>a PCI_1 master read operation, SErr1* is asserted.  | 0x0              |
| 3    | MemErr     | Mask bit.<br>When this bit is set and a memory parity error has been detected,<br>SErr1* is asserted.                                    | 0x0              |
| 4    | MasAbort1  | Mask bit.<br>When this bit is set and the GT-96100A performs a PCI_1 master<br>abort, SErr1* is asserted.                                | 0x0              |
| 5    | TarAbort1  | Mask bit.<br>When this bit is set and the GT-96100A detects a PCI_1 target<br>abort, SErr1* is asserted.                                 | 0x0              |
| 31:6 | Reserved   |                                                                                                                                          | 0x0              |

## Table 419: SErr1\* Mask, PCI\_1 Events Offset: 0xca8 (RESERVED if configured for only PCI\_0)



# 22. RESET CONFIGURATION

The GT-96100A must acquire some knowledge about the system before it is configured by the software.

Special modes of operation are sampled on RESET in order to enable the GT-96100A to function as required. Certain pins must be pulled up to VCC3.3 or down to GND (4.7K Ohm recommended) externally to accomplish this.

The following configuration pins are continuously sampled from Rst\* assertion until three TClk cycles after Rst\* is deasserted. This does not apply to Frame1\*/Req64\* that requires zero hold time in respect to RESET rise (as defined in PCI spec).

**NOTE:** Rst\* must be de-asserted for at least 10 PClk cycles before any CPU transactions are generated.

| Pin                      | Configuration Function                                                                                                                                                                                           |  |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DAdr[2], Frame1*/Req64*: | PCI Bus Configuration                                                                                                                                                                                            |  |
|                          | 00-Only PCI_0 is used as 64-bit.<br>01-Only PCI_0 is used as 32-bit, PCI_1 is NOT used.<br>10-Reserved.<br>11-Both PCI_0 and PCI_1 are used as 32-bit.                                                           |  |
| Interrupt0*:             | CPU Data Endianess                                                                                                                                                                                               |  |
|                          | 0-Big endian<br>1-Little endian                                                                                                                                                                                  |  |
| Ready*, CSTiming*        | Multi-GT-96100A Address ID                                                                                                                                                                                       |  |
|                          | 00-GT responds to SysAD[26,25]= 00<br>01-GT responds to SysAD[26,25]= 01<br>10-GT responds to SysAD[26,25]= 10<br>11- GT responds to SysAD[26,25]= 11<br><b>NOTE:</b> Boot GT-96100A should be programmed to 11. |  |
| BankSel[0]:              | PCI Class Code Default Select                                                                                                                                                                                    |  |
|                          | 0-Memory Controller (0x580)<br>1-Network Controller (0x280)                                                                                                                                                      |  |
| DAdr[10]:                | Multiple GT-96100A Support                                                                                                                                                                                       |  |
|                          | 0-Not supported.<br>1-Supported.                                                                                                                                                                                 |  |
| DAdr[9]:                 | 66 MHz PCI                                                                                                                                                                                                       |  |
|                          | 0-Disable.<br>1-Enable.                                                                                                                                                                                          |  |
| DAdr[8]:                 | I2O Support                                                                                                                                                                                                      |  |
|                          | 0-Enable.<br>1-Disable.                                                                                                                                                                                          |  |

#### Table 420: Reset Configuration



| Pin        |                          | Configuration Function                                                                                                         |
|------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| DAdr[7]:   |                          | UMA Support                                                                                                                    |
|            | 0-<br>1-                 | Enable - DMAReq[0]*/MREQ* functions as MREQ*.<br>Disable - DMAReq[0]*/MREQ* functions as DMAReq[0]*.                           |
| DAdr[6]:   |                          | Programming Conditional PCI Retry                                                                                              |
|            | 0-<br>1-                 | Enable.<br>Disable.                                                                                                            |
| DAdr[5]:   |                          | Expansion ROM Enable                                                                                                           |
|            | 0-<br>1-                 | Enable.<br>Disable.                                                                                                            |
| DAdr[4:3]: |                          | Device Boot Bus Width (Controlled by BootCS*) AND CS[3]* Device Width.                                                         |
|            | 00-<br>01-<br>10-<br>11- | 8 bits<br>16 bits<br>32 bits<br>64 bits                                                                                        |
| DAdr[0]:   |                          | Autoload                                                                                                                       |
|            | 0-<br>1-                 | Enable.<br>Disable.                                                                                                            |
| SDQM[1]:   |                          | PCI_1 Power Management                                                                                                         |
|            | 0-<br>1-                 | Disable.<br>Enable.                                                                                                            |
| SDQM[0]:   |                          | PCI_0 Power Management                                                                                                         |
|            | 0-<br>1-                 | Disable.<br>Enable.                                                                                                            |
| DMAReq[3]* |                          | Duplicate ALE                                                                                                                  |
|            | 0-<br>1-                 | Do not Duplicate ALE.<br>Duplicate ALE output on ADP[1] (no ECC in system).                                                    |
| DMAReq[1]* |                          | Duplicate SDRAM Control Signals                                                                                                |
|            | 0-<br>1-                 | Do not Duplicate SRAS*, SCAS* and DWr*.<br>Duplicate SRAS*, SCAS* and DWr* on ADP[7], ADP[6] and ADP[3] (no<br>ECC in system). |
| ADP[7:4]   |                          | Reserved                                                                                                                       |
|            |                          | Design in the option to pull-up or pull-down these pins.                                                                       |

## Table 420: Reset Configuration (Continued)

| Pin        | Configuration Function      |  |
|------------|-----------------------------|--|
| DAdr[1]    | Reserved                    |  |
|            | Must pull LOW during Reset. |  |
| DMAReq[2]* | Reserved                    |  |
|            | Must pull LOW during Reset. |  |
| SDQM[2]    | Reserved                    |  |
|            | Must pull LOW during Reset. |  |
| SDQM[3]    | Reserved                    |  |
|            | Must pull LOW during Reset. |  |

## Table 420: Reset Configuration (Continued)



# 23. CONNECTING THE MEMORY CONTROLLER TO SDRAM AND DEVICES

In order to connect the memory (SDRAM and Devices), follow the pin connections for the appropriate SDRAM and devices listed in this section's tables.

# 23.1 SDRAM

The GT-96100A supports both 64-bit and 32-bit SDRAM.

Table 421: 64-bit SDRAM

| Connection         | Connect                                                                                      | То                                                                                                                                                                                        |
|--------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SDRAM Address      | DAdr[12:0]                                                                                   | A[10:0]<br>A[11] (64/128/256 Mbit only)<br>A[12] (256 Mbit only)                                                                                                                          |
| SDRAM Bank Address | BankSel[1:0]                                                                                 | BA0<br>BA1 (64/128/256 Mbit only)                                                                                                                                                         |
| SDRAM Data         | AD[63:0]                                                                                     | D[63:0], SDRAM Data pins                                                                                                                                                                  |
| SDRAM Control Pins | SRAS*<br>SCAS*<br>DWr* <sup>1</sup>                                                          | SDRAM Row Address Strobe<br>SDRAM Column Address Strobe<br>Write Enable                                                                                                                   |
| Chip Selects       | SCS[0]*<br>SCS[1]*<br>SCS[2]*<br>SCS[3]*                                                     | Chip Select, Bank 0<br>Chip Select, Bank 1<br>Chip Select, Bank 2<br>Chip Select, Bank 3                                                                                                  |
| Byte Enables       | SDQM[0]*<br>SDQM[1]*<br>SDQM[2]*<br>SDQM[3]*<br>SDQM[4]*<br>SDQM[5]*<br>SDQM[6]*<br>SDQM[6]* | D[7:0] Byte Enable<br>D[15:8] Byte Enable<br>D[23:16] Byte Enable<br>D[31:24] Byte Enable<br>D[39:32] Byte Enable<br>D[47:40] Byte Enable<br>D[55:48] Byte Enable<br>D[63:56] Byte Enable |
| ECC Bits           | ADP[7:0]                                                                                     | D[63:0] ECC byte                                                                                                                                                                          |
| Clock              | Same Clock Output used for TClk                                                              | Clock Input                                                                                                                                                                               |

1. SRAS\*, SCAS\*, and DWr\* can be duplicated on ADP[7], ADP[6] and ADP[3] if programmed on RESET.



### Table 422: 32-bit SDRAM

| Connection                        | Connect                                                                                      | То                                                                                                                                                                                                                         |
|-----------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SDRAM Address                     | DAdr[11:0]                                                                                   | A[10:0]<br>A[11] (64/128 Mbit only)                                                                                                                                                                                        |
| SDRAM Bank Address                | BankSel[1:0]                                                                                 | BA0<br>BA1 (64/128 Mbit only)                                                                                                                                                                                              |
| SDRAM Even Data<br>SDRAM Odd Data | AD[31:0]<br>AD[63:32]                                                                        | Even D[31:0] SDRAM Data pins<br>Odd D[31:0] SDRAM Data pins                                                                                                                                                                |
| SDRAM Control Pins                | SRAS*<br>SCAS*<br>DWr* <sup>1</sup>                                                          | SDRAM Row Address Strobe<br>SDRAM Column Address Strobe<br>Write Enable                                                                                                                                                    |
| Chip Selects                      | SCS[0]*<br>SCS[1]*<br>SCS[2]*<br>SCS[3]*                                                     | Chip Select, Bank 0<br>Chip Select, Bank 1<br>Chip Select, Bank 2<br>Chip Select, Bank 3                                                                                                                                   |
| Byte Enables                      | SDQM[0]*<br>SDQM[1]*<br>SDQM[2]*<br>SDQM[3]*<br>SDQM[4]*<br>SDQM[5]*<br>SDQM[6]*<br>SDQM[7]* | Even D[7:0] Byte Enable<br>Even D[15:8] Byte Enable<br>Even D[23:16] Byte Enable<br>Even D[31:24] Byte Enable<br>Odd D[7:0] Byte Enable<br>Odd D[15:8] Byte Enable<br>Odd D[23:16] Byte Enable<br>Odd D[31:24] Byte Enable |
| ECC Bits                          | Not supported for 32-bit SDRAM                                                               |                                                                                                                                                                                                                            |
| Clock                             | Same Clock Output used for TClk.                                                             | Clock Input                                                                                                                                                                                                                |

1. SRAS\*, SCAS\*, and DWr\* can be duplicated on ADP[7], ADP[6] and ADP[3] if programmed on RESET.

## 23.2 Devices

The GT-96100A supports 64-, 32-, 16- and 8-bit devices.

### Table 423: 64-bit Devices

| Connection     | Connect       | То                                |
|----------------|---------------|-----------------------------------|
| Device Address | BAdr[2:0]     | To the device's LSB address bits. |
|                | AD[31:6]      | Address Latch Inputs              |
|                | ALE           | Address LE                        |
|                | Latch Outputs | Device Address Bits [28:3]        |



| Connection          | Connect                                                                                                                                                  | То                                                                                                                                                                                                |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device Data         | AD[63:0]                                                                                                                                                 | Device Data Pins [63:0]                                                                                                                                                                           |
| Device Control Pins | ALE<br>AD[41:32]<br>Control latch bit[41] output<br>Control latch bit[40] output<br>Control latch bit[39:36] outputs<br>Control latch bit[35:32] outputs | Control latch LE<br>Control Latch Inputs<br>Becomes DevRW*<br>Becomes BootCS*<br>Becomes CS[3:0]*<br>Becomes DMAAck[3:0]*                                                                         |
| Write Strobes       | Wr[0]*<br>Wr[1]*<br>Wr[2]*<br>Wr[3]*<br>Wr[4]*<br>Wr[4]*<br>Wr[5]*<br>Wr[6]*<br>Wr[6]*                                                                   | D[7:0] Write Strobe<br>D[15:8] Write Strobe<br>D[23:16] Write Strobe<br>D[31:24] Write Strobe<br>D[39:32] Write Strobe<br>D[47:40] Write Strobe<br>D[55:48] Write Strobe<br>D[63:56] Write Strobe |
| ECC Bits            | Not supported for Devices.                                                                                                                               |                                                                                                                                                                                                   |

### Table 423: 64-bit Devices (Continued)

#### Table 424: 32-bit Devices

| Connection          | Connect                          | То                                |
|---------------------|----------------------------------|-----------------------------------|
| Device Address      | BAdr[2:0]                        | To the device's LSB address bits. |
|                     | AD[31:5]                         | Address Latch Inputs              |
|                     | ALE                              | Address LE                        |
|                     | Latch Outputs                    | Device Address Bits [29:3]        |
| Device Data         | AD[31:0]                         | Device Even Data Pins [31:0]      |
|                     | AD[63:32]                        | Device Odd Data Pins[31:0]        |
| Device Control Pins | ALE                              | Control latch LE                  |
|                     | AD[41:32]                        | Control Latch Inputs              |
|                     | Control latch bit[41] output     | Becomes DevRW*                    |
|                     | Control latch bit[40] output     | Becomes BootCS*                   |
|                     | Control latch bit[39:36] outputs | Becomes CS[3:0]*                  |
|                     | Control latch bit[35:32] outputs | Becomes DMAAck[3:0]*              |

| Connection    | Connect                  | То                         |  |
|---------------|--------------------------|----------------------------|--|
| Write Strobes | Wr[0]*                   | Even D[7:0] Write Strobe   |  |
|               | Wr[1]*                   | Even D[15:8] Write Strobe  |  |
|               | Wr[2]*                   | Even D[23:16] Write Strobe |  |
|               | Wr[3]*                   | Even D[31:24] Write Strobe |  |
|               | Wr[4]*                   | Odd D[7:0] Write Strobe    |  |
|               | Wr[5]*                   | Odd D[15:8] Write Strobe   |  |
|               | Wr[6]*                   | Odd D[23:16] Write Strobe  |  |
|               | Wr[7]*                   | Odd D[31:24] Write Strobe  |  |
| ECC Bits      | Not supported for Device | Not supported for Devices. |  |

## Table 424: 32-bit Devices (Continued)

#### Table 425: 16-bit Devices

| Connection          | Connect                                                                                                                                                  | То                                                                                                                        |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| Device Address      | BAdr[2:0]<br>AD[31:4]<br>ALE<br>Latch Outputs                                                                                                            | To the device's LSB address bits.<br>Address Latch Inputs<br>Address LE<br>Device Address Bits [30:3]                     |
| Device Data         | AD[15:0]<br>AD[47:32]                                                                                                                                    | Device Even Data Pins [15:0]<br>Device Odd Data Pins[15:0]                                                                |
| Device Control Pins | ALE<br>AD[41:32]<br>Control latch bit[41] output<br>Control latch bit[40] output<br>Control latch bit[39:36] outputs<br>Control latch bit[35:32] outputs | Control latch LE<br>Control Latch Inputs<br>Becomes DevRW*<br>Becomes BootCS*<br>Becomes CS[3:0]*<br>Becomes DMAAck[3:0]* |
| Write Strobes       | Wr[0]*<br>Wr[1]*<br>Wr[4]*<br>Wr[5]*                                                                                                                     | Even D[7:0] Write Strobe<br>Even D[15:8] Write Strobe<br>Odd D[7:0] Write Strobe<br>Odd D[15:8] Write Strobe              |
| ECC Bits            | Not supported for Devices.                                                                                                                               |                                                                                                                           |



| Connection          | Connect                          | То                                |
|---------------------|----------------------------------|-----------------------------------|
| Device Address      | BAdr[2:0]                        | To the device's LSB address bits. |
|                     | AD[31:3]                         | Address Latch Inputs              |
|                     | ALE                              | Address LE                        |
|                     | Latch Outputs                    | Device Address Bits [31:3]        |
| Device Data         | AD[7:0]                          | Device Even Data Pins [7:0]       |
|                     | AD[39:32]                        | Device Odd Data Pins[7:0]         |
| Device Control Pins | ALE                              | Control latch LE                  |
|                     | AD[41:32]                        | Control Latch Inputs              |
|                     | Control latch bit[41] output     | Becomes DevRW*                    |
|                     | Control latch bit[40] output     | Becomes BootCS*                   |
|                     | Control latch bit[39:36] outputs | Becomes CS[3:0]*                  |
|                     | Control latch bit[35:32] outputs | Becomes DMAAck[3:0]*              |
| Write Strobes       | Wr[0]*                           | Even D[7:0] Write Strobe          |
|                     | Wr[4]*                           | Odd D[7:0] Write Strobe           |
| ECC Bits            | Not supported for Devices.       |                                   |

#### Table 426: 8-bit Devices



## 24. JTAG INTERFACE

## 24.1 IEEE Standard 1149.1

The GT-96100A supports test mode operation through it's JTAG boundary scan interface to enable board testing.

The JTAG interface is IEEE 1149.1 standard compliant. It supports mandatory and optional boundary scan instructions.

## 24.2 TAP Controller

The Test Access Port (TAP) is constructed with a 5-pin interface and a 16-state Finite State Machine (FSM), as defined by IEEE JTAG standard 1149.1.

To place the GT-96100A in functional mode, the JTAG interface must be disabled by resetting the JTAG state machine.

According to the IEEE 1149.1 standard, the JTAG state machine is not reset when the GT-96100A RESET is asserted. The JTAG state machine can only be reset by one of the following methods:

- Asserting TRST\* (JTAG[4]).
- By setting TMS (JTAG[1]) for at least five TCK (JTAG[0]) cycles.

To place the GT-96100A in the boundary scan test mode, the JTAG state machine must be moved to it's control states. The TMS & TDI inputs control the state transitions of the JTAG state machine, as specified in the 1149.1 standard. The JTAG state machine has various states for shifting instructions to the Instruction Register and for shifting data to and from the boundary scan, identification, or bypass registers.

**NOTE:** Although the JTAG state machine is not reset, the GT-96100A RESET must be de-asserted (pulled up) when the GT-96100A is in the boundary scan test mode. In order to meet this requirement, the BSDL file defines the RESET within a compliant pattern.

# 24.3 Instruction Register (IR)

The Instruction register (IR) is a 4-bit two-stage register. It contains the command that is shifted in when the TAP FSM is in the Shift-IR state. When the TAP FSM is in the Capture-IR state, the IR outputs all four bits in parallel.

The GT-96100A supports the following instructions:

| Instruction         | Code | Description                                                                                                                                                                                                                   |
|---------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HIGHZ               | 0011 | Select the Bypass Register between TDI and TDO.<br>Sets the GT-96100A output pins to high-impedance state.                                                                                                                    |
| IDCODE              | 0010 | Selects the Identification Register between TDI and TDO.<br>This 32-bit register is used to identify the GT-96100A device.<br>See Table 428                                                                                   |
| EXTEST              | 0000 | Selects the Boundary Scan Register between TDI and TDO.<br>Output boundary scan register cells drive the output pins of<br>the GT-96100A. Input boundary scan register cell sample the<br>input pin of the GT-96100A.         |
| SAMPLE/PRE-<br>LOAD | 0001 | Selects the Boundary Scan Register between TDI and TDO.<br>Sample input pins of the GT-96100A to input boundary scan<br>register cells. Preload output boundary scan register cells<br>with the Boundary Scan Register value. |
| BYPASS              | 1111 | Selects the single bit Bypass Registers between TDI and TDO. This allows for rapid data movement through an untested device.                                                                                                  |

Table 427: Supported JTAG Instructions

**NOTE:** Bi-directional pins can be programmed to be either input or output, depending on their control bit in the Boundary Scan Register.

# 24.4 Bypass Register (BR)

The Bypass Register (BR) is a one-bit serial shift register that connects TDI to TDO when the IR holds the Bypass command, and the TAP FSM is in the Shift-DR state. Data that is driven on the TDI input pin is shifted out one cycle later on the TDO output pin. The Bypass Register is loaded with "0" when the TAP FSM is in the Capture-DR state.

# 24.5 JTAG Scan Chain

The JTAG Scan Chain is a serial shift register that is used to sample and drive all of the GT-96100A pins during the JTAG tests. It is a 216-bit deep shift register in the GT-96100A, thereby allowing it to sequentially access all of the data pins. For further details, go to JTAG Scan Chain in BSDL format (Hash://www.GalileoT.com/library/ raclib.htm) for a full description.



# 24.6 ID Register

The ID Register is a 32-bit deep serial shift register. The ID Register is loaded with vendor and device information when the TAP FSM is in the Capture-DR state. In the GT-96100A, the ID Register is loaded with "000110010100000000101010111" during Capture\_DR. The Identification code format of the ID Register is shown in Table 428 which describes the various ID Code fields.

#### Table 428: IDCODE Register Map

| Bits  | Value            | Description     |
|-------|------------------|-----------------|
| 31:28 | 0010             | Version         |
| 27:12 | 1001011001010011 | Part number     |
| 11:1  | 00010101011      | Manufacturer ID |
| 0     | 1                | Mandatory       |

When the JTAG interface is not connected in a JTAG chain on the board:

- It's input pins must be pulled to VCC3.3, or GND (4.7K Ohm recommended).
- It's output pin (TDO) must be left unconnected.

JTAG TMS & TDI input pins must be pulled HIGH, and TCLK & TRST\* input pins must be pulled LOW.



## **25.** BIG AND LITTLE ENDIAN

## 25.1 Background

**NOTE:** For a description of big and little endian and how it is used in Galileo Technology system controllers, go to Endianess Explained! (http://www.GalileoT.com/library/syslib.htm) on the Galileo Technology Website.

There are three bits in the GT-96100A which control byte swapping on the CPU and PCI interfaces. One bit is located in the CPU Interface Configuration Register (0x000) bit 12. The other two bits are in PCI Internal Command register (0xc00) bits 0 and 16.

All these bits are given the same value as sampled at RESET on Interrupt0\* pin. These bits can also be programmed after reset is de-asserted.

If all bits are set to 1, the GT-96100A assumes Little-endian data format and NO byte swapping is done within the device.

Additionally, there are three WORD-SWAP bits in GT-96100A which controls 32-bit word swap on access to/ from PCI:

- Bit 10 controls PCI master interface word swap.
- Bit 11 controls PCI target interface word swap when accessed through non-swap BARs.
- Bit 12 controls PCI target interface word swap when accessed through swap BARs.

Since the PCI bus is 32-bit wide and the GT-96100A data path is 64-bit wide, byte swap is not good enough in case of working in a BIG endian PCI bus configuration. These three bits are used for endianess compensation for this case.

On top of the above, the GT-96100A supports byte swapping on serial data transferred between the communication unit agents and memory/PCI. Each of the serial DMA channels has two configuration bits associated with it that control byte swapping - one bit controls swapping of incoming (receive) data, and the other bit controls swapping of outgoing (transmit) data. Refer to the Ethernet and SDMA sections for more details about serial DMA configuration options.<sup>1</sup>

The nomenclature for this section is shown in Table 429.

DMA descriptors that are used by the serial DMA channels are not considered data, and therefore are not affected by the setting of receive/transmit swap bits in the DMA configuration registers. Descriptors swapping is controlled via one bit in the CIU configuration register. Refer to CIU section for details.

#### Table 429: Nomenclature

| Name            | Definition                                                                                                                                                                                      |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| W, Word         | 32-bits of data, R4600 terminology                                                                                                                                                              |
| DW, Double Word | 64-bits of data, R4600 terminology                                                                                                                                                              |
| Even Address    | Address of which A[2] == 0<br>In Little-endian format, this address points to the LEAST significant W of a DW.<br>In Big-endian format, this address points to the MOST significant W of a DW.  |
| Odd Address     | Address of which A[2] == 1.<br>In Little-endian format, this address points to the MOST significant W of a DW.<br>In Big-endian format, this address points to the LEAST significant W of a DW. |
| Even Word       | LEAST significant W of a DW.                                                                                                                                                                    |
| Odd Word        | MOST significant W of a DW.                                                                                                                                                                     |

## 25.1.1 Bit 12 of the CPU Interface Configuration register

Bit 12 of the CPU Interface Configuration register (0x000) affects the following:

- Setting this bit to 1 (Little-endian mode) means there is no byte swapping within the CPU Interface unit on any data transfer.
- Setting this bit to 0 (Big endian mode) means that byte swapping takes place on data transfers from CPU to the GT-96100A internal registers (including Configuration Data register, offset 0xcfc). No byte swapping takes place on data transfers for which the source/target is external.

## 25.1.2 Bits 0 and 16 of the PCI Internal Command register

Bit 0 of the PCI Internal Command register (0xc00) controls byte swapping of GT-96100A PCI master interface. Bit 16 controls byte swapping of GT-96100A PCI target interface. These bits affect the following:

- Setting these bits to 1 means there is no byte swapping within the PCI Interface unit on any data transfer.
- Setting these bits to 0 means that no byte swapping takes place on data transfers from PCI to/from the GT-96100A internal registers. Byte swapping does take place on data transfers for which the source/target is external

## 25.1.3 Bits 10-12 of the PCI Internal Command register

Setting these bits to 0 means there is no word swapping.

Setting these bits to 1 means that no word swapping takes place on data transfers from PCI to/from the GT-96100A internal registers. Word swapping does take place on data transfers for which the source/target is external.

**NOTE:** Only the 32-bit PCI interface supports word swapping.



# 25.2 Configuring a System for Big and Little Endian

Table 430 shows the basic combinations of the resources and swapping bits with sample data.

- CPU bit = Bit 12 of the CPU Interface Configuration register (0x000).
- PCI byte swap bit = Bits 0 and 16 of the PCI Internal Command register (0xc00).
- PCI word swap bit = Bits 10-12 of the PCI Internal Command register (0xc00).

**NOTE:** The sample data is 0x04030201.

#### Table 430: Configuring for Big and Little Endian

|                                                               | Swap Bits (CPU bit: PCI byte swap bit: PCI word swap bit) |          |          |          |
|---------------------------------------------------------------|-----------------------------------------------------------|----------|----------|----------|
| Resource                                                      | 110                                                       | 001      | 010      | 101      |
| Internal Registers (CPU access)                               | 04030201                                                  | 01020304 | 01020304 | 04030201 |
| Internal Registers (PCI access)                               | 04030201                                                  | 04030201 | 04030201 | 04030201 |
| Internal PCI Configuration Registers (CPU access)             | 04030201                                                  | 01020304 | 01020304 | 04030201 |
| Internal PCI Configuration Registers (PCI access)             | 04030201                                                  | 04030201 | 04030201 | 04030201 |
| External PCI Configuration Registers                          | 04030201                                                  | 04030201 | 01020304 | 01020304 |
| Memory (DRAM and Devices) (CPU access)                        | 04030201                                                  | 04030201 | 04030201 | 04030201 |
| Memory (DRAM and Devices) (PCI access)                        | 04030201                                                  | 01020304 | 04030201 | 01020304 |
| CPU to PCI (Except external PCI Configuration Regis-<br>ters) | 04030201                                                  | 01020304 | 04030201 | 01020304 |



#### USING THE GT-96100A WITHOUT THE CPU INTERFACE 26.

Table 431 lists the pins that must be strapped when the GT-96100A is used without the CPU interface (i.e., PCI Memory Controller only).

NOTE: Rst\* and TClk must always be connected in any system. Each pin must be strapped with a separate resistor unless otherwise noted.

| Pin                      | Strapping <sup>1</sup>                                               |
|--------------------------|----------------------------------------------------------------------|
| ValidOut*                | Pulled up to VCC through a resistor.                                 |
| Release*                 | Pulled up to VCC through a resistor.                                 |
| SysAD[63:0] <sup>2</sup> | Pulled up to VCC through a resistor.                                 |
| SysCmd[8:0] <sup>3</sup> | Pulled up to VCC through a resistor.                                 |
| SysADC[8:0]              | No Connect.                                                          |
| ValidIn*                 | No Connect.                                                          |
| WrRdy*                   | No Connect.                                                          |
| Interrupt*               | Sampled at RESET, see Section 22. "Reset Configuration" on page 452. |
| Hit                      | Pulled down to GND.                                                  |
| ScTCE*                   | Pulled up to VCC.                                                    |

#### Table 431: CPU-less Pin Strapping

1. Galileo Technology recommends using 4.7KOhm resistors.

SysAD[63:0] can be pulled up through a single resistor instead of 64 separate resistors.
 SysCmd[8:0] can be pulled up through a single resistor instead of 9 separate resistors.



# 27. USING THE GT-96100A IN DIFFERENT PCI CONFIGURATIONS

The PCI interface of the GT-96100A can be used in 4 different modes:

- No PCI.
- PCI\_0 as 32-bit PCI.
- PCI\_0 and PCI\_1 as 32-bit PCI.
- PCI\_0 as 64-bit PCI.

Table 432 lists what must be done with the pins when the GT-96100A is used without any PCI interface.

**NOTE:** Rst\* must be connected. Most pins should be strapped HIGH or LOW through a resistor. Galileo Technology recommends using 4.7 KOhm resistors.

| Pin             | Pin Usage                              |
|-----------------|----------------------------------------|
| VREF0           | VREF0                                  |
| PCIk0           | Pulled up to VCC through a resistor.   |
| DevSel0*        | Pulled up to VCC through a resistor.   |
| Stop0*          | Pulled up to VCC through a resistor.   |
| Par0            | No Connect.                            |
| PErr0*          | Pulled up to VCC through a resistor.   |
| Frame0*         | Pulled up to VCC through a resistor.   |
| IRdy0*          | Pulled up to VCC through a resistor.   |
| TRdy0*          | Pulled up to VCC through a resistor.   |
| Gnt0*           | Pulled down to GND through a resistor. |
| IdSel0          | Pulled down to GND through a resistor. |
| SErr0*          | Pulled up to VCC through a resistor.   |
| Req0*           | No Connect.                            |
| Int0*           | Pulled up to VCC through a resistor.   |
| Lock0*          | Pulled up to VCC through a resistor.   |
| PAD0[31:0]      | No Connect.                            |
| CBE0[3:0]*      | No Connect.                            |
| VREF1           | Tie directly to 3V or 5V power plane.  |
| PClk1           | Pulled up to VCC through a resistor.   |
| DevSel1*/Ack64* | Pulled up to VCC through a resistor.   |
| Stop1*          | Pulled up to VCC through a resistor.   |
| Par1/Par64      | No Connect.                            |

#### Table 432: No PCI Interface

| Pin                    | Pin Usage                              |
|------------------------|----------------------------------------|
| PErr1*                 | Pulled up to VCC through a resistor.   |
| Frame1*/Req64*         | Pulled up to VCC through a resistor.   |
| IRdy1*                 | Pulled up to VCC through a resistor.   |
| TRdy1*                 | Pulled up to VCC through a resistor.   |
| Gnt1*                  | Pulled down to GND through a resistor. |
| ldSel1                 | Pulled down to GND through a resistor. |
| SErr1*                 | Pulled up to VCC through a resistor.   |
| Req1*                  | No Connect.                            |
| PAD1[31:0]/PAD0[63:32] | No Connect.                            |
| CBE1[3:0]*/CBE0[7:4]*  | No Connect.                            |

### Table 432: No PCI Interface (Continued)

Table 433 lists what must be done with the pins when the GT-96100A is used with PCI\_0 as a 32-bit PCI interface only (i.e., no PCI\_1).

**NOTE:** When the GT-96100A is configured to a single 32-bit PCI\_0 interface, the GT-96100A drives all PCI\_1 interface signals to a random value. Therefore, there is no need to put pull ups or pull downs on PCI\_1 interface signals.

Table 433: PCI\_0 as 32-bit PCI Only

| Pin      | Pin Usage |
|----------|-----------|
| VREF0    | VREF0     |
| PClk0    | PClk0     |
| DevSel0* | DevSel0*  |
| Stop0*   | Stop0*    |
| Par0     | Par0      |
| PErr0*   | PErr0*    |
| Frame0*  | Frame0*   |
| IRdy0*   | IRdy0*    |
| TRdy0*   | TRdy0*    |
| Gnt0*    | Gnt0*     |
| ldSel0   | IdSel0    |
| SErr0*   | SErr0*    |
| Req0*    | Req0*     |



| Pin                    | Pin Usage                                                                     |  |
|------------------------|-------------------------------------------------------------------------------|--|
|                        |                                                                               |  |
| IntO*                  | Int0*                                                                         |  |
| Lock0*                 | Lock0*                                                                        |  |
| PAD0[31:0]             | PAD0[31:0]                                                                    |  |
| CBE0[3:0]*             | CBE0[3:0]*                                                                    |  |
| VREF1                  | Tie directly to 3V or 5V power plane.                                         |  |
| PClk1                  | Pulled up to VCC through a resistor.                                          |  |
| DevSel1*/Ack64*        | Pulled up to VCC through a resistor.                                          |  |
| Stop1*                 | Pulled up to VCC through a resistor.                                          |  |
| Par1/Par64             | No Connect.                                                                   |  |
| PErr1*                 | Pulled up to VCC through a resistor.                                          |  |
| Frame1*/Req64*         | Pulled up to VCC through a resistor.                                          |  |
| IRdy1*                 | Pulled up to VCC through a resistor.                                          |  |
| TRdy1*                 | Pulled up to VCC through a resistor.                                          |  |
| Gnt1*                  | Pulled down to GND through a resistor or pulled up to VCC through a resistor. |  |
| ldSel1                 | Pulled down to GND through a resistor.                                        |  |
| SErr1*                 | Pulled up to VCC through a resistor.                                          |  |
| Req1*                  | No Connect.                                                                   |  |
| PAD1[31:0]/PAD0[63:32] | No Connect.                                                                   |  |
| CBE1[3:0]*/CBE0[7:4]*  | No Connect.                                                                   |  |

| Table 433: PCI | 0 as 32-bit PCI Onl | v (Continued) |
|----------------|---------------------|---------------|
|                |                     |               |

Table 434 lists what must be done with the pins when the GT-96100A is used with PCI\_0 as a 32-bit PCI interface and PCI\_1 as a 32-bit PCI interface.

| Pin             | Pin Usage  |
|-----------------|------------|
| VREF0           | VREF0      |
| PClk0           | PClk0      |
| DevSel0*        | DevSel0*   |
| Stop0*          | Stop0*     |
| Par0            | Par0       |
| PErr0*          | PErr0*     |
| Frame0*         | Frame0*    |
| IRdy0*          | IRdy0*     |
| TRdy0*          | TRdy0*     |
| Gnt0*           | Gnt0*      |
| IdSel0          | IdSel0     |
| SErr0*          | SErr0*     |
| Req0*           | Req0*      |
| Int0*           | Int0*      |
| Lock0*          | Lock0*     |
| PAD0[31:0]      | PAD0[31:0] |
| CBE0[3:0]*      | CBE0[3:0]* |
| VREF1           | VREF1      |
| PClk1           | PClk1      |
| DevSel1*/Ack64* | DevSel1*   |
| Stop1*          | Stop1*     |
| Par1/Par64      | Par1       |
| PErr1*          | PErr1*     |
| Frame1*/Req64*  | Frame1*    |
| IRdy1*          | IRdy1*     |
| TRdy1*          | TRdy1*     |
| Gnt1*           | Gnt1*      |
| ldSel1          | ldSel1     |
| SErr1*          | SErr1*     |
| Req1*           | Req1*      |
|                 |            |

# Table 434: PCI\_0 as 32-bit PCI and PCI\_1 as 32-bit PCI



| Table 434: PCI_0 as 32-bit P | CI and PCI 1 as 32-bit PCI ( | Continued) |
|------------------------------|------------------------------|------------|
|                              |                              |            |

| Pin                    | Pin Usage  |
|------------------------|------------|
| PAD1[31:0]/PAD0[63:32] | PAD1[31:0] |
| CBE1[3:0]*/CBE0[7:4]*  | CBE1[3:0]* |

Table 435 lists what must be done with the pins when the GT-96100A is used with PCI\_0 as a 64-bit PCI interface only (i.e. no PCI\_1).

| Pin Usage                                             |  |  |  |
|-------------------------------------------------------|--|--|--|
| VREF0                                                 |  |  |  |
| PClk0                                                 |  |  |  |
| DevSel0*                                              |  |  |  |
| Stop0*                                                |  |  |  |
| Par0                                                  |  |  |  |
| PErr0*                                                |  |  |  |
| Frame0*                                               |  |  |  |
| IRdy0*                                                |  |  |  |
| TRdy0*                                                |  |  |  |
| Gnt0*                                                 |  |  |  |
| ldSel0                                                |  |  |  |
| SErr0*                                                |  |  |  |
| Req0*                                                 |  |  |  |
| Int0*                                                 |  |  |  |
| Lock0*                                                |  |  |  |
| PAD0[31:0]                                            |  |  |  |
| CBE0[3:0]*                                            |  |  |  |
| Tie directly to 3V or 5V power plane (same as VREF0). |  |  |  |
| Tie directly to PClk0.                                |  |  |  |
| Ack64*                                                |  |  |  |
| Pulled up to VCC through a resistor.                  |  |  |  |
| Par64                                                 |  |  |  |
| Pulled up to VCC through a resistor.                  |  |  |  |
|                                                       |  |  |  |

# Table 435: PCI\_0 as 64-bit PCI Only

| Pin                    | Pin Usage                              |
|------------------------|----------------------------------------|
| Frame1*/Req64*         | Req64*                                 |
| IRdy1*                 | Pulled up to VCC through a resistor.   |
| TRdy1*                 | Pulled up to VCC through a resistor.   |
| Gnt1*                  | Pulled up to VCC through a resistor.   |
| ldSel1                 | Pulled down to GND through a resistor. |
| SErr1*                 | Pulled up to VCC through a resistor.   |
| Req1*                  | No Connect.                            |
| PAD1[31:0]/PAD0[63:32] | PAD0[63:32]                            |
| CBE1[3:0]*/CBE0[7:4]*  | CBE0[7:4]*                             |

# Table 435: PCI\_0 as 64-bit PCI Only (Continued)



# 28. PHASED LOCKED LOOP (PLL) APPLICATION NOTES

NOTE: Future revisions of this datasheet will contain new information and guidelines about using PLL.

The GT-96100A contains a Phase Locked Loop (PLL) logic. It is used to improve AC timing of the GT-96100A TClk output signals.

The following sections describe the special care the PLL requires from the system designer.

# 28.1 PLL Power Supply

The GT-96100A's internal PLL has a separate power supply. There are two dedicated pins for this purpose - VccPLL and VssPLL. See Section 33. "Pinout Table, 492 Pin BGA" on page 533 for exact pin numbers.

These analog power supplies must be isolated from the digital power supply pads and be noise filtered.

The internal PLL has two parallel capacitors values and two serial resistors used for VccPLL and VssPLL, see Figure 79. The values for the capacitors are  $0\Omega$  and  $4.7\Omega$ , respectively. The two resistors have a value of 1nf and 100nf, respectively.

#### Figure 78: Filtering Circuit



**NOTE:** At this stage, the above recommendations are based on simulations. Galileo uses the above values for testing the GT-96100A. However, some changes to the above values might be required due to difference in package and the physical design of the devices.







**NOTE:** The capacitors and the resistor must be located as close as possible to the GT-96100A and only have a minimum distance between them. Also, the capacitors must be assembled so that the 1nf capacitor is closest to the GT-96100A.

# 28.2 PLL Characteristics

PLL maximum pull-in time PLUS locking time is 0.5 ms. This means that the reset pin must be kept asserted for at least 0.5ms after TClk is on.



# **29.** SYSTEM CONFIGURATIONS

# 29.1 Minimal System Configuration

- Low Cost RV4650 CPU
- 32-bit SDRAM
- 8-bit Boot EPROM
- 32-bit PCI

### Figure 80: Minimal System Configuration





# 29.2 Typical System Configuration

- Support for RV4700/5260 CPU.
- Support for 16-bit Devices.
- Support for 64-bit SDRAM.
- Two 32-bit PCI buses (3.3 and 5V support).

### Figure 81: Typical System Configuration





# 29.3 High Performance System

- Support for RV5000/5270 CPU.
- Support for 2nd Level Cache.
- Support for 64-bit Devices.
- Support for 64-bit PCI.
- Multiple Banks of SDRAM.
- Buffer used for Large AD loading.

### Figure 82: High Performance System





# **30. REGISTER TABLES**

The GT-96100A's internal registers are accessed by the CPU or from the PCI bus.

The registers are memory-mapped for the CPU and memory- or I/O-mapped for the PCI.

The registers' address is comprised of the value in the Internal Space Decode register and the register Offset. The value in the Internal Space Decode register [14:0] is matched against bits [35:21] of the actual address; therefore, this value must be the actual address bits [35:21] shifted right once.

For example, to access "Channel 0 DMA Byte Count" register (offset 0x800) immediately after Reset:

- The full address is the default value in the Internal Space Decode register;
- this value is 0x0a0 shifted left once, which gives 0x140, two zero's and the offset 0x800, to become a 32-bit address of 0x14000800.

The location of the registers in the memory space can be changed by changing the value programmed into the Internal Space Decode register. For example, after changing the value in the Internal Space Decode register by writing to 0x14000068 a value of 0bd, an access to the "Channel 0 DMA Byte Count" register is with 0x17a00800.

When writing to the internal registers from the PCI with Byte Enable = 0xF, the write is ignored (as per PCI specifications).

If a write occurs to the following registers with at least one CBE\* pin asserted, the entire 32-bit word is written:

- CPU Interface
- Processor Address Space Decoders
- Device Address Space Decoders
- All SDRAM and Device registers
- All DMA registers
- All Communication unit registers
- Timer/Counter

The following internal registers are CBE\* sensitive:

- PCI Internal registers
- PCI Configuration registers
- Interrupt Registers

# 30.1 Access to On-Chip PCI Configuration Space Registers

An access from the CPU to one of the GT-96100A PCI configuration registers is performed differently than accesses to all other registers. The access is performed indirectly by writing the PCI configuration register offset into the Configuration Address register and then reading, or writing, the data from/to the Configuration Data register.

For example, to read data from the Status and Command register, the register offset "0x004" is written into the Configuration Address register, offset 0xcf8 (or full address from the previous example 0xbd000cf8). Then, reading from the Configuration Data register (offset 0xcfc), returns the data of the Status and Command register.



# 30.2 Register Maps

# Table 436: CPU Registers Map

| Description                           | Offset   | Page Number |  |  |
|---------------------------------------|----------|-------------|--|--|
| CPU Configuration                     |          |             |  |  |
| CPU Interface Configuration           | 0x000000 | page 85     |  |  |
| Multi-GT Register                     | 0x000120 | page 87     |  |  |
| CPU Address Decode                    |          |             |  |  |
| SCS[1:0]* Low Decode Address          | 0x000008 | page 87     |  |  |
| SCS[1:0]* High Decode Address         | 0x000010 | page 87     |  |  |
| SCS[3:2]* Low Decode Address          | 0x000018 | page 88     |  |  |
| SCS[3:2]* High Decode Address         | 0x000020 | page 88     |  |  |
| CS[2:0]* Low Decode Address           | 0x000028 | page 88     |  |  |
| CS[2:0]* High Decode Address          | 0x000030 | page 88     |  |  |
| CS[3]* & Boot CS* Low Decode Address  | 0x000038 | page 88     |  |  |
| CS[3]* & Boot CS* High Decode Address | 0x000040 | page 89     |  |  |
| PCI_0 I/O Low Decode Address          | 0x000048 | page 89     |  |  |
| PCI_0 I/O High Decode Address         | 0x000050 | page 89     |  |  |
| PCI_0 Memory 0 Low Decode Address     | 0x000058 | page 89     |  |  |
| PCI_0 Memory 0 High Decode Address    | 0x000060 | page 89     |  |  |
| PCI_0 Memory 1 Low Decode Address     | 0x000080 | page 90     |  |  |
| PCI_0 Memory 1 High Decode Address    | 0x000088 | page 90     |  |  |
| PCI_1 I/O Low Decode Address          | 0x000090 | page 90     |  |  |
| PCI_1 I/O High Decode Address         | 0x000098 | page 90     |  |  |
| PCI_1 Memory 0 Low Decode Address     | 0x0000A0 | page 90     |  |  |
| PCI_1 Memory 0 High Decode Address    | 0x0000A8 | page 91     |  |  |
| PCI_1 Memory 1 Low Decode Address     | 0x0000B0 | page 91     |  |  |
| PCI_1 Memory 1 High Decode Address    | 0x0000B8 | page 91     |  |  |
| Internal Space Decode                 | 0x000068 | page 91     |  |  |
| SCS[1:0]* Address Remap               | 0x0000D0 | page 91     |  |  |
| SCS[3:2]* Address Remap               | 0x0000D8 | page 92     |  |  |
| CS[2:0]* Remap                        | 0x0000E0 | page 92     |  |  |
| CS[3]* & Boot CS* Remap               | 0x0000E8 | page 92     |  |  |



| Description                         | Offset   | Page Number |  |
|-------------------------------------|----------|-------------|--|
| CPU Address Decode (Continued)      |          |             |  |
| PCI_0 I/O Remap                     | 0x0000F0 | page 92     |  |
| PCI_0 Memory 0 Remap                | 0x0000F8 | page 92     |  |
| PCI_0 Memory 1 Remap                | 0x000100 | page 93     |  |
| PCI_1 I/O Remap                     | 0x000108 | page 93     |  |
| PCI_1 Memory 0 Remap                | 0x000110 | page 93     |  |
| PCI_1 Memory 1 Remap                | 0x000118 | page 93     |  |
| CPU Errors Report                   |          |             |  |
| CPU Error Address (Low)             | 0x070    | page 151    |  |
| CPU Error Address (High)            | 0x078    | page 151    |  |
| CPU Error Data (Low)                | 0x128    | page 151    |  |
| CPU Error Data (High)               | 0x130    | page 151    |  |
| CPU Error Parity                    | 0x138    | page 151    |  |
| CPU Sync Barrier                    |          |             |  |
| PCI_0 Sync Barrier Virtual Register | 0x0000C0 | page 94     |  |
| PCI_1 Sync Barrier Virtual Register | 0x0000C8 | page 94     |  |

# Table 436: CPU Registers Map (Continued)

# Table 437: SDRAM Registers Map

| Description                     | Offset   | Page Number |
|---------------------------------|----------|-------------|
| SDRAM and Device Address Decode |          |             |
| SCS[0]* Low Decode Address      | 0x000400 | page 130    |
| SCS[0]* High Decode Address     | 0x000404 | page 130    |
| SCS[1]* Low Decode Address      | 0x000408 | page 130    |
| SCS[1]* High Decode Address     | 0x00040C | page 130    |
| SCS[2]* Low Decode Address      | 0x000410 | page 131    |
| SCS[2]* High Decode Address     | 0x000414 | page 131    |
| SCS[3]* Low Decode Address      | 0x000418 | page 131    |
| SCS[3]* High Decode Address     | 0x00041C | page 131    |
| CS[0]* Low Decode Address       | 0x000420 | page 131    |
| CS[0]* High Decode Address      | 0x000424 | page 132    |



| Table 437: | SDRAM | Registers | Map | (Continued) |
|------------|-------|-----------|-----|-------------|
|            |       | registers | map | (Continued) |

| Description                                 | Offset   | Page Number |  |
|---------------------------------------------|----------|-------------|--|
| SDRAM and Device Address Decode (Continued) |          |             |  |
| CS[1]* Low Decode Address                   | 0x000428 | page 132    |  |
| CS[1]* High Decode Address                  | 0x00042C | page 132    |  |
| CS[2]* Low Decode Address                   | 0x000430 | page 132    |  |
| CS[2]* High Decode Address                  | 0x000434 | page 132    |  |
| CS[3]* Low Decode Address                   | 0x000438 | page 133    |  |
| CS[3]* High Decode Address                  | 0x00043C | page 133    |  |
| Boot CS* Low Decode Address                 | 0x000440 | page 133    |  |
| Boot CS* High Decode Address                | 0x000444 | page 133    |  |
| Address Decode Error                        | 0x000470 | page 133    |  |
| SDRAM Configuration                         |          |             |  |
| SDRAM Configuration                         | 0x000448 | page 134    |  |
| SDRAM Operation Mode                        | 0x000474 | page 135    |  |
| SDRAM Burst Mode                            | 0x000478 | page 135    |  |
| SDRAM Address Decode                        | 0x00047C | page 136    |  |
| SDRAM Parameters                            |          |             |  |
| SDRAM Bank0 Parameters                      | 0x00044C | page 137    |  |
| SDRAM Bank1 Parameters                      | 0x000450 | page 138    |  |
| SDRAM Bank2 Parameters                      | 0x000454 | page 138    |  |
| SDRAM Bank3 Parameters                      | 0x000458 | page 139    |  |
| ECC                                         |          |             |  |
| ECC Upper Data                              | 0x000480 | page 139    |  |
| ECC Lower Data                              | 0x000484 | page 139    |  |
| ECC from Memory                             | 0x000488 | page 139    |  |
| ECC Calculated                              | 0x00048C | page 139    |  |
| ECC Error report                            | 0x000490 | page 140    |  |

# Table 437: SDRAM Registers Map (Continued)

| Description                 | Offset   | Page Number |  |
|-----------------------------|----------|-------------|--|
| Device Parameters           |          |             |  |
| Device Bank0 Parameters     | 0x00045C | page 140    |  |
| Device Bank1 Parameters     | 0x000460 | page 141    |  |
| Device Bank2 Parameters     | 0x000464 | page 141    |  |
| Device Bank3 Parameters     | 0x000468 | page 141    |  |
| Device Boot Bank Parameters | 0x00046C | page 142    |  |

# Table 438: DMA Registers Map

| Description                          | Offset   | Page Number |  |
|--------------------------------------|----------|-------------|--|
| DMA Record                           |          |             |  |
| Channel 0 DMA Byte Count             | 0x000800 | page 232    |  |
| Channel 1 DMA Byte Count             | 0x000804 | page 232    |  |
| Channel 2 DMA Byte Count             | 0x000808 | page 232    |  |
| Channel 3 DMA Byte Count             | 0x00080C | page 233    |  |
| Channel 0 DMA Source Address         | 0x000810 | page 233    |  |
| Channel 1 DMA Source Address         | 0x000814 | page 233    |  |
| Channel 2 DMA Source Address         | 0x000818 | page 233    |  |
| Channel 3 DMA Source Address         | 0x00081C | page 233    |  |
| Channel 0 DMA Destination Address    | 0x000820 | page 233    |  |
| Channel 1 DMA Destination Address    | 0x000824 | page 234    |  |
| Channel 2 DMA Destination Address    | 0x000828 | page 234    |  |
| Channel 3 DMA Destination Address    | 0x00082C | page 234    |  |
| Channel 0 Next Record Pointer        | 0x000830 | page 234    |  |
| Channel 1 Next Record Pointer        | 0x000834 | page 234    |  |
| Channel 2 Next Record Pointer        | 0x000838 | page 235    |  |
| Channel 3 Next Record Pointer        | 0x00083C | page 235    |  |
| Channel 0 Current Descriptor Pointer | 0x000870 | page 235    |  |
| Channel 1 Current Descriptor Pointer | 0x000874 | page 235    |  |
| Channel 2 Current Descriptor Pointer | 0x000878 | page 235    |  |
| Channel 3 Current Descriptor Pointer | 0x00087C | page 236    |  |



## Table 438: DMA Registers Map (Continued)

| Description            | Offset                 | Page Number |  |  |
|------------------------|------------------------|-------------|--|--|
| DMA Record (Continued) | DMA Record (Continued) |             |  |  |
| Channel 0 Control      | 0x000840               | page 236    |  |  |
| Channel 1 Control      | 0x000844               | page 239    |  |  |
| Channel 2 Control      | 0x000848               | page 239    |  |  |
| Channel 3 Control      | 0x00084C               | page 239    |  |  |
| DMA Arbiter            |                        |             |  |  |
| Arbiter Control        | 0x000860               | page 240    |  |  |

### Table 439: Timer/Counter Registers Map

| Description            | Offset   | Page Number |
|------------------------|----------|-------------|
| Timer /Counter 0       | 0x000850 | page 403    |
| Timer /Counter 1       | 0x000854 | page 403    |
| Timer /Counter 2       | 0x000858 | page 403    |
| Timer /Counter 3       | 0x00085C | page 404    |
| Timer /Counter Control | 0x000864 | page 404    |

#### Table 440: PCI Registers Map

| Description               | Offset       | Page Number |  |  |
|---------------------------|--------------|-------------|--|--|
| PCI Internal              | PCI Internal |             |  |  |
| PCI_0 Command             | 0x000C00     | page 172    |  |  |
| PCI_1 Command             | 0x000C80     | page 174    |  |  |
| PCI_0 Time Out & Retry    | 0x000C04     | page 174    |  |  |
| PCI_1 Time Out & Retry    | 0x000C84     | page 174    |  |  |
| PCI_0 SCS[1:0]* Bank Size | 0x000C08     | page 175    |  |  |
| PCI_1 SCS[1:0]* Bank Size | 0x000C88     | page 175    |  |  |
| PCI_0 SCS[3:2]* Bank Size | 0x000C0C     | page 175    |  |  |
| PCI_1 SCS[3:2]* Bank Size | 0x000C8C     | page 176    |  |  |
| PCI_0 CS[2:0]* Bank Size  | 0x000C10     | page 176    |  |  |
| PCI_1 CS[2:0]* Bank Size  | 0x000C90     | page 176    |  |  |



## Table 440: PCI Registers Map (Continued)

| Description                                       | Offset   | Page Number |  |
|---------------------------------------------------|----------|-------------|--|
| PCI Internal (Continued)                          |          |             |  |
| PCI_0 CS[3]* & Boot CS* Bank Size                 | 0x000C14 | page 177    |  |
| PCI_1 CS[3]* & Boot CS* Bank Size                 | 0x000C94 | page 177    |  |
| PCI_0 Base Address Registers' Enable              | 0x000C3C | page 178    |  |
| PCI_1 Base Address Registers' Enable              | 0x000CBC | page 179    |  |
| PCI_0 Prefetch/Max Burst Size                     | 0x000C40 | page 179    |  |
| PCI_1 Prefetch/Max Burst Size                     | 0x000CC0 | page 179    |  |
| PCI_0 SCS[1:0]* Base Address Remap                | 0x000C48 | page 180    |  |
| PCI_1 SCS[1:0]* Base Address Remap                | 0x000CC8 | page 180    |  |
| PCI_0 SCS[3:2]* Base Address Remap                | 0x000C4C | page 181    |  |
| PCI_1 SCS[3:2]* Base Address Remap                | 0x000CCC | page 179    |  |
| PCI_0 CS[2:0]* Base Address Remap                 | 0x000C50 | page 182    |  |
| PCI_1 CS[2:0]* Base Address Remap                 | 0x000CD0 | page 182    |  |
| PCI_0 CS[3]* & Boot CS* Address Remap             | 0x000C54 | page 182    |  |
| PCI_1 CS[3]* & Boot CS* Address Remap             | 0x000CD4 | page 182    |  |
| PCI_0 Swapped SCS[1:0]* Base Address Remap        | 0x000C58 | page 180    |  |
| PCI_1 Swapped SCS[1:0]* Base Address Remap        | 0x000CD8 | page 180    |  |
| PCI_0 Swapped SCS[3:2]* Base Address Remap        | 0x000C5C | page 181    |  |
| PCI_1 Swapped SCS[3:2]* Base Address Remap        | 0x000CDC | page 181    |  |
| PCI_0 Swapped CS[3]* & BootCS* Base Address Remap | 0x000C64 | page 183    |  |
| PCI_1 Swapped CS[3]* & BootCS* Base Address Remap | 0x000CE4 | page 183    |  |
| PCI_0 Configuration Address                       | 0x000CF8 | page 183    |  |
| PCI_1 Configuration Address                       | 0x000CF0 | page 184    |  |
| PCI_0 Configuration Data Virtual Register         | 0x000CFC | page 184    |  |
| PCI_1 Configuration Data Virtual Register         | 0x000CF4 | page 184    |  |
| PCI_0 Interrupt Acknowledge Virtual Register      | 0x000C34 | page 184    |  |
| PCI_1 Interrupt Acknowledge Virtual Register      | 0x000C30 | page 184    |  |



| Description                                         | Offset   | Page Number |  |
|-----------------------------------------------------|----------|-------------|--|
| PCI Configuration                                   |          |             |  |
| PCI_0 Device and Vendor ID                          | 0x000000 | page 185    |  |
| PCI_1 Device and Vendor ID                          | 0x000080 | page 185    |  |
| PCI_0 Status and Command                            | 0x000004 | page 186    |  |
| PCI_1 Status and Command                            | 0x000084 | page 187    |  |
| PCI_0 Class Code and Revision ID                    | 0x00008  | page 188    |  |
| PCI_1 Class Code and Revision ID                    | 0x000088 | page 188    |  |
| PCI_0 BIST, Header Type, Latency Timer, Cache Line  | 0x0000C  | page 188    |  |
| PCI_1 BIST, Header Type, Latency Timer, Cache Line  | 0x00008C | page 189    |  |
| PCI_0 SCS[1:0]* Base Address                        | 0x000010 | page 190    |  |
| PCI_1 SCS[1:0]* Base Address                        | 0x000090 | page 190    |  |
| PCI_0 SCS[3:2]* Base Address                        | 0x000014 | page 191    |  |
| PCI_1 SCS[3:2]* Base Address                        | 0x000094 | page 191    |  |
| PCI_0 CS[2:0]* Base Address                         | 0x000018 | page 191    |  |
| PCI_1 CS[2:0]* Base Address                         | 0x000098 | page 192    |  |
| PCI_0 CS[3]* & Boot CS* Base Address                | 0x00001C | page 192    |  |
| PCI_1 CS[3]* & Boot CS* Base Address                | 0x00009C | page 192    |  |
| PCI_0 Internal Registers Memory Mapped Base Address | 0x000020 | page 193    |  |
| PCI_1 Internal Registers Memory Mapped Base Address | 0x0000A0 | page 193    |  |
| PCI_0 Internal Registers I/O Mapped Base Address    | 0x000024 | page 193    |  |
| PCI_1 Internal Registers I/O Mapped Base Address    | 0x0000A4 | page 193    |  |
| PCI_0 Subsystem ID and Subsystem Vendor ID          | 0x00002C | page 194    |  |
| PCI_1 Subsystem ID and Subsystem Vendor ID          | 0x0000AC | page 194    |  |
| Expansion ROM Base Address Register                 | 0x000030 | page 194    |  |
| PCI_0 Interrupt Pin and Line                        | 0x00003C | page 195    |  |
| PCI_1 Interrupt Pin and Line                        | 0x0000BC | page 195    |  |



## Table 440: PCI Registers Map (Continued)

| Description                                  | Offset   | Page Number |  |
|----------------------------------------------|----------|-------------|--|
| PCI Configuration, Function 1                |          |             |  |
| PCI_0 Swapped SCS[1:0]* Base Address         | 0x000110 | page 198    |  |
| PCI_1 Swapped SCS[1:0]* Base Address         | 0x000190 | page 198    |  |
| PCI_0 Swapped SCS[3:2]* Base Address         | 0x000114 | page 198    |  |
| PCI_1 Swapped SCS[3:2]* Base Address         | 0x000194 | page 199    |  |
| PCI_0 Swapped CS[3]* & Boot CS* Base Address | 0x00011C | page 199    |  |
| PCI_1 Swapped CS[3]* & Boot CS* Base Address | 0x00019C | page 200    |  |

### Table 441: Interrupts Registers Map

| Description                    | Offset   | Page Number |
|--------------------------------|----------|-------------|
| Interrupt Main Cause register  | 0x000C18 | page 428    |
| Interrupt0* Main Mask register | 0x000C1C | page 432    |
| Interrupt1* Main Mask register | 0x000C24 | page 434    |
| Interrupt High Cause register  | 0x000C98 | page 430    |
| Interrupt0* High Mask register | 0x000C9C | page 433    |
| Interrupt1* High Mask register | 0x000CA4 | page 435    |
| Interrupt0* Select register    | 0x000C70 | page 431    |
| Interrupt1* Select register    | 0x000C74 | page 432    |
| Serial Cause register          | 0x103A00 | page 436    |
| SerInt0* Mask register         | 0x103A80 | page 438    |
| SerInt1* Mask register         | 0x103A88 | page 439    |
| Ethernet0 Cause register       | 0x084850 | page 440    |
| Ethernet0 Mask register        | 0x084858 | page 440    |
| Ethernet1 Cause register       | 0x088850 | page 441    |
| Ethernet1 Mask register        | 0x088858 | page 441    |
| SDMA Cause register            | 0x103A10 | page 441    |
| SDMA Mask register             | 0x103A90 | page 441    |
| MPSC0 Cause register           | 0x103A20 | page 444    |
| MPSC0 Mask register            | 0x103AA0 | page 444    |
| MPSC1 Cause register           | 0x103A24 | page 445    |



| Table 441: | Interrupts | Registers | Map ( | (Continued) |
|------------|------------|-----------|-------|-------------|
|            | memupto    | registers | map ( | oominaca)   |

| Description            | Offset   | Page Number |
|------------------------|----------|-------------|
| MPSC1 Mask register    | 0x103AA4 | page 445    |
| MPSC2 Cause register   | 0x103A28 | page 445    |
| MPSC2 Mask register    | 0x103AA8 | page 445    |
| MPSC3 Cause register   | 0x103A2C | page 446    |
| MPSC3 Mask register    | 0x103AAC | page 446    |
| MPSC4 Cause register   | 0x103A30 | page 446    |
| MPSC4 Mask register    | 0x103AB0 | page 446    |
| MPSC5 Cause register   | 0x103A34 | page 446    |
| MPSC5 Mask register    | 0x103AB4 | page 446    |
| MPSC6 Cause register   | 0x103A38 | page 446    |
| MPSC6 Mask register    | 0x103AB8 | page 446    |
| MPSC7 Cause register   | 0x103A3C | page 446    |
| MPSC7 Mask register    | 0x103ABC | page 446    |
| FlexTDM Cause register | 0x103A40 | page 447    |
| FlexTDM Mask register  | 0x103AC0 | page 447    |
| BRG Cause register     | 0x103A48 | page 448    |
| BRG Mask register      | 0x103AC8 | page 448    |
| GPP0 Cause register    | 0x103A50 | page 448    |
| GPP0 Mask register     | 0x103AD0 | page 448    |
| GPP1 Cause register    | 0x103A54 | page 449    |
| GPP1 Mask register     | 0x103AD4 | page 449    |
| GPP2 Cause register    | 0x103A58 | page 449    |
| GPP2 Mask register     | 0x103AD8 | page 449    |
| PCI_0 SErr0 Mask       | 0x000C28 | page 449    |
| PCI_1 SErr1 Mask       | 0x000CA8 | page 451    |



| Table | 442: | I2O | Suppo   | ort Rea | isters | Мар |
|-------|------|-----|---------|---------|--------|-----|
|       |      | -2- | - app - |         |        |     |

| Description                          | Offset  | Page Number |
|--------------------------------------|---------|-------------|
| Inbound Message Register 0           | 0x00010 | page 211    |
| Inbound Message Register 1           | 0x00014 | page 211    |
| Outbound Message Register 0          | 0x00018 | page 211    |
| Outbound Message Register 1          | 0x0001C | page 211    |
| Inbound Doorbell Register            | 0x00020 | page 212    |
| Inbound Interrupt Cause Register     | 0x00024 | page 212    |
| Inbound Interrupt Mask Register      | 0x00028 | page 213    |
| Outbound Doorbell Register           | 0x0002C | page 213    |
| Outbound Interrupt Cause Register    | 0x00030 | page 214    |
| Outbound Interrupt Mask Register     | 0x00034 | page 214    |
| Inbound Queue Port Virtual Register  | 0x00040 | page 215    |
| Outbound Queue Port Virtual Register | 0x00044 | page 215    |
| Queue Control Register               | 0x00050 | page 215    |
| Queue Base Address Register          | 0x00054 | page 216    |
| Inbound Free Head Pointer Register   | 0x00060 | page 216    |
| Inbound Free Tail Pointer Register   | 0x00064 | page 216    |
| Inbound Post Head Pointer Register   | 0x00068 | page 216    |
| Inbound Post Tail Pointer Register   | 0x0006C | page 217    |
| Outbound Free Head Pointer Register  | 0x00070 | page 217    |
| Outbound Free Tail Pointer Register  | 0x00074 | page 217    |
| Outbound Post Head Pointer Register  | 0x00078 | page 218    |
| Outbound Post Tail Pointer Register  | 0x0007C | page 218    |

**NOTE:** I<sub>2</sub>O registers can be accessed from the CPU and PCI\_0 sides (unless stated otherwise). If accessed from the PCI\_0 side, address offset is with respect to the PCI\_0 SCS[1:0]\* Base Address register contents. If accessed from CPU side, the address offset is with respect to the CPU Internal Space Base Register + 0x1c00.



\_\_\_\_\_

| Table 443: Communication | Unit Register Map |
|--------------------------|-------------------|
|--------------------------|-------------------|

| Description                                                                   | Offset   | Page<br>Number |
|-------------------------------------------------------------------------------|----------|----------------|
| Ethernet Ports                                                                | •        | ·              |
| Ethernet PHY Address Register (EPAR)                                          | 0X080800 | page 285       |
| Ethernet SMI Register (ESMIR)                                                 | 0X080810 | page 286       |
| Ethernet0 Ports                                                               | ·        |                |
| Ethernet0 Port Configuration Register (E0PCR)                                 | 0X084800 | page 286       |
| Ethernet0 Port Configuration Extend Register (E0PCXR)                         | 0X084808 | page 288       |
| Ethernet0 Port Command Register (E0PCMR)                                      | 0X084810 | page 291       |
| Ethernet0 Port Status Register (E0PSR)                                        | 0X084818 | page 291       |
| Ethernet0 Serial Parameters Register (E0SPR)                                  | 0X084820 | page 292       |
| Ethernet0 Hash Table Pointer Register (E0HTPR)                                | 0X084828 | page 293       |
| Ethernet0 Flow Control Source Address Low (E0FCSAL)                           | 0X084830 | page 293       |
| Ethernet0 Flow Control Source Address High (E0FCSAH)                          | 0X084838 | page 294       |
| Ethernet0 SDMA Configuration Register (E0SDCR)                                | 0X084840 | page 294       |
| Ethernet0 SDMA Command Register (E0SDCMR)                                     | 0X084848 | page 295       |
| Ethernet0 Interrupt Cause Register (E0ICR)                                    | 0X084850 | page 296       |
| Ethernet0 Interrupt Mask Register (E0IMR)                                     | 0X084858 | page 299       |
| Ethernet0 IP Differentiated Services CodePoint to Priority0 low (E0DSCP2P0L)  | 0x84860  | page 299       |
| Ethernet0 IP Differentiated Services CodePoint to Priority0 high (E0DSCP2P0H) | 0x84864  | page 299       |
| Ethernet0 IP Differentiated Services CodePoint to Priority1 low (E0DSCP2P1L)  | 0x84868  | page 299       |
| Ethernet0 IP Differentiated Services CodePoint to Priority1 high (E0DSCP2P1H) | 0x8486c  | page 299       |
| Ethernet0 VLAN Priority Tag to Priority (E0VPT2P)                             | 0x88870  | page 299       |
| Ethernet0 First Rx Descriptor Pointer 0 (E0FRDP0)                             | 0X084880 | page 263       |
| Ethernet0 First Rx Descriptor Pointer 1 (E0FRDP1)                             | 0X084884 |                |
| Ethernet0 First Rx Descriptor Pointer 2 (E0FRDP2)                             | 0X084888 |                |
| Ethernet0 First Rx Descriptor Pointer 3 (E0FRDP3)                             | 0X08488C |                |
| Ethernet0 Current Rx Descriptor Pointer 0 (E0CRDP0)                           | 0X0848A0 |                |
| Ethernet0 Current Rx Descriptor Pointer 1 (E0CRDP1)                           | 0X0848A4 |                |
| Ethernet0 Current Rx Descriptor Pointer 2 (E0CRDP2)                           | 0X0848A8 |                |
| Ethernet0 Current Rx Descriptor Pointer 3 (E0CRDP3)                           | 0X0848AC |                |

| Description                                                                  | Offset        | Page<br>Number |
|------------------------------------------------------------------------------|---------------|----------------|
| Ethernet0 Ports (Continued)                                                  |               | -              |
| Ethernet0 Current Tx Descriptor Pointer 0 (E0CTDP0)                          | 0X0848E0      | page 255       |
| Ethernet0 Current Tx Descriptor Pointer 1 (E0CTDP1)                          | 0X0848E4      |                |
| Ethernet0 MIB Counters                                                       | 0X085800      | page 302       |
|                                                                              | -<br>0X0858FF |                |
| Ethernet1 Ports                                                              | 1             |                |
| Ethernet1 Port Configuration Register (E1PCR)                                | 0X088800      | page 286       |
| Ethernet1 Port Configuration Extend Register (E1PCXR)                        | 0X088808      | page 288       |
| Ethernet1 Port Command Register (E1PCMR)                                     | 0X088810      | page 291       |
| Ethernet1 Port Status Register (E1PSR)                                       | 0X088818      | page 291       |
| Ethernet1 Serial Parameters Register (E1SPR)                                 | 0X088820      | page 292       |
| Ethernet1 Hash Table Pointer Register (E1HTPR)                               | 0X088828      | page 293       |
| Ethernet1 Flow Control Source Address Low (E1FCSAL)                          | 0X088830      | page 293       |
| Ethernet1 Flow Control Source Address High (E1FCSAH)                         | 0X088838      | page 294       |
| Ethernet1 SDMA Configuration Register (E1SDCR)                               | 0X088840      | page 294       |
| Ethernet1 SDMA Command Register (E1SDCMR)                                    | 0X088848      | page 295       |
| Ethernet1 Interrupt Cause Register (E0ICR)                                   | 0X088850      | page 296       |
| Ethernet1 Interrupt Mask Register (E0IMR)                                    | 0X088858      | page 299       |
| Ethernet IP Differentiated Services CodePoint to Priority0 low (E0DSCP2P0L)  | 0x84860       | page 299       |
| Ethernet IP Differentiated Services CodePoint to Priority0 high (E0DSCP2P0H) | 0x84864       | page 299       |
| Ethernet IP Differentiated Services CodePoint to Priority1 low (E0DSCP2P1L)  | 0x84868       | page 299       |
| Ethernet IP Differentiated Services CodePoint to Priority1 high (E0DSCP2P1H) | 0x8486c       | page 299       |
| Ethernet VLAN Priority Tag to Priority (E0VPT2P)                             | 0x84870       | page 299       |
| Ethernet1 First Rx Descriptor Pointer 0 (E1FRDP0)                            | 0X088880      | page 263       |
| Ethernet1 First Rx Descriptor Pointer 1 (E1FRDP1)                            | 0X088884      |                |
| Ethernet1 First Rx Descriptor Pointer 2 (E1FRDP2)                            | 0X088888      |                |
| Ethernet1 First Rx Descriptor Pointer 3 (E1FRDP3)                            | 0X088888C     |                |



| Description                                         | Offset                                      | Page<br>Number                                              |
|-----------------------------------------------------|---------------------------------------------|-------------------------------------------------------------|
| Ethernet1 Current Rx Descriptor Pointer 0 (E1CRDP0) | 0X0888A0                                    | page 263                                                    |
| Ethernet1 Current Rx Descriptor Pointer 1 (E1CRDP1) | 0X0888A4                                    |                                                             |
| Ethernet1 Current Rx Descriptor Pointer 2 (E1CRDP2) | 0X0888A8                                    |                                                             |
| Ethernet1 Current Rx Descriptor Pointer 3 (E1CRDP3) | 0X0888AC                                    |                                                             |
| Ethernet1 Current Tx Descriptor Pointer 0 (E1CTDP0) | 0X0888E0                                    | page 255                                                    |
| Ethernet1 Current Tx Descriptor Pointer 1 (E1CTDP1) | 0X0888E4                                    |                                                             |
| Ethernet1 MIB Counters                              | 0X089800                                    | page 302                                                    |
|                                                     | -<br>0X0898FF                               |                                                             |
| SDMAs                                               |                                             |                                                             |
| SDMA Group Configuration Register                   | 0X101AF0                                    | page 312                                                    |
| SDMA Group 0, Channel0                              |                                             |                                                             |
| Channel0 Configuration Register (S0DC0)             | 0X000 <b>9</b> 00                           | page 312                                                    |
| Channel0 Command Register (S0DCM0)                  | 0X000 <b>9</b> 08                           | page 314                                                    |
| Channel0 Rx Descriptor                              | 0X008 <b>9</b> 00<br>-<br>0X008 <b>9</b> 0F | Not to be<br>accessed<br>during nor-<br>mal opera-<br>tion. |
| Channel0 Current Rx Descriptor Pointer (S0CRDP0)    | 0X008 <b>9</b> 10                           | page 316                                                    |
| Channel0 Tx Descriptor                              | 0X00C <b>9</b> 00<br>-<br>0X00C <b>9</b> 0F | Not to be<br>accessed<br>during nor-<br>mal opera-<br>tion. |
| Channel0 Current Tx Descriptor Pointer (S0CTDP0)    | 0X00C <b>9</b> 10                           | page 316                                                    |
| Channel0 First Tx Descriptor Pointer (S0FTDP0)      | 0X00C <b>9</b> 14                           | page 316                                                    |



| Description                                      | Offset                                      | Page<br>Number                                                                               |
|--------------------------------------------------|---------------------------------------------|----------------------------------------------------------------------------------------------|
| SDMA Group 0, Channel1                           | 011301                                      | Rumber                                                                                       |
| Channel1 Configuration Register (S0DC1)          | 0X010 <b>9</b> 00                           | For a<br>description<br>of the<br>Channel1<br>registers,<br>see the                          |
| Channel1 Command Register (S0DCM1)               | 0X010 <b>9</b> 08                           |                                                                                              |
| Channel1 Rx Descriptor                           | 0X018 <b>9</b> 00<br>-<br>0X018 <b>9</b> 0F |                                                                                              |
| Channel1 Current Rx Descriptor Pointer (S0CRDP1) | 0X018 <b>9</b> 10                           | descrip-<br>tions for                                                                        |
| Channel1 Tx Descriptor                           | 0X01C <b>9</b> 00                           | the<br>Channel0                                                                              |
|                                                  | -<br>0X01C <b>9</b> 0F                      | registers.                                                                                   |
| Channel1 Current Tx Descriptor Pointer (S0CTDP1) | 0X01C <b>9</b> 10                           |                                                                                              |
| Channel1 First Tx Descriptor Pointer (S0FTDP1)   | 0X01C <b>9</b> 14                           |                                                                                              |
| SDMA Group 0, Channel2                           |                                             |                                                                                              |
| Channel2 Configuration Register (S0DC2)          | 0X020 <b>9</b> 00                           | For a<br>description<br>of the<br>Channel2<br>registers,<br>see the<br>descrip-<br>tions for |
| Channel2 Command Register (S0DCM2)               | 0X020 <b>9</b> 08                           |                                                                                              |
| Channel2 Rx Descriptor                           | 0X028 <b>9</b> 00                           |                                                                                              |
|                                                  | -<br>0X028 <b>9</b> 0F                      |                                                                                              |
| Channel2 Current Rx Descriptor Pointer (S0CRDP2) | 0X028 <b>9</b> 10                           |                                                                                              |
| Channel2 Tx Descriptor                           | 0X02C <b>9</b> 00                           | the<br>Channel0                                                                              |
|                                                  | -<br>0X02C <b>9</b> 0F                      | registers.                                                                                   |
| Channel2 Current Tx Descriptor Pointer (S0CTDP2) | 0X02C <b>9</b> 10                           |                                                                                              |
| Channel2 First Tx Descriptor Pointer (S0FTDP2)   | 0X02C <b>9</b> 14                           |                                                                                              |



| Description                                      | Offset                                      | Page<br>Number                                                                                                                |
|--------------------------------------------------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| SDMA Group 0, Channel3                           |                                             | ·                                                                                                                             |
| Channel3 Configuration Register (S0DC3)          | 0X030 <b>9</b> 00                           | For a<br>description<br>of the<br>Channel3<br>registers,<br>see the                                                           |
| Channel3 Command Register (S0DCM3)               | 0X030 <b>9</b> 08                           |                                                                                                                               |
| Channel3 Rx Descriptor                           | 0X038 <b>9</b> 00<br>-<br>0X038 <b>9</b> 0F |                                                                                                                               |
| Channel3 Current Rx Descriptor Pointer (S0CRDP3) | 0X038 <b>9</b> 10                           | descrip-<br>tions for                                                                                                         |
| Channel3 Tx Descriptor                           | 0X03C <b>9</b> 00                           | the<br>Channel0<br>registers.                                                                                                 |
|                                                  | 0X03C <b>9</b> 0F                           |                                                                                                                               |
| Channel3 Current Tx Descriptor Pointer (S0CTDP3) | 0X03C <b>9</b> 10                           |                                                                                                                               |
| Channel3 First Tx Descriptor Pointer (S0FTDP3)   | 0X03C <b>9</b> 14                           |                                                                                                                               |
| SDMA Group 0, Channel4                           |                                             |                                                                                                                               |
| Channel4 Configuration Register (S0DC4)          | 0X040 <b>9</b> 00                           | For a<br>description<br>of the<br>Channel4<br>registers,<br>see the<br>descrip-<br>tions for<br>the<br>Channel0<br>registers. |
| Channel4 Command Register (S0DCM4)               | 0X040 <b>9</b> 08                           |                                                                                                                               |
| Channel4 Rx Descriptor                           | 0X048 <b>9</b> 00<br>-<br>0X048 <b>9</b> 0F |                                                                                                                               |
| Channel4 Current Rx Descriptor Pointer (S0CRDP4) | 0X048 <b>9</b> 10                           |                                                                                                                               |
| Channel4 Tx Descriptor                           | 0X04C <b>9</b> 00                           |                                                                                                                               |
|                                                  | -<br>0X04C <b>9</b> 0F                      |                                                                                                                               |
| Channel4 Current Tx Descriptor Pointer (S0CTDP4) | 0X04C <b>9</b> 10                           | For a<br>description<br>of the<br>Channel4<br>registers,<br>see the<br>descrip-<br>tions for<br>the<br>Channel0<br>registers. |
| Channel4 First Tx Descriptor Pointer (S0FTDP4)   | 0X04C <b>9</b> 14                           |                                                                                                                               |



| Description                                      | Offset                 | Page<br>Number                                                                                                  |
|--------------------------------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------|
|                                                  | Offset                 | Number                                                                                                          |
| SDMA Group 0, Channel5                           |                        |                                                                                                                 |
| Channel5 Configuration Register (S0DC5)          | 0X050 <b>9</b> 00      | For a<br>description<br>of the<br>Channel5<br>registers,                                                        |
| Channel5 Command Register (S0DCM5)               | 0X050 <b>9</b> 08      |                                                                                                                 |
| Channel5 Rx Descriptor                           | 0X058 <b>9</b> 00<br>- |                                                                                                                 |
|                                                  | 0X058 <b>9</b> 0F      | see the descrip-                                                                                                |
| Channel5 Current Rx Descriptor Pointer (S0CRDP5) | 0X058 <b>9</b> 10      | tions for                                                                                                       |
| Channel5 Tx Descriptor                           | 0X05C <b>9</b> 00      | the<br>Channel0<br>registers.                                                                                   |
|                                                  | 0X05C <b>9</b> 0F      |                                                                                                                 |
| Channel5 Current Tx Descriptor Pointer (S0CTDP5) | 0X05C <b>9</b> 10      |                                                                                                                 |
| Channel5 First Tx Descriptor Pointer (S0FTDP5)   | 0X05C <b>9</b> 14      |                                                                                                                 |
| SDMA Group 0, Channel6                           |                        | •                                                                                                               |
| Channel6 Configuration Register (S0DC6)          | 0X060 <b>9</b> 00      | For a<br>description<br>of the<br>Channel6<br>registers,<br>see the<br>descrip-<br>tions for<br>the<br>Channel0 |
| Channel6 Command Register (S0DCM6)               | 0X060 <b>9</b> 08      |                                                                                                                 |
| Channel6 Rx Descriptor                           | 0X068 <b>9</b> 00      |                                                                                                                 |
|                                                  | 0X068 <b>9</b> 0F      |                                                                                                                 |
| Channel6 Current Rx Descriptor Pointer (S0CRDP6) | 0X068 <b>9</b> 10      |                                                                                                                 |
| Channel6 Tx Descriptor                           | 0X06C <b>9</b> 00      |                                                                                                                 |
|                                                  | 0X06C <b>9</b> 0F      | registers.                                                                                                      |
| Channel6 Current Tx Descriptor Pointer (S0CTDP6) | 0X06C <b>9</b> 10      | ]                                                                                                               |
| Channel6 First Tx Descriptor Pointer (S0FTDP6)   | 0X06C <b>9</b> 14      |                                                                                                                 |



| Description                                      | Offset                                      | Page<br>Number                                              |
|--------------------------------------------------|---------------------------------------------|-------------------------------------------------------------|
| SDMA Group 0, Channel7                           |                                             |                                                             |
| Channel7 Configuration Register (S0DC7)          | 0X070 <b>9</b> 00                           | For a                                                       |
| Channel7 Command Register (S0DCM7)               | 0X070 <b>9</b> 08                           | description<br>of the                                       |
| Channel7 Rx Descriptor                           | 0X078 <b>9</b> 00<br>-                      | Channel7<br>registers,<br>see the                           |
|                                                  | 0X078 <b>9</b> 0F                           | descrip-                                                    |
| Channel7 Current Rx Descriptor Pointer (S0CRDP7) | 0X078 <b>9</b> 10                           | tions for                                                   |
| Channel7 Tx Descriptor                           | 0X07C <b>9</b> 00<br>-                      | the<br>Channel0                                             |
|                                                  | 0X07C <b>9</b> 0F                           | registers.                                                  |
| Channel7 Current Tx Descriptor Pointer (S0CTDP7) | 0X07C <b>9</b> 10                           |                                                             |
| Channel7 First Tx Descriptor Pointer (S0FTDP7)   | 0X07C <b>9</b> 14                           |                                                             |
| SDMA Group 1, Channel0                           | _                                           |                                                             |
| Channel1 Configuration Register (S1DC0)          | 0X100 <b>9</b> 00                           | page 312                                                    |
| Channel1 Command Register (S1DCM0)               | 0X100 <b>9</b> 08                           | page 314                                                    |
| Channel1 Rx Descriptor                           | 0X108 <b>9</b> 00<br>-<br>0X108 <b>9</b> 0F | Not to be<br>accessed<br>during nor-<br>mal opera-<br>tion. |
| Channel1 Current Rx Descriptor Pointer (S1CRDP0) | 0X108 <b>9</b> 10                           | page 316                                                    |
| Channel1 Tx Descriptor                           | 0X10C <b>9</b> 00<br>-<br>0X10C <b>9</b> 0F | Not to be<br>accessed<br>during nor-<br>mal opera-<br>tion. |
| Channel1 Current Tx Descriptor Pointer (S1CTDP0) | 0X10C <b>9</b> 10                           | page 316                                                    |
| Channel1 First Tx Descriptor Pointer (S1FTDP0)   | 0X10C <b>9</b> 14                           | page 316                                                    |



Γ

| Description                                      | Offset                                      | Page<br>Number                                                                                                       |
|--------------------------------------------------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| SDMA Group 1, Channel1                           |                                             |                                                                                                                      |
| Channel1 Configuration Register (S1DC1)          | 0X110 <b>9</b> 00                           | For a                                                                                                                |
| Channel1 Command Register (S1DCM1)               | 0X110 <b>9</b> 08                           | description<br>of the                                                                                                |
| Channel1 Rx Descriptor                           | 0X118 <b>9</b> 00 -<br>0X118 <b>9</b> 0F    | Channel1<br>registers,<br>see the                                                                                    |
| Channel1 Current Rx Descriptor Pointer (S1CRDP1) | 0X118 <b>9</b> 10                           | descrip-                                                                                                             |
| Channel1 Tx Descriptor                           | 0X11C <b>9</b> 00                           | tions for<br>the                                                                                                     |
|                                                  | -<br>0X11C <b>9</b> 0F                      | Channel0 registers.                                                                                                  |
| SDMA Group 1, Channel1 (Continued)               |                                             |                                                                                                                      |
| Channel1 Current Tx Descriptor Pointer (S1CTDP1) | 0X11C <b>9</b> 10                           | For a                                                                                                                |
| Channel1 First Tx Descriptor Pointer (S1FTDP1)   | 0X11C <b>9</b> 14                           | description<br>of the<br>Channel1<br>registers,<br>see the<br>descrip-<br>tions for<br>the<br>Channel0<br>registers. |
| SDMA Group 1, Channel2                           |                                             | 1                                                                                                                    |
| Channel2 Configuration Register (S1DC2)          | 0X120 <b>9</b> 00                           | For a                                                                                                                |
| Channel2 Command Register (S1DCM2)               | 0X120 <b>9</b> 08                           | description<br>of the                                                                                                |
| Channel2 Rx Descriptor                           | 0X128 <b>9</b> 00<br>-<br>0X128 <b>9</b> 0F | Channel2<br>registers,<br>see the                                                                                    |
| Channel2 Current Rx Descriptor Pointer (S1CRDP2) | 0X128 <b>9</b> 10                           | descrip-<br>tions for                                                                                                |
| Channel2 Tx Descriptor                           | 0X12C <b>9</b> 00<br>-<br>0X12C <b>9</b> 0F | the<br>Channel0<br>registers.                                                                                        |
| Channel2 Current Tx Descriptor Pointer (S1CTDP2) | 0X12C <b>9</b> 10                           |                                                                                                                      |
| Channel2 First Tx Descriptor Pointer (S1FTDP2)   | 0X12C <b>9</b> 14                           |                                                                                                                      |
|                                                  |                                             |                                                                                                                      |



| Description                                      | Offset                                      | Page<br>Number                                                                                                                |
|--------------------------------------------------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| SDMA Group 1, Channel3                           |                                             |                                                                                                                               |
| Channel3 Configuration Register (S1DC3)          | 0X130 <b>9</b> 00                           | For a<br>description<br>of the<br>Channel3<br>registers,<br>see the<br>descrip-<br>tions for<br>the<br>Channel0<br>registers. |
| Channel3 Command Register (S1DCM3)               | 0X130 <b>9</b> 08                           |                                                                                                                               |
| Channel3 Rx Descriptor                           | 0X138 <b>9</b> 00<br>-<br>0X138 <b>9</b> 0F |                                                                                                                               |
| Channel3 Current Rx Descriptor Pointer (S1CRDP3) | 0X138 <b>9</b> 10                           |                                                                                                                               |
| Channel3 Tx Descriptor                           | 0X13C <b>9</b> 00<br>-<br>0X13C <b>9</b> 0F |                                                                                                                               |
| Channel3 Current Tx Descriptor Pointer (S1CTDP3) | 0X13C <b>9</b> 10                           |                                                                                                                               |
| Channel3 First Tx Descriptor Pointer (S1FTDP3)   | 0X13C <b>9</b> 14                           |                                                                                                                               |
| SDMA Group 1, Channel4                           |                                             |                                                                                                                               |
| Channel4 Configuration Register (S1DC4)          | 0X140 <b>9</b> 00                           | For a                                                                                                                         |
| Channel4 Command Register (S1DCM4)               | 0X140 <b>9</b> 08                           | description<br>of the<br>Channel4<br>registers,<br>see the<br>descrip-<br>tions for<br>the<br>Channel0<br>registers.          |
| Channel4 Rx Descriptor                           | 0X148 <b>9</b> 00<br>-<br>0X148 <b>9</b> 0F |                                                                                                                               |
| Channel4 Current Rx Descriptor Pointer (S1CRDP4) | 0X148 <b>9</b> 10                           |                                                                                                                               |
| Channel4 Tx Descriptor                           | 0X14C <b>9</b> 00<br>-<br>0X14C <b>9</b> 0F |                                                                                                                               |
| Channel4 Current Tx Descriptor Pointer (S1CTDP4) | 0X14C <b>9</b> 10                           |                                                                                                                               |
| Channel4 First Tx Descriptor Pointer (S1FTDP4)   | 0X14C <b>9</b> 14                           | 1                                                                                                                             |



| Description                                      | Offset                 | Page<br>Number                                                                                                                |
|--------------------------------------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| SDMA Group 1, Channel5                           |                        |                                                                                                                               |
| Channel5 Configuration Register (S1DC5)          | 0X150 <b>9</b> 00      | For a description of the                                                                                                      |
| Channel5 Command Register (S1DCM5)               | 0X150 <b>9</b> 08      |                                                                                                                               |
| Channel5 Rx Descriptor                           | 0X158 <b>9</b> 00      | Channel5<br>registers,                                                                                                        |
|                                                  | 0X158 <b>9</b> 0F      | see the descrip-                                                                                                              |
| Channel5 Current Rx Descriptor Pointer (S1CRDP5) | 0X158 <b>9</b> 10      | tions for                                                                                                                     |
| Channel5 Tx Descriptor                           | 0X15C <b>9</b> 00      | the<br>Channel0                                                                                                               |
|                                                  | -<br>0X15C <b>9</b> 0F | registers.                                                                                                                    |
| Channel5 Current Tx Descriptor Pointer (S1CTDP5) | 0X15C <b>9</b> 10      | -                                                                                                                             |
| Channel5 First Tx Descriptor Pointer (S1FTDP5)   | 0X15C <b>9</b> 14      |                                                                                                                               |
| SDMA Group 1, Channel6                           |                        |                                                                                                                               |
| Channel6 Configuration Register (S1DC6)          | 0X160 <b>9</b> 00      | For a                                                                                                                         |
| Channel6 Command Register (S1DCM6)               | 0X160 <b>9</b> 08      | description<br>of the                                                                                                         |
| Channel6 Rx Descriptor                           | 0X168 <b>9</b> 00      | Channel6<br>registers,                                                                                                        |
|                                                  | 0X168 <b>9</b> 0F      | see the descrip-                                                                                                              |
| Channel6 Current Rx Descriptor Pointer (S1CRDP6) | 0X168 <b>9</b> 10      | tions for                                                                                                                     |
| Channel6 Tx Descriptor                           | 0X16C <b>9</b> 00      | the<br>Channel0                                                                                                               |
|                                                  | 0X16C <b>9</b> 0F      | registers.                                                                                                                    |
| Channel6 Current Tx Descriptor Pointer (S1CTDP6) | 0X16C <b>9</b> 10      | For a<br>description<br>of the<br>Channel6<br>registers,<br>see the<br>descrip-<br>tions for<br>the<br>Channel0<br>registers. |
| Channel6 First Tx Descriptor Pointer (S1FTDP6)   | 0X16C <b>9</b> 14      |                                                                                                                               |



| Description                                      | Offset                 | Page<br>Number         |
|--------------------------------------------------|------------------------|------------------------|
| SDMA Group 1, Channel7                           |                        |                        |
| Channel7 Configuration Register (S1DC7)          | 0X170 <b>9</b> 00      | For a                  |
| Channel7 Command Register (S1DCM7)               | 0X170 <b>9</b> 08      | description<br>of the  |
| Channel7 Rx Descriptor                           | 0X178 <b>9</b> 00      | Channel7<br>registers, |
|                                                  | -<br>0X178 <b>9</b> 0F | see the                |
| Channel7 Current Rx Descriptor Pointer (S1CRDP7) | 0X178 <b>9</b> 10      | descrip-<br>tions for  |
| Channel7 Tx Descriptor                           | 0X17C <b>9</b> 00      | the<br>Channel0        |
|                                                  | -<br>0X17C <b>9</b> 0F | registers.             |
| Channel7 Current Tx Descriptor Pointer (S1CTDP7) | 0X17C <b>9</b> 10      |                        |
| Channel7 First Tx Descriptor Pointer (S1FTDP7)   | 0X17C <b>9</b> 14      |                        |
| MPSC0                                            |                        |                        |
| MPSC0 Main Configuration Low (MMCRL0)            | 0X000 <b>A</b> 00      | page 329               |
| MPSC0 Main Configuration High (MMCRH0)           | 0X000 <b>A</b> 04      | page 333               |
| MPSC0 Protocol Configuration (MPCR0)             | 0X000 <b>A</b> 08      | page 339               |
| Channel0 Register1 (CH0R1)                       | 0X000 <b>A</b> 0C      | page 337               |
| Channel0 Register2 (CH0R2)                       | 0X000 <b>A</b> 10      |                        |
| Channel0 Register3 (CH0R3)                       | 0X000 <b>A</b> 14      |                        |
| Channel0 Register4 (CH0R4)                       | 0X000 <b>A</b> 18      |                        |
| Channel0 Register5 (CH0R5)                       | 0X000 <b>A</b> 1C      |                        |
| Channel0 Register6 (CH0R6)                       | 0X000 <b>A</b> 20      |                        |
| Channel0 Register7 (CH0R7)                       | 0X000 <b>A</b> 24      |                        |
| Channel0 Register8 (CH0R8)                       | 0X000 <b>A</b> 28      |                        |
| Channel0 Register9 (CH0R9)                       | 0X000 <b>A</b> 2C      |                        |
| Channel0 Register10 (CH0R10)                     | 0X000 <b>A</b> 30      |                        |



|                                        | 046-14            | Page                                      |
|----------------------------------------|-------------------|-------------------------------------------|
| Description                            | Offset            | Number                                    |
| MPSC1                                  |                   | 1                                         |
| MPSC1 Main Configuration Low (MMCRL1)  | 0X008 <b>A</b> 00 | For a<br>description<br>of the            |
| MPSC1 Main Configuration High (MMCRH1) | 0X008 <b>A</b> 04 |                                           |
| MPSC1 Protocol Configuration (MPCR1)   | 0X008 <b>A</b> 08 | MPSC1<br>registers,                       |
| Channel1 Register1 (CH1R1)             | 0X008 <b>A</b> 0C | see the                                   |
| Channel1 Register2 (CH1R2)             | 0X008 <b>A</b> 10 | descrip-<br>tions for                     |
| Channel1 Register3 (CH1R3)             | 0X008 <b>A</b> 14 | the MPSC0                                 |
| Channel1 Register4 (CH1R4)             | 0X008 <b>A</b> 18 | registers<br>on page                      |
| Channel1 Register5 (CH1R5)             | 0X008 <b>A</b> 1C | 499.                                      |
| Channel1 Register6 (CH1R6)             | 0X008 <b>A</b> 20 |                                           |
| Channel1 Register7 (CH1R7)             | 0X008 <b>A</b> 24 |                                           |
| Channel1 Register8 (CH1R8)             | 0X008 <b>A</b> 28 |                                           |
| Channel1 Register9 (CH1R9)             | 0X008 <b>A</b> 2C |                                           |
| Channel1 Register10 (CH1R10)           | 0X008 <b>A</b> 30 |                                           |
| Channel1 Register11 (CH1R11)           | 0X008 <b>A</b> 34 |                                           |
| MPSC2                                  |                   |                                           |
| MPSC2 Main Configuration Low (MMCRL2)  | 0X010 <b>A</b> 00 | For a                                     |
| MPSC2 Main Configuration High (MMCRH2) | 0X010 <b>A</b> 04 | description<br>of the                     |
| MPSC2 Protocol Configuration (MPCR2)   | 0X010 <b>A</b> 08 | MPSC1<br>registers,                       |
| Channel2 Register1 (CH2R1)             | 0X010 <b>A</b> 0C | see the                                   |
| Channel2 Register2 (CH2R2)             | 0X010 <b>A</b> 10 | descrip-<br>tions for                     |
| Channel2 Register3 (CH2R3)             | 0X010 <b>A</b> 14 | the MPSC0<br>registers<br>on page<br>499. |
| Channel2 Register4 (CH2R4)             | 0X010 <b>A</b> 18 |                                           |
| Channel2 Register5 (CH2R5)             | 0X010 <b>A</b> 1C |                                           |
| Channel2 Register6 (CH2R6)             | 0X010 <b>A</b> 20 |                                           |
| Channel2 Register7 (CH2R7)             | 0X010 <b>A</b> 24 |                                           |
| Channel2 Register8 (CH2R8)             | 0X010 <b>A</b> 28 |                                           |
| Channel2 Register9 (CH2R9)             | 0X010 <b>A</b> 2C |                                           |
| Channel2 Register10 (CH2R10)           | 0X010 <b>A</b> 30 |                                           |



| Description                            | Offset            | Page<br>Number         |
|----------------------------------------|-------------------|------------------------|
| Description<br>MPSC3                   | Unset             | Number                 |
| MPSC3 Main Configuration Low (MMCRL3)  | 0X018 <b>A</b> 00 | For a                  |
| MPSC3 Main Configuration High (MMCRH3) | 0X018 <b>A</b> 04 | description            |
| MPSC3 Protocol Configuration (MPCR3)   | 0X018 <b>A</b> 04 | of the<br>MPSC3        |
| Channel3 Register1 (CH3R1)             | 0X018A08          | registers,             |
| Channel3 Register2 (CH3R2)             | 0X018 <b>A</b> 0C | see the<br>descrip-    |
| Channel3 Register3 (CH3R3)             | 0X018 <b>A</b> 10 | tions for<br>the MPSC0 |
| Channel3 Register4 (CH3R4)             | 0X018 <b>A</b> 14 | registers              |
|                                        | 0X018 <b>A</b> 18 | on page<br>499.        |
| Channel3 Register5 (CH3R5)             |                   |                        |
| Channel3 Register6 (CH3R6)             | 0X018 <b>A</b> 20 |                        |
| Channel3 Register7 (CH3R7)             | 0X018 <b>A</b> 24 |                        |
| Channel3 Register8 (CH3R8)             | 0X018 <b>A</b> 28 |                        |
| Channel3 Register9 (CH3R9)             | 0X018 <b>A</b> 2C |                        |
| Channel3 Register10 (CH3R10)           | 0X018 <b>A</b> 30 |                        |
| MPSC4                                  |                   | _                      |
| MPSC4 Main Configuration Low (MMCRL4)  | 0X020 <b>A</b> 00 | For a description      |
| MPSC4 Main Configuration High (MMCRH4) | 0X020 <b>A</b> 04 | of the                 |
| MPSC4 Protocol Configuration (MPCR4)   | 0X020 <b>A</b> 08 | MPSC4 registers,       |
| Channel4 Register1 (CH4R1)             | 0X020 <b>A</b> 0C | see the<br>descrip-    |
| Channel4 Register2 (CH4R2)             | 0X020 <b>A</b> 10 | tions for              |
| Channel4 Register3 (CH4R3)             | 0X020 <b>A</b> 14 | the MPSC0<br>registers |
| Channel4 Register4 (CH4R4)             | 0X020 <b>A</b> 18 | on page                |
| Channel4 Register5 (CH4R5)             | 0X020 <b>A</b> 1C | 499.                   |
| Channel4 Register6 (CH4R6)             | 0X020 <b>A</b> 20 |                        |
| Channel4 Register7 (CH4R7)             | 0X020 <b>A</b> 24 |                        |
| Channel4 Register8 (CH4R8)             | 0X020 <b>A</b> 28 |                        |
| Channel4 Register9 (CH4R9)             | 0X020 <b>A</b> 2C |                        |
| Channel4 Register10 (CH4R10)           | 0X020 <b>A</b> 30 |                        |



| Description                            | Offset            | Page<br>Number                 |
|----------------------------------------|-------------------|--------------------------------|
| MPSC5                                  |                   |                                |
| MPSC5 Main Configuration Low (MMCRL5)  | 0X028 <b>A</b> 00 | For a<br>description<br>of the |
| MPSC5 Main Configuration High (MMCRH5) | 0X028 <b>A</b> 04 |                                |
| MPSC5 Protocol Configuration (MPCR5)   | 0X028 <b>A</b> 08 | MPSC5                          |
| Channel5 Register1 (CH5R1)             | 0X028 <b>A</b> 0C | registers, see the             |
| Channel5 Register2 (CH5R2)             | 0X028 <b>A</b> 10 | descrip-<br>tions for          |
| Channel5 Register3 (CH5R3)             | 0X028 <b>A</b> 14 | the MPSC0                      |
| Channel5 Register4 (CH5R4)             | 0X028 <b>A</b> 18 | registers<br>on page           |
| Channel5 Register5 (CH5R5)             | 0X028 <b>A</b> 1C | 499.                           |
| Channel5 Register6 (CH5R6)             | 0X028 <b>A</b> 20 |                                |
| Channel5 Register7 (CH5R7)             | 0X028 <b>A</b> 24 |                                |
| Channel5 Register8 (CH5R8)             | 0X028 <b>A</b> 28 |                                |
| Channel5 Register9 (CH5R9)             | 0X028 <b>A</b> 2C |                                |
| Channel5 Register10 (CH5R10)           | 0X028 <b>A</b> 30 |                                |
| MPSC6                                  | •                 |                                |
| MPSC6 Main Configuration Low (MMCRL6)  | 0X030 <b>A</b> 00 | For a                          |
| MPSC6 Main Configuration High (MMCRH6) | 0X030 <b>A</b> 04 | description<br>of the          |
| MPSC6 Protocol Configuration (MPCR6)   | 0X030 <b>A</b> 08 | MPSC6                          |
| Channel6 Register1 (CH6R1)             | 0X030 <b>A</b> 0C | registers,<br>see the          |
| Channel6 Register2 (CH6R2)             | 0X030 <b>A</b> 10 | descrip-<br>tions for          |
| Channel6 Register3 (CH6R3)             | 0X030 <b>A</b> 14 | the MPSC0                      |
| Channel6 Register4 (CH6R4)             | 0X030 <b>A</b> 18 | registers<br>on page           |
| Channel6 Register5 (CH6R5)             | 0X030 <b>A</b> 1C | 499.                           |
| Channel6 Register6 (CH6R6)             | 0X030 <b>A</b> 20 |                                |
| Channel6 Register7 (CH6R7)             | 0X030 <b>A</b> 24 |                                |
| Channel6 Register8 (CH6R8)             | 0X030 <b>A</b> 28 |                                |
| Channel6 Register9 (CH6R9)             | 0X030 <b>A</b> 2C |                                |
| Channel6 Register10 (CH6R10)           | 0X030 <b>A</b> 30 |                                |



| Description                                      | Offerst             | Page                                  |  |
|--------------------------------------------------|---------------------|---------------------------------------|--|
| Description                                      | Offset              | Number                                |  |
| MPSC7                                            |                     |                                       |  |
| MPSC7 Main Configuration Low (MMCRL7)            | 0X038 <b>A</b> 00   | For a description                     |  |
| MPSC7 Main Configuration High (MMCRH7)           | 0X038 <b>A</b> 04   | of the                                |  |
| MPSC7 Protocol Configuration (MPCR7)             | 0X038 <b>A</b> 08   | MPSC7<br>registers,                   |  |
| Channel7 Register1 (CH7R1)                       | 0X038 <b>A</b> 0C   | see the                               |  |
| Channel7 Register2 (CH7R2)                       | 0X038 <b>A</b> 10   | descrip-<br>tions for                 |  |
| Channel7 Register3 (CH7R3)                       | 0X038 <b>A</b> 14   | the MPSC0<br>registers                |  |
| Channel7 Register4 (CH7R4)                       | 0X038 <b>A</b> 18   | on page                               |  |
| Channel7 Register5 (CH7R5)                       | 0X038 <b>A</b> 1C   | 499.                                  |  |
| Channel7 Register6 (CH7R6)                       | 0X038 <b>A</b> 20   |                                       |  |
| Channel7 Register7 (CH7R7)                       | 0X038 <b>A</b> 24   |                                       |  |
| Channel7 Register8 (CH7R8)                       | 0X038 <b>A</b> 28   |                                       |  |
| Channel7 Register9 (CH7R9)                       | 0X038 <b>A</b> 2C   |                                       |  |
| Channel7 Register10 (CH7R10)                     | 0X038 <b>A</b> 30   |                                       |  |
| FlexTDM0                                         |                     |                                       |  |
| FlexTDM0 Transmit Dual Port RAM (TDPR0), block 0 | 0X000 <b>B</b> 00 - | 0X000 <b>B</b> FF                     |  |
| FlexTDM0 Transmit Dual Port RAM (TDPR0), block 1 | 0X001 <b>B</b> 00 - | 0X001 <b>B</b> 00 - 0X001 <b>B</b> FF |  |
| FlexTDM0 Transmit Dual Port RAM (TDPR0), block 2 | 0X002 <b>B</b> 00 - | 0X002 <b>B</b> 00 - 0X002 <b>B</b> FF |  |
| FlexTDM0 Transmit Dual Port RAM (TDPR0), block 3 | 0X003 <b>B</b> 00 - | 0X003 <b>B</b> 00 - 0X003 <b>B</b> FF |  |
| FlexTDM0 Receive Dual Port RAM (RDPR0), block 0  | 0X004 <b>B</b> 00 - | 0X004 <b>B</b> 00 - 0X004 <b>B</b> FF |  |
| FlexTDM0 Receive Dual Port RAM (RDPR0), block 1  | 0X005 <b>B</b> 00 - | 0X005 <b>B</b> 00 - 0X005 <b>B</b> FF |  |
| FlexTDM0 Receive Dual Port RAM (RDPR0), block 2  | 0X006 <b>B</b> 00 - | 0X006 <b>B</b> 00 - 0X006 <b>B</b> FF |  |
| FlexTDM0 Receive Dual Port RAM (RDPR0), block 3  | 0X007 <b>B</b> 00 - | 0X007 <b>B</b> 00 - 0X007 <b>B</b> FF |  |
| FlexTDM0 Transmit Read Pointer (TTRP0)           | 0X008 <b>B</b> 00   |                                       |  |
| FlexTDM0 Receive Read Pointer (TRRP0)            | 0X008 <b>B</b> 04   |                                       |  |
| FlexTDM0 Configuration Register (TCR0)           | 0X008 <b>B</b> 08   | page 384                              |  |
| FlexTDM0 AUX ChannelA Tx Register (ATA0)         | 0X008 <b>B</b> 0C   |                                       |  |
| FlexTDM0 AUX ChannelA Rx Register (ARA0)         | 0X008 <b>B</b> 10   |                                       |  |



| Table 443: ( | Communication | Unit Registe | er Man | (Continued) |
|--------------|---------------|--------------|--------|-------------|
|              | oommunioution | onnencegiou  | si map | (Continueu) |

|                                                  |                     | Page                                  |  |
|--------------------------------------------------|---------------------|---------------------------------------|--|
| Description                                      | Offset              | Number                                |  |
| FlexTDM0 (Continued)                             |                     |                                       |  |
| FlexTDM0 AUX ChannelB Tx Register (ATB0)         | 0X008 <b>B</b> 14   |                                       |  |
| FlexTDM0 AUX ChannelB Rx Register (ARB0)         | 0X008 <b>B</b> 18   |                                       |  |
| FlexTDM1                                         |                     |                                       |  |
| FlexTDM1 Transmit Dual Port RAM (TDPR1), block 0 | 0X010 <b>B</b> 00 - | 0X010 <b>B</b> FF                     |  |
| FlexTDM1 Transmit Dual Port RAM (TDPR1), block 1 | 0X011 <b>B</b> 00 - | 0X011 <b>B</b> FF                     |  |
| FlexTDM1 Transmit Dual Port RAM (TDPR1), block 2 | 0X012 <b>B</b> 00 - | 0X012 <b>B</b> FF                     |  |
| FlexTDM1 Transmit Dual Port RAM (TDPR1), block 3 | 0X013 <b>B</b> 00 - | 0X013 <b>B</b> FF                     |  |
| FlexTDM1 Receive Dual Port RAM (RDPR1), block 0  | 0X014 <b>B</b> 00 - | 0X014 <b>B</b> FF                     |  |
| FlexTDM1 Receive Dual Port RAM (RDPR1), block 1  | 0X015 <b>B</b> 00 - | 0X015 <b>B</b> FF                     |  |
| FlexTDM1 Receive Dual Port RAM (RDPR1), block 2  | 0X016 <b>B</b> 00 - | 0X016 <b>B</b> FF                     |  |
| FlexTDM1 Receive Dual Port RAM (RDPR1), block 3  | 0X017 <b>B</b> 00 - | 0X017 <b>B</b> 00 - 0X017 <b>B</b> FF |  |
| FlexTDM1 Transmit Read Pointer (TTRP1)           | 0X018 <b>B</b> 00   |                                       |  |
| FlexTDM1 Receive Read Pointer (TRRP1)            | 0X018 <b>B</b> 04   |                                       |  |
| FlexTDM1 Configuration Register (TCR1)           | 0X018 <b>B</b> 08   | page 384                              |  |
| FlexTDM1 AUX ChannelA Tx Register (ATA1)         | 0X018 <b>B</b> 0C   |                                       |  |
| FlexTDM1 AUX ChannelA Rx Register (ARA1)         | 0X018 <b>B</b> 10   |                                       |  |
| FlexTDM1 AUX ChannelB Tx Register (ATB1)         | 0X018 <b>B</b> 14   |                                       |  |
| FlexTDM1 AUX ChannelB Rx Register (ARB1)         | 0X018 <b>B</b> 18   | 0X018 <b>B</b> 18                     |  |
| FlexTDM2                                         |                     |                                       |  |
| FlexTDM2 Transmit Dual Port RAM (TDPR2), block 0 | 0X020 <b>B</b> 00 - | 0X020 <b>B</b> FF                     |  |
| FlexTDM2 Transmit Dual Port RAM (TDPR2), block 1 | 0X021 <b>B</b> 00 - | 0X021 <b>B</b> FF                     |  |
| FlexTDM2 Transmit Dual Port RAM (TDPR2), block 2 | 0X022 <b>B</b> 00 - | 0X022 <b>B</b> FF                     |  |
| FlexTDM2 Transmit Dual Port RAM (TDPR2), block 3 | 0X023 <b>B</b> 00 - | 0X023 <b>B</b> FF                     |  |
| FlexTDM2 Receive Dual Port RAM (RDPR2), block 0  | 0X024 <b>B</b> 00 - | 0X024 <b>B</b> FF                     |  |
| FlexTDM2 Receive Dual Port RAM (RDPR2), block 1  | 0X025 <b>B</b> 00 - | 0X025 <b>B</b> FF                     |  |
| FlexTDM2 Receive Dual Port RAM (RDPR2), block 2  | 0X026 <b>B</b> 00 - | 0X026 <b>B</b> FF                     |  |
| FlexTDM2 Receive Dual Port RAM (RDPR2), block 3  | 0X027 <b>B</b> 00 - | 0X027 <b>B</b> 00 - 0X027 <b>B</b> FF |  |
| FlexTDM2 Transmit Read Pointer (TTRP2)           | 0X028 <b>B</b> 00   | 0X028 <b>B</b> 00                     |  |
| FlexTDM2 Receive Read Pointer (TRRP2)            | 0X028 <b>B</b> 04   |                                       |  |



#### Table 443: Communication Unit Register Map (Continued)

| Description                                      | Offset              | Page<br>Number                        |  |
|--------------------------------------------------|---------------------|---------------------------------------|--|
| FlexTDM2 (Continued)                             |                     |                                       |  |
| FlexTDM2 Configuration Register (TCR2)           | 0X028 <b>B</b> 08   | page 384                              |  |
| FlexTDM2 AUX ChannelA Tx Register (ATA2)         | 0X028 <b>B</b> 0C   |                                       |  |
| FlexTDM2 AUX ChannelA Rx Register (ARA2)         | 0X028 <b>B</b> 10   |                                       |  |
| FlexTDM2 AUX ChannelB Tx Register (ATB2)         | 0X028 <b>B</b> 14   |                                       |  |
| FlexTDM2 AUX ChannelB Rx Register (ARB2)         | 0X028 <b>B</b> 18   |                                       |  |
| FlexTDM3                                         |                     |                                       |  |
| FlexTDM3 Transmit Dual Port RAM (TDPR3), block 0 | 0X030 <b>B</b> 00 - | 0X030 <b>B</b> FF                     |  |
| FlexTDM3 Transmit Dual Port RAM (TDPR3), block 1 | 0X031 <b>B</b> 00 - | 0X031 <b>B</b> FF                     |  |
| FlexTDM3 Transmit Dual Port RAM (TDPR3), block 2 | 0X032 <b>B</b> 00 - | 0X032 <b>B</b> 00 - 0X032 <b>B</b> FF |  |
| FlexTDM3 Transmit Dual Port RAM (TDPR3), block 3 | 0X033 <b>B</b> 00 - | 0X033 <b>B</b> 00 - 0X033 <b>B</b> FF |  |
| FlexTDM3 Receive Dual Port RAM (RDPR3), block 0  | 0X034 <b>B</b> 00 - | 0X034 <b>B</b> 00 - 0X034 <b>B</b> FF |  |
| FlexTDM3 Receive Dual Port RAM (RDPR3), block 1  | 0X035 <b>B</b> 00 - | 0X035 <b>B</b> 00 - 0X035 <b>B</b> FF |  |
| FlexTDM3 Receive Dual Port RAM (RDPR3), block 2  | 0X036 <b>B</b> 00 - | 0X036 <b>B</b> FF                     |  |
| FlexTDM3 Receive Dual Port RAM (RDPR3), block 3  | 0X037 <b>B</b> 00 - | 0X037 <b>B</b> FF                     |  |
| FlexTDM3 Transmit Read Pointer (TTRP3)           | 0X038 <b>B</b> 00   |                                       |  |
| FlexTDM3 Receive Read Pointer (TRRP3)            | 0X038 <b>B</b> 04   | 0X038 <b>B</b> 04                     |  |
| FlexTDM3 Configuration Register (TCR3)           | 0X038 <b>B</b> 08   | 0X038 <b>B</b> 08 page 384            |  |
| FlexTDM3 AUX ChannelA Tx Register (ATA3)         | 0X038 <b>B</b> 0C   | 0X038 <b>B</b> 0C                     |  |
| FlexTDM3 AUX ChannelA Rx Register (ARA3)         | 0X038 <b>B</b> 10   | 0X038 <b>B</b> 10                     |  |
| FlexTDM3 AUX ChannelB Tx Register (ATB3)         | 0X038 <b>B</b> 14   | 0X038 <b>B</b> 14                     |  |
| FlexTDM3 AUX ChannelB Rx Register (ARB3)         | 0X038 <b>B</b> 18   | 0X038 <b>B</b> 18                     |  |



| Description                            | Offset            | Page<br>Number           |  |
|----------------------------------------|-------------------|--------------------------|--|
| Baud Rate Generators                   |                   |                          |  |
| BRG0 Configuration Register (BCR0)     | 0X102 <b>A</b> 00 | page 399                 |  |
| BRG0 Baud Tuning Register (BTR0)       | 0X102 <b>A</b> 04 | page 400                 |  |
| BRG1 Configuration Register (BCR1)     | 0X102 <b>A</b> 08 | For BRG1                 |  |
| BRG1 Baud Tuning Register (BTR1)       | 0X102 <b>A</b> 0C | through<br>BRG7 con-     |  |
| BRG2 Configuration Register (BCR2)     | 0X102 <b>A</b> 10 | figuration<br>and tuning |  |
| BRG2 Baud Tuning Register (BTR2)       | 0X102 <b>A</b> 14 | registers,               |  |
| BRG3 Configuration Register (BCR3)     | 0X102 <b>A</b> 18 | see BRG0                 |  |
| BRG3 Baud Tuning Register (BTR3)       | 0X102 <b>A</b> 1C |                          |  |
| BRG4 Configuration Register (BCR4)     | 0X102 <b>A</b> 20 |                          |  |
| BRG4 Baud Tuning Register (BTR4)       | 0X102 <b>A</b> 24 |                          |  |
| BRG5 Configuration Register (BCR5)     | 0X102 <b>A</b> 28 |                          |  |
| BRG5 Baud Tuning Register (BTR5)       | 0X102 <b>A</b> 2C |                          |  |
| BRG6 Configuration Register (BCR6)     | 0X102 <b>A</b> 30 |                          |  |
| BRG6 Baud Tuning Register (BTR6)       | 0X102 <b>A</b> 34 |                          |  |
| BRG7 Configuration Register (BCR7)     | 0X102 <b>A</b> 38 |                          |  |
| BRG7 Baud Tuning Register (BTR7)       | 0X102 <b>A</b> 3C |                          |  |
| Routing Registers                      |                   |                          |  |
| Main Routing Register (MRR)            | 0X101 <b>A</b> 00 | page 414                 |  |
| Receive Clock Routing Register (RCRR)  | 0X101 <b>A</b> 10 | page 418                 |  |
| Transmit Clock Routing Register (TCRR) | 0X101 <b>A</b> 20 | page 420                 |  |
| General Purpose Ports                  |                   |                          |  |
| General Purpose Configuration 0 (GPC0) | 0X100 <b>A</b> 00 | page 407                 |  |
| General Purpose Configuration 1 (GPC1) | 0X100 <b>A</b> 04 | page 409                 |  |
| General Purpose Configuration 2 (GPC2) | 0X100 <b>A</b> 08 | page 412                 |  |
| General Purpose Input/Output 0 (GPIO0) | 0X100 <b>A</b> 20 | page 407                 |  |
| General Purpose Input/Output 1 (GPIO1) | 0X100 <b>A</b> 24 | page 410                 |  |
| General Purpose Input/Output 2 (GPIO2) | 0X100 <b>A</b> 28 | page 412                 |  |
| General Purpose Data 0 (GPD0)          | 0X100 <b>A</b> 40 | page 408                 |  |
| General Purpose Data 1 (GPD1)          | 0X100 <b>A</b> 44 | page 410                 |  |

#### Table 443: Communication Unit Register Map (Continued)



| Table 443: | Communication | Unit | <b>Register Ma</b> | p ( | (Continued) |
|------------|---------------|------|--------------------|-----|-------------|
|            | oommunioution | 0    | rtegister mu       | P 1 |             |

| Description                                      | Offset            | Page<br>Number |  |  |
|--------------------------------------------------|-------------------|----------------|--|--|
| General Purpose Ports (Continued)                |                   |                |  |  |
| General Purpose Data 2 (GPD2)                    | 0X100 <b>A</b> 48 | page 413       |  |  |
| General Purpose Level 0 (GPL0)                   | 0X100 <b>A</b> 60 | page 408       |  |  |
| General Purpose Level 1 (GPL1)                   | 0X100 <b>A</b> 64 | page 411       |  |  |
| General Purpose Level 2 (GPL2)                   | 0X100 <b>A</b> 68 | page 413       |  |  |
| Watchdog                                         |                   |                |  |  |
| Watchdog Configuration Register (WDC)            | 0X101 <b>A</b> 80 | page 401       |  |  |
| Watchdog Value Register (WDV)                    |                   | page 402       |  |  |
| Communication Unit Arbiter                       |                   |                |  |  |
| Comm Unit Arbiter Configuration Register (CUACR) | 0X101 <b>A</b> C0 | page 251       |  |  |
| PCI Arbiters                                     |                   |                |  |  |
| PCI_0 Arbiter Configuration Register             | 0X101 <b>A</b> E0 | page 243       |  |  |
| PCI_1 Arbiter Configuration Register             | 0X101 <b>A</b> E4 | page 245       |  |  |

### **31. DC CHARACTERISTICS**

#### Table 444: Absolute Maximum Ratings

| Symbol              | Parameter                    | Min. | Max. | Unit |
|---------------------|------------------------------|------|------|------|
| V <sub>CC</sub> 2.5 | Core Supply Voltage          | -0.3 | 3.0  | V    |
| V <sub>CC</sub> 3.3 | IO Supply Voltage            | -0.3 | 4.0  | V    |
| Vi                  | Input Voltage                | -0.3 | 5.5  | V    |
| l <sub>ik</sub>     | Input Protect Diode Current  |      | +-20 | mA   |
| I <sub>ok</sub>     | Output Protect Diode Current |      | +-20 | mA   |
| T <sub>c</sub>      | Operating Case Temperature   | 0    | 110  | С    |
| T <sub>stg</sub>    | Storage Temperature          | -40  | 125  | С    |

**NOTE:** Operation at or beyond the maximum ratings is not recommended or guaranteed. Extended exposure at the maximum rating for extended periods of time may adversely affect device reliability.

| Table 445: Recommended Operating Conditions |  |
|---------------------------------------------|--|
|                                             |  |

| Symbol              | Parameter           | Min.  | Тур. | Max.                | Unit |
|---------------------|---------------------|-------|------|---------------------|------|
| V <sub>CC</sub> 2.5 | Core Supply Voltage | 2.375 | 2.5  | 2.625               | V    |
| V <sub>CC</sub> 3.3 | I/O Supply Voltage  | 3.15  | 3.3  | 3.45                | V    |
| Vi                  | Input Voltage       | -0.3  |      | 5.5                 | V    |
| Vo                  | Output Voltage      | 0     |      | V <sub>CC</sub> 3.3 | V    |
| T <sub>c</sub>      | Case Temperature    | 0     |      | 70                  | С    |

#### Table 446: Pin Capacitance

| Symbol           | Parameter                      | Min. | Тур. | Max. | Unit |
|------------------|--------------------------------|------|------|------|------|
| C <sub>in</sub>  | Input Capacitance PCI PAD      |      | 2.5  | 4.5  | pF   |
|                  | Input Capacitance Non PCI PAD  |      | 2    | 3.5  |      |
| C <sub>out</sub> | Output Capacitance PCI PAD     |      | 2.5  | 4.5  | pF   |
|                  | Output Capacitance Non PCI PAD |      | 2    | 3.5  |      |



### 31.1 DC Electrical Characteristics Over Operating Range

(Tc=0-70°C; V<sub>cc</sub>3.3=+3.3V, +/-5%, V<sub>CC</sub>2.5= +2.5V, +/-5%)

| Symbol | Parameter                        | Test Condition                                          | Min. | Max. | Unit | Loading |
|--------|----------------------------------|---------------------------------------------------------|------|------|------|---------|
| Vih    | Input HIGH level                 | Guaranteed Logic<br>HIGH level                          | 2.0V |      | V    |         |
| Vil    | Input LOW level                  | Guaranteed Logic LOW level                              |      | 0.8V | V    |         |
| Voh    | Output HIGH Volt-<br>age:        | loH = 8,12,16,24 <sup>1</sup> mA                        | 2.4  |      | V    | 50pF    |
| Vol    | Output LOW Volt-<br>age:         | loL = 8,12,16,24 <sup>1</sup> mA                        |      | 0.4  | V    | 50pF    |
| lih    | Input HIGH Current               |                                                         |      | +-1  | uA   |         |
| lil    | Input LOW Current                |                                                         |      | +-1  | uA   |         |
| lozh   | High Impedance<br>Output Current |                                                         |      | +-1  | uA   |         |
| lozl   | High Impedance<br>Output Current |                                                         |      | +-1  | uA   |         |
| lcc    | Operating Current                | I/O<br>VCC3.3=3.465V<br>f = 100MHz TClk/<br>66Mhz PClk  |      | 440  | mA   |         |
|        |                                  | Core<br>VCC2.5=2.625V<br>f = 100MHz TClk/<br>66Mhz PClk |      | 880  | mA   |         |

Table 447: DC Electrical Characteristics Over Operating Range

1. See Table 448, "Driving Pad Characteristics," on page 510.

| Output Current | Pads Name                                                                                                                                                                                                                                                                        |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCI Pads       | CBE0_[3:0], CBE1_[3:0], DevSel0_, DevSel1_, Frame0_, Frame1_, Gnt0_, Gnt1_,<br>IDSel0, IDSel1, Interrupt1_, Irdy0_, Irdy1_, Lock0_, PAD0[31:0], PAD1[31:0], Par0,<br>Par1, PClk0, PClk1, PErr0_, PErr1_, Req0_, Req1_, SErr0_, SErr1_, Stop0_,<br>Stop1_, Trdy0_, Trdy1_, Reset_ |
| 4mA Pads       | JTAG[3]                                                                                                                                                                                                                                                                          |
| 8mA Pads       | GPP[15:0], MDC, MDIO, MII0[14:0], MII1[14:0], NMI_, PORTA[6:0], PORTB[6:0], PORTC[6:0], PORTD[6:0], PORTE[6:0], PORTF[6:0], WDE_                                                                                                                                                 |
| 16mA Pads      | AD[63:0], ADP[1], ADP[3:2], ADP[7:6], ALE, BypsOE_, ClkOutPLL, CSTiming_,<br>DMAReq_[0], Interrupt0_, ScDOE_, SCS_[3:0], ScWord[1:0], SDQM[7:0],<br>SerInt0_, SerInt1_, SysAD[63:0], SysADC[7;0], SysCmd[8:0], ValidIn_, WrRdy_                                                  |
| 24mA Pads      | ADP[0], ADP[5:4], BankSel, DAdr[10:0], DMAReq_[3:1], DWr_, SCAS_, SRAS_                                                                                                                                                                                                          |

#### Table 448: Driving Pad Characteristics

### 31.1.1 Power Sequencing Notes

The voltage power must be turned on sequentially so that the highest voltage power is always the preceding one; i.e.the highest voltage power must be turned on first, then the second highest voltage power and so on and so forth.

This power up sequence must be used due to the presence of protection diodes between the two power rails. If the power is turned on in incorrect sequence and if the tie-high terminal becomes tie low, these diodes leaks current.

Likewise, when powering down, turn off the lowest voltage first. Turn off the next highest and so on and so forth.



#### 31.1.2 Power Consumption

Figure 83 illustrate the GT-96100A power consumption in various common configurations and frequencies.









### 31.2 Thermal Data

Table 449 shows the package thermal data for the GT-96100A.

Using the commercial grade device, Galileo Technology recommends the use of heatsink for most systems, especially those with little or no airflow.

Use an adequate airflow, layout, and other means to meet the recommended operating conditions listed in Table 449.

| Airflow | 0 m/s    | 1 m/s                      | 2 m/s  |
|---------|----------|----------------------------|--------|
| θja     | 18.5 c/w | 16.6 c/w                   | 15 c/w |
| Ψ jt    | 0.37 c/w | 0.37 c/w 0.43 c/w 0.53 c/w |        |
| θjc     | 5.9 c/w  |                            |        |

 Table 449: Thermal data for GT-96100A in BGA 492



### 32. AC TIMING

**NOTE:** The following targets are subject to change.

#### Table 450: AC Timing Measurement Formulas

| Commercial                                               | Industrial                                                                                                                        |
|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| I/O Supply Voltage:<br>TCase= 70° C; VCC= +3.3V, +/- 5%  | <b>NOTE:</b> AC timing specifications for the 66Mhz industrial grade part will be included in future revisions of this datasheet. |
| Core Supply Voltage:<br>TCase= 70° C; VCC= +2.5V, +/- 5% |                                                                                                                                   |

#### Table 451: AC Commercial Grade Timing

All Delays, Setup, and Hold times are referred to TClk RISING edge, unless stated otherwise.

|                                                                           |                        | 83   | Mhz  | 100  | Mhz  |               |         |  |
|---------------------------------------------------------------------------|------------------------|------|------|------|------|---------------|---------|--|
| Signals                                                                   | Description            | Min. | Max. | Min. | Max. | Unit          | Loading |  |
| Clk                                                                       | Clk                    |      |      |      |      |               |         |  |
| TClk                                                                      | Pulse Width<br>High    | 4.8  |      | 4    |      | ns            |         |  |
| TClk                                                                      | Pulse Width<br>Low     | 4.8  |      | 4    |      | ns            |         |  |
| TClk                                                                      | Clock Period           | 12   |      | 10   |      | ns            |         |  |
| TClk                                                                      | Rise Time              |      | TBD  |      | TBD  | V/ns          |         |  |
| TClk                                                                      | Fall Time              |      | TBD  |      | TBD  | V/ns          |         |  |
| Reset**                                                                   | Active Device<br>Reset | 10   |      | 10   |      | TClk<br>Cycle |         |  |
| CPU Interface                                                             |                        |      |      |      |      | -             |         |  |
| SysAD[63:0],<br>SysCMD[8:0], Valid-<br>Out*, Release*,<br>ScTCE*          | Setup                  | 3.5  |      | 2.5  |      | ns            |         |  |
| ScMatch                                                                   | Setup                  | 5    |      | 2.5  |      |               |         |  |
| SysAD[63:0],<br>SysCMD[8:0], Valid-<br>Out*, Release*,<br>ScTCE*, ScMatch | Hold                   | 1    |      | 1    |      | ns            |         |  |

## Table 451: AC Commercial Grade Timing (Continued) All Delays, Setup, and Hold times are referred to TClk RISING edge, unless stated otherwise.

|                                                                                                          |                                                          | 83   | Mhz  | 100  | Mhz  |      |         |
|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------|------|------|------|------|------|---------|
| Signals                                                                                                  | Description                                              | Min. | Max. | Min. | Max. | Unit | Loading |
| CPU Interface (Contin                                                                                    | nued)                                                    |      |      |      |      |      |         |
| SysAD[63:0],<br>SysCMD[8:0],<br>SysADC[7:0], ScDOE*,<br>ValidIn*, WrRdy*,<br>ScWord[1:0],<br>Interrupt0* | Output Delay                                             | 2    | 7    | 2    | 5    | ns   | 50pF    |
| PCI Interface                                                                                            |                                                          |      |      |      |      |      |         |
| Pclk0, Pclk1                                                                                             | Clock Period                                             | 15   |      | 15   |      | ns   |         |
| All Bussed Inputs                                                                                        | Setup                                                    | 4    |      | 3.5  |      | ns   |         |
| All Point to Point Inputs                                                                                | Setup                                                    | 7    |      | 6    |      |      |         |
| All Inputs                                                                                               | Hold                                                     | 0    |      | 0    |      | ns   |         |
| All Outputs, except<br>Req*                                                                              | Output Delay                                             | 2    | 9    | 2    | 8    | ns   |         |
| Req*                                                                                                     | Output Delay                                             | 2    | 11   | 2    | 10   | ns   |         |
| Memory Interface                                                                                         |                                                          |      |      |      |      |      |         |
| AD[63:0]                                                                                                 | Setup                                                    | 3    |      | 2    |      | ns   |         |
| AD[63:0]                                                                                                 | Hold                                                     | 1    |      | 1    |      | ns   |         |
| AD[63:0], SCS[3:0]*                                                                                      | Output Delay                                             | 2    | 7    | 2    | 5.5  | ns   | 50pF    |
| DAdr[10:0]                                                                                               | Output Delay                                             | 2    | 7    | 2    | 5    | ns   | 50pF    |
| DAdr[2:0]                                                                                                | Output Delay<br>(Device Burst)                           | 2    | 7    | 2    | 5    | ns   | 50pF    |
| DAdr[10:3]                                                                                               | Output Delay<br>from TClk Fall-<br>ing<br>(Device Write) | 2    | 7    | 2    | 6    | ns   | 50pF    |
| ADP[7:0]                                                                                                 | Output Delay<br>(Parity)                                 | 2    | 7    | 2    | 5.5  | ns   | 50pF    |
| ADP[7:0]                                                                                                 | Setup (Parity)                                           | 3    |      | 2    |      | ns   | 50pF    |
| ADP[7:0]                                                                                                 | Hold (Parity)                                            | 1    |      | 1    |      | ns   |         |
| ADP[3:0]/EOT[3:0]*                                                                                       | Setup<br>(EOT[3:0]*)                                     | 4    |      | 3    |      | ns   |         |



|                                    |                                           | 83   | Mhz  | 100  | Mhz  |      |         |
|------------------------------------|-------------------------------------------|------|------|------|------|------|---------|
| Signals                            | Description                               | Min. | Max. | Min. | Max. | Unit | Loading |
| Memory Interface (C                | ontinued)                                 |      |      |      |      |      |         |
| ADP[3:0]/EOT[3:0]*                 | Hold<br>(EOT[3:0]*)                       | 1    |      | 1    |      | ns   |         |
| ADP[1]/ALE                         | Output Delay<br>(ALE)                     | 2    | 7    | 2    | 5.5  | ns   | 30pF    |
| ADP[1]/ALE                         | Output Delay,<br>TClk Falling<br>(ALE)    | 2    | 7    | 2    | 6    | ns   | 30pF    |
| ADP[3]/DWr*                        | Output Delay<br>(DWr*)                    | 2    | 7    | 2    | 6    | ns   | 50pF    |
| ADP[5:4]/{Dadr[11],<br>BankSel[1]} | Output Delay<br>(Dadr[11],<br>BankSel[1]) | 2    | 7    | 2    | 6    | ns   | 50pF    |
| ADP[7:6]/<br>{SRAS*,SCAS*}         | Output Delay<br>(SRAS* and<br>SCAS*)      | 2    | 7    | 2    | 6    | ns   | 50pF    |
| SDQM[7:0]                          | Output Delay                              | 2    | 7    | 2    | 6    |      |         |
| Ready*                             | Setup                                     | 6    |      | 5    |      | ns   |         |
| Ready*                             | Hold                                      | 1    |      | 1    |      | ns   |         |
| DMAReq[0]*/MREQ*/<br>SRAS*         | Setup<br>(DMAReq[0]/<br>MREQ*)            | 4.5  |      | 3.5  |      | ns   |         |
| DMAReq[0]*/MREQ*/<br>SRAS*         | Hold<br>(DMAReq[0]/<br>MREQ*)             | 1    |      | 1    |      | ns   |         |
| DMAReq[0]*/MREQ*/<br>SRAS*         | Output Delay<br>(SRAS*)                   | 2    | 7    | 2    | 6    | ns   | 50pF    |
| DMAReq[1]*/<br>BankSel[1]          | Setup<br>(DMAReq[1]*)                     | 4.5  |      | 3.5  |      | ns   |         |
| DMAReq[1]*/<br>BankSel[1]          | Hold<br>(DMAReq[1]*)                      | 1    |      | 1    |      | ns   |         |
| DMAReq[1]*/<br>BankSel[1]          | Output Delay<br>(BankSel[1])              | 2    | 7    | 2    | 5    | ns   | 50pF    |
| DMAReq[2]*/DAdr[11]                | Setup<br>(DMAReq[2]*)                     | 4.5  |      | 3.5  |      | ns   |         |

# Table 451: AC Commercial Grade Timing (Continued) All Delays, Setup, and Hold times are referred to TClk RISING edge, unless stated otherwise.

#### Table 451: AC Commercial Grade Timing (Continued)

All Delays, Setup, and Hold times are referred to TClk RISING edge, unless stated otherwise.

|                              |                                   | 83   | Mhz  | 100  | Mhz  |      |         |
|------------------------------|-----------------------------------|------|------|------|------|------|---------|
| Signals                      | Description                       | Min. | Max. | Min. | Max. | Unit | Loading |
| Memory Interface (Co         | ontinued)                         |      |      |      |      |      |         |
| DMAReq[2]*/DAdr[11]          | Hold<br>(DMAReq[2]*)              | 1    |      | 1    |      | ns   |         |
| DMAReq[2]*/DAdr[11]          | Output Delay<br>(DAdr[11])        | 1.3  | 7    | 1.3  | 5    | ns   | 50pF    |
| DMAReq[3]*/SCAS*/<br>EOT[0]* | Setup<br>(DMAReq[3]*/<br>EOT[0]*) | 4.5  |      | 3.5  |      | ns   |         |
| DMAReq[3]*/SCAS*/<br>EOT[0]* | Hold<br>(DMAReq[3]*/<br>EOT[0]*)  | 1    |      | 1    |      | ns   |         |
| DMAReq[3]*/SCAS*/<br>EOT[0]* | Output Delay<br>(SCAS*)           | 2    | 7.5  | 2    | 6    | ns   | 50pF    |
| MGnt*/ByPsOE*                | Output Delay<br>(MGnt*)           | 2    | 7    | 2    | 6    | ns   | 30pF    |
| MGnt*/ByPsOE*                | Output Delay<br>(Bypass OE*)      | 2    | 7.5  | 2    | 6.5  | ns   | 30pF    |
| SRAS*,SCAS*, DWr*            | Output Delay                      | 2    | 7    | 2    | 5    | ns   | 50pF    |
| ALE                          | Output Delay                      | 2    | 7    | 2    | 5.5  | ns   | 30pF    |
| ALE                          | Output Delay,<br>TClk Falling     | 2    | 7    | 2    | 5.5  | ns   | 30pF    |
| CSTiming*                    | Output Delay                      | 2    | 7    | 2    | 5.5  | ns   | 30pF    |

### 32.1 TClk/PClk Restrictions

TClk cycle must be smaller than PClk cycle by at least 1ns (Tpclk> T tclk + 1ns). This restriction applies to all sync modes.

There is one exception to this restriction. TClk and PClk can run at the same frequency if the following conditions are met:

- The two clocks are synchronized (derived from the same clock source).
- If running at sync mode 1, a minimum skew of 5.5ns must be observed between rising edge of TClk and PClk, as shown in Figure 84. Galileo Technology recommends using an inverted TClk as PClk in order to guarantee this skew.
- If running at sync mode 2 or 3, a maximum skew of 2ns between rising edge of TClk and PClk must be met.





#### Figure 84: TClk = PClk, in Sync Mode = 1, Skew Requirement

In addition to the above restriction, there are few sync modes specific restrictions, summarized in Table 452.

| Sync<br>Mode | PCIk Frequency<br>Range  | Restrictions                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0,4          | from DC up to TClk       | Tpclk > Ttclk + 1ns                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1            | from TClk/2 up to TClk   | <ul> <li>Tpclk &lt; 2T tclk -1ns, unless running with synchronized</li> <li>Tpclk = 2Ttclk and minimum skew of 5.5ns between PClk rise and TClk rise is guaranteed, as shown in Figure 84. For example, if T tclk = 15ns (66MHz), Tpclk should be smaller than 29ns (unless running with synchronized clocks).</li> <li>NOTE: To guarantee this skew, Galileo Technology recommends using an inverted TClk as PClk.</li> </ul> |
| 2,3          | from TClk/2 up to TClk   | <b>TClk and PClk are synchronized</b> , and a maximum skew of 2ns between PClk rise and TClk rise is guaranteed.                                                                                                                                                                                                                                                                                                               |
| 5            | from TClk/3 up to TClk/2 | Tpclk < 3T tclk - 1ns, unless running with synchronized<br>Tpclk = 3T tclk and minimum skew of 5.5ns between PClk rise<br>and TClk rise is guaranteed. For example, if T tclk = 13.3ns<br>(75MHz), Tpclk should be smaller than 39ns (unless running<br>with synchronized clocks).                                                                                                                                             |
| 6,7          | from TClk/3 up to TClk/2 | <b>TClk and PClk are synchronized</b> , and a maximum skew of 2ns between PClk rise and TClk rise is guaranteed.                                                                                                                                                                                                                                                                                                               |

#### Table 452: TClk/PClk Restrictions

The sync mode can be programed by the CPU, the PCI or during autoload. For sync mode information, see Section 7.14.1 "PCI Internal Registers" on page 172.

### 32.2 Serial (Communication) Clock Domain AC Characteristic

- (TC= 0 70°C; VDDI/O= +3.3V, +/- 5%; VDDC = +2.5V=/-5%; External Load=50pf)
- **NOTE:** For information on the settings for Receive Sync Delay (RSD), Transmit Sync Delay(TSD), Driving Edge (DE), and Sync Edge (SE), see Section 15.4 "FlexTDM Configuration Register (TCR)" on page 384.

| Symbol | Description               | Min | Max | Unit |
|--------|---------------------------|-----|-----|------|
| t20    | TRCLK Cycle Time          | 18  |     | ns   |
| t21    | TRCLK Width Low           | 7.2 |     | ns   |
| t22    | TRCLK Width High          | 7.2 |     | ns   |
| t23    | TRSYNC Setup Time         | 5   |     | ns   |
| t24    | TRSYNC Hold Time          | 5   |     | ns   |
| t25    | TRSYNC Rise and Fall Time |     | 15  | ns   |
| t27    | TRXD Setup Time           | 5   |     | ns   |
| t28    | TRXD Hold Time            | 5   |     | ns   |

#### Table 453: Flex-TDM Receive Timing - Normal Clock

#### Figure 85: Flex-TDM Receive Timing - Normal Clock Waveform





| Symbol | Description               | Min | Max | Unit |
|--------|---------------------------|-----|-----|------|
| t40    | TTCLK Cycle Time          | 18  |     | ns   |
| t41    | TTCLK Width Low           | 7.2 |     | ns   |
| t42    | TTCLK Width High          | 7.2 |     | ns   |
| t43    | TTSYNC Setup Time         | 5   |     | ns   |
| t44    | TTSYNC Hold Time          | 5   |     | ns   |
| t45    | TTSYNC Rise and Fall Time |     | 15  | ns   |
| t46    | TDSTRB Output Delay       |     | 13  | ns   |
| t47    | TTCLK to TDCLK Delay Time |     | 8   | ns   |
| t48    | TTXD Output Delay         |     | 13  | ns   |

 Table 454: Flex-TDM Transmit Timing - Normal Speed Clock

#### Figure 86: Flex-TDM Transmit Timing - Normal Speed Clock Waveform



| Symbol | Description               | Min | Max | Unit |
|--------|---------------------------|-----|-----|------|
| t30    | TRCLK Cycle Time          | 18  |     | ns   |
| t31    | TRCLK Width Low           | 7.2 |     | ns   |
| t32    | TRCLK Width High          | 7.2 |     | ns   |
| t33    | TRSYNC Setup Time         | 5   |     | ns   |
| t34    | TRSYNC Hold Time          | 5   |     | ns   |
| t35    | TRSYNC Rise and Fall Time |     | 15  | ns   |
| t37    | TRXD Setup Time           | 5   |     | ns   |
| t38    | TRXD Hold Time            | 5   |     | ns   |

#### Figure 87: Flex-TDM Receive Timing - Double Speed Clock Waveform







#### Figure 88: Flex-TDM Receive Timing - Double Speed Clock Waveform

| Table 456: Flex-TDM | Transmit Timin | a - Double S | Speed Clock |
|---------------------|----------------|--------------|-------------|
|                     | manomit mining | g - Double c |             |

| Symbol | Description               | Min | Max | Unit |
|--------|---------------------------|-----|-----|------|
| t50    | TTCLK Cycle Time          | 18  |     | ns   |
| t51    | TTCLK Width Low           | 7.2 |     | ns   |
| t52    | TTCLK Width High          | 7.2 |     | ns   |
| t53    | TTSYNC Setup Time         | 5   |     | ns   |
| t54    | TTSYNC Hold Time          | 5   |     | ns   |
| t55    | TTSYNC Rise and Fall Time |     | 15  | ns   |
| t56    | TDSTRB Output Delay       |     | 13  | ns   |
| t57    | TTCLK to TDCLK Delay      |     | 8   | ns   |
| t58    | TTXD Output Delay         |     | 13  | ns   |





#### Figure 89: Flex-TDM Transmit Timing - Double Speed Clock Waveform

#### Figure 90: Flex-TDM Transmit Timing - Double Speed Clock Waveform





| Symbol | Description     | Min | Max | Unit |
|--------|-----------------|-----|-----|------|
| t60    | RCLK Cycle Time | 18  |     | ns   |
| t61    | RCLK Width Low  | 7.2 |     | ns   |
| t62    | RCLK Width High | 7.2 |     | ns   |
| t63    | RXD Setup Time  | 5   |     | ns   |
| t64    | RXD Hold Time   | 5   |     | ns   |
| t65    | CD* Setup Time  | 5   |     | ns   |
| t66    | CD* Hold Time   | 5   |     | ns   |

Table 457: MPSC Receive Timing

#### Figure 91: MPSC Receive Timing



| Symbol | Description     | Min | Max | Unit |
|--------|-----------------|-----|-----|------|
| t70    | TCLK Cycle Time | 18  |     | ns   |
| t71    | TCLK Width Low  |     |     | ns   |
| t72    | TCLK Width High | 7.2 |     | ns   |
| t73    | TXD Delay Time  |     | 13  | ns   |
| t74    | RTS* Delay Time |     | 13  | ns   |
| t75    | CTS* Setup Time | 5   |     | ns   |
| t76    | CTS* Hold Time  | 5   |     | ns   |

#### Figure 92: MPSC Transmit Timing





### 32.3 MPSC Waveforms

### 32.3.1 Output Delay From RTS\*





#### Figure 94: Output Delay From RTS\*, Synchronous CTS\* (CTSS=1 in MMCRLx) Waveform





### 32.3.2 Output Delay From CTS\*









#### 32.3.3 CTS\* Loss In Synchronous Protocol

Figure 97: CTS\* Loss In Synchronous Protocol: Start of Frame Waveform With CTS Lost







Figure 98: CTS\* Loss In Synchronous Protocol: Start of Frame Waveform Without CTS Lost









### 32.3.4 Reception Control Using CD\*







#### 32.3.5 External Sync





#### 32.3.6 Transmit Synchronize to Receive





Figure 104:Transmit Synchronize to Receive (TSYN=1 in MMCRLx), External Sync (RSYL=0 in MMCRHx), CD\* and CTS\* Pulse Mode (CTSM=1 and CDM=1 in MMCRLx), Synchronous CTS\* (CTSS=1 in MMCRLx) Waveform





### 32.4 MII Waveforms

### 32.4.1 Transmit Timing

#### Table 459: MII Transmit Timing

| Symbol | Description                           | Min | Тур              | Max | Unit |
|--------|---------------------------------------|-----|------------------|-----|------|
| Tmtxcc | MII TxCLK Cycle                       |     | 40t <sup>1</sup> |     | ns   |
| Tmtxch | MII TxCLK High                        | 15t |                  | 25t | ns   |
| Tmtxcl | MII TxCLK Low                         | 15t |                  | 25t | ns   |
| Tmtxv  | MII TxCLK rising to TXD, TXEN valid   |     |                  | 20  | ns   |
| Tmtxh  | MII TXD, TXEN hold after TxCLK rising | 5   |                  |     | ns   |

1. t=1 for 100Mb/s operation, t=10 for 10Mb/s operation

#### Figure 105:MII Port Transmit Signals Timing



### 32.4.2 Receive Timing

#### Table 460: MII Receive Timing

| Symbol | Description                             | Min | Тур              | Max | Unit |
|--------|-----------------------------------------|-----|------------------|-----|------|
| Tmrxcc | MII RxCLK Cycle                         |     | 40t <sup>1</sup> |     | ns   |
| Tmrxch | MII RxCLK High                          | 15t |                  | 25t | ns   |
| Tmrxcl | MII RxCLK Low                           | 15t |                  | 25t | ns   |
| Tmrxs  | MII RXD, RXDV setup before RxCLK rising | 10  |                  |     | ns   |
| Tmrxh  | MII RXD, RXDV hold after RxCLK rising   | 5   |                  |     | ns   |

1. t=1 for 100Mb/s operation, t=10 for 10Mb/s operation



#### Figure 106:MII Port Receive Signals Timing



### 32.5 JTAG AC Characteristics

#### Table 461: JTAG AC Characteristics

| Symbol | Description            | Min  | Max | Unit |
|--------|------------------------|------|-----|------|
| Tjck   | Jtack Clock Period     | 1000 |     | ns   |
| Tjckh  | TCK High Period        | 400  |     | ns   |
| Tjckl  | TCK Low Period         | 400  |     | ns   |
| Tjdis  | TDI and TMS Setup Time | 20   |     | ns   |
| Tjdih  | TDI and TMS Hold Time  | 20   |     | ns   |
| Tjdo   | TDO Output Delay       | 2    | 20  | ns   |

#### Figure 107: JTAG AC Timing





### 32.6 Additional Delay Due to Capacitive Loading

Some applications may require additional capacitive loading on different output pins of the GT-96100A. For example, when using multiple GT-96100A devices connected to the same SysAD bus, the 50pF load specification may be exceeded. This additional loading affects the output delays of the signals, depending on the drive strength of the output driver.

The following section describes how to calculate the affects of additional loading on the output drivers.

### 32.6.1 Calculating the Maximum Delay due to Loading

The basic equation for calculating the maximum delay is:

Tmax = [Atypa + (Btyp \* Cr)] \* 1.6

where:

- Tmax is the maximum delay in nanoseconds.
- Atypa must be calculated by the designer as shown in Section 32.6.1.1 "Calculating Atypa" on page 531.
- Btyp is a parameter according to the specific output buffer from Table 462.
- Cr is the capacitance required, in picofarads.

#### 32.6.1.1 Calculating Atypa

Atypa can be calculated by using the given values in the AC Timing Parameters table. We start with the equation:

Tspec = [Atypa + (Btyp \* Cds)] \* 1.6

and solving for Atypa:

Atypa = (Tspec/1.6) - (Btyp \* Cds)

where:

- Tspec is the maximum delay parameter from the AC Timing Parameters Table, in nanoseconds.
- Btyp is a parameter according to the specific output buffer from Table 462.
- Cds is the capacitance parameter from the AC Timing Parameters Table, in picofarads.

**NOTE:** 1.6 is the worst case derating factor.

#### 32.6.2 Calculating the Minimum Delay due to Loading

The basic equation for calculating the maximum delay is:

Tmin = [Atypb + (Btyp \* Cr)] \* 0.7

where:

- Tmin is the minimum delay in nanoseconds
- Atypb must be calculated by the designer as shown in Section 32.6.2.1 "Calculating Atypb" on page 532
- Btyp is a parameter according to the specific output buffer from Table 462
- Cr is the capacitance required, in picofarads.

#### 32.6.2.1 Calculating Atypb

Atypb can be calculated by using the given values in the AC Timing Parameters table. We start with the equation:

Tspec = [Atypb + (Btyp \* Cds)] \* 0.7

and solving for Atypb:

Atypb = (Tspec/0.7) - (Btyp \* Cds)

where:

- Tspec is the maximum delay parameter from the AC Timing Parameters Table, in nanoseconds
- Btyp is a parameter according to the specific output buffer from Table 462
- Cds is the capacitance parameter from the AC Timing Parameters Table, in picofarads.

**NOTE:** 0.7 is the worst case derating factor.

#### 32.6.3 Btyp Values

Table 462 lists the Btyp values for the different output buffers of the GT-96100A. See the DC Parameters Section for the corresponding pin and output driver.

| Output Driver   | Low to High Btyp Value | High to Low Btype Value |
|-----------------|------------------------|-------------------------|
| 4mA             | 0.06                   | 0.077                   |
| 8mA             | 0.031                  | 0.039                   |
| 12mA            | 0.021                  | 0.028                   |
| 16mA            | 0.018                  | 0.022                   |
| All PCI Outputs | 0.015                  | 0.018                   |

Table 462: Btyp Values

### 32.6.4 Tmax Calculating Example

The following is an example of how to calculate the maximum delay on the AD[0] line for a 75pF load.

From the AC Timing Parameters Table, for a 50pF load, the maximum output delay on the AD[0] line is specified as 7ns for 83 Mhz. Looking at Table 462, Btyp for AD[0], which is an 8mA driver, is = 0.031 (Low to High transition).

Substituting these values into:

Atypa = (Tspec/1.6) - (Btyp \* Cds)

gives Atypa = 2.83.

Substituting Atypa of 3.45, Btyp of 0.031 and Cr of 75pF in:

Tmax = [Atypa + (Btyp \* Cr)] \* 1.6

gives Tmax = 8.25. This means that the maximum output delay of AD[0] with a 75pF load is 8.25ns.



### 33. PINOUT TABLE, 492 PIN BGA

**NOTE:** The following table is sorted by ball number.

| D - 11 " |             |         |          |         |            |
|----------|-------------|---------|----------|---------|------------|
| Ball #   | Signal Name |         |          | C01–C26 |            |
| A01–A26  | Т           | B01–B26 | B01–B26  |         | Τ          |
| A01      | Req0_       | B01     | PAD0[28] | C01     | PAD0[24]   |
| A02      | GPP[14]     | B02     | JTAG[3]  | C02     | PAD0[30]   |
| A03      | GPP[13]     | B03     | JTAG[0]  | C03     | GNT0_      |
| A04      | GPP[6]      | B4      | VssPLL   | C04     | JTAG[1]    |
| A05      | VccPLL      | B05     | GPP[7]   | C05     | GPP[12]    |
| A06      | MII1[14]    | B06     | GPP[2]   | C06     | GPP[9]     |
| A07      | MII1[10]    | B07     | MDC      | C07     | GPP[3]     |
| A08      | MII1[4]     | B08     | MII1[13] | C08     | GPP[0]     |
| A09      | MII1[3]     | B09     | MII1[9]  | C09     | MII1[12]   |
| A10      | NC          | B10     | MII1[5]  | C10     | MII1[6]    |
| A11      | MII0[12]    | B11     | MII1[1]  | C11     | MII1[8]    |
| A12      | MII0[11]    | B12     | MII0[13] | C12     | NC         |
| A13      | MII0[8]     | B13     | MII0[9]  | C13     | MII0[6]    |
| A14      | MII0[2]     | B14     | MII0[5]  | C14     | MII0[4]    |
| A15      | MII0[1]     | B15     | NC       | C15     | PORTF[5]   |
| A16      | PORTF[6]    | B16     | PORTF[3] | C16     | PORTF[1]   |
| A17      | PORTF[4]    | B17     | PORTE[6] | C17     | PORTE[3]   |
| A18      | PORTF[2]    | B18     | PORTE[4] | C18     | PORTD[6]   |
| A19      | PORTE[5]    | B19     | PORTD[5] | C19     | NC         |
| A20      | PORTE[1]    | B20     | PORTD[0] | C20     | PORTC[5]   |
| A21      | PORTD[4]    | B21     | PORTC[6] | C21     | PORTC[1]   |
| A22      | NC          | B22     | PORTC[0] | C22     | PORTB[4]   |
| A23      | PORTC[3]    | B23     | PORTB[0] | C23     | PORTA[3]   |
| A24      | PORTB[1]    | B24     | PORTA[2] | C24     | DMAReq[0]_ |
| A25      | PORTA[4]    | B25     | Ready_   | C25     | AD[0]      |
| A26      | PORTA[0]    | B26     | AD[33]   | C26     | AD[2]      |
|          | 1           | 1       |          |         |            |

#### Table 463: GT-96100A Pinout Table

| Ball #  | Signal Name |         |          |         |          |
|---------|-------------|---------|----------|---------|----------|
| D01–D26 |             | E01–E26 |          | F01–10, | F17–F26  |
| D01     | PAD0[17]    | E01     | Irdy0_   | F01     | PErr0_   |
| D02     | PAD0[25]    | E02     | PAD0[20] | F02     | Frame0_  |
| D03     | PAD0[29]    | E03     | PAD0[23] | F03     | PAD0[18] |
| D04     | JTAG[2]     | E04     | PAD0[26] | F04     | PAD0[22] |
| D05     | JTAG[4]     | E05     | PAD0[31] | F05     | PAD0[27] |
| D06     | GPP[8]      | E06     | GPP[15]  | F06     | GND      |
| D07     | GPP[5]      | E07     | GPP[10]  | F07     | GND      |
| D08     | GPP[1]      | E08     | GPP[11]  | F08     | VCC 2.5  |
| D09     | MDIO        | E09     | GPP[4]   | F09     | VCC 3.3  |
| D10     | MII1[11]    | E10     | NC       | F10     | VCC 3.3  |
| D11     | MII1[2]     | E11     | MII1[7]  | F17     | VCC 3.3  |
| D12     | MII0[14]    | E12     | MII1[0]  | F18     | VCC 2.5  |
| D13     | MII0[7]     | E13     | MII0[10] | F19     | VCC 2.5  |
| D14     | MII0[0]     | E14     | MII0[3]  | F20     | GND      |
| D15     | PORTF[0]    | E15     | NC       | F21     | GND      |
| D16     | PORTE[2]    | E16     | PORTD[2] | F22     | AD[1]    |
| D17     | PORTE[0]    | E17     | PORTD[3] | F23     | AD[36]   |
| D18     | PORTD[1]    | E18     | PORTC[2] | F24     | AD[4]    |
| D19     | PORTC[4]    | E19     | PORTB[2] | F25     | AD[39]   |
| D20     | PORTB[6]    | E20     | PORTB[3] | F26     | AD[11]   |
| D21     | PORTB[5]    | E21     | PORTA[5] | G01–G0  | 06       |
| D22     | PORTA[6]    | E22     | PORTA[1] | G01     | PAD0[14] |
| D23     | ALE         | E23     | BypsOE_  | G02     | DevSel0_ |
| D24     | CSTiming_   | E24     | AD[34]   | G03     | CBE0_[2] |
| D25     | AD[32]      | E25     | AD[5]    | G04     | PAD0[21] |
| D26     | AD[37]      | E26     | AD[9]    | G05     | IDSel0   |
|         | -           | •       | -        | G06     | GND      |



| Ball #  | Signal Name |          |          |                              |            |
|---------|-------------|----------|----------|------------------------------|------------|
| G21–G26 |             | J21–J26  |          | L11–L16                      | 6, L22–L26 |
| G21     | GND         | J21      | VCC 3.3  | L11                          | GND        |
| G22     | AD[35]      | J22      | AD[38]   | L12                          | GND        |
| G23     | AD[6]       | J23      | AD[10]   | L13                          | GND        |
| G24     | AD[7]       | J24      | AD[12]   | L14                          | GND        |
| G25     | AD[42]      | J25      | AD[45]   | L15                          | GND        |
| G26     | AD[13]      | J26      | ADP[4]   | L16                          | GND        |
| H01–H06 | , H21–H26   | K01–K06, | K21–K26  | L22                          | AD[46]     |
| H01     | PAD0[10]    | K01      | PAD0[6]  | L23                          | ADP[1]     |
| H02     | Par0        | K02      | PAD0[9]  | L24                          | AD[15]     |
| H03     | Trdy0_      | K03      | PAD0[13] | L25                          | ADP[5]     |
| H04     | PAD0[16]    | K04      | CBE0_[1] | L26                          | SDQM[5]    |
| H05     | CBE0_[3]    | K05      | Lock0_   | M01–M05, M11–M16,<br>M22–M26 |            |
| H06     | VCC 2.5     | K06      | VCC 3.3  | M01                          | PAD0[1]    |
| H21     | VCC 2.5     | K21      | VCC 3.3  | M02                          | PAD0[2]    |
| H22     | AD[3]       | K22      | AD[41]   | M03                          | PAD0[5]    |
| H23     | AD[8]       | K23      | AD[44]   | M04                          | CBE0_[0]   |
| H24     | AD[40]      | K24      | AD[14]   | M05                          | PAD0[3]    |
| H25     | AD[43]      | K25      | AD[47]   | M11                          | GND        |
| H26     | ADP[0]      | K26      | SDQM[0]  | M12                          | GND        |
| J01–J06 |             | J01–J05  |          | M13                          | GND        |
| J01     | PAD0[8]     | L01      | PAD0[4]  | M14                          | GND        |
| J02     | PAD0[12]    | L02      | PAD0[7]  | M15                          | GND        |
| J03     | PAD0[15]    | L03      | VREF0    | M16                          | GND        |
| J04     | Stop0_      | L04      | PAD0[11] | M22                          | DWr_       |
| J05     | PAD0[19]    | L05      | SErr0_   | M23                          | SDQM[4]    |
| J06     | VCC 2.5     |          |          | M24                          | SCAS_      |
|         |             | _        |          | M25                          | SDQM[1]    |
|         |             |          |          | M26                          | SCS_[0]    |

Table 463: GT-96100A Pinout Table (Continued)



| Ball #   | Signal Name                  |                     |            |         |            |         |
|----------|------------------------------|---------------------|------------|---------|------------|---------|
|          | N01–N05, N11–N16,<br>N22–N26 |                     | · · ·      |         | T11–T16,   | T22–T26 |
| N01      | PAD0[0]                      | P22                 | DAdr[4]    | T11     | GND        |         |
| N02      | TClk                         | P23                 | DAdr[7]    | T12     | GND        |         |
| N03      | NC                           | P24                 | DAdr[3]    | T13     | GND        |         |
| N04      | PClk0                        | P25                 | DAdr[2]    | T14     | GND        |         |
| N05      | NC                           | P26                 | DAdr[5]    | T15     | GND        |         |
| N11      | GND                          | R01–R05,<br>R22–R26 | R11–R16,   | T16     | GND        |         |
| N12      | GND                          | R01                 | PAD1[30]   | T22     | AD[17]     |         |
| N13      | GND                          | R02                 | PAD1[25]   | T23     | SDQM[7]    |         |
| N14      | GND                          | R03                 | CBE1_[3]   | T24     | DMAReq_[1] |         |
| N15      | GND                          | R04                 | PAD1[24]   | T25     | NC         |         |
| N16      | GND                          | R05                 | PAD1[27]   | T26     | DAdr[10]   |         |
| N22      | SCS_[1]                      | R11                 | GND        | U01–U06 | , U21–U26  |         |
| N23      | DAdr[0]                      | R12                 | GND        | U01     | PAD1[26]   |         |
| N24      | DAdr[1]                      | R13                 | GND        | U02     | PAD1[22]   |         |
| N25      | SRAS_                        | R14                 | GND        | U03     | PAD1[23]   |         |
| N26      | NC                           | R15                 | GND        | U04     | PAD1[19]   |         |
| P01–P05, | P11–P16                      | R16                 | GND        | U05     | PErr1_     |         |
| P01      | PAD1[28]                     | R22                 | DAdr[9]    | U06     | VCC 3.3    |         |
| P02      | PClk1                        | R23                 | SCS_[2]    | U21     | VCC 3.3    |         |
| P03      | ClkOutPLL                    | R24                 | DMAReq_[2] | U22     | AD[48]     |         |
| P04      | NC                           | R25                 | DAdr[8]    | U23     | ADP[6]     |         |
| P05      | PAD1[29]                     | R26                 | DAdr[6]    | U24     | SDQM[3]    |         |
| P11      | GND                          | T01–T05             |            | U25     | SCS_[3]    |         |
| P12      | GND                          | T01                 | PAD1[31]   | U26     | DMAReq_[3] |         |
| P13      | GND                          | T02                 | VREF1      |         |            |         |
| P14      | GND                          | Т03                 | PAD1[17]   |         |            |         |
| P15      | GND                          | T04                 | IDsel1     |         |            |         |
| P16      | GND                          | T05                 | PAD1[16]   |         |            |         |
|          |                              |                     |            |         |            |         |



| Ball #   | Signal Name |         |                      |         |             |
|----------|-------------|---------|----------------------|---------|-------------|
| V01–V06, | , V21–V26   | Y01-Y06 | , Y21–Y26            | AA23–AA | 126         |
| V01      | PAD1[20]    | Y01     | CBE1_[2]             | AA23    | AD[55]      |
| V02      | PAD1[18]    | Y02     | DevSel1_             | AA24    | AD[22]      |
| V03      | Frame1_     | Y03     | PAD1[13]             | AA25    | AD[51]      |
| V04      | Stop1_      | Y04     | PAD1[14]             | AA26    | AD[16]      |
| V05      | PAD1[15]    | Y05     | PAD1[4]              | AB01–AE | 324         |
| V06      | VCC 3.3     | Y06     | GND                  | AB01    | SErr1_      |
| V21      | VCC 2.5     | Y21     | GND                  | AB02    | PAD1[9]     |
| V22      | AD[53]      | Y22     | AD[56]               | AB03    | PAD1[5]     |
| V23      | AD[49]      | Y23     | AD[23]               | AB04    | SysAD[4]    |
| V24      | ADP[3]      | Y24     | AD[20]               | AB05    | SysAD[46]   |
| V25      | SDQM[6]     | Y25     | AD[18]               | AB06    | SysAD[45]   |
| V26      | BankSel[0]  | Y26     | ADP[2]               | AB07    | SysAD[12]   |
| W01–W0   | 6, W21–W26  | AA01–A  | AA01–AA10, AA17–AA22 |         | SysAD[33]   |
| W01      | PAD1[21]    | AA01    | Trdy1_               | AB09    | SysADC[1]   |
| W02      | lrdy1_      | AA02    | PAD1[12]             | AB10    | NC          |
| W03      | Par1        | AA03    | PAD1[11]             | AB11    | SysAD[62]   |
| W04      | CBE1_[1]    | AA04    | PAD1[10]             | AB12    | SysAD[52]   |
| W05      | CBE1_[0]    | AA05    | PAD1[0]              | AB13    | NC          |
| W06      | VCC 2.5     | AA06    | GND                  | AB14    | NC          |
| W21      | VCC 2.5     | AA07    | GND                  | AB15    | SysAD[20]   |
| W22      | AD[25]      | AA08    | VCC 2.5              | AB16    | SysAD[26]   |
| W23      | AD[52]      | AA09    | VCC 2.5              | AB17    | SysCMD[1]   |
| W24      | AD[50]      | AA10    | VCC 3.3              | AB18    | ScDOE_      |
| W25      | ADP[7]      | AA17    | VCC 3.3              | AB19    | Interrupt1_ |
| W26      | SDQM[2]     | AA18    | VCC 3.3              | AB20    | Interrupt0_ |
|          |             | AA19    | VCC 2.5              | AB21    | ByPassPLL   |
|          |             | AA20    | GND                  | AB22    | AD[29]      |
|          |             | AA21    | GND                  | AB23    | AD[58]      |
|          |             | AA22    | AD[27]               | AB24    | AD[24]      |

Table 463: GT-96100A Pinout Table (Continued)

| Ball #    | Signal Name |        |           |        |           |
|-----------|-------------|--------|-----------|--------|-----------|
| AB25–AB26 |             | AD01–A | D26       | AE01–A | E26       |
| AB25      | AD[54]      | AD01   | PAD1[6]   | AE01   | PAD1[7]   |
| AB26      | AD[19]      | AD02   | PAD1[2]   | AE02   | Req1_     |
| AC01-AC   | 26          | AD03   | SysAD[40] | AE03   | SysAD[10] |
| AC01      | PAD1[8]     | AD04   | SysAD[37] | AE04   | SysAD[13] |
| AC02      | PAD1[1]     | AD05   | SysAD[41] | AE05   | SysAD[11] |
| AC03      | PAD1[3]     | AD06   | SysAD[15] | AE06   | SysAD[9]  |
| AC04      | Gnt1_       | AD07   | SysAD[38] | AE07   | SysAD[35] |
| AC05      | SysAD[8]    | AD08   | SysAD[34] | AE08   | SysAD[3]  |
| AC06      | SysAD[39]   | AD09   | SysAD[0]  | AE09   | SysAD[1]  |
| AC07      | SysAD[14]   | AD10   | SysADC[3] | AE10   | SysADC[0] |
| AC08      | SysAD[44]   | AD11   | SysADC[6] | AE11   | SysADC[2] |
| AC09      | SysADC[5]   | AD12   | SysAD[49] | AE12   | SysAD[30] |
| AC10      | SysADC[7]   | AD13   | SysAD[16] | AE13   | SysAD[29] |
| AC11      | SysAD[63]   | AD14   | SysAD[17] | AE14   | SysAD[28] |
| AC12      | SysAD[51]   | AD15   | SysAD[24] | AE15   | SysAD[25] |
| AC13      | SysAD[19]   | AD16   | SysAD[22] | AE16   | SysAD[21] |
| AC14      | SysAD[18]   | AD17   | SysAD[23] | AE17   | SysAD[53] |
| AC15      | SysAD[50]   | AD18   | SysCMD[6] | AE18   | SysAD[56] |
| AC16      | SysAD[57]   | AD19   | ValidOut_ | AE19   | SysCMD[5] |
| AC17      | SysCMD[7]   | AD20   | Release_  | AE20   | SysCMD[3] |
| AC18      | SysCMD[2]   | AD21   | NC        | AE21   | WrRdy_    |
| AC19      | ValidIn_    | AD22   | SerInt0_  | AE22   | ScWord[1] |
| AC20      | ScMatch     | AD23   | NMI_      | AE23   | Reset_    |
| AC21      | ScWord[0]   | AD24   | AD[30]    | AE24   | WDE_      |
| AC22      | AD[62]      | AD25   | AD[60]    | AE25   | AD[31]    |
| AC23      | AD[63]      | AD26   | AD[57]    | AE26   | AD[59]    |
| AC24      | AD[28]      |        |           |        |           |
| AC25      | AD[26]      |        |           |        |           |
| AC26      | AD[21]      |        |           |        |           |



| Ball #   | Signal Name |
|----------|-------------|
| AF01–AF2 | ?6          |
| AF01     | SysAD[36]   |
| AF02     | SysAD[7]    |
| AF03     | SysAD[43]   |
| AF04     | SysAD[6]    |
| AF05     | SysAD[5]    |
| AF06     | SysAD[42]   |
| AF07     | SysAD[47]   |
| AF08     | SysAD[2]    |
| AF09     | SysAD[32]   |
| AF10     | SysADC[4]   |
| AF11     | SysAD[31]   |
| AF12     | SysAD[48]   |
| AF13     | SysAD[60]   |
| AF14     | SysAD[61]   |
| AF15     | SysAD[54]   |
| AF16     | SysAD[27]   |
| AF17     | SysAD[55]   |
| AF18     | SysAD[59]   |
| AF19     | SysAD[58]   |
| AF20     | SysCMD[8]   |
| AF21     | SysCMD[4]   |
| AF22     | SysCMD[0]   |
| AF23     | ScTCE_      |
| AF24     | SerInt1_    |
| AF25     | OutModePLL  |
| AF26     | AD[61]      |

**NOTE:** All NC pins must be connected to ground for future devices compatibility. In order to use these pins in a future device, Galileo Technology recommends that these pins be connected by zero ohm resistors.



|    | 1         | 2        | 3         | 4         | 5         | 6         | 7         | 8         | 9         | 10        | 11        | 12        | 13        | 14        |
|----|-----------|----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| А  | Req0_     | GPP[14]  | GPP[13]   | GPP[6]    | VccPLL    | MII1[14]  | MII1[10]  | MII1[4]   | MII1[3]   | NC        | MII0[12]  | MII0[11]  | MII0[8]   | MII0[2]   |
| В  | PAD0[28]  | JTAG[3]  | JTAG[0]   | VssPLL    | GPP[7]    | GPP[2]    | MDC       | MII1[13]  | MII1[9]   | MII1[5]   | MII1[1]   | MII0[13]  | MII0[9]   | MII0[5]   |
| С  | PAD0[24]  | PAD0[30] | Gnt0_     | JTAG[1]   | GPP[12]   | GPP[9]    | GPP[3]    | GPP[0]    | MII1[12]  | MII1[6]   | MII1[8]   | NC        | MII0[6]   | MII0[4]   |
| D  | PAD0[17]  | PAD0[25] | PAD0[29]  | JTAG[2]   | JTAG[4]   | GPP[8]    | GPP[5]    | GPP[1]    | MDIO      | MII1[11]  | MII1[2]   | MII0[14]  | MII0[7]   | MII0[0]   |
| Е  | Irdy0_    | PAD0[20] | PAD0[23]  | PAD0[26]  | PAD0[31]  | GPP[15]   | GPP[10]   | GPP[11]   | GPP[4]    | NC        | MII1[7]   | MII1[0]   | MII0[10]  | MII0[3]   |
| F  | PErr0_    | Frame0_  | PAD0[18]  | PAD0[22]  | PAD0[27]  | VSS       | VSS       | VCC2.5    | VCC3.3    | VCC3.3    |           |           |           |           |
| G  | PAD0[14]  | DevSel0_ | CBE0_[2]  | PAD0[21]  | IDSel0    | VSS       |           |           |           |           | I         |           |           |           |
| н  | PAD0[10]  | Par0     | Trdy0_    | PAD0[16]  | CBE0_[3]  | VCC2.5    |           |           |           |           |           |           |           |           |
| J  | PAD0[8]   | PAD0[12] | PAD0[15]  | Stop0_    | PAD0[19]  | VCC2.5    |           |           |           |           |           |           |           |           |
| к  | PAD0[6]   | PAD0[9]  | PAD0[13]  | CBE0_[1]  | Lock0_    | VCC3.3    |           |           |           |           |           |           |           |           |
| L  | PAD0[4]   | PAD0[7]  | VREF0     | PAD0[11]  | SErr0_    |           |           |           |           |           | VSS       | VSS       | VSS       | VSS       |
| м  | PAD0[1]   | PAD0[2]  | PAD0[5]   | CBE0_[0]  | PAD0[3]   |           |           |           |           |           | VSS       | VSS       | VSS       | VSS       |
| Ν  | PAD0[0]   | TClk     | NC        | PClk0     | NC        |           |           |           |           |           | VSS       | VSS       | VSS       | VSS       |
| Ρ  | PAD1[28]  | PClk1    | ClkOutPLL | NC        | PAD1[29]  |           |           |           |           |           | VSS       | VSS       | VSS       | VSS       |
| R  | PAD1[30]  | PAD1[25] | CBE1_[3]  | PAD1[24]  | PAD1[27]  |           |           |           |           |           | VSS       | VSS       | VSS       | VSS       |
| т  | PAD1[31]  | VREF1    | PAD1[17]  | IDSel1    | PAD1[16]  |           |           |           |           |           | VSS       | VSS       | VSS       | VSS       |
| U  | PAD1[26]  | PAD1[22] | PAD1[23]  | PAD1[19]  | PErr1_    | VCC3.3    |           |           |           |           |           |           |           |           |
| v  | PAD1[20]  | PAD1[18] | Frame1_   | Stop1_    | PAD1[15]  | VCC3.3    |           |           |           |           |           |           |           |           |
| w  | PAD1[21]  | Irdy1_   | Par1      | CBE1_[1]  | CBE1_[0]  | VCC2.5    |           |           |           |           |           |           |           |           |
| Y  | CBE1_[2]  | DevSel1_ | PAD1[13]  | PAD1[14]  | PAD1[4]   | VSS       |           |           |           |           |           |           |           |           |
| AA | Trdy1_    | PAD1[12] | PAD1[11]  | PAD1[10]  | PAD1[0]   | VSS       | VSS       | VCC2.5    | VCC2.5    | VCC3.3    |           |           |           |           |
| AB | SErr1_    | PAD1[9]  | PAD1[5]   | SysAD[4]  | SysAD[46] | SysAD[45] | SysAD[12] | SysAD[33] | SysADC[1] | NC        | SysAD[62] | SysAD[52] | NC        | NC        |
| AC | PAD1[8]   | PAD1[1]  | PAD1[3]   | Gnt1_     | SysAD[8]  | SysAD[39] | SysAD[14] | SysAD[44] | SysADC[5] | SysADC[7] | SysAD[63] | SysAD[51] | SysAD[19] | SysAD[18] |
| AD | PAD1[6]   | PAD1[2]  | SysAD[40] | SysAD[37] | SysAD[41] | SysAD[15] | SysAD[38] | SysAD[34] | SysAD[0]  | SysADC[3] | SysADC[6] | SysAD[49] | SysAD[16] | SysAD[17] |
| AE | PAD1[7]   | Req1_    | SysAD[10] | SysAD[13] | SysAD[11] | SysAD[9]  | SysAD[35] | SysAD[3]  | SysAD[1]  | SysADC[0] | SysADC[2] | SysAD[30] | SysAD[29] | SysAD[28] |
| AF | SysAD[36] | SysAD[7] | SysAD[43] | SysAD[6]  | SysAD[5]  | SysAD[42] | SysAD[47] | SysAD[2]  | SysAD[32] | SysADC[4] | SysAD[31] | SysAD[48] | SysAD[60] | SysAD[61] |
|    | 1         | 2        | 3         | 4         | 5         | 6         | 7         | 8         | 9         | 10        | 11        | 12        | 13        | 14        |

#### Figure 108:GT-96100A Pinout Map (top view, left side)



| Figure 109:GT-96100A       | Pinout Map | (top view.  | right side) |
|----------------------------|------------|-------------|-------------|
| I Iguite Toolor of toolook | i mout mup | (top 11011) | ngni siac)  |

| 15        | 16        | 17        | 18        | 19          | 20          | 21        | 22        | 23       | 24         | 25         | 26         |    |
|-----------|-----------|-----------|-----------|-------------|-------------|-----------|-----------|----------|------------|------------|------------|----|
| MII0[1]   | PORTF[6]  | PORTF[4]  | PORTF[2]  | PORTE[5]    | PORTE[1]    | PORTD[4]  | NC        | PORTC[3] | PORTB[1]   | PORTA[4]   | PORTA[0]   | А  |
| NC        | PORTF[3]  | PORTE[6]  | PORTE[4]  | PORTD[5]    | PORTD[0]    | PORTC[6]  | PORTC[0]  | PORTB[0] | PORTA[2]   | Ready_     | AD[33]     | в  |
| PORTF[5]  | PORTF[1]  | PORTE[3]  | PORTD[6]  | NC          | PORTC[5]    | PORTC[1]  | PORTB[4]  | PORTA[3] | DMAReq[0]_ | AD[0]      | AD[2]      | с  |
| PORTF[0]  | PORTE[2]  | PORTE[0]  | PORTD[1]  | PORTC[4]    | PORTB[6]    | PORTB[5]  | PORTA[6]  | ALE      | CSTiming_  | AD[32]     | AD[37]     | D  |
| NC        | PORTD[2]  | PORTD[3]  | PORTC[2]  | PORTB[2]    | PORTB[3]    | PORTA[5]  | PORTA[1]  | BypsOE_  | AD[34]     | AD[5]      | AD[9]      | E  |
|           |           | VDD3.3    | VDD2.5    | VDD2.5      | VSS         | VSS       | AD[1]     | AD[36]   | AD[4]      | AD[39]     | AD[11]     | F  |
|           |           |           |           |             |             | VSS       | AD[35]    | AD[6]    | AD[7]      | AD[42]     | AD[13]     | G  |
|           |           |           |           |             |             | VDD2.5    | AD[3]     | AD[8]    | AD[40]     | AD[43]     | ADP[0]     | н  |
|           |           |           |           |             |             | VDD3.3    | AD[38]    | AD[10]   | AD[12]     | AD[45]     | ADP[4]     | J  |
|           |           |           |           |             |             | VDD3.3    | AD[41]    | AD[44]   | AD[14]     | AD[47]     | SDQM[0]    | к  |
| VSS       | VSS       | 1         |           |             |             |           | AD[46]    | ADP[1]   | AD[15]     | ADP[5]     | SDQM[5]    | L  |
| VSS       | VSS       |           |           |             |             |           | DWr_      | SDQM[4]  | SCAS_      | SDQM[1]    | SCS_[0]    | м  |
| VSS       | VSS       |           |           |             |             |           | SCS_[1]   | DAdr[0]  | DAdr[1]    | SRAS_      | NC         | N  |
| VSS       | VSS       |           |           |             |             |           | DAdr[4]   | DAdr[7]  | DAdr[3]    | DAdr[2]    | DAdr[5]    | Р  |
| VSS       | VSS       |           |           |             |             |           | DAdr[9]   | SCS_[2]  | DMAReq_[2] | DAdr[8]    | DAdr[6]    | R  |
| VSS       | VSS       | :         |           |             |             |           | AD[17]    | SDQM[7]  | DMAReq_[1] | NC         | DAdr[10]   | т  |
|           |           |           |           |             |             | VDD3.3    | AD[48]    | AD P [6] | SDQM[3]    | SCS_[3]    | DMAReq_[3] | U  |
|           |           |           |           |             |             | VDD2.5    | AD[53]    | AD[49]   | ADP[3]     | SDQM[6]    | BankSel[0] | v  |
|           |           |           |           |             |             | VDD2.5    | AD[25]    | AD[52]   | AD[50]     | ADP[7]     | SDQM[2]    | w  |
|           |           |           |           | I           |             | VSS       | AD[56]    | AD[23]   | AD[20]     | AD[18]     | ADP[2]     | Y  |
|           |           | VDD3.3    | VDD3.3    | VDD2.5      | VSS         | VSS       | AD[27]    | AD[55]   | AD[22]     | AD[51]     | AD[16]     | AA |
| SysAD[20] | SysAD[26] | SysCMD[1] | ScDOE_    | Interrupt1_ | Interrupt0_ | ByPassPLL | AD[29]    | AD[58]   | AD[24]     | AD[54]     | AD[19]     | AB |
| SysAD[50] | SysAD[57] | SysCMD[7] | SysCMD[2] | ValidIn_    | ScMatch     | ScWord[0] | AD[62]    | AD[63]   | AD[28]     | AD[26]     | AD[21]     | AC |
| SysAD[24] | SysAD[22] | SysAD[23] | SysCMD[6] | ValidOut_   | Release_    | NC        | SerInt0_  | NMI_     | AD[30]     | AD[60]     | AD[57]     | AD |
| SysAD[25] | SysAD[21] | SysAD[53] | SysAD[56] | SysCMD[5]   | SysCMD[3]   | WrRdy_    | ScWord[1] | Reset_   | WDE_       | AD[31]     | AD[59]     | AE |
| SysAD[54] | SysAD[27] | SysAD[55] | SysAD[59] | SysAD[58]   | SysCMD[8]   | SysCMD[4] | SysCMD[0] | ScTCE_   | SerInt1_   | OutModePLL | AD[61]     | AF |
| 15        | 16        | 17        | 18        | 19          | 20          | 21        | 22        | 23       | 24         | 25         | 26         |    |



### 34. 492 BGA PACKAGE MECHANICAL INFORMATION

Figure 110:492 BGA Package Mechanical Information





### 35. GT-96100A PART NUMBERING

#### Figure 111:Sample Part Number



### 35.1 Standard Part Number

The standard part number for the GT-96100A is: GT-96100A-B-x.

Without the –XYYY–ZZ suffix, this part number indicates that it is the commercial temperature grade, 100MHz version. In other words, GT-96100A–B-x is the same as GT-96100A–B–x–C100–00, although it is not marked with the suffix information.

### 35.2 Valid Part Numbers

The following part numbers are the only valid part numbers that can be used when ordering the GT-96100A:

- GT-96100A–B–x, Commercial Temperature, 100MHz
- GT-96100A-B-x-C083-00, Commercial Temperature, 83MHz



## **36.** ABBREVIATIONS

| b                    | bit                                            |
|----------------------|------------------------------------------------|
| В                    | byte                                           |
| Gbps                 | gigabits per second                            |
| KHz                  | kilohertz                                      |
| mA                   | milliampere                                    |
| MHz                  | megahertz                                      |
| ns                   | nanosecond                                     |
|                      |                                                |
| V                    | volt                                           |
| V<br>GB              | volt<br>gigabytes                              |
|                      |                                                |
| GB                   | gigabytes                                      |
| GB<br>Gb             | gigabytes<br>gigabits                          |
| GB<br>Gb<br>KB       | gigabytes<br>gigabits<br>kilobytes             |
| GB<br>Gb<br>KB<br>Kb | gigabytes<br>gigabits<br>kilobytes<br>kilobits |





### **37. REVISION HISTORY**

#### Table 464: Document History

| Document Type                                                                                                                                                                                                                                      | Rev. Number              | Date                   | Comments                                   |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------------------|--------------------------------------------|--|--|
| Product Preview                                                                                                                                                                                                                                    | 0.1                      | April 17, 2000         | Preliminary Release                        |  |  |
| Datasheet                                                                                                                                                                                                                                          | 1.0                      | 3 October, 2000        |                                            |  |  |
| 1. In Table 107, "SDRAI<br>bit 10 & bit 11; initial valu<br>Bits 31:12; initial value ch                                                                                                                                                           | e changed from 0x1 to    |                        | ade:                                       |  |  |
| 2. In Table 281 "Hash Ta<br>Bits 52:51was added.<br>Bits 63:51 changed to bit                                                                                                                                                                      | •                        | bllowing changes were  | e made:                                    |  |  |
| 3. In Table 463 "GT–961<br>AD21 changed from VSS<br>The note at the end of the                                                                                                                                                                     | to NC.                   | following changes wer  | re made:                                   |  |  |
| 4. In the Features section                                                                                                                                                                                                                         | on 83MHz for CPU frequ   | uency support was cha  | anged to 100MHz.                           |  |  |
| 5. In Section 13.7.4 "Tra                                                                                                                                                                                                                          | insmit SDMA Notes" on    | page 317, informatior  | n added.                                   |  |  |
| 6. In Table 270 "PCI_0 A tion enable field                                                                                                                                                                                                         | Arbiter Configuration Re | gister, Offset: 0x101A | E0", a note was added in Priority Arbitra- |  |  |
| 7. In Section 12.1 "Fund                                                                                                                                                                                                                           | tional Overview" on pag  | ge 253, added informa  | tion.                                      |  |  |
| <ul> <li>8. In Table 14 "Interrupt Interface Pin Assignments", the following changes were made:</li> <li>SoR section deleted.</li> <li>GPP is defined as 15:0, no reserved bits.</li> <li>Interrupt1* notation as SoR type was deleted.</li> </ul> |                          |                        |                                            |  |  |
| 9. In Table 181 "PCI_1 SCS[1:0]* Base Address, Offset: 0x090 from PCI_0 or CPU; 0x010 from PCI_1", initial value changed to 0x08 from 0x04.                                                                                                        |                          |                        |                                            |  |  |
| 10. Table 183 "PCI_1 SCS[3:2]* Base Address, Offset: 0x094 from PCI_0 or CPU; 0x014 from PCI_1", initial value changed to 0x01000008 from 0x01000004.                                                                                              |                          |                        |                                            |  |  |
| 11. In Table 375, Table 3                                                                                                                                                                                                                          | 76, Table 377 and Table  | 378, GPP changed to    | o 15:0.                                    |  |  |
| 12. In Table 200 "PCI_1 F<br>changed to 0x00090001                                                                                                                                                                                                 |                          | x0c0 from PCI_0 or CI  | PU, 0x040 from PCI_11", initial value      |  |  |



#### Table 464: Document History (Continued)

| Document Type                                                                                                                                                                                                 | Rev. Number                                        | Date                    | Comments                                            |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-------------------------|-----------------------------------------------------|--|--|--|--|
| Datasheet                                                                                                                                                                                                     | 1.0                                                | 3 October, 2000         |                                                     |  |  |  |  |
| 13. Table 204 "Function 1<br>from PCI_1", initial value                                                                                                                                                       |                                                    |                         | ffset: 0x190 from PCI_0 or CPU; 0x110               |  |  |  |  |
| 14. Table 206 "Function 1 from PCI_1", initial value                                                                                                                                                          |                                                    |                         | ffset: 0x194 from PCI_0 or CPU; 0x114               |  |  |  |  |
| 15. In Section 32. "AC Tin<br>Rst* changed to Reset**.<br>"10 TClk Cycle" to "0.5 n                                                                                                                           |                                                    | following changes wer   | e made:                                             |  |  |  |  |
| 16. Table 415, Table 416<br>"the value latched in th                                                                                                                                                          |                                                    |                         | lue latched in the GPD register bit is '0'.         |  |  |  |  |
| 17. In Table 292 "Serial P<br>Ethernet_1", The followin<br>Initial value changed to "<br>The function description                                                                                             | ng changes were made:<br>11001 (64 bit time)" fror |                         | for Ethernet_0; 0x088820 for                        |  |  |  |  |
| 18. Section 31.1.1 "Powe                                                                                                                                                                                      | er Sequencing Notes" or                            | n page 510 was added    | l.                                                  |  |  |  |  |
| 19. Section Table 327: "CHxR1 - Sync/Abort Register (SYNR), Offset: 0x000A0C, 0x008A0C, 0x010A0C, 0x018A0C, 0x020A0C, 0x028A0C, 0x030A0C, 0x038A0C (where x is channel 0 to 7)" on page 342 was modified.     |                                                    |                         |                                                     |  |  |  |  |
| 20. In Section 14.1.3 "Re                                                                                                                                                                                     | ceive DPLL Clock Reco                              | very" on page 328, the  | e text was modified.                                |  |  |  |  |
| 21. In Section 14.7.1.1 "A encoding must be set to                                                                                                                                                            |                                                    |                         | . sampling rate" changed to "the DPLL               |  |  |  |  |
| <ul> <li>22. In Table 6 "PCI Bus 0 Pin Assignments", the following changes were made:</li> <li>"Req0*/PARB0_GNT0" changed to "Req0*/PARB0_GNT1"</li> </ul>                                                    |                                                    |                         |                                                     |  |  |  |  |
| "functions as the                                                                                                                                                                                             | 0                                                  | t" changed to "function | out grant 1"<br>ns as the arbiter's grant 1 output" |  |  |  |  |
|                                                                                                                                                                                                               | REQ0" changed to "Gn<br>nput request 0" changed    |                         | ut request 1"                                       |  |  |  |  |
|                                                                                                                                                                                                               |                                                    |                         | ns as the arbiter's request 1 input".               |  |  |  |  |
| <ul> <li>23. In Table 7 "PCI Bus 1 Pin Assignments", the following changes were made:</li> <li>"Req1*/PARB1_GNT0" changed to "Req1*/PARB1_GNT1"</li> </ul>                                                    |                                                    |                         |                                                     |  |  |  |  |
| "PCI_1 arbiter output grant 0" changed to "PCI_1 arbiter output grant 1"                                                                                                                                      |                                                    |                         |                                                     |  |  |  |  |
|                                                                                                                                                                                                               |                                                    | -                       | ns as the arbiter's grant 1 output"                 |  |  |  |  |
| <ul> <li>"Gnt1*/PARB1_REQ0" changed to "Gnt1*/PARB1_REQ1"</li> <li>"BCL 1 arbitrarianut answert 0" changed to "BCL 1 arbitrarianut asswert 1"</li> </ul>                                                      |                                                    |                         |                                                     |  |  |  |  |
| <ul> <li>"PCI_1 arbiter input request 0" changed to "PCI_1 arbiter input request 1"</li> <li>"functions as the arbiter's request 0 input" changed to "functions as the arbiter's request 1 input".</li> </ul> |                                                    |                         |                                                     |  |  |  |  |



| Document Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Rev. Number                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Date                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Comments                                                                                                                                                                                                                            |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Datasheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 3 October, 2000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                     |  |  |  |  |
| Datasheet         24. In Table 11 "WAN Pin         "PARB0_GNT1"         "PCI_0 arbiter of         "PCI_0 arbiter of         "PCI_0 arbiter in         "PCI_0 arbiter in         "PCI_0 arbiter in         "PCI_0 arbiter in         "PCI_0 arbiter of         "PCI_1 arbiter of         "PARB1_GNT1"         "PCI_1 arbiter of         "PARB1_REQ1"         "PCI_1 arbiter of         "PARB1_GNT2"         "PCI_1 arbiter of         "PARB1_GNT5"         "PCI_1 arbiter of         "PARB1_GNT5"         "PCI_1 arbiter of         "PARB1_GNT5" | 1.0 Assignments", the follo changed to "PARB0_G output grant 1" changed changed to "PARB0_F nput request 1" changed changed to "PARB0_F nput request 2" changed changed to "PARB0_G output grant 2" changed changed to "PARB0_G output grant 3" changed changed to "PARB0_F nput request 3" changed changed to "PARB0_F nput request 3" changed changed to "PARB0_F nput request 4" changed changed to "PARB1_G output grant 1" changed changed to "PARB1_G output grant 2" changed changed to "PARB1_G output grant 2" changed changed to "PARB1_G output grant 1" changed changed to "PARB1_G output grant 2" changed changed to "PARB1_G output grant 2" changed changed to "PARB1_G output grant 2" changed changed to "PARB1_G output grant 5" changed changed to "PARB1_G output grant 3" changed | 3 October, 2000<br>wing changes were m<br>SNT2"<br>to "PCI_0 arbiter outp<br>REQ2"<br>d to "PCI_0 arbiter input<br>REQ3"<br>d to "PCI_0 arbiter input<br>SNT3"<br>to "PCI_0 arbiter outp<br>SNT4"<br>to "PCI_0 arbiter outp<br>REQ4"<br>d to "PCI_0 arbiter input<br>REQ5"<br>d to "PCI_0 arbiter input<br>REQ5"<br>d to "PCI_1 arbiter outp<br>REQ2"<br>d to "PCI_1 arbiter input<br>REQ3"<br>d to "PCI_1 arbiter input<br>REQ3"<br>d to "PCI_1 arbiter input<br>REQ3"<br>d to "PCI_1 arbiter outp<br>SNT3"<br>to "PCI_1 arbiter outp<br>SNT4"<br>to "PCI_1 arbiter outp<br>SNT6"<br>to "PCI_0 arbiter outp<br>SNT4"<br>to "PCI_1 arbiter outp | aade:<br>ut grant 2"<br>ut request 2"<br>ut request 3"<br>ut grant 3"<br>ut grant 4"<br>ut grant 4"<br>ut request 4"<br>ut request 5"<br>ut grant 2"<br>ut request 2"<br>ut request 3"<br>ut grant 3"<br>ut grant 3"<br>ut grant 6" |  |  |  |  |
| <ul><li>"PARB0_REQ5"</li><li>"PCI_0 arbiter in</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <ul> <li>"PCI_1 arbiter output grant 3" changed to "PCI_1 arbiter output grant 4"</li> <li>"PARB0_REQ5" changed to "PARB0_REQ6"</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                     |  |  |  |  |
| <ul> <li>"PCI_1 arbiter in</li> <li>"PARB0_GNT4"</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <ul> <li>"PCI_1 arbiter input request 3" changed to "PCI_1 arbiter input request 4"</li> <li>"PARB0_GNT4" changed to "PARB0_GNT5"</li> <li>"PCI_0 arbiter output grant 4" changed to "PCI_0 arbiter output grant 5"</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                     |  |  |  |  |
| PARB0_G5, PARB0_R5<br>"0 - this pin to function as<br>changed to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 25. In Table 270 "PCI_0 Arbiter Configuration Register, Offset: 0x101AE0", the following changes were made: PARB0_G5, PARB0_R5 changed to PARB0_GNT1,PARB0_REQ1 "0 - this pin to function as all PSclk1."                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                     |  |  |  |  |



#### Table 464: Document History (Continued)

| Document Type                                                                                                                                                                                                                                                            | Rev. Number                                                                                                                                                                                                                                                    | Date                  | Comments                                 |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------|--|--|--|--|
| Datasheet                                                                                                                                                                                                                                                                | 1.0                                                                                                                                                                                                                                                            | 3 October, 2000       |                                          |  |  |  |  |
| 26. In Table 271 "PCI_1 /<br>changed to "(execpt for b                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                |                       | E4", "(execpt for bit 29 is reserved)"   |  |  |  |  |
| Jtag[2] type changed fror                                                                                                                                                                                                                                                | 27. In Table 16 "Test Interface Pin Assignments", the following changes were made:<br>Jtag[2] type changed from "O" to "I"<br>Jtag[3] type changed from "I" to "O".                                                                                            |                       |                                          |  |  |  |  |
| 28. In Table 463 "GT-961                                                                                                                                                                                                                                                 | 100A Pinout Table", AD2                                                                                                                                                                                                                                        | 21 signal name change | ed from "Vss" to "NC".                   |  |  |  |  |
|                                                                                                                                                                                                                                                                          | Backoff Algorithm Option<br>ameters Register <limit4< th=""><th></th><th>_Configuration_Extend<limit4>"</limit4></th></limit4<>                                                                                                                                |                       | _Configuration_Extend <limit4>"</limit4> |  |  |  |  |
| 30. In Table 292 "Serial F<br>Ethernet_1", the following<br>Bit 22 was added and bit                                                                                                                                                                                     | g changes were made:                                                                                                                                                                                                                                           |                       | for Ethernet_0; 0x088820 for             |  |  |  |  |
| t21 & t22 max value were                                                                                                                                                                                                                                                 | <ul> <li>31. In Table 453 "Flex-TDM Receive Timing - Normal Clock", the following changes were made:</li> <li>t21 &amp; t22 max value were removed.</li> <li>t23 &amp; t27 min value changed from 8 to 5.</li> </ul>                                           |                       |                                          |  |  |  |  |
| t41 & t42 max value were<br>t43 min value changed fr<br>t46 max value CHANGEI                                                                                                                                                                                            | 32. In Table 454 "Flex-TDM Transmit Timing - Normal Speed Clock", the following changes were made:<br>t41 & t42 max value were removed<br>t43 min value changed from 8 to 5<br>t46 max value CHANGED from 10 to 13.<br>t48, was added at the end of the table. |                       |                                          |  |  |  |  |
| t31 & t32 max value wre                                                                                                                                                                                                                                                  | <ul> <li>33. In Table 455 "Flex-TDM Receive Timing - Double Speed Clock", the following changes were made:</li> <li>t31 &amp; t32 max value wre removed.</li> <li>t33 &amp; t37 min value changed from 8 to 5.</li> </ul>                                      |                       |                                          |  |  |  |  |
| <ul> <li>34. In Table 456 "Flex-TDM Transmit Timing - Double Speed Clock", the following changes were made:</li> <li>t51 &amp; t52 max value were removed.</li> <li>t53 min value changed from 8 to 5</li> <li>t56 &amp; t58 max value changed from 10 to 13.</li> </ul> |                                                                                                                                                                                                                                                                |                       |                                          |  |  |  |  |
| 35. In Table 457 "MPSC 1<br>t61 & t62 max value were<br>t63 & t65 min value chan                                                                                                                                                                                         | e removed.                                                                                                                                                                                                                                                     | lowing changes were r | made:                                    |  |  |  |  |



#### Table 464: Document History (Continued)

| Document Type                                                                                                                                                                                | Rev. Number                                                                                                | Date                     | Comments                                                            |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--------------------------|---------------------------------------------------------------------|--|--|--|
| Datasheet                                                                                                                                                                                    | 1.0                                                                                                        | 3 October, 2000          |                                                                     |  |  |  |
| 36. In Table 458 "MPSC Transmit Timing", the following changes were made:<br>t71 & t72 max value were removed.<br>t73 max value changed from 10 to 13.<br>t75 min value changed from 8 to 5. |                                                                                                            |                          |                                                                     |  |  |  |
| 37. New Section 36, Abb                                                                                                                                                                      | reviations was added.                                                                                      |                          |                                                                     |  |  |  |
| 38. In Section 5.11.1 "SD<br>changed as follows:<br>Bits 7:0 changed to 11:0                                                                                                                 |                                                                                                            |                          | 30, table 86 through to table103 were                               |  |  |  |
| 39. Section 4.8.2 "MultiG                                                                                                                                                                    | T Bit In The CPU Config                                                                                    | guration Register" on p  | age 82 was modified.                                                |  |  |  |
| 40. Section 4.8.4 "Multi-G                                                                                                                                                                   | ST Restrictions" on page                                                                                   | e 83 was modified.       |                                                                     |  |  |  |
| pins 8:0 & 9 & 10 were cl                                                                                                                                                                    | hanged to "Reserved (N                                                                                     | lust be zero)".          | ving changes were made:<br>ers, and the PCI Configuration data reg- |  |  |  |
| 42. Figure 44 modified.                                                                                                                                                                      |                                                                                                            |                          |                                                                     |  |  |  |
| 43. In Table 17, pin OutM                                                                                                                                                                    | lodePLL description mo                                                                                     | dified to "pin is in hi- | z state."                                                           |  |  |  |
|                                                                                                                                                                                              | 44. In Table 316 the following changes were made:<br>The initial value for bits 5:2 was changed to '1111'. |                          |                                                                     |  |  |  |
| 45. In Table 172, the initia                                                                                                                                                                 | 45. In Table 172, the initia value was changed from 0x9652 to 0x9653.                                      |                          |                                                                     |  |  |  |
| 46. In Table 173, the initia                                                                                                                                                                 | 46. In Table 173, the initia value was changed from 0x965211ab to 0x965311ab.                              |                          |                                                                     |  |  |  |
| 47. In Table 173, the initia                                                                                                                                                                 | 47. In Table 173, the initia value was changed from 0x02ab to 0x03.                                        |                          |                                                                     |  |  |  |
| 48. Table Table 403. The ister'.                                                                                                                                                             | title was corrrected fror                                                                                  | n 'Ethernet1 Cause       | Register' to 'Ethernet1 Mask Reg-                                   |  |  |  |
| 49. Table 449 "Thermal d                                                                                                                                                                     | ata for GT-96100A in B                                                                                     | GA 492" was modified     |                                                                     |  |  |  |