

# 1.8V MULTI-QUEUE FLOW-CONTROL DEVICES (128 QUEUES) 40 BIT WIDE CONFIGURATION

5,242,880 bits 10,485,760 bits IDT72P51767 IDT72P51777

#### **FEATURES**

- Choose from among the following memory density options:
   IDT72P51767 Total Available Memory = 5,242,880 bits
   IDT72P51777 Total Available Memory = 10,485,760 bits
- Configurable from 1 to 128 Queues
- · Multiple default configurations of symmetrical queues
- Default multi-queue device configurations
  - IDT72P51767: 512 x 40 x 128Q
  - IDT72P51777: 1,024 x 40 x 128Q
- Number of queues and queue sizes may be configured; at master reset, though serial programming, (via the queue address bus)
- 166 MHz High speed operation (6ns cycle time)
- 0.48ns access time
- Independent Read and Write access per queue
- Echo Read Clock available
- Internal PLL
- On-chip Output Impedance matching

- User Selectable Bus Matching Options:
  - x40 in to x40 out x20 in to x20 out
  - x40 in to x20 out x20in to x40out
- User selectable I/O: 1.5V HSTL or 1.8V eHSTL
- 100% Bus Utilization, Read and Write on every clock cycle
- Selectable Back off one (BOI) or IDT standard mode of operation
- · Ability to operate on packet or word boundaries
- · Mark and Re-Write operation
- · Mark and Re-Read operation
- Individual, Active queue flags (EF, FF, PAE, PAF)
- 8 bit parallel flag status on both read and write ports
- · Direct or polled operation of flag status bus
- Expansion of up to 256 queues
- JTAG Functionality (Boundary Scan)
- Available in a 376-pin BGA, 1mm pitch, 23mm x 23mm
- HIGH Performance submicron CMOS technology
- Industrial temperature range (-40°C to +85°C) is available
- Green parts available, seeing Ordering Information

## **FUNCTIONAL BLOCK DIAGRAM**

#### 10G DDR MULTI-QUEUE FLOW-CONTROL DEVICE



 $IDT and the \, IDT \, logo \, are \, registered \, trademarks \, of \, Integrated \, Device \, Technology, \, Income \, Tec$ 

COMMERCIAL AND INDUSTRIAL TEMPERATURE RANGES

**FEBRUARY 2009** 

## **Table of Contents**

| Features                                | 1  |
|-----------------------------------------|----|
| Description                             | 5  |
| Pin configuration                       | 7  |
| Detailed Description                    | 8  |
| Pin Descriptions                        | 10 |
| Pin number table                        |    |
| Recommended DC operating conditions     | 16 |
| Absolute maximum ratings                | 16 |
| DC electrical characteristics           | 17 |
| AC electrical characteristics           | 19 |
| Functional description                  | 22 |
| Serial Programming                      | 24 |
| Default Programming                     | 27 |
| Parallel Programming                    | 27 |
| Modes of operation                      | 29 |
| Standard mode operation                 |    |
| IDT Standard mode vs. BOI mode          | 29 |
| PLL on vs PLL off modes                 |    |
| Read Queue Selection and Read Operation | 33 |
| Switching Queues on the Write Port      |    |
| Switching Queues on the Read Port       |    |
| Flag Description                        | 52 |
| PAFn Flag Bus Operation                 | 52 |
| Full Flag Operation                     | 52 |
| Empty Flag Operation                    | 52 |
| Almost Full Flag                        |    |
| Almost Empty Flag                       | 53 |
| JTAG Interface                          | 83 |
| JTAG AC electrical characteristics      | 87 |
| Ordering Information                    | 88 |

## **List of Tables**

| Table 1 — Summary of the differences between the 4M MQ and 10G MQ                                                                                               | 9  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| Table 2 — DC and AC specifications (informative)                                                                                                                | 21 |
| Table 3 — IDT to XGMII Interface Mapping Schema                                                                                                                 | 21 |
| Table 3 — IDT to XGMII Interface Mapping Schema  Table 4 — Device programming mode comparison  Table 5 — Setting the queue programming mode during master reset | 22 |
| Table 5 — Setting the queue programming mode during master reset                                                                                                | 23 |
| Table 6 — ID[2:0] and WRADD[7:5]/RDADD[7:5] Configuration                                                                                                       | 27 |
| Table 7 — Parallel Programming Mode Queue Configuration Example(1)                                                                                              | 28 |
| Table 8 — Write Address Bus, WRADD[7:0]                                                                                                                         | 32 |
| Table 9 — Read Address Bus, RDADD[7:0]                                                                                                                          | 33 |
| Table 9 — Read Address Bus, RDADD[7:0]                                                                                                                          | 35 |
| Table 11 — Backup Usage when Re-entering a Queue                                                                                                                | 43 |
| Table 13 — Same Queue Switch                                                                                                                                    | 15 |
| Table 12 — Read Queue Switch Operation                                                                                                                          | 45 |
| Table 14 — Flag operation boundaries & Timing                                                                                                                   | 55 |
| Table 14 — Flag operation boundaries & Timing                                                                                                                   | 57 |
| Table 16 — Bus-Matching Configurations                                                                                                                          | 58 |
|                                                                                                                                                                 |    |

# **List of Figures**

| Figure 1. Multi-Queue Flow-Control Device Block Diagram                                       | 8 |
|-----------------------------------------------------------------------------------------------|---|
|                                                                                               |   |
| Figure 2h Tumped Canacitive Load Tynical Derating                                             | 8 |
|                                                                                               |   |
| Figure 3. HSTL Termination for XGMII                                                          |   |
| Figure 4. Reference Signals                                                                   |   |
| Figure 5. Expansion for Unlimited Number of Multi-Queue Devices Example                       |   |
| Figure 6. Device Programming Hierarchy                                                        |   |
| Figure 7. DDR Read Operation with PLL ON                                                      |   |
| Figure 8. DDR Read Operation with PLL OFF                                                     |   |
| Figure 9. SDR Read Operation with PLL ON                                                      | 1 |
| Figure 10. SDR Read Operation with PLL OFF                                                    |   |
| Figure 11. Write Port Switching Queues Signal Sequence                                        |   |
| Figure 12. Switching Queues Bus Efficiency                                                    |   |
| Figure 13. Simultaneous Queue Switching                                                       |   |
| Figure 14. Application: Reading words from the MQ using the EOP bit to end the read operation |   |
| Figure 15. Output Data during a Queue Switch (SDR w/o PLL)                                    |   |
| Figure 16. Output Data during a Queue Switch (SDR w/ PLL)                                     |   |
| Figure 17. Output Data during a Queue Switch (DDR w/ PLL)                                     |   |
| Figure 18. Output Data during a Queue Switch (DDR w/o PLL)4                                   | 0 |
| Figure 19. Output Data during two Queue Switches (DDR w/ PLL)                                 |   |
| Figure 20. Output Data during two Queue Switches (DDR w/o PLL)                                |   |
| Figure 21. Read Port Switching Queues Signal Sequence4                                        |   |
| Figure 22. Switching Queues Bus Efficiency4                                                   |   |
| Figure 23. Simultaneous Queue Switching4                                                      |   |
| Figure 24. MARK and Re-Write Sequence4                                                        |   |
| Figure 25. MARK and Re-Read Sequence4                                                         |   |
| Figure 26. MARKing a Queue - Write Queue MARK4                                                |   |
| Figure 27. MARKing a Queue - Read Queue MARK4                                                 |   |
| Figure 28. UN-MARKing a Queue - Write Queue UN-MARK4                                          | 8 |
| Figure 29. UN-MARKing a Queue - Read Queue UN-MARK4                                           |   |
| Figure 30. Leaving a MARK active on the Write Port4                                           |   |
| Figure 31. Leaving a MARK active on the Read Port4                                            |   |
| Figure 32. Inactivating a MARK on the Write Port Active                                       |   |
| Figure 33. Inactivating a MARK on the Read Port Active5                                       | 0 |
| Figure 34. DDR Source Synchronous Center Aligned Clocking5                                    | 7 |
| Figure 35. SDR Edge Aligned Clocking5                                                         | 7 |
| Figure 36. Bus-Matching Byte Arrangement                                                      |   |
| Figure 37. Master Reset6                                                                      | 0 |
| Figure 38. Default Programming6                                                               |   |
| Figure 39. Write Address/Read Address Programming                                             |   |
| Figure 40. Serial Port Connection for Serial Programming                                      | 3 |
| Figure 41. Serial Programming (2 Device Expansion)6                                           |   |
| Figure 42. SDR Write Queue Select, Write Operation and Full Flag Operation6                   |   |
| Figure 43. DDR Write Operation, Write Queue Select, Full Flag Operation6                      | 6 |
| Figure 44. Write Queue Select, Mark and Rewrite                                               | 7 |
| Figure 45. Full Flag Timing in Expansion Configuration                                        | 8 |
| Figure 46. SDR Read Queue Select, Read Operation (IDT mode)                                   | 9 |
| Figure 47. DDR Read Operation, Read Queue Select, EF & PAE Flag Operation                     | 0 |
| Figure 48. Read Queue Select, Mark and Reread (IDT mode)                                      |   |
| Figure 49. Standard Mode Pointers on Queue Re-entry for DDR Read Operation                    | 2 |
| Figure 50. BOI Mode Pointers on Queue Re-entry for DDR Read Operation                         |   |
| Figure 51. Read Queue Selection with Read Operations (IDT mode) (SDR mode, PLL = OFF)         |   |
| Figure 52. Read Queue Select, Read Operation and OE Timing                                    |   |
| Figure 53. Almost Full Flag Timing and Queue Switch                                           | 5 |
| Figure 54. Almost Full Flag Timing                                                            | 5 |

# **List of Figures (Continued)**

| Figure 55. Almost Empty Flag Timing                                                             | 76 |
|-------------------------------------------------------------------------------------------------|----|
| Figure 55. Almost Empty Flag Timing<br>Figure 56. PAEn - Direct Mode - Status Word Selection    |    |
| Figure 57. PAFn - Direct Mode - Status Word Selection                                           |    |
| Figure 58. PAEn - Direct Mode, Flag Operation                                                   | 78 |
| Figure 59. PAFn - Direct Mode, Flag Operation                                                   | 79 |
| igure 60. PAFn Bus - Polled Mode                                                                | 80 |
| Figure 61. Connecting two 10G MQ 128Q devices in Expansion Mode                                 | 81 |
| Figure 62. Connecting THREE or more 10G MQ 128Q in Expansion Mode Using WADDR bit 7/RDADD bit 7 | 82 |
| Figure 63. Boundary Scan Architecture                                                           | 83 |
| Figure 64. TAP Controller State Diagram                                                         |    |
| Figure 65. Standard JTAG Timing                                                                 | 87 |

#### **DESCRIPTION**

The IDT72P51767/ IDT72P51777 multi-queue flow-control devices are single chip solutions containing up to 128 configurable queues. All queues within the device have a common data input bus, Din [39:0] (write port) and a common data output bus Qout [39:0], (read port). Data written into the write port is directed to a respective queue via an integrated de-multiplex function. Data read from the read port is accessed from a given queue transparently via an internal multiplex operation. Data writes and reads can be performed at high speeds up to 166MHz DDR allowing data rates up to 10Gigabits/s (OC-192). By utilizing high speed interfaces such as 1.5V HSTL, coupled with a x40 bit data bus and 10Mb of data storage, the 10G Multi-Queue can interface with the industry standard 10 Gigabits/sec Media Independent Interface (XGMII) to allow high speed data transmission over 10G Ethernet and SONET line cards. Data write and read operations are totally independent of each other. The Write Clock and Read Clock can operate at independent frequencies. A different gueue may be selected on the write port and read port or both ports may select the same queue simultaneously. Multiple clocking schemes are offered for this device as well. The user can utilize either single ended or differential clocking for DDR read operations. DDR write operation utilize a single ended clock. SDR write and read operations utilize a single ended clock.

The devices provide Full flag and Empty flag status for the queue selected for write and read operations respectively. Also a Programmable Almost Full  $(\overline{PAF})$  and Programmable Almost Empty  $(\overline{PAE})$  flag for each queue is provided. Two 8 bit programmable flag busses  $(\overline{PAF}n,\overline{PAE}n)$  are available, providing status of queues that are not the present queue selected for write or read operations. When 8 or fewer queues are configured in the device, these flag busses provide an individual flag per queue, when more than 8 queues are used; the queue status is multiplexed through the 8 stus lines. The multiplexing can be configured either a Polled or Direct mode of bus.

Bus Matching is available on this device; either port can be x20 bits or x40 bits wide. When Bus Matching is used the device ensures the logical transfer of data throughput.. With a 40 data bits configuration parity checking and packet tagging is achievable if desired. Parity checking is available through the use of

4 user selectable bits as part of the 40 bit word. The user will be able to pass along parity bits through the Multi-Queue to use for error detection in a up/down stream device. The Multi-Queue device does not provide parity checking circuits.

In Back off One mode, the user can switch queues without having to read the last pipelined data word that is stored in the output register which in IDT standard mode is required to be read out during a queue switch. The last pipelined data word in BOI mode is retained in the output data register until it is actively read.

A Mark and Re-write and a Mark and Re-read function are available on the write and read ports respectively. These functions allows for a mark location to be independently issued on the read and/or write ports, in their respective queues. The option to reset a given queue to the mark location effectively dropping data written into the queue or allow data to be read again from the device.

The devices offer a default configuration upon reset, offering 128 symmetrical queues configured at start-up, which means the user can program the number of queues to divide the 10Mb/5Mb of memory depending on the device. The Multi-Queues can even be programmed to support one single queue to be used as a FIFO for high performance applications of sequential queuing. The programmable flag positions are also user programmable. If the user does not wish to program the multi-queue device, a default option is available that configures the device in a predetermined manner. A Master Reset latches in all configuration setup pins and must be performed before programming of the device can take place.

The multi-queue flow-control devices have the capability of operating its I/O in either 1.5V HSTL, or 1.8V eHSTL mode. The type of I/O is selected via the IOSEL input. The core supply voltage (VCC) to the multi-queue is always 1.8V, however the output levels can be set independently via a separate supply, VDDQ. The package used will be a 23mm x 23mm, BB-376 BGA package for better noise immunity and ground bounce prevention.

A JTAG test port is provided, here the multi-queue flow-control device has a fully functional Boundary Scan feature, compliant with IEEE 1149.1 Standard Test Access Port and Boundary Scan Architecture.



Figure 1. Multi-Queue Flow-Control Device Block Diagram

#### PIN CONFIGURATION



NOTE:

1. DNC - Do Not Connect.

PBGA (BB376-1, order code: BB) TOP VIEW

#### **DETAILED DESCRIPTION**

#### **MULTI-QUEUE STRUCTURE**

The IDT multi-queue flow-control device has a single data input port and single data output port with up to 128 FIFO queues in parallel buffering between the two ports. The user can setup between 1 and 128 Queues within the device. These queues can be configured to utilize the total available memory, providing the user with full flexibility and ability to configure the queues to be various depths, independent of one another.

#### MEMORY ORGANIZATION/ALLOCATION

The memory is organized into what is known as "blocks", each block being 256 x40 bits. When the user is configuring the number of queues and individual queue sizes the user must allocate the memory to respective queues, in units of blocks, that is, a single queue can be made up from 0 to m blocks, where m is the total number of blocks available within a device. Also the total size of any given queue must be in increments of 256 x40. For the IDT72P51767 and IDT72P51777 the Total Available Memory is 1024 and 512 blocks respectively (a block being 256 x40). Queues can be built from these blocks to make any size queue desired and any number of queues desired.

#### **BUS WIDTHS**

The input port is common to all queues within the device, as is the output port. The device provides the user with Bus Matching options such that the input port and output port can be either x20, x40 bits wide, the read and write port widths can be set independently of one another. Because a ports are common to all queues the width of the queues is not individually set. The input width of all queues are the same and the output width of all queues are the same.

#### WRITING TO & READING FROM THE MULTI-QUEUE

Data being written into the device via the input port is directed to a discrete queue via the write queue address input. Conversely, data being read from the device read port is read from a queue selected via the read queue address input. Data can be simultaneously written into and read from the same queue or different queues. Once a queue is selected for data writes or reads, the writing and reading operation is performed in the same manner as a conventional IDT synchronous FIFO, utilizing clocks and enables, there is a single clock and enable per port. When a specific queue is addressed on the write port, data placed on the data inputs is written to that queue sequentially based on therising edge of a write clock provided setup and hold times are met. Conversely, data is read on to the output port after an access time from a rising edge on a read clock

The operation of the write port is comparable to the function of a conventional FIFO operating in standard IDT mode. Write operations can be performed on the write port provided that the queue currently selected is not full, a full flag output provides status of the selected queue. When a queue is selected on the output port, the next word in that queue will be available for reading on the output register. All subsequent words from that queue require an enabled read cycle. Data cannot be read from a selected queue if that queue is empty, the read port provides an Empty flag indicating when data read out is valid. If the user switches to a queue that is empty, the last word from the previous queue will remain on the output bus. The device can operate in IDT Standard mode or  $\overline{BOI}$  mode. In IDT Standard mode the read port provides a word to the output bus (Qout) for each clock cycle that  $\overline{REN}$  is asserted. Refer to Figure 46,  $\overline{SDRReadQueue}$   $\overline{Select}$ ,  $\overline{ReadQueue}$   $\overline{Select}$ ,  $\overline{ReadQueue}$ 

As mentioned, the write port has a full flag, providing full status of the selected queue. Along with the full flag a dedicated almost full flag is provided, this almost full flag is similar to the almost full flag of a conventional IDT FIFO. The device provides a user programmable almost full flag for all 128 queues and when a

respective queue is selected on the write port, the almost full flag provides status for that queue. Conversely, the read port has an Empty flag, providing status of the data being read from the queue selected on the read port. As well as the Empty flag the device provides a dedicated almost empty flag. This almost empty flag is similar to the almost empty flag of a conventional IDT FIFO. The device provides a user programmable almost empty flag for each 128 queues and when a respective queue is selected on the read port, the almost empty flag provides status for that queue.

#### **PROGRAMMABLE FLAG BUSSES**

In addition to these dedicated flags, full & almost full on the write port and Output Ready & almost empty on the read port, there are two flag status busses. An almost full flag status bus is provided, this bus is 8 bits wide. Also, an almost empty flag status bus is provided, again this bus is 8 bits wide. The purpose of these flag busses is to provide the user with a means by which to monitor the data levels within queues that may not be selected on the write or read port. As mentioned, the device provides almost full and almost empty registers (programmable by the user) for each of the 128 queues in the device.

In the IDT72P51767/72P51777 multi-queue flow-control devices the user has the option of utilizing 1 to 128 queues, therefore the 8 bit flag status busses are multiplexed between the 128 queues, a flag bus can only provide status for 8 of the 128 queues at any moment, this is referred to as a "Status Word", such that when the bus is providing status of queues 1 through 8, this is status word 1, when it is queues 9 through 16, this is status word 2 and so on up to status word 16. If less than 128 queues are setup in the device, there are still 4 status words, such that in "Polled" mode of operation the flag bus will still cycle through 4 status words. If for example only 22 queues are setup, status words 1 and 2 will reflect status of queues 1 through 8 and 9 through 16 respectively. Status word 3 will reflect the status of queues 17 through 22 on the least significant 6 bits, the most significant 2 bits of the flag bus are don't care. The remaining status words are not used as there are no queues to report.

The flag busses are available in two user selectable modes of operation, "Polled" or "Direct". When operating in polled mode a flag bus provides status of each status word sequentially, that is, on each rising edge of a clock the flag bus is updated to show the status of each status word in order. The rising edge of the write clock will update the almost full bus and a rising edge on the read clock will update the almost empty bus. The mode of operation is always the same for both the almost full and almost empty flag busses. When operating in direct mode, the status word on the flag bus is selected by the user. So the user can actually address the status word to be placed on the flag status busses, these flag busses operate independently of one another. Addressing of the almost full flag bus is done via the write port and addressing of the almost empty flag bus is done via the read port.

#### **EXPANSION**

Expansion of multi-queue devices is possible. Expansion achieves either depth or queue expansion. Depth Expansion means expanding the depths of individual queues. Queue expansion means increasing the total number of queues available. Depth expansion is possible by virtue of the fact that more memory blocks within a multi-queue device can be allocated to a fewer number of queues to increase the depth of each queue. For example, depth expansion of 2 devices provides the possibility of 2 queues, each queue being setup within a single device utilizing all memory blocks available to produce a single queue. This is the deepest queue that can setup within a device.

For queue expansion a maximum number of 256 queues (2 x 128 queues) may be setup. If fewer queues are desired, then more memory blocks will be available to increase queue depths if desired. Refer to Figure 61, *Connecting two 10G Multi-Queue 128Q devices in Expansion Mode*, and Figure 62,

Connecting three or more 10G Multi-Queue 128Q in Expansion mode using WRADD bit 7/RDADD bit 7for device connection details.

#### 10Gbps MULTI-QUEUE DIFFERENCES FROM THE 4M MULTI-QUEUE

The 10G Multi-Queue was developed to support very high performance applications that needed 10Gb/s of bandwidth, and the flexibility of buffering packets of information in large bursts such as Jumbo Ethernet packets that can be as large as 9KBs. Listed below are the differences between the 10G Multi-Queue and the previous 4M Multi-Queue with descriptions of the enhancements made to support performance functions in queuing.

#### **PERFORMANCE ENHANCEMENTS**

- 333.34 Mbps (per pin) High speed data rate in DDR mode
- x40 Din and x40 Qout (8 more pins for user selectable operation such as parity check or packet tagging)
- Electrical compatibility to 802.3ae XGMII specification for passive interconnection to Ethernet devices.
  - Single clocking in DDR and SDR, PLL on/off Mode. (PAD\_PLLON pin) allowing data latency to be the same for SDR and DDR.
- Burst of 2 timing and interface logic
  - Output impedance matching for signal quality on the output pins.
  - More Data latency (same cycle on write, 1 cycle on read)

- Three "echo" output pins: ERCLK, ERCLK, and EREN used for Source Synchronous data on the output. Data can be center aligned on the Echo Clock or issued on the rising edge of the Echo Clock.
- Access Time (Ta) reduced to 0.48ns with Echo Clock used for faster Synchronized data delivery down stream

#### **USER FLEXIBILITY IMPROVEMENTS**

- 10Mbits of storage and queuing density for support large packet frames such as Jumbo Ethernet
- During a Queue switch, BOI mode preserves the data word in the output register until it's read.
  - "Real Time" Flags, for both DDR and SDR.
    - PAF/PAE have 1 more cycle (WCLK/RCLK) latency (3 vs. 2)
    - Tskew of EF/PAE with respect to WCLK has 1 WCLK cycle delay.
    - Tskew of FF/PAF with respect to RCLK has 1 RCLK cycle delay.
  - Programmable Default configuration of 128, 64, 32, 16, 8 or 4 symmetrical queues are available using DFM, QSEL[2:0] pins
  - User selectable I/O: 1.5V HSTL, or 1.8V eHSTL for faster switching I/O
  - Expansion of up to 256 queues and/or 80Mbit logical configuration using up to 8 multi-queue devices
  - Default flag offset value is defined according to bus matching configuration
    - The PAE flag can be used as a packet indicator

# TABLE 1 — SUMMARY OF THE DIFFERENCES BETWEEN THE 4M MQ AND 10G MQ

| FEATURE                     | 4M MQ (IDT72P51769) | 10M MQ (IDT72P51777) |
|-----------------------------|---------------------|----------------------|
| Data Transfer Modes         | SDR                 | SDR, DDR             |
| Bus Width                   | x36, x18, x9        | x40, x20             |
| XGMII Compatibility         | no                  | yes                  |
| Access time (ta)            | 3.6 ns max          | 0.48ns max           |
| Data Storage Capacity       | 4Mb                 | 10Mb                 |
| Data Throughput             | 7.2Gbps             | 10Gbps               |
| Operating Frequency         | 200mhz              | 166mhz               |
| Configurable Queues         | Up to 128           | Up to 128            |
| Package                     | 256 pin PBGA        | 376 pin BGA          |
| Output Impedance Technology | no                  | yes                  |
| I/O Voltages                | 1.5V,1.8V,2.5V      | 1.5V,1.8V            |
| Echo read Clock             | no                  | yes                  |
| Modes of Operation          | FWFT, IDT, Packet   | IDT, BOI             |
| Output data Clocking        | Edge aligned        | Centered aligned     |

## **PIN DESCRIPTIONS**

| Symbol &                                                 | Name                      | I/O TYPE            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------------|---------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (Pin No.) BM [3:0] (BM3-BB13 BM2-AA12 BM1-BB12 BM0-BB11) | Bus Matching              | 1.8V LVTTL<br>INPUT | These pins define the bus width and data transfer rate (DDR/SDR) of the input write port and the output read port of the device. The bus widths/data rates are set during a Master Rest cycle. The BM[3:0] signals must meet the setup and hold time requirements of Master Reset and must not toggle/change state after a Master Reset cycle.                                                                                                                                                                                                                                                                                                                                                                      |
| BOI<br>(P20)                                             | Back Off One<br>Mode      | HSTL<br>INPUT       | When in BOI, data is back-off one position in which Packet 1 and Packet 2 are out again during second Queue Switch. See section on 10Gbps Multi-queue Differences from the 4M multi-queue, previous page.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| D[39:0]<br>(See Pin No.<br>table for details)            | Data Input Bus            | HSTL<br>INPUT       | These are the 32 data input pins. Data is written into the device via these input pins on the rising edge of WCLK provided that WEN is LOW. Any unused data input pins should be tied HIGH.  D[39:36] user definable input bits  D[33] user definableD[32] user definableD[31:0] data input bits                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DFM<br>(AA11)                                            | Default Mode              | 1.8V LVTTL<br>INPUT | The 10G multi-queue device requires programming after master reset. The user can do this serially via the serial port, or the user can use the default method. If DFM is LOW at Master Reset then serial mode will be selected, if DFM is HIGH then default mode is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| EF<br>(N21)                                              | Empty Flag                | HSTL<br>OUTPUT      | The Empty Flag (EF) provides valid status for the selected queue. The Empty Flag indicates the selected queue is empty, all words have been read. This flag is delayed to match the data output path delay.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ERCLK<br>(E22)                                           | Echo Read<br>Clock        | HSTL<br>OUTPUT      | The rising edge of this clock is centered aligned with Qout data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ERCLK<br>(F20)                                           | Echo Read<br>Clock        | HSTL<br>OUTPUT      | Read Clock Echo is the inverse of ERCLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| EREN<br>(E21)                                            | Echo Read<br>Enable       | HSTL<br>OUTPUT      | Echo Read Enable output, used in conjunction with ERCLK and ERCLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ESTR<br>(R20)                                            | PAEn Flag Bus             | HSTL<br>INPUT       | If direct operation of the $\overline{PAE}$ n bus has been selected, the ESTR input is used in conjunction with RCLK and the RDADD bus to select a quadrant of queues to be placed on to $\overline{PAE}$ n output. A quadrant addressed via the RDADD bus is selected on the rising edge of RCLK provided that ESTR is HIGH. If Polled operation has been selected, ESTR should be tied inactive, LOW. Note, that a $\overline{PAE}$ n flag bus selection cannot be made, (ESTR must NOT go active) until programming of the part has been completed and SENO has gone LOW.                                                                                                                                        |
| ESYNC<br>(P21)                                           | PAEn Bus Sync             | HSTL<br>OUTPUT      | ESYNC is an output from the multi-queue device that provides a synchronizing pulse for the PAEn bus during Polled operation of the PAEn bus. During Polled operation each quadrant of queue status flags is loaded on to the PAEn bus outputs sequentially based on RCLK. The first RCLK rising edge loads quadrant 1 on to PAEn, the second RCLK rising edge loads quadrant 2 and so on. The fifth RCLK rising edge will again load quadrant 1. During the RCLK cycle that quadrant 1 of a selected device is placed on to the PAEn bus, the ESYNC output will be HIGH. For all other quadrants of that device, the ESYNC output will be LOW.                                                                      |
| EXI<br>(R21)                                             | PAEn Bus<br>Expansion In  | HSTL<br>INPUT       | The EXI input is used when multi-queue devices are connected in expansion mode and Polled PAEn bus operation has been selected. EXI of device 'N' connects directly to EXO of device 'N-1'. The EXI receives a token from the previous device in a chain. In single device mode the EXI input must be tied LOW if the PAEn bus is operated in direct mode. If the PAEn bus is operated in polled mode the EXI input must be connected to the EXO output of the same device. In expansion mode the EXI of the first device should be tied LOW, when direct mode is selected.                                                                                                                                         |
| EXO<br>(P22)                                             | PAEn Bus<br>Expansion Out | HSTL<br>OUTPUT      | EXO is an output that is used when multi-queue devices are connected in expansion mode and Polled PAEn bus operation has been selected. EXO of device 'N' connects directly to EXI of device 'N+1'. This pin pulses when device N has placed its final (4th) quadrant on to the PAEn bus with respect to RCLK. This pulse (token) is then passed on to the next device in the chain 'N+1' and on the next RCLK rising edge the first quadrant of device N+1 will be loaded on to the PAEn bus. This continues through the chain and EXO of the last device is then looped back to EXI of the first device. The ESYNC output of each device in the chain provides synchronization to the user of this looping event. |
| FF<br>(E1)                                               | Full Flag                 | HSTL<br>OUTPUT      | This pin provides the full flag output for the active Queue, that is, the queue selected on the input port for write operations, (selected via WCLK, WRADD bus and WADEN). On the WCLK cycle after a queue selection, this flag will show the status of the newly selected queue. Data can be written to this queue provided FF is HIGH. This flag has High-Impedance capability, this is important during expansion of                                                                                                                                                                                                                                                                                             |

| Symbol &<br>Pin No.                        | Name                      | I/O TYPE            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------------|---------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FF (Continued) (E1)                        | Full Flag                 | HSTL<br>OUTPUT      | devices, when the $\overline{FF}$ flag output of up to 8 devices may be connected together on a common line. The device with a queue selected takes control of the $\overline{FF}$ bus, all other devices place their $\overline{FF}$ output into High-Impedance. When a queue selection is made on the write port this output will switch from High-Impedance control on the next WCLK cycle. This flag is asserted synchronous to WCLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| FM<br>(U2)                                 | Flag Mode                 | 1.8V LVTTL<br>INPUT | This pin is setup before a Master Reset and must not toggle during any device operation. The state of the FM pin during Master Reset will determine whether the PAFn and PAEn flag busses operate in either Polled or Direct mode. If FM is HIGH, Polled mode is selected, if FM LOW, Direct mode is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| FSTR<br>(T2)                               | PAFn Flag<br>Bus Strobe   | HSTL<br>INPUT       | If direct mode for the $\overline{PAF}n$ bus has been selected, the FSTR input is used in conjunction with WCLK and the WRADD bus to select a quadrant of queues to be placed on to the $\overline{PAF}n$ bus outputs. A quadrant addressed via the WRADD bus is selected on the rising edge of WCLK provided that FSTR is HIGH. If polled operations has been selected, FSTR should be tied inactive, LOW. Note, that a $\overline{PAF}n$ flag bus selection cannot be made, (FSTR must NOT go active) until programming of the part has been completed and SENO has gone LOW.                                                                                                                                                                                                                                                                                                                                                                                                              |
| FSYNC<br>(J2)                              | PAFn Bus Sync             | HSTL<br>OUTPUT      | FSYNC is an output from the multi-queue device that provides a synchronizing pulse for the $\overline{PAF}n$ bus during Polled operation of the $\overline{PAF}n$ bus. During Polled operation each quadrant of queue status flags is loaded on to the $\overline{PAF}n$ bus outputs sequentially based on WCLK. The first WCLK rising edge loads quadrant 1 on to $\overline{PAF}n$ , the second WCLK rising edge loads quadrant 2 and so on. The fifth WCLK rising edge will again load quadrant 1 queue status flags. During the WCLK cycle that quadrant 1 of a selected device is placed on to the $\overline{PAF}n$ bus, the FSYNC output will be HIGH. For all other quadrants of that device, the FSYNC output will be LOW.                                                                                                                                                                                                                                                          |
| FXI<br>(T1)                                | PAFn Bus<br>Expansion In  | HSTL<br>INPUT       | The FXI input is used when multi-queue devices are connected in expansion mode and Polled PAFn bus operation has been selected. FXI of device 'N' connects directly to FXO of device 'N-1'. The FXI receives a token from the previous device in a chain. In single device mode the FXI input must be tied LOW if the PAFn bus is operated in direct mode. If the PAFn bus is operated in polled mode the FXI input must be connected to the FXO output of the same device. In expansion mode the FXI of the first device should be tied LOW, when direct mode is selected.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| FXO<br>(J3)                                | PAFn Bus<br>Expansion Out | HSTL<br>OUTPUT      | FXO is an output that is used when multi-queue devices are connected in expansion mode and Polled PAFn bus operation has been selected. FXO of device 'N' connects directly to FXI of device 'N+1'. This pin pulses when device N has placed its final (4th) quadrant on to the PAFn bus with respect to WCLK. This pulse (token) is then passed on to the next device in the chain 'N+1' and on the next WCLK rising edge the first quadrant of device N+1 will be loaded on to the PAFn bus. This continues through the chain and FXO of the last device is then looped back to FXI of the first device. The FSYNC output of each device in the chain provides synchronization to the user of this looping event.                                                                                                                                                                                                                                                                          |
| ID[2:0]<br>(ID2-A12<br>ID1-B12<br>ID0-A13) | Device ID Pins            | 1.8V LVTTL<br>INPUT | The ID[2:0] pins are used to uniquely address individual devices when multiple Multi-Queue devices are connected in expansion mode. Addressing devices in expansion mode requires matching WRADD/RDADD address bits with the address that is assigned to each device by the ID[2:0] pins. During write/read operations the WRADD/RDADD address are compared to the device ID [2:0] value. Note: expansion mode supports a maximum 256 queues, regardless of the number of devices used in expansion mode. The first device in a chain of multi-queue's (connected in expansion mode), may be setup as '000', the second as '001". In single device mode the ID[2:0] pins should be setup as '0xx' and the MSb (bit 7) of the WRADD and RDADD address busses should be zero. The ID[2:0] inputs setup a respective device ID during Master Reset. These ID pins must not toggle during any device operation. Note, the device selected as the 'Master' does not have to have the ID of '000'. |
| MAST<br>(U1)                               | Master Device             | 1.8V LVTTL<br>INPUT | The state of this input at Master Reset determines whether a given device (within a chain of devices), is the Master device or a Slave. If this pin is HIGH, the device is the master if it is LOW then it is a Slave. The master device is the first to take control of all outputs after a Master Reset, all slave devices go to High-Impedance, preventing bus contention. If a multi-queue device is being used in single device mode, this pin must be set HIGH.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| MRS<br>(T3)                                | Master Reset              | HSTL<br>INPUT       | The Master Reset is used to configure the device. To configure the device configuration signals must be asserted that meet the setup time and hold time requirements of a Master Reset cycle. Transitioning MRS from HIGH to LOW then LOW to HIGH performs a complete Master Reset cycle. Note, additional device programming is required after master reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|                                                                                                             | CRIPTION                                |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol & Pin No.                                                                                            | Name                                    | I/O TYPE            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ŌE<br>(R22)                                                                                                 | Output Enable                           | HSTL<br>INPUT       | The Output Enable signal is the three-state control of the multi-queue data output bus Q[39:0], Qout. If a device has been configured as a "Master" device, the Qout data outputs will be in a low impedance condition if the $\overline{OE}$ input is LOW. If $\overline{OE}$ is HIGH then the Qout data outputs will be in high impedance. If a device is configured a "Slave" device, then the Qout data outputs will always be in high impedance until that device has been selected on the Read Port, at which point $\overline{OE}$ provides three-state of that respective device.                                                                                                                                                                                                                                                                                                      |
| PAE<br>(N20)                                                                                                | Programmable<br>Almost-Empty<br>Flag    | HSTL<br>OUTPUT      | This pin provides the Almost-Empty flag status for the Queue that has been selected on the output port for read operations, (selected via RCLK, RDADD and RADEN). This pin is LOW when the selected Queue is almost-empty. This flag output may be duplicated on one of the PAEn bus lines. This flag is synchronized to RCLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| PAEn[7:0]<br>(PAE7-F21<br>PAE6-F22<br>PAE5-G20<br>PAE4-G21<br>PAE3-G22<br>PAE2-H20<br>PAE1-H21<br>PAE0-H22) | Programmable<br>Flag Bus                | HSTL<br>OUTPUT      | The PAEn bus is 8 bits wide. During a Master Reset this bus is setup for Almost Empty configuration. This output bus provides PAE status of 8 queues (1 quadrant), within a selected device. During Queue read/write operations these outputs provide programmable empty flag status or packet data available status, in either polled or direct mode. The mode of flag operation is determined during master reset via the state of the FM input. This flag bus is capable of High-Impedance state, this is important during expansion of multi-queue devices. During direct operation the PAEn bus is updated to show the PAE status of a quadrant of queues within a selected device. Selection is made using RCLK, ESTR and RDADD. During Polled operation the PAEn bus is loaded with the PAE status of multi-queue flow-control quadrants sequentially based on the rising edge of RCLK. |
| PAF<br>(F3)                                                                                                 | Programmable<br>Almost–Full Flag        | HSTL<br>OUTPUT      | This pin provides the Almost-Full flag status for the Queue that has been selected on the input port for write operations, (selected via WCLK, WRADD and WADEN). This pin is LOW when the selected Queue is almost-full. This flag output may be duplicated on one of the $\overline{PAF}$ n bus lines. The $\overline{PAE}$ flag is asserted synchronous to WCLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PAFn[7:0]<br>(PAF7-F2<br>PAF6-F1<br>PAF5-G3<br>PAF4-G2<br>PAF3-G1<br>PAF2-H3<br>PAF1-H2<br>PAF0-H1)         | Programmable<br>Almost-Full Flag<br>Bus | HSTL<br>OUTPUT      | The $\overline{PAF}n$ bus is 8 bits wide. At any one time this output bus provides $\overline{PAF}$ status of 8 queues (1 quadrant), within a selected device. During Queue read/write operations these outputs provide programmable full flag status, in either direct or polled mode. The mode of flag operation is determined during master reset via the state of the FM input. This flag bus is capable of High-Impedance state, this is important during expansion of multi-queue devices. During direct operation the $\overline{PAF}n$ bus is updated to show the $\overline{PAF}$ status of a quadrant of queues within a selected device. Selection is made using WCLK, FSTR, WRADD and WADEN. During Polled operation the $\overline{PAF}n$ bus is loaded with the $\overline{PAF}$ status of multi-queue flow-control quadrants sequentially based on the rising edge of WCLK.     |
| PLL ON<br>(V1)                                                                                              | PLL ON                                  | HSTL<br>INPUT       | This pin is used to enable the PLL. When PLL is activated, data will be clocked out by PLL generated clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Q[39:0](Qout)<br>(See Pin No.<br>table for details)                                                         | Data Output Bus                         | HSTL<br>OUTPUT      | These are the 40 data output pins. Data is read out of the device via these output pins on the rising edge of RCLK provided that $\overline{REN}$ is LOW, $\overline{OE}$ is LOW and the Queue is selected. Due to bus-matching not all outputs may be used, any unused outputs should not be connected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| QSEL[2:0]<br>(QSEL2-BB10<br>QSEL1-AA10<br>QSEL0-BB9)                                                        | Queue Select                            | 1.8V LVTTL<br>INPUT | The QSEL pins provides various queue programming options. Refer to Table 10, Write Queue Switch Operation for details.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RADEN<br>(T22)                                                                                              | Read Address<br>Enable                  | HSTL<br>INPUT       | The RADEN input is used in conjunction with RCLK and the RDADD address bus to select a queue to be read from. A queue addressed via the RDADD bus is selected on the rising edge of RCLK provided that RADEN is HIGH. RADEN should be asserted (HIGH) only during a queue change cycle(s). RADEN should not be permanently tied HIGH. RADEN cannot be HIGH for the same RCLK cycle as ESTR. Note, that a read queue selection cannot be made, (RADEN must NOT go active) until programming of the part has been completed and SENO has gone LOW.                                                                                                                                                                                                                                                                                                                                               |
| RCLK<br>(J22)                                                                                               | Read Clock                              | HSTL<br>INPUT       | When enabled by $\overline{\text{REN}}$ , the rising edge of RCLK reads data from the selected queue via the output bus Qout. The queue to be read is selected via the RDADD address bus and a rising edge of RCLK while RADEN is HIGH. A rising edge of RCLK in conjunction with ESTR and RDADD will also select the $\overline{\text{PAE}}$ n flag quadrant to be placed on the $\overline{\text{PAE}}$ n bus during direct flag operation. During polled flag operation the $\overline{\text{PAE}}$ n bus is cycled with respect to RCLK and the ESYNC signal is synchronized to RCLK. The $\overline{\text{PAE}}$ , and                                                                                                                                                                                                                                                                    |

| Symbol &<br>Pin No.                                                                                                          | Name                    | I/O TYPE       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------------------------------------------------------------------------------------------------------|-------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RCLK (Cont'd)<br>(J22)                                                                                                       | Read Clock              | HSTL<br>INPUT  | EF outputs are all synchronized to RCLK. During device expansion the EXO and EXI signals are based on RCLK. RCLK must be continuous and free-running.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| RCS<br>(J21)                                                                                                                 | Read Chip<br>Select     | HSTL<br>INPUT  | The RCS signal in concert with REN signal provides control to enable data on to the output read data bus. During a Master Reset cycle the RCS it is don't care signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RDADD[7:0]<br>(RDADD7-V20<br>RDADD6-V21<br>RDADD5-V22<br>RDADD4-U20<br>RDADD3-U21<br>RDADD2-U22<br>RDADD1-T20<br>RDADD0-T21) | Read Address<br>Bus     | HSTL<br>INPUT  | For the 128Q device the RDADD bus is 8 bits. The RDADD bus is a dual purpose address bus. The first function of RDADD is to select a Queue to be read from. The least significant 5 bits of the bus, RDADD[4:0] are used to address 1 of 128 possible queues within a multi-queue device. The most significant 3 bits, RDADD[7:5] are used to select 1 of 8 possible multi-queue devices that may be connected in expansion mode. These 3 MSB's will address a device with the matching ID code. (See ID[2:0] description for more detail on matching ID code. The second function of the RDADD bus is to select the quadrant of queues to be loaded on to the PAEn bus during strobed flag mode. The least significant 4 bits, RDADD[3:0] are used to select the quadrant of a device to be placed on the PAEn bus. The most significant 3 bits, RDADD[7:5] are again used to select 1 of 8 possible multi-queue devices that may be connected in expansion mode. Address bit RDADD[4] is don't care during quadrant selection. |
| REN<br>(J20)                                                                                                                 | Read Enable             | HSTL<br>INPUT  | The REN input enables read operations from a selected Queue based on a rising edge of RCLK. A queue to be read from can be selected via RCLK, RADEN and the RDADD address bus regardless of the state of REN. Data from a newly selected queue will be available on the Qout output bus on the second RCLK cycle after queue selection regardless of REN. A read enable is not required to cycle the PAEn bus (in polled mode) or to select the PAEn quadrant, (in direct mode).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| SCLK<br>(K3)                                                                                                                 | Serial Clock            | HSTL<br>INPUT  | If serial programming of the multi-queue device has been selected during master reset, the SCLK input clocks the serial data through the multi-queue device. Data setup on the SI input is loaded into the device on the rising edge of SCLK provided that SENI is enabled, LOW. When expansion of devices is performed the SCLK of all devices should be connected to the same source.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| SENI<br>(K1)                                                                                                                 | Serial Input<br>Enable  | HSTL<br>INPUT  | During serial programming of a multi-queue device, data loaded onto the SI input will be clocked into the part (via a rising edge of SCLK), provided the SENI input of that device is LOW. If multiple devices are cascaded, the SENI input should be connected to the SENO output of the previous device. So when serial loading of a given device is complete, its SENO output goes LOW, allowing the next device in the chain to be programmed (SENO will follow SENI of a given device once that device is programmed). The SENI input of the master device (or single device), should be controlled by the user.                                                                                                                                                                                                                                                                                                                                                                                                            |
| SENO<br>(K2)                                                                                                                 | Serial Output<br>Enable | HSTL<br>OUTPUT | This output is used to indicate that serial programming or default programming of the multi-queue device has been completed. SENO follows SENI once programming of a device is complete. Therefore, SENO will go LOW after programming provided SENI is LOW, once SENI is taken HIGH again, SENO will also go HIGH. When the SENO output goes LOW, the device is ready to begin normal read/write operations. If multiple devices are cascaded and serial programming of the devices will be used, the SENO output should be connected to the SENI input of the next device in the chain. When serial programming of the first device is complete, SENO will go LOW, thereby taking the SENI input of the next device LOW and so on throughout the chain. When a given device in the chain is fully programmed the SENO output essentially follows the SENI input. The user should monitor the SENO output of the final device in the chain. When this output goes LOW, serial loading of all devices has been completed.        |
| SI<br>(L2)                                                                                                                   | Serial In               | HSTL<br>INPUT  | During serial programming this pin is loaded with the serial data that will configure the multi-queue devices. Data present on SI will be loaded on a rising edge of SCLK provided that SENI is LOW. In expansion mode the serial data input is loaded into the first device in a chain. When that device is loaded and its SENO has gone LOW, the data present on SI will be directly output to the SO output. The SO pin of the first device connects to the SI pin of the second and so on. The multi-queue device setup registers are shift registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SO (L3)                                                                                                                      | Serial Out              | HSTL<br>OUTPUT | This output is used in expansion mode and allows serial data to be passed through devices in the chain to complete programming of all devices. The SI of a device connects to SO of the previous device in the chain. The SO of the final device in a chain should not be connected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| TCK<br>(B10)                                                                                                                 | JTAG Clock              | HSTL<br>INPUT  | Clock input for JTAG function. One of four terminals required by IEEE Standard 1149.1-1990. Test operations of the device are synchronous to TCK. Data from TMS and TDI are sampled on the rising edge of TCK and outputs change on the falling edge of TCK. If the JTAG function is not used this signal needs to be tied to GND.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Symbol &<br>(Pin No.)                                                                                                | Name                     | I/O TYPE      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------------------------------------------------------------------------------------------|--------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TDI (A11)                                                                                                            | JTAG Test Data           | HSTL<br>INPUT | One of four terminals required by IEEE Standard 1149.1-1990. During the JTAG boundary scan operation, Input test data serially loaded via the TDI on the rising edge of TCK to either the Instruction Register, ID Register and Bypass Register. An internal pull-up resistor forces TDI HIGH if left unconnected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| TDO<br>(B11)                                                                                                         | JTAG Test Data<br>Output | HSTL          | One of four terminals required by IEEE Standard 1149.1-1990. During the JTAG boundary scan operation, test data serially loaded output via the TDO on the falling edge of TCK from either the Instruction Register, ID Register and Bypass Register. This output is high impedance except when shifting, while in SHIFT-DR and SHIFT-IR controller states.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| TP<br>(U3)                                                                                                           | IDT Internal<br>Test Pin | LVTTL         | For IDT internal test purpose only, must be tied to GND for normal/correct operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| TMS<br>(A10)                                                                                                         | JTAG Mode<br>Select      | HSTL<br>INPUT | TMS is a serial input pin. One of four terminals required by IEEE Standard 1149.1-1990. TMS directs the device through its TAP controller states. An internal pull-up resistor forces TMS HIGH if left unconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TRST<br>(A9)                                                                                                         | JTAG Reset               | HSTL<br>INPUT | TRST is an asynchronous reset pin for the JTAG controller. The JTAG TAP controller does not automatically reset upon power-up, thus it must be reset by either this signal or by setting TMS= HIGH for five TCK cycles. If the TAP controller is not properly reset then the outputs will always be in high-impedance. If the JTAG function is used but the user does not want to use TRST, then TRST can be tied with MRS to ensure proper queue operation. If the JTAG function is not used then this signal needs to be tied to GND. An internal pull-up resistor forces TRST HIGH if left unconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| WADEN<br>(M3)                                                                                                        | Write Address<br>Enable  | HSTL<br>INPUT | The WADEN input is used in conjunction with WCLK and the WRADD address bus to select a queue to be written in to. A queue addressed via the WRADD bus is selected on the rising edge of WCLK provided that WADEN is HIGH. WADEN should be asserted (HIGH) only during a queue change cycle(s). WADEN should not be permanently tied HIGH. WADEN cannot be HIGH for the same WCLK cycle as FSTR. Note, that a write queue selection cannot be made, (WADEN must NOT go active) until programming of the part has been completed and SENO has gone LOW.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| WCLK<br>(M2)                                                                                                         | Write Clock              | HSTL<br>INPUT | When enabled by WEN, the rising edge of WCLK writes data into the selected Queue via the input bus, Din. The Queue to be written to is selected via the WRADD address bus and a rising edge of WCLK while WADEN is HIGH. A rising edge of WCLK in conjunction with FSTR and WRADD will also select the flag quadrant to be placed on the PAFn bus during direct flag operation. During polled flag operation the PAFn bus is cycled with respect to WCLK and the FSYNC signal is synchronized to WCLK. The PAFn, PAF and FF outputs are all synchronized to WCLK. During device expansion the FXO and FXI signals are based on WCLK. The WCLK must be continuous and free-running                                                                                                                                                                                                                                                                                                                                                                     |
| WCS<br>(L1)                                                                                                          | Write Chip<br>Select     | HSTL<br>INPUT | The $\overline{WCS}$ signal in concert with $\overline{WEN}$ signal provides control to enable data from the input write data bus to be written into the device. During a Master Reset cycle the $\overline{WCS}$ it is don't care signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| WEN<br>(M1)                                                                                                          | Write Enable             | HSTL<br>INPUT | The WEN input enables write operations to a selected Queue based on a rising edge of WCLK. A queue to be written to can be selected via WCLK, WADEN and the WRADD address bus regardless of the state of WEN. Data present on Din can be written to a newly selected queue on the second WCLK cycle after queue selection provided that WEN is LOW. A write enable is not required to cycle the PAFn bus (in polled mode) or to select the PAFn quadrant, (in direct mode).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| WRADD[7:0]<br>(WRADD7-R2<br>WRADD6-R1<br>WRADD5-P3<br>WRADD4-P2<br>WRADD3-P1<br>WRADD2-N3<br>WRADD1-N2<br>WRADD0-N1) | Write Address<br>Bus     | HSTL<br>INPUT | The WRADD bus is 8 bits. The WRADD bus is a dual purpose address bus. The first function of WRADD is to select a Queue to be written to. The least significant 5 bits of the bus, WRADD[4:0] are used to address 1 of 128 possible queues within a multi-queue device. The most significant 3 bits, WRADD[7:5] are used to select 1 of 8 possible multi-queue devices that may be connected in expansion mode. These 3 MSB's will address a device with the matching ID code. (See ID[2:0] description for more detail on matching ID code. The second function of the WRADD bus is to select the quadrant of queues to be loaded on to the $\overline{\text{PAFn}}$ bus during strobed flag mode. The least significant 4 bits, WRADD[3:0] are used to select the quadrant of a device to be placed on the $\overline{\text{PAFn}}$ bus. The most significant 3 bits, WRADD[7:5] are again used to select 1 of 8 possible multi-queue devices that may be connected in expansion mode. Address bit WRADD[4] is don't care during quadrant selection. |
| ZQ<br>(N22)                                                                                                          | ZQ                       | HSTL<br>INPUT | Output Impedance Matching Input. This input is used to tune the device outputs to the system data bus impedance. Q[39:0] output impedance is set to $0.2  x  RQ$ , where RQ is a resistor connected between ZQ and ground. This pin cannot be connected directly to GND or left unconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Symbol & Pin No.        | Name           | I/O TYPE | Description                                                                                                                                                                                                      |
|-------------------------|----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VDD<br>(See below)      | +1.8V Supply   | Power    | These are VCC power supply pins and must all be connected to a +1.8V supply                                                                                                                                      |
| VDDQ<br>(See below)     | Output Voltage | Power    | These pins must be tied to the desired output supply voltage (=1.5V for HSTL and =1.8V for eHSTL).                                                                                                               |
| Vref<br>(J1, M21)       | Reference      | INPUT    | This is a Voltage Reference input and must be connected to a voltage level determined from the table Voltage "Recommended DC Operating Conditions". The input provides the reference level for HSTL/eHSTLinputs. |
| GND<br>(See below)      | Ground         | Ground   | These are Ground pins and must all be connected to the Ground of the power supply.                                                                                                                               |
| AVDD<br>(K21, M22)      | PLL Power      | Power    | 1.8V PLL Power Supply.                                                                                                                                                                                           |
| AVSS<br>(L(21,22), K22) | PLL Ground     | Ground   | Ground for the PLL device. Should be connected to ground of the system.                                                                                                                                          |

#### NOTE:

## **PIN NUMBER TABLE**

| Symbol  | Name             | I/O TYPE            | Pin Number                                                                                                                                                                                                                                                                                                                                                    |
|---------|------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D[39:0] | Data Input Bus   | HSTL-LVTTL<br>INPUT | D39-AA9, D38-BB8, D37-AA8, D36-BB7, D35-AA7, D34-BB6, D33-AA6, D32-BB5, D31-AA5, D30-BB4, D29-AA4, D28-BB3, D27-AA3, D(26,25)-Y(3,4), D(24-22)-W(3-1), D(21,20)-V(3,2), D(19,18)-E(2,3), D(17-15)-D(1-3), D(14,13)-C(4,3), D12-B3, D11-A3, D10-B4, D9-A4, D8-B5, D7-A5, D6-B6, D5-A6, D4-B7, D3-A7, D2-B8, D1-A8, D0-B9                                       |
| Q[39:0] | Data Output Bus  | HSTL-LVTTL          | Q39-AA13, Q38-BB14, Q37-AA14, Q36-BB15, Q35-AA15, Q34-AA15, Q33-AA16, Q32-BB17, Q31-AA17, Q30-BB18, Q29-AA18, Q28-BB19, Q27-AA19, Q26-BB20, Q25-AA20, Q(24,23)-Y(20,19), Q(22-20)-W(20-22), Q(19-17)-D(22-20), Q(16,15)-C(19,20), Q14-B20, Q13-A20, Q12-B19, Q11-A19, Q10-B18, Q9-A18, Q8-B17, Q7-A17, Q6-B16, Q5-A16, Q4-B15, Q3-A15, Q2-B14, Q1-A14, Q0-B13 |
| VDD     | +1.8V Supply     | Power               | D(4-10,13-19), E(4-9,14-17,19), G18, H(4,5,18,19), J(4,19), P(4,19), R(3-5,18,19), V(4-8,15-19), W(4-10,13-19)                                                                                                                                                                                                                                                |
| VDDQ    | O/P Rail Voltage | Power               | C(5-10,13-18) E18, F(4,5,18,19), G(4,5,19), T(4,5,18,19), U(4,5,18,19), Y(5-10,14-18)                                                                                                                                                                                                                                                                         |
| GND     | Ground Pin       | Ground              | A(1,2,21,22), B(1,2,21,22), C(1,2,11,12,21,22), D(11,12), E(10-13), J(5,9-14,18), K(4,5,9-14,18-20), L(4,5,9-14,18-20), M(4,5,9-14,18-20), N(4,5,9-14,18,19), P(5,9-14,18), V(9-14), W(11,12), Y(1,2,11-13,21,22), AA(1,2,21,22), BB(1,2,21,22)                                                                                                               |

<sup>1.</sup> Inputs should not change after Master Reset.

#### **ABSOLUTE MAXIMUM RATINGS**

| Symbol | Rating                                  | Commercial                  | Unit |
|--------|-----------------------------------------|-----------------------------|------|
| VTERM  | Terminal Voltage<br>with respect to GND | -0.5 to +2.9 <sup>(2)</sup> | V    |
| Tstg   | Storage Temperature                     | -55 to +125                 | °C   |
| Іоит   | DC Output Current                       | -50 to +50                  | mA   |

#### NOTES:

- 1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.
- 2. Compliant with JEDEC JESD8-5. VDD terminal only.

## **CAPACITANCE** (TA = +25°C, f = 1.0MHz)

| Symbol                | Parameter <sup>(1)</sup> | Conditions | Max.              | Unit |
|-----------------------|--------------------------|------------|-------------------|------|
| CIN <sup>(2,3)</sup>  | Input<br>Capacitance     | VIN = 0V   | 10 <sup>(3)</sup> | pF   |
| Cout <sup>(1,2)</sup> | Output<br>Capacitance    | Vout = 0V  | 15                | pF   |

#### NOTES:

- 1. With output deselected,  $(\overline{OE} \ge V_{IH})$ .
- 2. Characterized values, not currently tested.
- 3. CIN for Vref is 20pF.

#### RECOMMENDED DC OPERATING CONDITIONS

| VECO                               | ALCOMMENDED DC OPERATING CONDITIONS |                   |                      |             |                      |        |
|------------------------------------|-------------------------------------|-------------------|----------------------|-------------|----------------------|--------|
| Symbol                             | Param                               | eter              | Min.                 | Тур.        | Max.                 | Unit   |
| Vdd                                | Supply Voltage                      |                   | 1.7                  | 1.8         | 1.9                  | V      |
| VDDQ                               | Output Rail Voltage for I/Os        | — eHSTL<br>— HSTL | 1.7<br>1.4           | 1.8<br>1.5  | 1.9<br>1.6           | V<br>V |
| GND                                | Supply Voltage                      |                   | 0                    | 0           | 0                    | V      |
| VIH <sup>(2)</sup>                 | Input High Voltage                  | — eHSTL<br>— HSTL | VREF+0.2<br>VREF+0.2 | ,<br>       | _                    | V<br>V |
| VIL                                | Input Low Voltage                   | — eHSTL<br>— HSTL |                      |             | VREF-0.2<br>VREF-0.2 | V<br>V |
| VREF <sup>(1)</sup><br>(HSTL only) | Voltage Reference Input             | — eHSTL<br>— HSTL | 0.8<br>0.68          | 0.9<br>0.75 | 1.0<br>0.9           | V<br>V |
| TA                                 | Operating Temperature Commercial    |                   | 0                    | _           | 70                   | °C     |
| TA                                 | Operating Temperature Indus         | trial             | -40                  | _           | 85                   | °C     |

#### NOTES:

- 1. VREF is only required for HSTL or eHSTL inputs.
- 2. VIH AC Component = VREF + 0.4V

#### DC ELECTRICAL CHARACTERISTICS

(Commercial: VDD =  $1.8V \pm 0.10V$ , TA =  $0^{\circ}$ C to  $+70^{\circ}$ C;Industrial: VDD =  $1.8V \pm 0.10V$ , TA =  $-40^{\circ}$ C to  $+85^{\circ}$ C)

| Symbol                 |                                                     | Parameter                                         |             |             |             | Unit |
|------------------------|-----------------------------------------------------|---------------------------------------------------|-------------|-------------|-------------|------|
| lu                     | Input Leakage Current                               |                                                   |             | -10         | 10          | μΑ   |
| llo                    | Output Leakage Current                              |                                                   |             | -10         | 10          | μА   |
| Voh1 <sup>(7)</sup>    | Output High Voltage (te                             | st conditions: RQ = $205\Omega$ IOH               | = -8mA)     | VDDQ/2-0.12 | VDDQ/2+0.12 | V    |
| VOL1 <sup>(8)</sup>    | Output Low Voltage (tes                             | it conditions: RQ = $205\Omega$ lo.               | = 8mA)      | VDDQ/2-0.12 | VDDQ/2+0.12 | V    |
| Voh2 <sup>(9)</sup>    | Output High Voltage (test conditions: IoH = -0.1mA) |                                                   |             | VDDQ-0.12   | VDDQ        | V    |
| Vol2 <sup>(10)</sup>   | Output Low Voltage (tes                             | Output Low Voltage (test conditions: IoL = 0.1mA) |             |             | 0.2         | V    |
| IDD1 <sup>(1,2)</sup>  | Active VDD Current (VDI                             | ) = 1.8V)                                         | I/O = HSTL  | _           | 200         | mA   |
|                        |                                                     |                                                   | I/O = eHSTL | _           | 200         | mA   |
| IDD2 <sup>(1, 5)</sup> | Standby VDD Current (VDD = 1.8V) I/O = HSTL         |                                                   | _           | 120         | mA          |      |
|                        |                                                     | I/O = eHSTL                                       |             | _           | 120         | mA   |
| IDDQ <sup>(1,2)</sup>  | Active VDDQ Current                                 | (VDDQ = 1.5V HSTL)                                | I/O = HSTL  | _           | 20          | mA   |
|                        |                                                     | (VDDQ = 1.8V eHSTL)                               | I/O = eHSTL | _           | 20          | mA   |

#### NOTES:

- 1. Both WCLK and RCLK toggling at 20MHz.
- 2. Data inputs toggling at 10MHz.
- 3. Total Power consumed: PT = [(VDD x IDD) + (VDDQ x IDDQ)].
- 4. Outputs are not 2.5V or 3.3V tolerant.
- 5. The following inputs should be pulled to GND: WRADD, RDADD, WADEN, FSTR, ESTR, SCLK, SI, EXI, FXI and all Data Inputs. The following inputs should be pulled to VDD: WEN, REN, SENI, MRS, TDI, TMS and TRST.
  All other inputs are don't care and should be at a known state.
- 6. The ZQ pin is used to control the device outputs (Q[39:0], EREN, ERCLK, and ERCLK).
- 7. Outputs are impedance-controlled. IOH= -(VDDQ/2)/(RQ/5) and is guaranteed by device characterization for  $175\Omega$ < RQ <  $350\Omega$ . This parameter is tested at RQ =  $250\Omega$  which gives a nominal  $50\Omega$  output impedance.
- 8. Outputs are impedance-controlled. IOL = (VDDO/2)/(RQ/5) and is guaranteed by device characterization for  $175\Omega$ < RQ <  $350\Omega$  This parameter is tested at RQ =  $250\Omega$  which gives a nominal  $50\Omega$  output impedance.
- 9. This measurement is taken to ensure that the output has the capability of pulling to the VDDQ rail, and is not intended to be used as an impedance measurement point.
- 10. This measurement is taken to ensure that the output has the capability of pulling to VSS, and is not intended to be used as an impedance measurement point.

#### **HSTL**

## 1.5V AC TEST CONDITIONS

| Input Pulse Levels            | 0.25 to 1.25V |
|-------------------------------|---------------|
| Input Rise/Fall Times         | 0.4ns         |
| Input Timing Reference Levels | 0.75          |
| Output Reference Levels       | VDDQ/2        |
|                               |               |

NOTE:

## **EXTENDED HSTL 1.8V AC TEST CONDITIONS**

| Input Pulse Levels            | 0.4 to 1.4V |
|-------------------------------|-------------|
| Input Rise/Fall Times         | 0.4ns       |
| Input Timing Reference Levels | 0.9         |
| Output Reference Levels       | VDDQ/2      |
|                               |             |

NOTE:

#### **AC TEST LOADS**



Figure 2a. AC Test Load



Figure 2b. Lumped Capacitive Load, Typical Derating

#### **OUTPUT ENABLE & DISABLE TIMING**



1. REN is HIGH.

<sup>1.</sup>  $VDDQ = 1.5V \pm 0.1V$ .

<sup>1.</sup>  $VDDQ = 1.8V \pm 0.1V$ .

## **AC ELECTRICAL CHARACTERISTICS**

(Commercial: VDD =  $1.8V \pm 0.10V$ , TA =  $0^{\circ}$ C to  $+70^{\circ}$ C; Industrial: VDD =  $1.8V \pm 0.10V$ , TA =  $-40^{\circ}$ C to  $+85^{\circ}$ C; JEDEC JESD8-A compliant)

|               |                                      | Comr   | nercial | Com'l a | ınd Ind'l |        |
|---------------|--------------------------------------|--------|---------|---------|-----------|--------|
|               |                                      | IDT72P | 51767L6 | IDT72P5 | 1767L7-5  | 1      |
| Symbol        |                                      | IDT72P | 51777L6 | IDT72P5 | 1777L7-5  |        |
|               | Parameter                            | Min.   | Max.    | Min.    | Max.      | Unit   |
| fc            | Clock Cycle Frequency                | _      | 166     | _       | 133       | MHz    |
| ta (PLL ON)   | Data Access Time                     | -1.0   | 1.0     | -1.2    | 1.2       | ns     |
| ta (PLL OFF)  | Data Access Time                     | 0.6    | 3.6     | 0.8     | 3.8       | ns     |
| tclk          | Clock Cycle Time                     | 6.0    |         | 7.5     | _         | ns     |
| tclkh         | Clock High Time                      | 2.8    |         | 3.0     | _         | ns     |
| tclkl         | Clock Low Time                       | 2.8    |         | 3.0     | _         | ns     |
| tos           | Data Setup Time                      | 0.48   | _       | 0.7     | _         | ns     |
| tDH .         | Data Hold Time                       | 0.48   |         | 0.7     | _         | ns     |
| tens          | Enable Setup Time                    | 2.0    |         | 2.2     | _         | ns     |
| tenh          | Enable Hold Time                     | 0.5    | _       | 0.7     | _         | ns     |
| trs           | Reset Pulse Width®                   | 30     | _       | 30      | _         | ns     |
| trss          | Reset Setup Time                     | 15     | _       | 15      | _         | ns     |
| trsr          | Reset Recovery Time                  | 10     | _       | 10      | _         | ns     |
| tohz          | Output Enable to Output in High Z    | 0.6    | 3.6     | 0.8     | 3.8       | ns     |
| toe           | Output Enable to OE                  | 0.6    | 3.6     | 0.8     | 3.8       | ns     |
| fs            | Clock Cycle (SCLK)                   | _      | 10      | _       | 10        | MHz    |
| tsclk         | Serial Clock Cycle                   | 100    | _       | 100     | _         | ns     |
| tsckh         | Serial Clock High                    | 45     | _       | 45      | _         | ns     |
| tsckl         | Serial Clock Low                     | 45     | _       | 45      | _         | ns     |
| tsds          | Serial Data in Setup                 | 20     | _       | 20      | _         | ns     |
| tsdh          | Serial Data in Hold                  | 0.8    | _       | 0.8     | _         | ns     |
| tsens         | Serial Enable Setup                  | 20     | _       | 20      | _         | ns     |
| tsenh         | Serial Enable Hold                   | 0.8    | _       | 0.8     | _         | ns     |
| tsdo          | SCLK to Serial Data Out              | _      | 20      | _       | 20        | ns     |
| tseno         | SCLK to Enable Out                   | _      | 20      | _       | 20        | ns     |
| tsdop         | Serial Data Out Delay                | 0.8    | 3.6     | 0.8     | 3.6       | ns     |
| tsenop        | Serial Enable Delay                  | 0.8    | 3.6     | 0.8     | 3.6       | ns     |
| <b>t</b> PCWQ | Programming to Write Queue Selection | _      | 7       | _       | 7         | cycles |
| tPCRQ.        | Programming to Read Queue Selection  | _      | 7       | _       | 7         | cycles |
| tas           | Address Setup                        | 2.0    | _       | 2.2     | _         | ns     |
| <b>t</b> AH   | Address Hold                         | 0.5    | _       | 0.7     | _         | ns     |
| twff          | Write Clock to Full Flag (FF)        | -      | 3.6     | _       | 3.8       | ns     |
| tref          | Read Clock to Empty Flag (EF)        |        | 3.6     |         | 3.8       | ns     |
| tsts          | Strobe Setup                         | 2.0    | _       | 2.2     | _         | ns     |
| tsth          | Strobe Hold                          | 0.5    | _       | 0.7     | _         | ns     |
| tos           | Queue Setup                          | 2.0    | _       | 2.2     | _         | ns     |
| to:H          | Queue Hold                           | 0.5    | _       | 0.7     | _         | ns     |
| twar          | WCLK to PAF flag                     | 0.6    | 3.6     | 0.8     | 3.8       | ns     |
| trae          | RCLK to PAE flag                     | 0.6    | 3.6     | 0.8     | 3.8       | ns     |
| tPAF          | WCLK to Sync PAF bus                 | 0.6    | 3.6     | 0.8     | 3.8       | ns     |
| tpae t        | RCLK to Sync PAE bus                 | 0.6    | 3.6     | 0.8     | 3.8       | ns     |
| tPAELZ        | RCLK to Low-Z                        | 0.6    | 3.6     | 0.8     | 3.8       | ns     |
| tPAEHZ        | RCLK to High-Z                       | 0.6    | 3.6     | 0.8     | 3.8       | ns     |
| tPAFLZ        | WCLK to PAF Bus Low-Z                | 0.6    | 3.6     | 0.8     | 3.8       | ns     |

#### NOTES:

- 1. Industrial temperature range product for the 7-5ns is available as a standard device. All other speed grades available by special order.
- 2. Values guaranteed by design, not currently tested.

## AC ELECTRICAL CHARACTERISTICS (CONTINUED)

(Commercial: VDD =  $1.8V \pm 0.10V$ , TA =  $0^{\circ}$ C to  $+70^{\circ}$ C; Industrial: VDD =  $1.8V \pm 0.10V$ , TA =  $-40^{\circ}$ C to  $+85^{\circ}$ C; JEDEC JESD8-A compliant)

|               |                                                   | Commercial Com'l and Ind'l    |      |         |      |      |
|---------------|---------------------------------------------------|-------------------------------|------|---------|------|------|
|               |                                                   | IDT72P51767L6 IDT72P51767L7-5 |      | 767L7-5 |      |      |
|               |                                                   | IDT72P51777L6 IDT72P51777L7-5 |      |         |      |      |
| Symbol        | Parameter                                         | Min.                          | Max. | Min.    | Max. | Unit |
| tpafhz        | WCLK to PAF Bus High-Z                            | 0.6                           | 3.6  | 0.8     | 3.8  | ns   |
| tffhz         | WCLK to FF High-Z                                 | 0.6                           | 3.6  | 0.8     | 3.8  | ns   |
| tfflz         | WCLK to FF Low-Z                                  | 0.6                           | 3.6  | 0.8     | 3.8  | ns   |
| tefhz         | RCLK to EF High-Z                                 | 0.6                           | 3.6  | 0.8     | 3.8  | ns   |
| teflz         | RCLK to EF Low-Z                                  | 0.6                           | 3.6  | 0.8     | 3.8  | ns   |
| tfsync        | WCLK to PAF Bus Sync                              | 0.6 3.6                       |      | 0.8     | 3.8  | ns   |
| tfxo          | WCLK to PAF Bus Exp                               | 0.6                           | 3.6  | 0.8     | 3.8  | ns   |
| tesync        | RCLK to PAF Bus Sync                              | 0.6                           | 3.6  | 0.8     | 3.8  | ns   |
| texo          | RCLK to PAF Bus Exp                               | 0.6                           | 3.6  | 0.8     | 3.8  | ns   |
| terclk (DDR)  | RCLK to ERCLK (DDR)                               | _                             | 2.5  | _       | 3.2  | ns   |
| terclk (SDR)  | RCLK to ERCLK (SDR)                               | _                             | 4    | _       | 5    | ns   |
| tskew1        | Skew time for $\overline{EF}$ and $\overline{FF}$ | 6.0                           | _    | 7.0     | _    | ns   |
| tskew2        | Skew time for PAF and PAE                         | 6.0                           | _    | 7.0     | _    | ns   |
| tskew3        | Skew time for PAF/PAE[0:7]                        | 6.0                           |      | 7.0     | _    | ns   |
| txis          | Expansion Input Setup                             | 2.0                           |      | 2.2     | _    | ns   |
| txih          | Expansion Input Hold                              | 0.5                           | _    | 0.7     | _    | ns   |
| <b>t</b> LOCK | PLL Lock Time                                     | _                             | 15   | _       | 15   | μs   |

#### NOTES:

<sup>1.</sup> Industrial temperature range product for the 7-5ns is available as a standard device. All other speed grades available by special order.

<sup>2.</sup> Values guaranteed by design, not currently tested.

#### XGMII REFERENCE SPECIFICATION

The XGMII uses 1.5V High Speed Transceiver Logic (HSTL) signal levels. The electrical characteristics of the XGMII are specified such that the XGMII can be applied within a variety of 10 Gb/s equipment types. The electrical specifications are selected for an integrated circuit to integrated circuit application. The electrical characteristics specified in this clause apply to all XGMII signals.

When implemented as a chip-to-chip interface, the XGMII uses High Speed Transceiver Logic (HSTL), specified for a 1.5 volt output buffer supply voltage. XGMII chip-to-chip signals shall comply with EIA/JEDEC Standard EIA/JESD8-6 using Class I, output buffers. Output impedance shall be greater than  $38\Omega$  to assure acceptable overshoot and undershoot performance in an un-terminated interconnection.

## TABLE 2 — DC AND AC SPECIFICATIONS (INFORMATIVE)

| Symbol | Parameter               | Minimum     | Nominal | Maximum   | Units |
|--------|-------------------------|-------------|---------|-----------|-------|
| VDDQ   | Output Voltage Supply   | 1.4         | 1.4 1.5 |           | V     |
| VREF   | Input Reference Voltage | 0.68 0.75   |         | 0.90      | V     |
| VIH_DC | DC Input Logic High     | VREF+0.10 - |         | VDDQ+0.3  | V     |
| VIL_DC | DC Input Logic Low      | -0.30 -     |         | VREF-0.1  | V     |
| VIH_AC | AC Input Logic High     | VREF+0.20 - |         | -         | V     |
| VIL_AC | AC Input Logic Low      | -           | -       | VREF-0.20 | V     |



Figure 3. HSTL Termination for XGMII

## TABLE 3 — IDT TO XGMII INTERFACE MAPPING SCHEMA

| Signal Type           | IDT Interface Signal<br>Nomenclature | XGMII Signal<br>Nomenclature |
|-----------------------|--------------------------------------|------------------------------|
| Input Port            |                                      |                              |
| - Input Port Data     | D[31:0]                              | TXD [31:0]                   |
|                       | D[32:39]                             | User definable               |
| - Input Port Enable   | WEN                                  | N/A                          |
| - Input Port Control  | N/A                                  | TXC[3:0]                     |
| - Input Port Status   | FF, PAF                              | N/A                          |
| - Input Port Clock    | WCLK                                 | TX_CLK                       |
| Output Port           |                                      |                              |
| - Output Port Data    | Q[31:0]                              | RXD [31:0]                   |
|                       | Q[32:39]                             | User definable               |
| - Output Port Enable  | REN                                  | N/A                          |
| - Output Port Control | N/A                                  | RXC [3:0}                    |
| - Output Port Status  | ĒF, PAE                              | N/A                          |
| - Output Port Clock   | RCLK                                 | RX_CLK                       |

#### **FUNCTIONAL DESCRIPTION**

#### **MASTER RESET**

A Master Reset is performed by toggling the  $\overline{\text{MRS}}$  input from HIGH to LOW to HIGH. During a master reset all internal multi-queue device setup and control registers are initialized and require programming either serially by the user via the serial port, or via parallel programming or by using the default settings. Refer to Figure 6, *Device Programming Hierarchy* for the programming hierarchy structure. During a master reset the state of the following inputs determine the functionality of the part, these pins should be held HIGH or LOW.

FM – Flag bus Mode BM [3:0] – Bus Matching options MAST – Master Device ID0, 1, 2 – Device ID QSEL[2:0] Queue Select Mode DFM - Programming mode, serial or default

Once a master reset has taken place, the device must be programmed either serially or via the default method before any read/write operations can begin. See Figure 37, *Master Reset* for relevant timing.

#### PROGRAMMING MODE CAPTURED

On the rising of  $\overline{\text{MRS}}$  the programming mode signals (QSEL [2:0], DFM) are captured. Once the programming mode signals are captured (latched), refer to Table 5, Setting the Queue Programming Mode during Master Reset for details. It will then require a number of clock cycles for the device to complete the configuration. Configuration completion is indicated when the  $\overline{\text{SENO}}$  signal transitions from high to low. The configuration completion indication is consistent with the previous MQ device.



Figure 4. Reference Signals

#### TABLE 4 — DEVICE PROGRAMMING MODE COMPARISON

| Programming Options | Serial Programming Mode                                 | Default/Parallel Programming Mode                                  |
|---------------------|---------------------------------------------------------|--------------------------------------------------------------------|
| Queue Selection     | Any number from 1 to 128                                | Any number from 1 to 128                                           |
| Queue Depth         | Each queue depth can be individualized                  | Default Value (total available memory divided by number of queues) |
| PAE/PAF             | Programmable to any value                               | Default value                                                      |
| Bus-Matching        | Any available option can be selected using BM[3:0] pins | Any available option can be selected using BM[3:0] pins            |
| I/O voltage         | Any available option can be selected                    | Any available option can be selected                               |

## TABLE 5—SETTING THE QUEUE PROGRAMMING MODE DURING MASTER RESET

| /MRS       | Default<br>Mode<br>(DFM) | OSEL 2 | QSEL 1 | QSEL 0 | Queue Programming Method                                                                          |
|------------|--------------------------|--------|--------|--------|---------------------------------------------------------------------------------------------------|
| 1          | 0                        | 0      | 0      | 0      | Serial programming mode                                                                           |
| 1          | 0                        | 0      | 0      | 1      | RESERVED                                                                                          |
| 1          | 0                        | 0      | 1      | 0      | RESERVED                                                                                          |
| 1          | 0                        | 0      | 1      | 1      | RESERVED                                                                                          |
| 1          | 0                        | 1      | 0      | 0      | RESERVED                                                                                          |
| 1          | 0                        | 1      | 0      | 1      | RESERVED                                                                                          |
| $\uparrow$ | 0                        | 1      | 1      | 0      | RESERVED                                                                                          |
| $\uparrow$ | 0                        | 1      | 1      | 1      | RESERVED                                                                                          |
| $\uparrow$ | 1                        | 0      | 0      | 0      | Selects 128 Queues                                                                                |
| $\uparrow$ | 1                        | 0      | 0      | 1      | Selects 64 Queues                                                                                 |
| $\uparrow$ | 1                        | 0      | 1      | 0      | Selects 32 Queues                                                                                 |
| $\uparrow$ | 1                        | 0      | 1      | 1      | Selects 16 Queues                                                                                 |
| $\uparrow$ | 1                        | 1      | 0      | 0      | Selects 8 Queues                                                                                  |
| $\uparrow$ | 1                        | 1      | 0      | 1      | Selects 4 Queues                                                                                  |
| 1          | 1                        | 1      | 1      | 0      | Parallel programming enables the user to program the number of queues using the Write Address bus |
| 1          | 1                        | 1      | 1      | 1      | Parallel programming enables the user to program the number of queues using the Read Address bus  |

6724 drw07

#### **SERIAL PROGRAMMING**

The multi-queue flow-control device is a fully programmable device, providing the user with flexibility in how queues are configured in terms of the number of queues, depth of each queue and position of the  $\overline{PAF}/\overline{PAE}$  flags within respective queues. All user programming is done via the serial port after a master reset has taken place. Internally the multi-queue device has setup registers which must be serially loaded, these registers contain values for every queue within the device, such as the depth and  $\overline{PAE}/\overline{PAF}$  offset values. The IDT72P51767/72P51777 devices are capable of up to 128 queues and therefore contain 128 sets of registers for the setup of each queue.

During a Master Reset if the DFM (Default Mode) input is LOW, then the device will require serial programming by the user. It is recommended that the user utilize a 'C' program provided by IDT, this program will prompt the user for all information regarding the multi-queue setup. The program will then generate a serial bit stream which should be serially loaded into the device via the serial port. For the IDT72P51767/72P51777 devices the serial programming requires a total number of serially loaded bits per device, (SCLK cycles with  $\overline{\text{SENI}}$  enabled), calculated by: 27+(Qx104) where Q is the number of queues the user wishes to setup within the device.

Once the master reset is complete and  $\overline{MRS}$  is HIGH, the device can be serially loaded. Data present on the SI (serial in), input is loaded into the serial port on a rising edge of SCLK (serial clock), provided that  $\overline{SENI}$  (serial in enable), is LOW. Once serial programming of the device has been successfully completed the device will indicate this via the  $\overline{SENO}$  (serial output enable) going active, LOW. Upon detection of completion of programming, the user should cease all programming and take  $\overline{SENI}$  inactive, HIGH. Note,  $\overline{SENO}$  follows  $\overline{SENI}$  once programming of a device is complete. Therefore,  $\overline{SENO}$  will go LOW after programming provided  $\overline{SENI}$  is LOW, once  $\overline{SENI}$  is taken HIGH again,  $\overline{SENO}$  will also go HIGH. The operation of the SO output is similar, when programming of a given device is complete, the SO output will follow the SI input.

If devices are being used in expansion configuration the serial ports of devices should be cascaded. The user can load all devices via the serial input port control pins, SI & SENI, of the first device in the chain. Again, the user may

utilize the 'C' program to generate the serial bit stream, the program prompting the user for the number of devices to be programmed. The  $\overline{SENO}$  and SO (serial out) of the first device should be connected to the  $\overline{SENO}$  and SI inputs of the second device respectively and so on, with the  $\overline{SENO}$  & SO outputs connecting to the  $\overline{SENI}$  & SI inputs of all devices through the chain. All devices in the chain should be connected to a common SCLK. The serial output port of the final device should be monitored by the user. When  $\overline{SENO}$  of the final device goes LOW, this indicates that serial programming of all devices has been successfully completed. Upon detection of completion of programming, the user should cease all programming and take  $\overline{SENO}$  of the first device in the chain inactive, HIGH.

As mentioned, the first device in the chain has its serial input port controlled by the user, this is the first device to have its internal registers serially loaded by the serial bit stream. When programming of this device is complete it will take its  $\overline{\text{SENO}}$  output LOW and bypass the serial data loaded on the SI input to its SO output. The serial input of the second device in the chain is now loaded with the data from the SO of the first device, while the second device has its  $\overline{\text{SENI}}$  input LOW. This process continues through the chain until all devices are programmed and the  $\overline{\text{SENO}}$  of the final device (or master device, ID = '000') goes LOW.

Once all serial programming has been successfully completed, normal operations, (queue selections on the read and write ports) may begin. When connected in expansion configuration, the IDT72P51767/72P51777 devices require a total number of serially loaded bits per device to complete serial programming, (SCLK cycles with  $\overline{\text{SENI}}$  enabled), calculated by: n[27+(Qx104)] where Q is the number of queues the user wishes to setup within the device, where n is the number of devices in the chain.

See Figure 40, *Serial Port Connection* and Figure 41, *Serial Programming* for connection and timing information.

The IDT72P51777/72P51767 device can be programmed using the serial input signals (SENI, SI, SCLK). Serial programming is accomplished by shifting in 26 bit words. It requires 1 Header Word to start the programming sequence and an additional 4 Programming Words for each queue that is configured within the device.

#### EACH OF THE 26 BIT WORDS ARE DESCRIBED BELOW:

Header Word: This is 1st 26-bit word and has the following bit assignments.

- Bits [25:7] is the Start of Header identifier.
- Bits [6:0] are the number of queues to be programmed.

The Start of Header identifier MUST be all ones (1's). The all 1's pattern in the Header word signifies the start of the programming cycle. The Header Word is only needed once for each device. For example, for 128 queues bits [6:0] = "11111111" for 32 queues bits [6:0] = "00111111".

| Bits  | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5   | 4   | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|-----|-----|----|----|----|----|
| Value | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | Q64 | Q32 | Q16 | Q8 | Q4 | Q2 | Q1 |

FF: This is the 2<sup>nd</sup> 26-bit word and represents the Full Flag programmed value. The Full Flag value is equal to the Queue depth-2. Each queue requires an individual FF value.

| Bits            | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18     | 17     | 16    | 15    | 14    | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6  | 5  | 4  | 3 | 2 | 1 | 0 |
|-----------------|----|----|----|----|----|----|--------|--------|--------|-------|-------|-------|------|------|------|------|-----|-----|-----|----|----|----|---|---|---|---|
| Binary<br>Value | 0  | 0  | 0  | 0  | 0  | 0  | 524288 | 262144 | 131072 | 65536 | 32768 | 16384 | 8192 | 4096 | 2048 | 1024 | 512 | 256 | 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 |

 $\overline{PAE}$ : This is the 3<sup>rd</sup> 26-bit word and represents the Programmable Almost Empty  $\overline{(PAE)}$  value. Each queue requires an individual  $\overline{PAE}$  value. The  $\overline{PAE}$  value that is programmed into the device is the number of words. For example, for a  $\overline{PAE}$  value = 52 words, bits [19:0] = "000000000000110100".

| Bits   | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18     | 17     | 16    | 15    | 14    | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6  | 5  | 4  | 3 | 2 | 1 | 0   |
|--------|----|----|----|----|----|----|--------|--------|--------|-------|-------|-------|------|------|------|------|-----|-----|-----|----|----|----|---|---|---|-----|
| Binary | 0  | 0  | 0  | 0  | 0  | 0  | 524288 | 262144 | 131072 | 65536 | 32768 | 16384 | 8192 | 4096 | 2048 | 1024 | 512 | 256 | 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1   |
| Value  |    |    |    |    |    |    |        |        |        |       |       |       |      |      |      |      |     |     |     |    |    |    |   |   |   | 1 ! |

PAF: This is the 4th 26-bit word and represents the Programmable Almost Full (PAF) value. Each queue requires an individual PAF value. The PAF value that is programmed into the device is the "Queue Depth Value" – "The PAF Offset value". For example, with a Queue Depth of 16K (16384) and a desired PAF value = 39 words, bits [19:0] = "000000111111111011001".

| Bits   | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18     | 17     | 16    | 15    | 14    | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6  | 5  | 4  | 3 | 2 | 1 | 0 |
|--------|----|----|----|----|----|----|--------|--------|--------|-------|-------|-------|------|------|------|------|-----|-----|-----|----|----|----|---|---|---|---|
| Binary | 0  | 0  | 0  | 0  | 0  | 0  | 524288 | 262144 | 131072 | 65536 | 32768 | 16384 | 8192 | 4096 | 2048 | 1024 | 512 | 256 | 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 |
| Value  |    |    |    |    |    |    |        |        |        |       |       |       |      |      |      |      |     |     |     |    |    |    |   |   |   |   |

#### **Queue End/Start Address**

This is the 5th 26-bit word and represents both the start and end address of each queue.

**End Address**: The queue end address is bits [25:13] of the 26-bit. An end addresses is specified as; Queue Depth – 1k. Ending address are specified in increments of 1K words. For example, for a Queue Depth of 16K, the first queue would have a starting address of 0, bits [12:0] = "000000000000000" and an end address of 15K, bits [25:13] = "00000000001111",

**Start Address**: The queue starting address is bits [12:0] of the 26-bit word. Start addresses are specified in increments of words. The first queue should always start at address 0. The starting address of the next queue should be programmed at an address that is words greater the ending address of the previous queue.

| Bits  | 25   | 24   | 23   | 22  | 21   | 20     | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11   | 10   | 9   | 8   | 7       | 6      | 5  | 4  | 3 | 2 | 1 | 0 |
|-------|------|------|------|-----|------|--------|----|----|----|----|----|----|----|------|------|------|-----|-----|---------|--------|----|----|---|---|---|---|
| Value | 4096 | 2048 | 1024 | 512 | 256  | 128    | 64 | 32 | 16 | 8  | 4  | 2  | 1  | 4096 | 2048 | 1024 | 512 | 256 | 128     | 64     | 32 | 16 | 8 | 4 | 2 | 1 |
|       | _    |      |      | _   | End, | Addres | SS |    |    |    |    |    |    |      |      |      | _   |     | Start A | ddress |    | _  |   |   |   | _ |

The following is an explanation of the binary file created by the C program for the 10G MQ devices (IDT72P51767/72P51777).

The Desired Device Configuration is:

- Number of Queues = 32
- Each Queue Depth = 16k
- Each Queue PAE Value = 52
- Each Queue PAF Value = 39



#### **DEFAULT PROGRAMMING**

During a Master Reset if the DFM (Default Mode) input is HIGH the multiqueue device will be configured for default programming, (serial programming is not permitted). Default programming provides the user with a simpler, however limited means to setup the multi-queue flow-control device, rather than using the serial programming method. The default mode will configure a multiqueue device with the maximum number of queues setup, and the available memory allocated equally between the queues. The values of the PAE/PAF offsets is determined by the state of the (default) pin during a master reset.

For the IDT72P51767/72P51777 devices the default mode will setup 128 queues, each queue being 256 x40, 512 x40, and 1024 x40 deep respectively.

When configuring the IDT72P51767/72P51777 devices in default mode the user simply has to apply WCLK cycles after a master reset, until  $\overline{\text{SENO}}$  goes LOW, this signals that default programming is complete. These clock cycles are required for the device to load its internal setup registers. When a single multiqueue device is used, the completion of device programming is signaled by the  $\overline{\text{SENO}}$  output of a device going from HIGH to LOW. Note, that  $\overline{\text{SENI}}$  must be held LOW when a device is setup for default programming mode.

When multi-queue devices are connected in expansion configuration, the  $\overline{SENI}$  of the first device in a chain can be held LOW. The  $\overline{SENO}$  of a device should connect to the  $\overline{SENI}$  of the next device in the chain. The  $\overline{SENO}$  of the final device is used to indicate that default programming of all devices is complete. When the master (ID='000')  $\overline{SENO}$  goes LOW normal operations may begin. Again, all devices will be programmed with their maximum number of queues and the memory divided equally between them. Please refer to Figure 38, *Default Programming*.

#### **PARALLEL PROGRAMMING**

During a Master Reset cycle (i.e. the MRS signal transitions from HIGH to LOW then LOW to HIGH) if the DFM (Default Mode) input signal is HIGH and the QSEL[2:0] input signal is "110" for Write address and "111" for Read address, the Multi-Queue Flow Control device is configured for Parallel Programming. Parallel Programming enables the number of queues within the

device to be set through either the Write Address (WRADD) bus or Read Address (RDADD) bus after the Master Reset cycle. Within Parallel Programming mode the Multi-Queue (MQ) device programmable parameters are; number of queues, queue depth,  $\overline{\text{PAE}/\text{PAF}}$  flag offset value, bus matching and the I/O voltage level. As previously indicated, the number of queues are configured using the write or read address bus, however bus matching is set during the Master Reset cycle. The value that is set during the Master Reset cycle is determined by the Bus Matching (BM) bits. For the IDT72P51767/72P51777 devices in Parallel Programming Mode the value of the  $\overline{\text{PAE}/\text{PAF}}$  offsets at master reset is determined by the state of the input.

When configuring the IDT72P51767/72P51777 devices in Parallel Programming Mode the user simply has to apply WCLK cycles after a master reset, until SENO goes LOW, this signals that Parallel Programming is complete. These clock cycles are required for the device to load its internal setup registers. When a single multi-queue device is used, the completion of device programming is signaled by the  $\overline{\text{SENO}}$  output of a device going from HIGH to LOW. Note, that SENI must be held LOW when a device is setup for Parallel Programming mode.

#### ID[2:0] PINS AND WRADD/RDADD CONFIGURATIONS

The 10G DDR Multi-Queue will have the ability to expand up to a maximum of 256 Queues by 2 to 8 devices depending on the configuration setup. For programming the ID Codes for each device the WRADD/RDADD address buses impose the limitation of 256 Queues because, with an 8-bit address bus, the 3 MSB in the WRADD/RDADD are used to decode the ID[2:0] pins on each device. The slave devices must be configured before the master device as well. For 8-device expansion the least [4:0] bits are used for expansion addressing meaning a configuration of 32 queues can be accomplished. The MSBs [7:5] will select which of the eight devices to access depending on their MSB ID[2:0] settings. If ID[2:0] is 000, then it serves as the master device. Otherwise, the devices will serve as the slave devices. Ex: For using two 128 queue MQ devices, ID[2:0] = 0xx is for selecting the master device. For using 8 devices, ID[2:0] = 111 is for selecting the 8th slave device and WRADD/RDADD bits [4:0] for configuring 32 queues/device. And so on.

TABLE 6 — ID[2:0] AND WRADD[7:5]/RDADD[7:5] CONFIGURATION

| Queues Addressed                                                | х | 128 | 64  | 32  | 16  | 8   | 4   | 2   |
|-----------------------------------------------------------------|---|-----|-----|-----|-----|-----|-----|-----|
| ID[2:0] Master Device Configuration<br>WRADD[7:5] or RDADD[7:5] |   | 0xx | 00x | 000 | 000 | 000 | 000 | 000 |
| ID[2:0] 2nd Device Configuration<br>WRADD[7:5] or RDADD[7:5]    |   | 1xx | 10x | 100 | 100 | 100 | 100 | 100 |
| ID[2:0] 3rd Device Configuration<br>WRADD[7:5] or RDADD[7:5]    |   | NA  | 01x | 010 | 010 | 010 | 010 | 010 |
| ID[2:0] 4th Device Configuration<br>WRADD[7:5] or RDADD[7:5]    |   | NA  | 11x | 110 | 110 | 110 | 110 | 110 |
| ID[2:0] 5th Device Configuration<br>WRADD[7:5] or RDADD[7:5]    |   | NA  | NA  | 001 | 001 | 001 | 001 | 001 |
| ID[2:0] 6th DeviceConfiguration<br>WRADD[7:5] or RDADD[7:5]     |   | NA  | NA  | 101 | 101 | 101 | 101 | 101 |
| ID[2:0] 7th Device Configuration<br>WRADD[7:5] or RDADD[7:5]    |   | NA  | NA  | 011 | 011 | 011 | 011 | 011 |
| ID[2:0] 8th Device Configuration<br>WRADD[7:5] or RDADD[7:5]    |   | NA  | NA  | 111 | 111 | 111 | 111 | 111 |

# TABLE 7 — PARALLEL PROGRAMMING MODE QUEUE CONFIGURATION EXAMPLE<sup>(1)</sup>

| WRADD/RDADD[7:0]  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------------|---|---|---|---|---|---|---|---|
| 128 Queues/Device | х | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 64 Queues/Device  | Х | 0 | 1 | 1 | 1 | 1 | 1 | 1 |
| 32 Queues/Device  | Х | 0 | 0 | 1 | 1 | 1 | 1 | 1 |
| 16 Queues/Device  | х | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 8 Queues/Device   | х | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
| 4 Queues/Device   | Х | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
| 1 Queue/Device    | Х | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

#### NOTE:

The 10G Multi-Queue also has the capability of expanded theoretically to unlimited number of devices. As Figure 5 shows, the WRADD[7] and RDADD[7] will act as the Write Chip Select Enable and Read Chip Select Enable respectively, and the user can then decode each Multi-Queue device separately using these pins and still maintain 128 Queues per device. The WRADD[6:0] and RDADD[6:0] can still be routed as shared buses to each device, as can write and read data buses and external control pins and flags.

To make this possible the ID pin, ID2 of all slave devices must be connected to "1" and the Master device ID Pins, ID[2:0], should equal 000. It is not recommend expanding greater than 10 devices because sufficient capacitive loading on each bus makes it diffcult to drive a greater multiple of devices per bus. The real  $\overline{WCS}$  and  $\overline{RCS}$  pins can be tied to a ground plane on the board to save FPGA pins.



Figure 5. Expansion for Unlimited Number of Multi-Queue Devices Example

<sup>1.</sup> Users can also program 6 different settings in Default Programming mode using QSEL[2:0] and DFM pins instead of using Parallel Programming Mode. This table above shows how a user might program the number of queues in the device and can program any 1-128 queues in the device by using the WRADD/RDADD[7:0] pins.

When Multi-Queue devices are connected in an Expansion Configuration, the  $\overline{SENI}$  signal of the first device in a chain must be held LOW. The  $\overline{SENO}$  signal of a device should connect to the  $\overline{SENI}$  of the next device in the chain. The  $\overline{SENO}$  of the final device is used to indicate that the programming of all devices is complete. When the master device (ID='000')  $\overline{SENO}$  signal goes LOW the internal programming is complete and queue write/read operation may begin. Please refer to Figure 41, *Parallel Programming* for signal timing details.

#### **PROGRAMMING HIERARCHY**

Configuring the device is a 2 stage sequence. The first stage is to set the expansion device type, the desired programming mode and the device operating mode during the master reset cycle (i.e. on the rising edge of Master Reset (MRS)). The second stage is to set values such as PAE/PAF, number of queues, queue depth, etc. using the programming mode (serial, parallel, default) selected in stage 1. Refer to Figure 6, *Device Programming Hierarchy*.



Figure 6. Device Programming Hierarchy

### **MODES OF OPERATION**

#### STANDARD MODE OPERATION

The 10G Multi-queue supports two modes of operation, IDT Standard Mode and BOI Mode.

#### **IDT STANDARD MODE VS. BOI MODE**

The device mode is configured during the master reset cycle. Only the read side is affected by these two modes, the write side is identical in both modes. In

IDT standard mode, the device operates as the IDT72P51769 (4M multiqueue) device as shown in Figure 49 and 50.

The other option, or BOI mode, has the device reissue the last data from a queue upon reentry to that queue. This allows for a customer to monitor a data bit and stop reading based on the output (e.g., End of Packet or EOP). Note: the  $\overline{\sf EF}$  flag is always updated "real time" using the read count in both modes.

#### PLL ON VS PLL OFF MODES

The PLL has a frequency response rate of 85-166MHz. The PLL reduces the access time (ta) for the DDR. Below 85MHz or in SDR mode, the PLL must be turned off. The following diagrams show the difference between the two modes:



#### NOTES:

- 1. Echo clocks are center aligned.
- 2. ERCLK is aligned with internal PLL generated clock.
- 3. QOUT is clocked out 1 cycle after valid REN.
- 4. Data Access time (Ta) is +/-1.0ns when PLL is on, with respect to rising edges of RCLK (1 Clock Latency).



Figure 7. DDR Read Operation with PLL ON

#### NOTES:

- 1. ERCLK has uncontrollable delay when PLL is off.
- 2. DOUT is clocked out 1 cycle after valid REN.
- 3. Data Access time (Ta) is <3.6ns when PLL is off, with respect to rising/falling edges of RCLK.

Figure 8. DDR Read Operation with PLL OFF



1. In single-ended clocking scheme, ERCLK is 50% duty cycle.

- 2. QOUT is clocked out 1 cycle after valid  $\overline{\text{REN}}$ .
- 3. Data Access time (Ta) is +/-1.0ns when PLL is on, with respect to rising edges of RCLK.

Figure 9. SDR Read Operation with PLL ON



- 1.  $\overline{\text{ERCLK}}$  has uncontrollable delay when PLL is off, Ta <3.6ns when PLL is off.
- 2. DOUT is clocked out 1 cycle after valid REN.
- 3. Data Access time (Ta) is <3.6ns when PLL is off, with respect to rising edges of RCLK.

Figure 10. SDR Read Operation with PLL OFF

#### STANDARD MODE OPERATION

# WRITE QUEUE SELECTION AND WRITE OPERATION (STANDARD MODE)

The IDT72P51767/72P51777 multi-queue flow-control devices can be configured up to a maximum of 128 queues which data can be written via a common write port using the data inputs (Din), write clock (WCLK) and write enable (WEN). The queue to be written is selected by the address present on the write address bus (WRADD) during a rising edge on WCLK while write address enable (WADEN) is HIGH. The state of WEN does not impact the queue selection. The queue selection requires 4 WCLK cycle. All subsequent data writes will be to this queue until another queue is selected.

Standard mode operation is defined as individual words will be written to the device. The write port is designed such that 100% bus utilization can be obtained. This means that data can be written into the device on every WCLK rising edge including the cycle that a new queue is being addressed.

Changing queues requires 4 WCLK cycles on the write port (see Figure 42, SDR Write Queue Select, Write Operation and Full flag Operation). WADEN goes high signaling a change of queue (clock cycle "A"). The address on WRADD at that time determines the next queue. Data presented during that cycle, will be written to the active (each) queue, provided  $\overline{\text{WEN}}$  is LOW. If  $\overline{\text{WEN}}$  is HIGH (inactive), data will not be written in a queue. The write port discrete fullflag will update to show the full status of the newly selected queue. Data present on the data input bus (Din), can be written into the newly selected queue on the rising edge of WCLK a change of queue, provided  $\overline{\text{WEN}}$  is LOW and the queue is not full. If the selected queue is full at the point of its selection, any writes to that queue will be prevented. Data cannot be written into a full queue.

Refer to Figure 42, *SDR Write Queue Select, Write Operation and Full flag Operation*, and Figure 45, *Full Flag Timing in Expansion Configuration* for timing diagrams.

## TABLE 8 — WRITE ADDRESS BUS, WRADD[7:0]

| Operation                  | WCLK | WADEN | FSTR |                                         | WF             | RAD          | D[7           | ':0]               |      |        |
|----------------------------|------|-------|------|-----------------------------------------|----------------|--------------|---------------|--------------------|------|--------|
| Write<br>Queue<br>Select   |      | 1     | 0    | 7 6<br>Device S<br>(Compare<br>ID2,1,0) | elect<br>ed to | Writ<br>(6 b | e Qu<br>its = | ieue A<br>64 Qi    | ueue | ess    |
| PAFn<br>Quadrant<br>Select |      | 0     | 1    | 7 6<br>Device S<br>(Compare<br>ID2,1,0) |                |              |               | 2<br>tatus<br>Addr |      | O<br>d |

| Status Word<br>Address | Queue Status on PAFn Bus                                          |
|------------------------|-------------------------------------------------------------------|
| 0000                   | Q0 : Q7 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7     |
| 0001                   | Q8 : Q15 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7    |
| 0010                   | Q16 : Q23 $\rightarrow \overline{PAF}0$ : $\overline{PAF}7$       |
| 0011                   | Q24 : Q31 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 0100                   | Q32 : Q39 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 0101                   | Q40 : Q47 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 0110                   | Q48 : Q55 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 0111                   | Q56 : Q63 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 1000                   | Q64 : Q71 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 1001                   | Q72 : Q79 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 1010                   | Q80 : Q87 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 1011                   | Q88 : Q95 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 1100                   | Q96 : Q103 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7  |
| 1101                   | Q104 : Q111 $\rightarrow \overline{PAF}0$ : $\overline{PAF}7$     |
| 1110                   | Q112 : Q119 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7 |
| 1111                   | Q120 : Q127 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7 |
|                        | 6724 drw11                                                        |

6724 drw11

# READ QUEUE SELECTION AND READ OPERATION (STANDARD MODE)

The IDT72P51767/72P51777 multi-queue flow-control devices can be configured up to a maximum of 128 queues which data can be read via a common read port using the data outputs (Qout), read clock (RCLK) and read enable ( $\overline{\text{REN}}$ ). An output enable,  $\overline{\text{OE}}$  control pin is also provided to allow High-Impedance selection of the Qout data outputs. The multi-queue device read port operates in standard IDT mode or BOI mode. The queue to be read is selected by the address presented on the read address bus (RDADD) during a rising edge on RCLK while read address enable (RADEN) is HIGH. The state of  $\overline{\text{REN}}$  does not impact the queue selection. The queue selection requires 4 RCLK cycles. All subsequent data reads will be from this queue until another queue is selected.

Standard mode operation is defined as individual words will be read from the device. The read port is designed such that 100% bus utilization can be obtained. This means that data can be read out of the device on every RCLK rising edge including the cycle that a new queue is being addressed.

Changing queues requires a minimum of four RCLK cycles on the read port (see Figure 46, \$SDR Read Queue Select, Read Operation\*). RADEN goes high signaling a change of queue (clock cycle "D"). The address on RDADD at that time determines the next queue. Data presented during that cycle will be read. Reading data can continue from the active queue, provided  $\overline{REN}$  is LOW. If  $\overline{REN}$  is HIGH (inactive), data will not be read from the queue. If a new selected queue is empty, reads from that queue will be prevented. Data cannot be read from an empty queue. Remember that  $\overline{OE}$  allows the user to place the data output bus (Qout) into High-Impedance and the data can be read in to the output register regardless of  $\overline{OE}$ .

Refer to Table 9, for Read Address Bus arrangement.

## TABLE 9 — READ ADDRESS BUS, RDADD[7:0]

| Operation                  | RCLK | RADEN | ESTR | RDA                                       | DD[7:0]                                                                |
|----------------------------|------|-------|------|-------------------------------------------|------------------------------------------------------------------------|
| Read Queue<br>Select       |      | 1     | 0    | (Compared to (                            | 4 3 2 1 0  Read Queue Address (6 bits = 64 Queues 7 bits = 128 Queues) |
| PAEn<br>Quadrant<br>Select |      | 0     | 1    | 7 6 5 Device Select (Compared to ID2,1,0) | 4 3 2 1 0<br>X Status Word<br>Address                                  |

| Status Word<br>Address | Queue Status on PAEn Bus                                          |
|------------------------|-------------------------------------------------------------------|
| 0000                   | Q0 : Q7 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7     |
| 0001                   | Q8 : Q15 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7    |
| 0010                   | Q16 : Q23 $\rightarrow \overline{PAF}0$ : $\overline{PAF}7$       |
| 0011                   | Q24 : Q31 $\rightarrow \overline{PAF}0$ : $\overline{PAF}7$       |
| 0100                   | Q32 : Q39 $\rightarrow \overline{PAF}0$ : $\overline{PAF}7$       |
| 0101                   | Q40 : Q47 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 0110                   | Q48 : Q55 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 0111                   | Q56 : Q63 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 1000                   | Q64 : Q71 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 1001                   | Q72 : Q79 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 1010                   | Q80 : Q87 $\rightarrow$ PAF0 : PAF7                               |
| 1011                   | Q88 : Q95 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7   |
| 1100                   | Q96 : Q103 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7  |
| 1101                   | Q104 : Q111 $\rightarrow \overline{PAF}0$ : $\overline{PAF}7$     |
| 1110                   | Q112 : Q119 → PAF0 : PAF7                                         |
| 1111                   | Q120 : Q127 $\rightarrow$ $\overline{PAF}$ 0 : $\overline{PAF}$ 7 |

6724 drw12

#### SWITCHING QUEUES ON THE WRITE PORT

The IDT72P51767/72P51777 multi-queue flow-control devices can be configured up to a maximum of 128 queues. Data is written into a queue using the Data Input (Din) bus, Write Clock (WCLK) and Write Enable (WEN) signals. Selecting a queue occurs by placing the queue address on the Write Address

bus (WRADD) during a rising edge of WCLK while Write Address Enable (WADEN) is HIGH. For reference, the state of Write Enable (WEN) is a "Don't Care" during a queue selection. WEN has significance during the queue mark operation. Selecting a queue requires 4 WCLK cycles. Refer to Figure 11, Write Port Switching Queues Signal Sequence.



Figure 11. Write Port Switching Queues Signal Sequence

The IDT72P51767/72P51777 multi-queue flow-control device supports changing (switching) queues every four (4) clock cycles. To switch from the Present Queue (PQ) to another queue requires a queue address to be placed on the Write Address Bus (WRADD) bus and a rising edge of Write Clock (WCLK) and Write Address Enable (WADEN) is HIGH. There are no restrictions as to the order to which queues are selected or switched into or out of.

For maximum efficiency, during the 4 clock cycles required to switch queues the IDT72P51767/72P51777 multi-queue flow-control device can continue to write into the Present Queue (PQ). The Present Queue is defined as the current selected queue. Refer to Figure 12, *Switching Queues Bus Efficiency*.



#### NOTES:

- PQ = Present Queue
   NQ = Next Queue
- \* Requires 4 clock cycles to switch queues.

Figure 12. Switching Queues Bus Efficiency

The IDT72P51767/72P51777 multi-queue flow-control device supports writing and reading from either the same queue of from different queues. The device also supports simultaneous queue switching on the write and read ports.

The simultaneous queue switching may occur with either the Write Clock and Read Clock synchronous or asynchronous to each other. For reference refer to Figure 13, *Simultaneous Queue Switching*.



Figure 13. Simultaneous Queue Switching

The multi-queue flow-control device requires 4 clock cycles to switch queues on the write port. Refer to Table 10, Write Queue Switch Operation for a detailed description of each queue switch clock cycle.

## **TABLE 10 — WRITE QUEUE SWITCH OPERATION**

| Queue Switch Cycle | IDT Mode                                                                 |
|--------------------|--------------------------------------------------------------------------|
| QS-1               | Queue Switch Initiated, Rewrite/No Rewrite selection                     |
| QS0                | Queue MARK / Un-MARK                                                     |
| QS1                | _                                                                        |
| QS2                | PAF signal updated for Next Queue (NQ)     Full Flag (FF) updated for NQ |
| QS3                | Start of Write Data Operation                                            |

#### **OUTPUT DATA DURING A QUEUE SWITCH**



During this cycle the 10G MQ device detects the assertion of  $\overline{\text{REN}}$ 

Data latency = cycle + 3.6ns (max)

#### NOTE:

1. Application specific.

Figure 14. Application: Reading words from the MQ using the EOP bit to end the read operation



Figure 15. Output Data during a Queue Switch (SDR w/o PLL)

Parameters: SDR Mode, PLL=ON, 1 read operation, centered aligned data/clock pause, 1 word read operation



Figure 16. Output Data during a Queue Switch (SDR w/ PLL)

Parameters: DDR Mode, PLL=ON, 1 word read operation, centered aligned data/clock pause with No queue switch, 1 word read operation



Figure 17. Output Data during a Queue Switch (DDR w/ PLL)

Parameters: DDR Mode, PLL=OFF, 1 word read operation, edge aligned data/clock pause with No queue switch, 1 word read operation



Figure 18. Output Data during a Queue Switch (DDR w/o PLL)

Parameters: DDR Mode, PLL=ON, 2 word read operation, WITH QUEUE SWITCH to NQ and QUEUE SWITCH BACK TO ORIGINAL QUEUE, 2 word read operation



Figure 19. Output Data during two Queue Switches (DDR w/ PLL)

Parameters: SDR Mode, PLL=OFF, 3 word read operation, edge aligned data/clock, pause with No queue switch.



## NOTE:

1. Application specific.

Figure 20. Output Data during two Queue Switches (DDR w/o PLL)

# TABLE 11 — BACKUP USAGE WHEN RE-ENTERING A QUEUE

| Operating      | Mode of   | Clock used by    | Method to Stop | -1 word MQ |
|----------------|-----------|------------------|----------------|------------|
| Frequency      | Operation | receiving device | Read Port      | backup     |
| Range          |           | to latch data    | operation      | required   |
| 1Mhz to 166Mhz | SDR       | Read Clock       | Word Count     | N          |
|                | PLL=OFF   |                  |                |            |
| 1Mhz to 166Mhz | SDR       | Read Clock       | EOP Processing | Y (BOI)    |
|                | PLL=OFF   |                  |                |            |
| 83.33Mhz to    | SDR       | /ERCLK           | Word Count     | N          |
| 166Mhz         | PLL=ON    |                  |                |            |
| 83.33Mhz to    | DDR       | /ERCLK           | EOP Processing | Y (BOI)    |
| 166Mhz         | PLL=ON    |                  |                |            |
| 1Mhz to 100Mhz | DDR       | Read Clock       | Word Count     | N          |
|                | PLL=OFF   |                  |                |            |
| 1Mhz to 100Mhz | SDR       | Read Clock       | EOP Process    | Y (BOI)    |
|                | PLL=OFF   |                  |                |            |
| 90Mhz to       | SDR       | ERCLK            | Word Count     | N          |
| 100Mhz         | PLL=OFF   |                  |                |            |
| 90Mhz to       | SDR       | ERCLK            | EOP Process    | Y (BOI)    |
| 100Mhz         | PLL=OFF   |                  |                |            |
|                |           |                  |                |            |

### SWITCHING QUEUES ON THE READ PORT

The IDT72P51767/72P51777 multi-queue flow-control devices can be configured up to a maximum of 128 queues. Data is read from a queue using the Data Output (Qout) bus, Read Clock (RCLK) and Read Enable  $(\overline{REN})$  signals. Selecting a queue on the read port occurs by placing the queue address on the Read Address bus (RDADD) during a rising edge of RCLK while Read

Address Enable (RADEN) is HIGH. For reference, the state of Read Enable ( $\overline{REN}$ ) is a "Don't Care" during a read port queue selection.  $\overline{REN}$  has significance during the queue mark operation. Selecting a queue requires 4 RCLK cycles. Refer to Figure 21, Read Port Switching Queues Signal Sequence.



Figure 21. Read Port Switching Queues Signal Sequence

The IDT72P51767/72P51777 multi-queue flow-control device supports changing (switching) queues every four (4) clock cycles. To switch from the Present Queue (PQ) to another queue requires a queue address to be placed on the Read Address Bus (RDADD) bus and a rising edge of Read Clock (RCLK) and Read Address Enable (RADEN) is HIGH. There are no restrictions as to the order to which queues are selected or switched into or out of.

For maximum efficiency, during the 4 clock cycles required to switch queues the IDT72P51767/72P51777 multi-queue flow-control device can continue to read from the Present Queue (PQ). The Present Queue is defined as the current selected queue. Refer to Figure 22. Switching Queues Bus Efficiency.



Figure 22. Switching Queues Bus Efficiency

#### SIMULTANEOUS QUEUE SWITCHING

The IDT72P51767/72P51777 multi-queue flow-control device supports reading and writing from either the same queue or from different queues. The device also supports simultaneous queue switching on the read and write ports. The simultaneous queue switching may occur with either the Read Clock and

Write Clock synchronous or asynchronous to each other. For reference refer to Figure 23, Simultaneous Queue Switching.

The multi-queue flow-control device requires 4 clock cycles to switch queues on the read port, refer to Table 12, Read Queue Switch Operation for a detailed description of each queue switch clock cycles.



Figure 23. Simultaneous Queue Switching

6724 drw18

# **TABLE 12 — READ QUEUE SWITCH OPERATION**

| Queue Switch<br>Cycle | IDT Mode                                             |
|-----------------------|------------------------------------------------------|
| QS-1                  | Queue Switch Initiated, Re-read/No Re-read selection |
| QS0                   | Queue MARK / Un-MARK                                 |
| QS1                   | _                                                    |
| QS2                   | PAE signal updated for Next Queue (NQ)               |
|                       | Empty Flag (EF) updated for NQ                       |
| QS3                   | Start of Read Data Operation                         |

# **TABLE 13 — SAME QUEUE SWITCH**

| PQ         | NQ                    | Supported   | Comment                   |
|------------|-----------------------|-------------|---------------------------|
| Not Marked | Not Marked            | Yes         | Queue Switch is ignored   |
| Not Marked | Marked                | Yes         | Add Mark to current queue |
| Marked     | Not Marked, No Reread | Not Allowed |                           |
| Marked     | Not Marked, Reread    | Yes         | Remove Mark               |
| Marked     | Marked, No Reread     | Not Allowed |                           |
| Marked     | Marked, Reread        | Yes         | Keep Mark                 |

Legend:

PQ = Present Queue NQ = Next Queue

### **QUEUE MARKing**

The overall intent of the MARK function is to provide the ability to either rewrite and/or re-read information that is stored into a queue.

A queue can be MARKed by either the write port or the read port. The MARK operation is port independent. The same queue can be marked by the write port and the read port simultaneously. Only the active queue can be MARKed, multiple queues can NOT be MARKed by a port. A port (write or read) may only designate one queue MARKed at a time. Upon a queue switch a decision must be made as to whether to return to the Marked location or the last access address.

#### MARK AND REWRITE/ MARK AND REREAD

The MARK functionality operates in any mode combination (BOI mode, IDT Standard Mode). Queues on the Write Port are MARKed using the WCLK & WADEN signals. Queues on the Read Port are MARKed using the RCLK and RADEN signals. Refer to the following timing diagrams for additional queue MARK details. Refer to Figure 24 and 25 for further information.



- @QS-1, if WEN=0 and WADEN=1, PQ will be updated in QS0,1, and 2, and NQ data will be written in QS3.
- @QS-1, if WEN\_N=1 and WADEN=1, there is no update for PQ during QS0-QS2. Next time PQ is switched back, data will be written into last update location (rewrite).
- @QSO, WADEN status is used to determine if a "mark" is requested for NQ. If WADEN=1 in QSO, NQ will be marked. In IDT mode, the first NQ position after QS is marked (latch WFCR values before QS3), data can't be read out beyond this location.
- @QS0, if WADEN=0, NQ is not marked.

Figure 24. MARK and Re-Write Sequence



- @QS-1, if REN=0 and RADEN=1, Present Queue will be updated in QS0, QS1, and QS2, and the data from the Next Queue (NQ) will be available in QS4.
- @QS-1, if REN=1 and RADEN=1, Present Queue will not be updated QS0-QS2. The Next time PQ is selected, the data will be from the last updated location.
- @QS0, RADEN status is used to determine if a "mark" is requested for NQ. If RADEN=1 in QS0, NQ will be marked. In IDT mode, first NQ position after QS is marked (latch RFCR values before QS3), data can't overwrite this location.

Figure 25. MARK and Re-Read Sequence





6724 drw36

Figure 26. MARKing a Queue - Write Queue MARK



| RADEN |   | ACTION                               |
|-------|---|--------------------------------------|
| A     | В |                                      |
| 1     | 1 | Selects the Queue and MARK the Queue |
| 1     | 0 | Selects a Queue                      |

6724 drw37

Figure 27. MARKing a Queue - Read Queue MARK

### **MARK Operational Notes:**

# Write Port

- MARKing can only occur during a Queue switch cycle
- The entire Queue is MARKed at a time.
- MARK is used to mark the first location of the Queue.
- MARK can NOT be moved within the queue.

# Read Port

- MARKing can only occur during a Queue switch cycle
- Only the first location of the Queue can be MARKed.
- The MARK can NOT be moved location to location within the queue.

## Un-MARKing a Queue

## **UN-MARKing a Queue**



| WADEN |   | ACTION                                |
|-------|---|---------------------------------------|
| A     | В |                                       |
| 1     | 0 | Selects a Queue and UN-MARK the Queue |

6724 drw38

Figure 28. UN-MARKing a Queue - Write Queue UN-MARK





6724 drw39

Figure 29. UN-MARKing a Queue - Read Queue UN-MARK

## **UN-MARK Operational Notes:**

### Write Port

- Un-MARKing can only occur during a Queue switch cycle.
- UN-MARKing a Queue can be accomplished by either switching to the same queue or switching to another queue.
- Note only 1 queue can be marked at any given time.
- The MARK can NOT be moved location to location within the queue.

### Read Port

- Un-MARKing can only occur during a Queue switch cycle.
- UN-MARKing a Queue can be accomplished by either switching to the same queue or switching to another queue.
- Note only 1 queue can be marked at any given time.
- The MARK can NOT be moved location to location within the queue.

# Leaving a MARK Active

During a Queue switch the value of  $\overline{WEN}$  for the write port and  $\overline{REN}$  for the read port determines whether the MARK remains active or is de-activated.

## Leaving a MARK active on the Write Port



Figure 30. Leaving a MARK active on the Write Port

# Leaving a MARK active on the Read Port



Figure 31. Leaving a MARK active on the Read Port

# Inactivating a MARK

During a Queue switch the value of  $\overline{WEN}$  for the write port and  $\overline{REN}$  for the read port determines whether the MARK remains active or is de-activated.

# Inactivating a MARK on the Write Port



Figure 32. Inactivating a MARK on the Write Port Active

# Inactivating a MARK on the Read Port



Figure 33. Inactivating a MARK on the Read Port Active

# Write Cycle



| Action             | WEN<br>(active LOW) | WADEN<br>(active HIGH) | WEN<br>(active LOW) | WADEN<br>(active HIGH) |
|--------------------|---------------------|------------------------|---------------------|------------------------|
| NO<br>Operation    | 0                   | 0                      | 0                   | 0                      |
| Selects a<br>Queue | 0                   | 1                      | 0                   | 1                      |
| NO<br>Operation    | 1                   | 0                      | 1                   | 0                      |
| NO<br>Operation    | 1                   | 1                      | 1                   | 1                      |

6724 drw44

# Read Cycle



| Action             | REN<br>(active LOW) | RADEN<br>(active HIGH) | REN<br>(active LOW) | RADEN<br>(active HIGH) |
|--------------------|---------------------|------------------------|---------------------|------------------------|
| NO<br>Operation    | 0                   | 0                      | 0                   | 0                      |
| Selects a<br>Queue | 0                   | 1                      | 0                   | 1                      |
| NO<br>Operation    | 1                   | 0                      | 1                   | 0                      |
| NO<br>Operation    | 1                   | 1                      | 1                   | 1                      |

6724 drw45

# **FLAG DESCRIPTION**

### **PAF**n FLAG BUS OPERATION

The IDT72P51767/72P51777 multi-queue flow-control device can be configured for up to 128 queues, each queue having its own almost full status. An active queue has its flag status output to the discrete flags,  $\overline{FF}$  and  $\overline{PAF}$ , on the write port. Queues that are not selected for a write operation can have their  $\overline{PAF}$  status monitored via the  $\overline{PAF}$ n bus. The  $\overline{PAF}$ n flag bus is 8 bits wide, so that 8 queues at a time can have their status output to the bus. If 9 or more queues are setup within a device then there are 2 methods by which the device can share the bus between queues, "Direct" mode and "Polled" mode depending on the state of the FM (Flag Mode) input during a Master Reset. If 8 or less queues are setup within a device then each will have its own dedicated output from the bus. If 8 or less queues are setup in single device mode, it is recommended to configure the  $\overline{PAF}$ n bus to polled mode as it does not require using the write address (WRADD).

### **FULL FLAG OPERATION**

The multi-queue flow-control device provides a single Full Flag output,  $\overline{FF}$ . The  $\overline{FF}$  flag output provides a full status of the queue currently selected on the write port for write operations. Internally the multi-queue flow-control device monitors and maintains a status of the full condition of all queues within it, however only the queue that is selected for write operations has its full status output to the  $\overline{FF}$  flag. This dedicated flag is often referred to as the "active queue full flag".

When queue switches are being made on the write port, the  $\overline{FF}$  flag output will switch to the new queue and provide the user with the new queue status, on the 3rd cycle after a new queue selection is made. The user then has a full status for the new queue one cycle ahead of the WCLK rising edge that data can be written into the new queue. That is, a new queue can be selected on the write port via the WRADD bus, WADEN enable and a rising edge of WCLK. On the 4th rising edge of WCLK, the  $\overline{FF}$  flag output will show the full status of the newly selected queue. On the forth rising edge of WCLK following the queue selection, data can be written into the newly selected queue provided that data and enable setup & hold times are met.

Note, the FF flag will provide status of a newly selected queue three WCLK cycle after queue selection, which is one cycle before data can be written to that queue. This prevents the user from writing data to a queue that is full, (assuming that a queue switch has been made to a queue that is actually full).

The FF flag is synchronous to the WCLK and all transitions of the FF flag occur based on a rising edge of WCLK. Internally the multi-queue device monitors and keeps a record of the full status for all queues. It is possible that the status of a FF flag maybe changing internally even though that flag is not the active queue flag (selected on the write port). A queue selected on the read port may experience a change of its internal full flag status based on read operations.

See Figure 42, *SDR Write Queue Select, Write Operation and Full Flag Operation* and Figure 45, *Full Flag Timing in Expansion Configuration* for timing information.

### **EXPANSION CONFIGURATION - FULL FLAG OPERATION**

When multi-queue devices are connected in Expansion configuration the  $\overline{FF}$  flags of all devices should be connected together, such that a system controller monitoring and managing the multi-queue devices write port only looks at a single  $\overline{FF}$  flag (as opposed to a discrete  $\overline{FF}$  flag for each device). This  $\overline{FF}$  flag is only pertinent to the queue being selected for write operations at that time. Remember, that when in expansion configuration only one multi-queue device can be written to at any moment in time, thus the  $\overline{FF}$  flag provides status of the active queue on the write port.

This connection of flag outputs to create a single flag requires that the  $\overline{FF}$  flag output have a High-Impedance capability, such that when a queue selection is made only a single device drives the  $\overline{FF}$  flag bus and all other  $\overline{FF}$  flag outputs connected to the  $\overline{FF}$  flag bus are placed into High-Impedance. The user does not have to select this High-Impedance state, a given multi-queue flow-control device will automatically place its  $\overline{FF}$  flag output into High-Impedance when none of its queues are selected for write operations.

When queues within a single device are selected for write operations, the FF flag output of that device will maintain control of the FF flag bus. Its FF flag will simply update between queue switches to show the respective queue full status.

The multi-queue device places its  $\overline{FF}$  flag output into High-Impedance based on the 1-3 bit ID code (1 if two multi-queue are configured with a maximum total of 256 queues, 2 if four devices are used totalling a maximum of 256 queues, and 3 if there are up to eight devices with a maximum total of 256 queues) found in the 1-3 most significant bits of the write queue address bus, WRADD. If the 1-3 most significant bits of WRADD match the 1-3 bit ID code setup on the static inputs, ID0, ID1 and ID2 then the  $\overline{FF}$  flag output of the respective device will be in a Low-Impedance state. If they do not match, then the  $\overline{FF}$  flag output of the respective device will be in a High-Impedance state. See Figure 45, Full Flag Timing in Expansion Configuration for details of flag operation, including when more than one device is connected in expansion.

## EMPTY FLAG OPERATION (EF)

The multi-queue flow-control device provides a single Empty flag output, EF. The rising edge of an RCLK cycle that places new data onto the output register of the read port. Internally the multi-queue flow-control device monitors and maintains a status of the empty condition of all queues within it.

See Figure 46, *SDR Read Queue Select, Read Operation* for details of the timing.

# **EXPANSION - EMPTY FLAG OPERATION**

When multi-queue devices are connected in Expansion configuration, the  $\overline{\text{EF}}$  flags of all devices should be connected together, such that a system controller monitoring and managing the multi-queue devices read port only looks at a single  $\overline{\text{EF}}$  flag (as opposed to a discrete  $\overline{\text{EF}}$  flag for each device). This  $\overline{\text{EF}}$  flag is only pertinent to the queue being selected for read operations at that time. Remember, that when in expansion configuration only one multi-queue device can be read from at any moment in time, thus the  $\overline{\text{EF}}$  flag provides status of the active queue on the read port.

This connection of flag outputs to create a single flag requires that the  $\overline{EF}$  flag output have a High-Impedance capability, such that when a queue selection is made only a single device drives the  $\overline{EF}$  flag bus and all other  $\overline{EF}$  flag outputs connected to the  $\overline{EF}$  flag bus are placed into High-Impedance. The user does not have to select this High-Impedance state, a given multi-queue flow-control device will automatically place its  $\overline{EF}$  flag output into High-Impedance when none of its queues are selected for read operations.

When queues within a single device are selected for read operations, the  $\overline{\text{EF}}$  flag output of that device will maintain control of the  $\overline{\text{EF}}$  flag bus. Its  $\overline{\text{EF}}$  flag will simply update between queue switches to show the respective queue status.

The multi-queue device places its EF flag output into High-Impedance based on the 1-3 bit ID code (1 if two multi-queue are configured with a maximum total of 256 queues, 2 if four devices are used totalling a maximum of 256 queues, and 3 if there are up to eight devices with a maximum total of 256 queues) found in the 3 most significant bits of the read queue address bus, RDADD. If the 3 most significant bits of RDADD match the 1-3 bit ID code setup on the static inputs, ID0, ID1 and ID2 then the  $\overline{\text{EF}}$  flag output of the respective device will be in a Low-Impedance state. If they do not match, then the  $\overline{\text{EF}}$  flag output of the respective device will be in a High-Impedance state.

#### ALMOST FULL FLAG

As previously mentioned the multi-queue flow-control device provides a single Programmable Almost Full flag output,  $\overline{PAF}$ . The  $\overline{PAF}$  flag output provides a status of the almost full condition for the active queue currently selected on the write port for write operations. Internally the multi-queue flow-control device monitors and maintains a status of the almost full condition of all queues within it, however only the queue that is selected for write operations has its full status output to the  $\overline{PAF}$  flag. This dedicated flag is often referred to as the "active queue almost full flag". The position of the  $\overline{PAF}$  flag boundary within a queue can be at any point within that queues depth. This location can be user programmed via the serial port or one of the default values (8 or 128) can be selected if the user has performed default programming.

As mentioned, every queue within a multi-queue device has its own almost full status, when a queue is selected on the write port, this status is output via the  $\overline{PAF}$  flag. The  $\overline{PAF}$  flag value for each queue is programmed during multi-queue device programming (along with the number of queues, queue depths and almost empty values). The  $\overline{PAF}$  offset value, m, for a respective queue can be programmed to be anywhere between '0' and 'D', where 'D' is the total memory depth for that queue. The  $\overline{PAF}$  value of different queues within the same device can be different values.

When queue switches are being made on the write port, the PAF flag output will switch to the new queue and provide the user with the new queue status, on the third cycle after a new queue selection is made, on the same WCLK cycle that data can actually be written to the new queue. That is, a new queue can be selected on the write port via the WRADD bus, WADEN enable and a rising edge of WCLK. On the third rising edge of WCLK following a queue selection, the PAF flag output will show the full status of the newly selected queue. The PAF is flag output is double register buffered, so when a write operation occurs at the almost full boundary causing the selected queue status to go almost full the PAF will go LOW 3 WCLK cycles after the write. The same is true when a read occurs, there will be a 3 WCLK cycle delay after the read operation.

So the  $\overline{PAF}$  flag delay from a write operation to  $\overline{PAF}$  flag LOW is 3 WCLK + twaf. The delay from a read operation to  $\overline{PAF}$  flag HIGH is tskew2 + WCLK + twaf.

Note, if tskew is violated there will be one added WCLK cycle delay.

The  $\overline{PAF}$  flag is synchronous to the WCLK and all transitions of the  $\overline{PAF}$  flag occur based on a rising edge of WCLK. Internally the multi-queue device monitors and keeps a record of the almost full status for all queues. It is possible that the status of a  $\overline{PAF}$  flag maybe changing internally even though that flag is not the active queue flag (selected on the write port). A queue selected on the read port may experience a change of its internal almost full flag status based on read operations. The multi-queue flow-control device also provides a duplicate of the  $\overline{PAF}$  flag on the  $\overline{PAF}$  flag bus, this will be discussed in detail in a later section of the data sheet.

See Figures 23 and 24 for Almost Full flag timing and queue switching.

# ALMOST EMPTY FLAG

As previously mentioned the multi-queue flow-control device provides a single Programmable Almost Empty flag output,  $\overline{PAE}$ . The  $\overline{PAE}$  flag output provides a status of the almost empty condition for the active queue currently selected on the read port for read operations. Internally the multi-queue flow-control device monitors and maintains a status of the almost empty condition of all queues within it, however only the queue that is selected for read operations has its empty status output to the  $\overline{PAE}$  flag. This dedicated flag is often referred to as the "active queue almost empty flag". The position of the  $\overline{PAE}$  flag boundary within a queue can be at any point within that queues depth. This location can be user programmed via the serial port or one of the default values (8 or 128) can be selected if the user has performed default programming.

As mentioned, every queue within a multi-queue device has its own almost empty status, when a queue is selected on the read port, this status is output via the  $\overline{PAE}$  flag. The  $\overline{PAE}$  flag value for each queue is programmed during multiqueue device programming (along with the number of queues, queue depths and almost full values). The  $\overline{PAE}$  offset value, n, for a respective queue can be programmed to be anywhere between '0' and 'D', where 'D' is the total memory depth for that queue. The  $\overline{PAE}$  value of different queues within the same device can be different values.

When queue switches are being made on the read port, the  $\overline{PAE}$  flag output will switch to the new queue and provide the user with the new queue status, on the third cycle after a new queue selection is made, on the same RCLK cycle that data actually falls through to the output register from the new queue. That is, a new queue can be selected on the read port via the RDADD bus, RADEN enable and a rising edge of RCLK. On the third rising edge of RCLK following a queue selection, the data word from the new queue will be available at the output register and the  $\overline{PAE}$  flag output will show the empty status of the newly selected queue. The  $\overline{PAE}$  is flag output is double register buffered, so when a read operation occurs at the almost empty boundary causing the selected queue status to go almost empty the  $\overline{PAE}$  will go LOW 3 RCLK cycles after the read. The same is true when a write occurs, there will be a 3 RCLK cycle delay after the write operation.

So the  $\overline{PAE}$  flag delay from a read operation to  $\overline{PAE}$  flag LOW is 3 RCLK + trae. The delay from a write operation to  $\overline{PAE}$  flag HIGH is tskew2 + RCLK + trae.

Note, if tskew is violated there will be one added RCLK cycle delay.

The  $\overline{\text{PAE}}$  flag is synchronous to the RCLK and all transitions of the  $\overline{\text{PAE}}$  flag occur based on a rising edge of RCLK. Internally the multi-queue device monitors and keeps a record of the almost empty status for all queues. It is possible that the status of a  $\overline{\text{PAE}}$  flag maybe changing internally even though that flag is not the active queue flag (selected on the read port). A queue selected on the write port may experience a change of its internal almost empty flag status based on write operations. The multi-queue flow-control device also provides a duplicate of the  $\overline{\text{PAE}}$  flag on the  $\overline{\text{PAE}}$  flag bus, this will be discussed in detail in a later section of the data sheet.

See Figures 25 and 26 for Almost Empty flag timing and queue switching.

## PAFn - DIRECT BUS

If FM is LOW at master reset then the  $\overline{PAF}$ n bus operates in Direct (addressed) mode. In direct mode the user can address the status word of queues they require and it will be placed on to the  $\overline{PAF}$ n bus. For example, consider the operation of the  $\overline{PAF}$ n bus when 26 queues have been setup. To output status of the first status word, Queue[0:7] the WRADD bus is used in conjunction with the FSTR ( $\overline{PAF}$  flag strobe) input and WCLK. The address present on the 4 least significant bits of the WRADD bus with FSTR HIGH will be selected as the status word address on a rising edge of WCLK. To address status word 0, Queue[0:7] the WRADD bus should be loaded with "0010000", the  $\overline{PAF}$ n bus will change status to show the new status word selected 1 WCLK cycle after status word selection.  $\overline{PAF}$ n[0:7] gets status of queues, Queue[0:7] respectively.

To address status word 1, Queue[8:15], the WRADD address is "00100001".  $\overline{\text{PAF}}$ n[0:7] gets status of queues, Queue[8:15] respectively. To address the 2nd status word, Queue[16:23], the WRADD address is "00100010".  $\overline{\text{PAF}}$ [0:7] gets status of queues, Queue[16:23] respectively. To address the 3rd status word, Queue[24:31], the WRADD address is "00100011".  $\overline{\text{PAF}}$ [0:1] gets status of queues, Queue[24:25] respectively. Remember, only 26 queues were setup, so when status word 4 is selected the unused outputs  $\overline{\text{PAF}}$ [2:7] will be don't care states.

Note, that if a read or write operation is occurring to a specific queue, say queue 'x' on the same cycle as a status word switch which will include the queue

'x', then there may be an extra WCLK cycle delay before that queues status is correctly shown on the respective output of the  $\overline{PAF}$ n bus. However, the active  $\overline{PAF}$  flag will show correct status at all times.

Status words can be selected on consecutive clock cycles, that is the status word on the  $\overline{PAF}$ n bus can change every WCLK cycle. Also, data present on the input bus, Din, can be written into a Queue on the same WCLK rising edge that a status word is being selected, the only restriction being that a write queue selection and  $\overline{PAF}$ n status word selection cannot be made on the same cycle.

If 8 or less queues are setup then queues, Queue[0:7] have their  $\overline{PAF}$  status output on  $\overline{PAF}$ [0:7] constantly.

When the multi-queue devices are connected in expansion of more than one device the  $\overline{PAF}$ n busses of all devices are connected together, when switching between status words of different devices the user must utilize the 1-3 most significant bits of the WRADD address bus (as well as the 2 LSB's). These 1-3 MSb's correspond to the device ID inputs, which are the static inputs, ID0, ID1 & ID2.

Please refer to Figure 57 **PAF***n* - *Direct Mode Status Word Selection* for timing information. Also refer to Table 8, *Write Address Bus, WRADD*.

### PAFn - POLLED BUS

If FM is HIGH at master reset then the  $\overline{PAF}n$  bus operates in Polled (looped) mode. In polled mode the  $\overline{PAF}n$  bus only cycles through the number of status words required to display the status of the number of queues that have been setup in the part. Every rising edge of the WCLK causes the next status word to be loaded on the  $\overline{PAF}n$  bus. The device configured as the master (MAST inputtied HIGH), will take control of the  $\overline{PAF}n$  after  $\overline{MRS}$  goes LOW. For the whole WCLK cycle that the first status word is on  $\overline{PAF}n$  the FSYNC ( $\overline{PAF}n$  bus sync) output will be HIGH, for all other status words, this FSYNC output will be LOW. This FSYNC output provides the user with a mark with which they can synchronize to the  $\overline{PAF}n$  bus, FSYNC is always HIGH for the WCLK cycle that the first status word of a device is present on the  $\overline{PAF}n$  bus.

When devices are connected in expansion configuration, only one device will be set as the Master (ID = '000'), MAST input tied HIGH, all other devices will have MAST tied LOW. The master device is the first device to take control of the PAFn bus and will place its first status word on the bus on the rising edge of WCLK. For the next n WCLK cycles (n= number of queues divided by 8 with n being increased by one for any remainder) the master device will maintain control of the PAFn bus and cycle its status words through it, all other devices hold their PAF noutputs in High-Impedance. When the master device has cycled all of its status words it passes a token to the next device in the chain and that device assumes control of the PAFn bus and then cycles its status words and so on, the PAFn bus control token being passed on from device to device. This token passing is done via the FXO outputs and FXI inputs of the devices ("PAF Expansion Out" and "PAF Expansion In"). The FXO output of the master device connects to the FXI of the second device in the chain and the FXO of the second connects to the FXI of the third and so on. The final device in a chain has its FXO connected to the FXI of the first device, so that once the PAFn bus has cycled through all status words of all devices, control of the PAFn will pass to the master device again and so on. The FSYNC of each respective device will operate independently and simply indicate when that respective device has taken control of the bus and is placing its first status word on to the PAFn bus.

When operating in single device mode the FXI input must be connected to the FXO output of the same device. In single device mode a token is still required to be passed into the device for accessing the  $\overline{\mathsf{PAF}}$ n bus.

Please refer to Figure 60, **PAF** n Bus – Polled Mode for timing information.

## **PAEn FLAG BUS OPERATION**

The IDT72P51767/72P51777 multi-queue flow-control device can be configured for up to 128 queues, each queue having its own almost empty/packet ready status. An active queue has its flag status output to the discrete flag,  $\overline{PAE}$ , on the read port. Queues that are not selected for a read operation can have their  $\overline{PAE}$  status monitored via the  $\overline{PAE}$ n bus. The  $\overline{PAE}$ n flag bus is 8 bits wide, so that 8 queues at a time can have their status output to the bus. If 9 or more queues are setup within a device then there are 2 methods by which the device can share the bus between queues, "Direct" mode and "Polled" mode depending on the state of the FM (Flag Mode) input during a Master Reset. If 8 or less queues are setup within a device then each will have its own dedicated output from the bus. If 8 or less queues are setup in single device mode, it is recommended to configure the  $\overline{PAE}$ n bus to polled mode as it does not require using the write address (WRADD).

## PAEn - DIRECT BUS

If FM is LOW at master reset then the  $\overline{PAE}$ n bus operates in Direct (addressed) mode. In direct mode the user can address the status word of queues they require to be placed on to the  $\overline{PAE}$ n bus. For example, consider the operation of the  $\overline{PAE}$ n bus when 26 queues have been setup. To output status of the first status word, Queue[0:7] the RDADD bus is used in conjunction with the ESTR ( $\overline{PAE}$  flag strobe) input and RCLK. The address present on the 2 least significant bits of the RDADD bus with ESTR HIGH will be selected as the status word address on a rising edge of RCLK. So to address status word 1, Queue[0:7] the RDADD bus should be loaded with "xxxx0000", the  $\overline{PAE}$ n bus will change status to show the new status word selected 1 RCLK cycle after status word selection.  $\overline{PAE}$ n[0:7] gets status of queues, Queue[0:7] respectively.

To address the second status word, Queue[8:15], the RDADD address is "xxxx0001".  $\overline{PAE}$ n[0:7] gets status of queues, Queue[8:15] respectively. To address the third status word, Queue[16:23], the RDADD address is "xxxx0010".  $\overline{PAE}$ [0:7] gets status of queues, Queue[16:23] respectively. To address the fourth status word, Queue[24:31], the RDADD address is "xxxxx0011".  $\overline{PAE}$ [0:1] gets status of queues, Queue[24:25] respectively. Remember, only 26 queues were setup, so when status word 4 is selected the unused outputs  $\overline{PAE}$ [2:7] will be don't care states.

Note, that if a read or write operation is occurring to a specific queue, say queue 'x' on the same cycle as a status word switch which will include the queue 'x', then there may be an extra RCLK cycle delay before that queues status is correctly shown on the respective output of the  $\overline{\mathsf{PAE}}$ n bus.

Status words can be selected on consecutive clock cycles, that is the status word on the  $\overline{PAE}$ n bus can change every RCLK cycle. Also, data can be read out of a Queue on the same RCLK rising edge that a status word is being selected, the only restriction being that a read queue selection and  $\overline{PAE}$ n status word selection cannot be made on the same RCLK cycle.

If 8 or less queues are setup then queues, Queue[0:7] have their  $\overline{PAE}$  status output on  $\overline{PAE}$ [0:7] constantly.

When the multi-queue devices are connected in expansion of more than one device the  $\overline{\text{PAE}}$ n busses of all devices are connected together, when switching between status words of different devices the user must utilize the 3 most significant bits of the RDADD address bus (as well as the 2 LSB's). These 3 MSb's correspond to the device ID inputs, which are the static inputs, ID0, ID1 & ID2.

Please refer to Figure 56, **PAE***n* - *Direct Mode Status Word Selection* for timing information. Also refer to Table 9, *Read Address Bus*, *RDADD*.

# **TABLE 14 — FLAG OPERATION BOUNDARIES & TIMING**

| Empty Flag, EF Flag Boundary                                                                                 |                                                                        |  |  |  |
|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--|--|--|
| I/O Set-Up                                                                                                   | <b>EF</b> Boundary Condition                                           |  |  |  |
| In40 to out40 (Almost Empty Mode)<br>(Both ports selected for same queue<br>when the 1st Word is written in) | EF Goes HIGH after 1 <sup>st</sup> Write (see note 1 below for timing) |  |  |  |
| In40 to out20<br>(Both ports selected for same queue<br>when the 1st Word is written in)                     | EF Goes HIGH after 1st Write<br>(see note 1 below for timing)          |  |  |  |
| In20 to out40 (Both ports selected for same queue when the 1st Word is written in)                           | EF Goes HIGH after 1st Write (see note 1 below for timing)             |  |  |  |

#### NOTE:

## 1. **EF** Timing

Assertion:

Write to EF HIGH: tSKEW1 + RCLK + tROV

If tskew1 is violated there may be 1 added clock: tskew1 + 2 RCLK + treeF De-assertion:

Read Operation to EF HIGH: tREF

2. In40 = SDR40 or DDR20

In20 = SDR20

| Full Flag, FF Boundary                                                                   |                                                                |  |  |  |
|------------------------------------------------------------------------------------------|----------------------------------------------------------------|--|--|--|
| I/O Set-Up                                                                               | FF Boundary Condition                                          |  |  |  |
| In40 to out40<br>(Both ports selected for same queue<br>when the 1st Word is written in) | FF Goes LOW after D Writes (see note below for timing)         |  |  |  |
| In40 to out40<br>(Write port only selected for queue<br>when the 1st Word is written in) | FF Goes LOW after D Writes (see note below for timing)         |  |  |  |
| In40 to out20<br>(Both ports selected for same queue<br>when the 1st Word is written in) | FF Goes LOW after D Writes (see note below for timing)         |  |  |  |
| In40 to out20<br>(Write port only selected for queue<br>when the 1st Word is written in) | FF Goes LOW after D Writes (see note below for timing)         |  |  |  |
| In20 to out40<br>(Both ports selected for same queue<br>when the 1st Word is written in) | FF Goes LOW after ([D] x 2) Writes (see note below for timing) |  |  |  |
| In20 to out40<br>(Write port only selected for queue<br>when the 1st Word is written in) | FF Goes LOW after (D x 2) Writes (see note below for timing)   |  |  |  |

#### NOTE:

D = Queue Depth

#### FF Timing

Assertion:

Write Operation to FF LOW: tWFF

De-assertion:

Read to FF HIGH: tSKEW1 + tWFF

If tSKEW1 is violated there may be 1 added clock: tSKEW1+WCLK +tWFF

1. In40 = SDR40 or DDR20

ln20 = SDR20

| Programmable Almost Full Flag, PAF & PAFn Bus Boundary |                                   |  |  |
|--------------------------------------------------------|-----------------------------------|--|--|
| I/O Set-Up                                             | PAF & PAFn Boundary               |  |  |
| in40 to out40                                          | PAF/PAFn Goes LOW after           |  |  |
| (Both ports selected for same queue when the 1st       | D-mWrites                         |  |  |
| Word is written in until the boundary is reached)      | (see note below for timing)       |  |  |
| in40 to out40                                          | PAF/PAFn Goes LOW after           |  |  |
| (Write port only selected for same queue when the      | D-mWrites                         |  |  |
| 1st Word is written in until the boundary is reached)  | (see note below for timing)       |  |  |
| in40 to out20                                          | PAF/PAFn Goes LOW after           |  |  |
|                                                        | D-m Writes (see below for timing) |  |  |

## NOTE:

D = Queue Depth

m = Almost Full Offset value.

1. In40 = SDR40 or DDR20

ln20 = SDR20

# PAF Timing

Assertion: Write Operation to PAF LOW: 3 WCLK + tWAF De-assertion: Read to PAF HIGH: tSKEW2 + WCLK + tWAF

If tSKEW2 is violated there may be 1 added clock: tSKEW2 + 3 WCLK + tWAF

**PAF**n Timing

Assertion: Write Operation to PAFn LOW: 2 WCLK\* + tPAF De-assertion: Read to PAFn HIGH: tSKEW3 + WCLK\* + tPAF

If tSKEW3 is violated there may be 1 added clock: tSKEW3 + 3 WCLK\* + tPAF

\* If a queue switch is occurring on the write port at the point of flag assertion or de-assertion there may be one additional WCLK clock cycle delay.

# **TABLE 14 — FLAG OPERATION BOUNDARIES & TIMING (CONTINUED)**

| Programmable Almost Empty Flag, PAE Boundary                                                                           |                                                                         |  |  |  |
|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--|--|--|
| I/O Set-Up                                                                                                             | PAE Assertion                                                           |  |  |  |
| in40 to out40 (Both ports selected for same queue when the 1st Word is written in until the boundary is reached)       | PAE Goes HIGH after n+1<br>Writes<br>(see note below for timing)        |  |  |  |
| in40 to out20<br>(Both ports selected for same queue when the 1st<br>Word is written in until the boundary is reached) | PAE Goes HIGH after n+1<br>Writes<br>(see note below for timing)        |  |  |  |
| in20 to out40<br>(Both ports selected for same queue when the 1st<br>Word is written in until the boundary is reached) | PAE Goes HIGH after<br>([n+1] x 2) Writes<br>(see note belowfor timing) |  |  |  |

#### NOTE:

n = Almost Empty Offset value. 1. In40 = SDR40 or DDR20

ln20 = SDR20

### **PAE** Timing

Assertion: Read Operation to PAE LOW: 3 RCLK + tRAE De-assertion: Write to PAE HIGH: tskew2 + RCLK + trae

If tSKEW2 is violated there may be 1 added clock: tSKEW2 + 3 RCLK + tRAE

| Programmable Almost Empty Flag Bus, PAEn Boundary     |                                                           |  |  |
|-------------------------------------------------------|-----------------------------------------------------------|--|--|
| I/O Set-Up                                            | PAEn Boundary Condition                                   |  |  |
| in40 to out40                                         | PAEn Goes HIGH after                                      |  |  |
| (Both ports selected for same queue when the 1st      | n+1 Writes                                                |  |  |
| Word is written in until the boundary is reached)     | (see note below for timing)                               |  |  |
| in40 to out40                                         | PAEn Goes HIGH after                                      |  |  |
| (Write port only selected for same queue when the     | n+1 Writes                                                |  |  |
| 1st Word is written in until the boundary is reached) | (see note below for timing)                               |  |  |
| in40 to out20                                         | PAEn Goes HIGH after n+1<br>Writes (see below for timing) |  |  |
| in20 to out40                                         | PAEn Goes HIGH after                                      |  |  |
| (Both ports selected for same queue when the 1st      | ([n+1] x 2) Writes                                        |  |  |
| Word is written in until the boundary is reached)     | (see note below for timing)                               |  |  |
| in20 to out40                                         | PAEn Goes HIGH after                                      |  |  |
| (Write port only selected for same queue when the     | ([n+1] x 2) Writes                                        |  |  |
| 1st Word is written in until the boundary is reached) | (see note below for timing)                               |  |  |

#### NOTF:

n = Almost Empty Offset value.

1. In40 = SDR40 or DDR20

In20 = SDR20

#### PAEn Timing

Assertion: Read Operation to  $\overline{PAE}$ n LOW: 3 RCLK\* + tPAE De-assertion: Write to  $\overline{PAE}$ n HIGH: tSKEW3 + RCLK\* + tPAE

If tSKEW3 is violated there may be 1 added clock: tSKEW3 + 3 RCLK\* + tPAE

\* If a queue switch is occurring on the read port at the point of flag assertion or de-assertion there may be one additional RCLK clock cycle delay.

## PAEn - POLLED BUS

If FM is HIGH at master reset then the  $\overline{PAE}n$  bus operates in Polled (looped) mode. In polled mode the  $\overline{PAE}n$  bus automatically cycles through the 4 status words within the device regardless of how many queues have been setup in the part. Everyrising edge of the RCLK causes the next status word to be loaded on the  $\overline{PAE}n$  bus. The device configured as the master (MAST input tied HIGH), will take control of the  $\overline{PAE}n$  after  $\overline{MRS}$  goes LOW. For the whole RCLK cycle that the first status word is on  $\overline{PAE}n$  the ESYNC ( $\overline{PAE}n$  bus sync) output will be HIGH, for all other status words, this ESYNC output will be LOW. This ESYNC output provides the user with a mark with which they can synchronize to the  $\overline{PAE}n$  bus, ESYNC is always HIGH for the RCLK cycle that the first status word of a device is present on the  $\overline{PAE}n$  bus.

When devices are connected in expansion configuration, only one device will be set as the Master (ID='000'), MAST input tied HIGH, all other devices will have MAST tied LOW. The master device is the first device to take control of the  $\overline{PAE}$ n bus and will place its first status word on the bus on the rising edge of RCLK after the  $\overline{MRS}$  input goes LOW. For the next n RCLK cycles (n=number of queues divided by 8 with n incrementing by one should there be a remainder)

the master device will maintain control of the  $\overline{PAE}n$  bus and cycle its status words through it, all other devices hold their  $\overline{PAE}n$  outputs in High-Impedance. When the master device has cycled all of its status words it passes a token to the next device in the chain and that device assumes control of the  $\overline{PAE}n$  bus and then cycles its status words and so on, the  $\overline{PAE}n$  bus control token being passed on from device to device. This token passing is done via the EXO outputs and EXI inputs of the devices (" $\overline{PAE}$  Expansion Out" and " $\overline{PAE}$  Expansion In"). The EXO output of the master device connects to the EXI of the second device in the chain and the EXO of the second connects to the EXI of the third and so on. The final device in a chain has its EXO connected to the EXI of the first device, so that once the  $\overline{PAE}n$  bus has cycled through all status words of all devices, control of the  $\overline{PAE}n$  will pass to the master device again and so on. The ESYNC of each respective device will operate independently and simply indicate when that respective device has taken control of the bus and is placing its first status word on to the  $\overline{PAE}n$  bus.

When operating in single device mode the EXI input must be connected to the EXO output of the same device. In single device mode a token is still required to be passed into the device for accessing the  $\overline{PAE}n$  bus.

# **TABLE 15 — INTERFACE DATA RATES**

|                 |                  | Supported Data Transfer Rate |  |
|-----------------|------------------|------------------------------|--|
| Input Interface | Output Interface | Combination                  |  |
| SDR             | SDR              | Yes                          |  |
| SDR             | DDR              | Yes                          |  |
| DDR             | SDR              | Yes                          |  |
| DDR             | DDR              | Yes                          |  |

## **INPUT INTERFACE**

The input port will support either Edge Aligned data clocking or Center Aligned data clocking. No device configuration is required. For reference XGMII uses center aligned clocking.

The input interface will support either Single Data Rate (SDR) data transfers or Double Data Rate (DDR) data transfers.

### **OUTPUTINTERFACE**

The output interface will provide a Centered Aligned data clock for Double Data Rate (DDR) operation and Edge Aligned data clock for Single Data Rate (SDR) operation. The output interface will support either Single Data Rate (SDR) data transfers or Double Data Rate (DDR) data transfers.

Note, the sum of (ta max + tsu min) must be less than the cycle time.



Figure 34. DDR Source Synchronous Center Aligned Clocking



Figure 35. SDR Edge Aligned Clocking

#### **BUS MATCHING OPERATION**

Bus Matching operation between the input port and output port is available. During a master reset of the multi-queue the state of the three setup pins, BM [3:0] (Bus Matching), determine the input and output port bus widths as shown in Table 16, "Bus Matching Configurations". 20 bit words and 40 bit words can be written into and read from the Queues. When writing to or reading from the multi-queue in a bus matching mode, the device orders data in a "Little Endian" format. See Figure 36, Bus Matching Byte Arrangement for details.

The Full flag and Almost Full flag operation is always based on writes and reads of data widths determined by the write port width. For example, if the input

port is x40 and the output port is x20, then two data reads from a full queue will be required to cause the full flag to go HIGH (queue not full). Conversely, the Empty flag and Almost Empty flag operations are always based on writes and reads of data widths determined by the read port. For example, if the input port is x20 and the output port is x40, two write operations will be required to cause the Empty flag ( $\overline{EF}$ ) of an empty queue to go HIGH (queue is not empty).

Note, that the input port serves all queues within a device, as does the output port, therefore the input bus width to all queues is equal (determined by the input port size) and the output bus width from all queues is equal (determined by the output port size).

# **TABLE 16 — BUS-MATCHING CONFIGURATIONS**

| BM3   | BM2   |     |     | Write   | Read    |             |             |
|-------|-------|-----|-----|---------|---------|-------------|-------------|
| (IDR) | (ODR) | BM1 | BM0 | Port    | Port    | PAE Default | PAF Default |
| 0     | 0     | 0   | 0   | DDR x40 | DDR x40 | 16          | D-16        |
| 0     | 0     | 0   | 1   | DDR x40 | DDR x20 | 16          | D-16        |
| 0     | 0     | 1   | 0   | DDR x40 | SDR x40 | 16          | D-16        |
| 0     | 0     | 1   | 1   | DDR x40 | SDR x20 | 16          | D-16        |
| 0     | 1     | 0   | 0   | DDR x20 | DDR x40 | 16          | D-16        |
| 0     | 1     | 0   | 1   | DDR x20 | DDR x20 | 32          | D-32        |
| 0     | 1     | 1   | 0   | DDR x20 | SDR x40 | 32          | D-32        |
| 0     | 1     | 1   | 1   | DDR x20 | SDR x20 | 32          | D-32        |
| 1     | 0     | 0   | 0   | SDR x40 | DDR x40 | 16          | D-16        |
| 1     | 0     | 0   | 1   | SDR x40 | DDR x20 | 32          | D-32        |
| 1     | 0     | 1   | 0   | SDR x40 | SDR x40 | 32          | D-32        |
| 1     | 0     | 1   | 1   | SDR x40 | SDR x20 | 32          | D-32        |
| 1     | 1     | 0   | 0   | SDR x20 | DDR x40 | 16          | D-16        |
| 1     | 1     | 0   | 1   | SDR x20 | DDR x20 | 32          | D-32        |
| 1     | 1     | 1   | 0   | SDR x20 | SDR x40 | 32          | D-32        |
| 1     | 1     | 1   | 1   | SDR x20 | SDR x20 | 64          | D-64        |



## NOTES:

- 1. Please refer to Table 16, Bus-Matching set-up for details.
- 2. Data bits not used in this configuration.

Figure 36. Bus-Matching Byte Arrangement



6724 drw46

NOTE:

1.  $\overline{\text{OE}}$  can toggle during this period.

Figure 37. Master Reset





6724 drw47

Figure 38. Default Programming

SCLK is not used and can be tied LOW.
 Programming of all devices must be complete (SENO of the final device is LOW), before any write or read port operations can take place, this includes queue selections.

 SENI of the first device in the chain must be held LOW
 The SENO of a device should connect to the SENI of the next device in the chain. The final device SENO is used to indicate programming complete.

4. When Default Programming is complete the SENO of the final device will go LOW.

The SENO of the final device in a chain is the "programming complete" signal.

61

1. This diagram illustrates multiple devices connected in expansion.



- NOTES:
  1. The SENO is the "programming complete" signal.
  2. SENI can be held LOW.
- 4. SCLK is not used and can be tied LOW.

  5. Programming of the device must be complete (SENO of the device is LOW), before any write or read port operations can take place, this includes queue selections. 3. When Parallel Programming is complete the SENO of the device will go LOW.
- 6. See Table 5, Setting the Queue Programming Mode for setting default number of Queues rising (QSEL[2:0].
  7. Depending on QSEL0 input, the Queue will be selected for programming the number of queues in parallel programming mode.

Figure 39. Write Address/Read Address Programming



Figure 40. Serial Port Connection for Serial Programming



- 1. SENI can be toggled during serial loading. Once serial programming of a device is complete, the SENI and SI inputs become transparent. SENI → SENO and SI → SO.

- 2. DFM is LOW and OSEL[2:0] = LOW during Master Reset to provide perior programming of the final device is LOW no further serial loads will be accepted.

  3. When SENO of the final device is LOW no further serial loads will be accepted.

  4. n = 27+(0x104); where Q is the number of queues required for the IDT72P5177777.

  5. Programming of all devices must be complete (SENO of the 2nd device is LOW), before any write or read port operations can take place, this includes queue selections.

Figure 41. Serial Programming (2 Device Expansion)



OE is active LOW.

Oueue, Ox is selected on the write port. Cycle: \*

The FF flag is providing status of a previously selected queue, within the same device.

Queue, Oy is selected for read operations \*AA\*

The FF flag output updates to show the status of Qx, it is not full. Current word is kept on the output bus since REN is HIGH. \* BB\* \* C\*

The FF flag provides status of previous queue.

Word W+1 is read from the previous queue regardless of REN due to FWFT. \* CC\*

Word, Wd is written into Ox. This causes Ox to go full.

\*D\*

The next available Word W0 of Qy is read out regardless of REN, 3 RCLK cycles after queue selection. This is FWFT operation.

Queue, Qy is selected within the same device as Qx. A write to Qx cannot occur on this cycle because it is full, FF is LOW.

No reads occur, REN is HIGH. Word, W0 is read from Qy, this causes Qy to go "not full", FF flag goes HIGH after time, tskewn + twrer. Note, if tskewn is violated the time FF HIGH will be: tskewn + WCLK + twrer. \* # \* \*

Again, a write to Ox cannot occur on this cycle because it is full, FF is LOW.

Word, W0 is read from Oy.

The FF flag updates after time twrr to show that queue, Qy is not full. \* # \*

Word, Wd-2 is written into Qy.

Word, Wd-1 is written into Qy.

Word, Wd is written into Qy, this causes Qy to go full,  $\overline{\rm FF}$  goes LOW. A write to Qy cannot occur on this cycle because it is full,  $\overline{\rm FF}$  is LOW.

Qy goes "not full" based on reading word W0 from Qy on cycle \*FF\*

Figure 42. SDR Write Queue Select, Write Operation and Full Flag Operation



- 1. First Queue is selected on the write port at Cycle 2.
  2. User must wait 3 clock cycles after Queue switch is issued for data to be written in.
  3. WEN is clocked in only on the rising edge of WCLK, set up time is 1.5ns, hold time is 0.5ns
  4. The FF flag has "real time" response to active WEN and changes only on rising edge of WCLK. Flag access time < 3.6ns
  5. Data X3 stays on the Write bus until Queue Y data is ready after 4 clock cycles
  6. FF goes high reflects Queue Y's status
  7. PAF flag updates 3 clock cycles after offset in register has been eclipsed

Figure 43. DDR Write Operation, Write Queue Select, Full Flag Operation



Figure 44. Write Queue Select, Mark and Rewrite

1. Only 1 queue can be marked at any given time. 2. Marking a queue can only occur during a queue switch.

Cycle:

Oueue "Y" is selected but not marked.

Oueue "Y" is selected.

Oueue "Y" is marked.



Cycle:

Queue, Q27 of device 1 is selected on the write port.  $^*A^*$ 

The FF flag of device 1 is in High-Impedance, the write port of device 2 was previously selected.

WEN is HIGH so no write occurs. The FF flag stays in High-Impedance for 3 WCLK cycles.

Queue, Q5 of device 1 is selected on the read port.

Word, Wx-1 is held on the outputs for 2 RCLK cycles after a read Queue switch. \*BB\*

The FF flag of device 2 goes to High-Impedance and the FF flag of device 1 goes to Low-Impedance, logic HIGH indicating that D1 Q27 is not full. ڻ

WEN is HIGH so no write occurs.

Word, Wx is read from the previously selected queue. \*CC\*

Word, Wd is written into Q27 of D1. This write operation causes Q27 to go full, FF goes LOW.
The first word from Q5 of D1 selected on cycle "AA" is read out. This read caused Q5 to go not full, therefore the FF flag will go HIGH after: tskew + twrs. \*D\*

Note if tskew1 is violated the time to FF flag HIGH is tskew1 + WLCK + twrF.

Queue, Q5 of device 1 is selected on the write port. No write occurs on this cycle. The FF flag updates to show the status of D1 Q5, it is not full, FF goes HIGH.

ئ پ

Word, Wd is written into Q5 of D1. This causes the queue to go full, FF goes LOW.

No write occurs regardless of WEN, the FF flag is LOW preventing writes. The FF flag goes HIGH due to the read from Q5 of D1 on cycle \*CC\*. (This read is not an enabled read.)

Oueue, Q9 of device 2 is selected on the write port.
The FF flag of device 1 goes to High-Impedance, this device was deselected on the write port on cycle \*I\*. The FF flag of device 2 goes to Low-Impedance and provides status of Q9 of D2. \*± \*- \*> \*≥

Figure 45. Full Flag Timing in Expansion Configuration



Cycle:
\*A\* Word Wn-4 is on the Oout bus from the present selected queue.
\*B\* Wn-3 is placed on Oout bus.
\*C\* Reads are disabled, Wn-3 remains on Oout bus.
\*D\* Reads are disabled Wn-3 remains on Oout bus.
\*E\* Read operation enabled.
\*F\* Word OP Wn-3 is read from the Oout bus.

Figure 46. SDR Read Queue Select, Read Operation (IDT mode)



#### NOTES:

- 1. On Cycle 2, Queue Y is addressed to read data from.
- 2. On Cycle 6, Queue Y data is available on the Read bus
- 3. On Cycle 5, EF and PAE flags have updated to give the status for Queue Y
- 4. Previous Data from Queue X will be read during queue switch until 3 cycle latency from queue switch, plus 1 cycle Read delay of the first word in Queue Y is completed.
- 5. REN is high for falling edge of cycle 3 and all of cycle 4 which means Words X6-X8 will not be available for read operation

Figure 47. DDR Read Operation, Read Queue Select, **EF** & **PAE** Flag Operation



2. Marking a queue can only occur during a queue switch. 1. Only 1 queue can be marked at any given time.

Oueue "F" is selected but not marked.

Oueue "G" is selected.

Oueue "G" is marked. Cycle: \*D\* 0 \*H\* 0

Figure 48. Read Queue Select, Mark and Reread (IDT mode)



Figure 49. Standard Mode Pointers on Queue Re-entry for DDR Read Operation



Figure 50. BOI Mode Pointers on Queue Re-entry for DDR Read Operation



\* $A^*$  Word Op Wo is read from the present selected queue, Op. \* $B^*$  Reads are disabled, word Op Wb+1 remains on the output bus.

\*C\* A new queue, On is selected for read port operations. Op Wb+1 remains on Qout bus.

REN is not asserted therefore no read operation occurs, Op Wb+1 remains on Qout bus. , \_

REN is not asserted therefore no read operation occurs, Op Wo+1 remains on Qout bus. REN is not asserted therefore no read operation occurs, Op Wb+1 remains on Qout bus.

Read operation is initiated. ڻ

\*H\* Word WD+1 of Qp is read.

Word Wb of On is read.

The queue, Op is again selected.

\*K\* Current Word is kept on the output bus since REN is HIGH.

\*L\* Word On Wb+2 remains on the Qout bus.
\*M\* Word On Wb+2 remains on the Qout bus.

Read operation is initiated. \*N\* Read operation is initiated.
\*O\* Word Wb+2 for Qn is read.
\*P\* Word Wb+2 for Qp is read.

Word WD+2 for Qp is read.

Figure 51. Read Queue Selection with Read Operations (IDT mode)

(SDR mode, PLL = OFF)



1. In expansion configuration the OE inputs of all devices should be connected together. This allows the output busses of all devices to be High-Impedance controlled.

\*A\* Queue A is selected for reads. No data will fall through on this cycle, the previous queue was read to empty.

\* $\mathbf{B}^*$  No read operation  $\overline{REN}$  = HIGH.

'C\* Previous data kept on output bus since there is no read operation.

\*D\* Previous data kept on output bus since there is no read operation.

Reads are disabled therefore word, W0 of QA remains on the output bus. Read from Queue A initiated.

Reads are again enabled. Word W0 is read from QA. Oueue, QB is selected on the read port. This queue is actually empty. Word, W1 is read from QA.

Word W3 is read from QA. ₩°₽±±5¥

Figure 52. Read Queue Select, Read Operation and OE Timing



# Cycle:

- \*Å\* Queue 5 of Device 1 is selected on the write port. A queue within Device 2 had previously been selected. The PAF output of device 1 is High-Impedance.
- \* $\mathbf{B}$ \* No write occurs,  $\overline{\text{WEN}}$  is HIGH.
- \*C\* No write occurs, WEN is HIGH.
- \*D\* No write occurs, WEN is HIGH.
- \*E\* Word, Wd-m is written into Q5 causing the PAF flag to go from HIGH to LOW. The flag latency is 3 WCLK cycles + twaf.
- \*F\* Queue 9 in device 1 is now selected for write operations. This queue is not almost full, therefore the PAF flag will update after a 3 WCLK + twaf latency.
- ${}^{\star}G^{\star}$  The  $\overline{PAF}$  flag goes LOW based on the write 2 cycles earlier.
- \*H\* No write occurs, WEN is HIGH.
- \*I\* The PAF flag goes HIGH due to the queue switch to Q9.

Figure 53. Almost Full Flag Timing and Queue Switch



# NOTE:

- 1. The waveform shows the  $\overline{PAF}$  flag operation when no queue switch occurs and a queue is selected on both the write and read ports is being written to then read from at the almost full boundary.
- 2. Flag Latencies:
  - Assertion: 2\*WCLK + twar
  - De-assertion: tskew2 + WCLK + twaF
- 3. If tskew2 is violated there will be one extra WCLK cycle.

Figure 54. Almost Full Flag Timing



# NOTE:

- 1. The waveform here shows the  $\overline{\text{PAE}}$  flag operation when no queue switches are occurring and a queue selected on both the write and read ports is being written to then read from at the almost empty boundary. Flag Latencies:
- 2. Assertion: 2\*RCLK + trae
  De-assertion: tskew2 + RCLK + trae
- 3. If tskew2 is violated there will be one extra RCLK cycle.

Figure 55. Almost Empty Flag Timing



# NOTES:

- 1. Status words can be selected on consecutive cycles.
- 2. On an RCLK cycle that the ESTR is HIGH, the RADEN input must be LOW.
- 3. There is a latency of 2 RCLK for the PAEn bus to switch.

Figure 56. PAEn - Direct Mode - Status Word Selection



# NOTES:

- 1. Status words can be selected on consecutive cycles.
- 2. On a WCLK cycle that the FSTR is HIGH, the WADEN input must be LOW.
- 3. There is a latency of 2 WCLK for the PAFn bus to switch.

Figure 57. PAFn - Direct Mode - Status Word Selection



# Cycle:

- \*A\* Queue 24 of Device 5 is selected for write operations. Word, Wp is written into the previously selected queue.
- \*AA\* Queue 24 of Device 5 is selected for read operations.

A status word from another device has control of the  $\overline{\text{PAE}}\text{n}$  bus.

The discrete PAE output of device 5 is currently in High-Impedance and the PAE active flag is controlled by the previously selected device.

- \*B\* Word Wp+1 is written into the previously selected queue.
- \*BB\* Current Word is kept on the output bus since REN is HIGH.
- \*C\* Word Wp+2 is written into the previously selected queue.
- \*D\* Word, Wn is written into the newly selected queue, Q24 of D5. This write will cause the PAE flag on the read port to go from LOW to HIGH (not almost empty) after time, tskews + RCLK + trae (if tskews is violated one extra RCLK cycle will be added).
- \*DD\* Status word 4 of Device 5 is selected on the PAEn bus. Q24 of device 5 will therefore have is PAE status output on PAE[0]. There is a single RCLK cycle latency before the PAEn bus changes to the new selection.
- \*E\* Queue 8 of Device 3 is selected for write operations.

Word Wn+1 is written into Q24 of D5.

- \*EE\* Word, Wy+1 is read from Q24 of D5.
- \*F\* No writes occur.
- \*FF\* Word, Wy+2 is read from Q24 of D5.

The PAEn bus changes control to D5, the PAEn outputs of D5 go to Low-Impedance and status word 4 is placed onto the outputs. The device of the previously selected status word now places its PAEn outputs into High-Impedance to prevent bus contention.

The discrete PAE flag will go HIGH to show that Q24 of D5 is not almost empty. Q24 of device 5 will have its PAE status output on PAE[0].

- \*G\* Status word 3 of device 4 is selected on the write port for the PAFn bus.
- \*GG\* The PAEn bus updates to show that Q24 of D5 is almost empty based on the reading out of word, Wy+1.

The discrete PAE flag goes LOW to show that Q24 of D5 is almost empty based on the reading of Wy+1.

Figure 58. PAEn - Direct Mode, Flag Operation



# Cycle:

- \*A\* Queue 31 of device 0 is selected for read operations.
  - The last word in the output register is available on Qout.  $\overline{\text{OE}}$  was previously taken LOW so the output bus is in Low-Impedance.
- \*AA\* Status word 4 of device 0 is selected for the PAFn bus. The bus is currently providing status of a previously selected status word, Quad Y of device X.
- ${}^{\star}B^{\star}$  No read operation.
- \*BB\* Queue 31 of device 0 is selected on the write port.
- \*CC\* PAFn continues to show status of Quad4 D0.

The  $\overline{PAF}$ n bus is updated with the status word selected on the previous cycle, D0 Quad 4.  $\overline{PAF}$ [7] is LOW showing the status of queue 31.

The PAFn outputs of the device previously selected on the PAFn bus go to High-Impedance.

- \*DD\* No write operation.
- \*E\* No read operations occur, REN is HIGH.
- \*EE\* PAF[7] goes HIGH to show that D0 Q31 is not almost empty due to the read on cycle \*C\*. The active queue PAF flag of device 0 goes from High-Impedance to Low-Impedance.

Word, Wy is written into D0 Q31.

- \*F\* Queue 2 of Device 6 is selected for read operations.
- \*FF\* Word, Wy+1 is written into D0 Q31.
- \*GG\* PAF[7] and the discrete PAF flag go LOW to show the write on cycle \*DD\* causes Q31 of D0 to again go almost full. Word, Wy+2 is written into D0 Q31.
- \*H\* No read operation.

Figure 59. **PAF**n - Direct Mode, Flag Operation



Figure 60. PAFn Bus - Polled Mode

1. This diagram is based on 3 devices connected in expansion configuration.

NOTE:

80



# NOTE:

1. ID2 MUST be unique between the devices.

Figure 61. Connecting two 10G MQ 128Q devices in Expansion Mode



Figure 62. Connecting THREE or more 10G MQ 128Q in Expansion Mode Using WADDR bit 7/RDADD bit 7

# JTAG INTERFACE

Five additional pins (TDI, TDO, TMS, TCK and TRST) are provided to support the JTAG boundary scan interface. The IDT72P51767/72P51777 incorporates the necessary tap controller and modified pad cells to implement the JTAG facility.

Note that IDT provides appropriate Boundary Scan Description Language program files for these devices.

The Standard JTAG interface consists of four basic elements:

- Test Access Port (TAP)
- TAP controller
- Instruction Register (IR)
- Data Register Port (DR)

The following sections provide a brief description of each element. For a complete description refer to the IEEE Standard Test Access Port Specification (IEEE Std. 1149.1-1990).

The Figure below shows the standard Boundary-Scan Architecture



Figure 63. Boundary Scan Architecture

# **TEST ACCESS PORT (TAP)**

The Tap interface is a general-purpose port that provides access to the internal of the processor. It consists of four input ports (TCLK, TMS, TDI,  $\overline{\text{TRST}}$ ) and one output port (TDO).

# **THE TAP CONTROLLER**

The Tap controller is a synchronous finite state machine that responds to TMS and TCLK signals to generate clock and control signals to the Instruction and Data Registers for capture and update of data.



# NOTES:

- 1. Five consecutive TCK cycles with TMS = 1 will reset the TAP.
- 2. TAP controller does not automatically reset upon power-up. The user must provide a reset to the TAP controller (either by TRST or TMS).
- 3. TAP controller must be reset before normal Queue operations can begin.

Figure 64. TAP Controller State Diagram

Refer to the IEEE Standard Test Access Port Specification (IEEE Std. 1149.1) for the full state diagram.

All state transitions within the TAP controller occur at the rising edge of the TCLK pulse. The TMS signal level (0 or 1) determines the state progression that occurs on each TCLK rising edge. The TAP controller takes precedence over the Queue and must be reset after power up of the device. See  $\overline{\mbox{TRST}}$  description for more details on TAP controller reset.

**Test-Logic-Reset** All test logic is disabled in this controller state enabling the normal operation of the IC. The TAP controller state machine is designed in such a way that, no matter what the initial state of the controller is, the Test-Logic-Reset state can be entered by holding TMS at high and pulsing TCK five times. This is the reason why the Test Reset  $(\overline{TRST})$  pin is optional.

**Run-Test-Idle** In this controller state, the test logic in the IC is active only if certain instructions are present. For example, if an instruction activates the self test, then it will be executed when the controller enters this state. The test logic in the IC is idles otherwise.

**Select-DR-Scan** This is a controller state where the decision to enter the Data Path or the Select-IR-Scan state is made.

**Select-IR-Scan** This is a controller state where the decision to enter the Instruction Pathis made. The Controller can return to the Test-Logic-Reset state other wise.

**Capture-IR** In this controller state, the shift register bank in the Instruction Register parallel loads a pattern of fixed values on the rising edge of TCK. The last two significant bits are always required to be "01".

**Shift-IR** In this controller state, the instruction register gets connected between TDI and TDO, and the captured pattern gets shifted on each rising edge of TCK. The instruction available on the TDI pin is also shifted into the instruction register.

**Exit1-IR** This is a controller state where a decision to enter either the Pause-IR state or Update-IR state is made.

**Pause-IR** This state is provided in order to allow the shifting of instruction register to be temporarily halted.

**Exit2-DR** This is a controller state where a decision to enter either the Shift-IR state or Update-IR state is made.

**Update-IR** In this controller state, the instruction in the instruction register is latched in to the latch bank of the Instruction Register on every falling edge of TCK. This instruction also becomes the current instruction once it is latched.

**Capture-DR** In this controller state, the data is parallel loaded in to the data registers selected by the current instruction on the rising edge of TCK.

**Shift-DR, Exit1-DR, Pause-DR, Exit2-DR and Update-DR** These controller states are similar to the Shift-IR, Exit1-IR, Pause-IR, Exit2-IR and Update-IR states in the Instruction path.

# THE INSTRUCTION REGISTER

The Instruction register allows an instruction to be shifted in serially into the processor at the rising edge of TCLK.

The Instruction is used to select the test to be performed, or the test data register to be accessed, or both. The instruction shifted into the register is latched at the completion of the shifting process when the TAP controller is at Update-IR state.

The instruction register must contain 4 bit instruction register-based cells which can hold instruction data. These mandatory cells are located nearest the serial outputs they are the least significant bits.

# **TEST DATA REGISTER**

The Test Data register contains three test data registers: the Bypass, the Boundary Scan register and Device ID register.

These registers are connected in parallel between a common serial input and a common serial data output.

The following sections provide a brief description of each element. For a complete description, refer to the IEEE Standard Test Access Port Specification (IEEE Std. 1149.1-1990).

### **TEST BYPASS REGISTER**

The register is used to allow test data to flow through the device from TDI to TDO. It contains a single stage shift register for a minimum length in serial path. When the bypass register is selected by an instruction, the shift register stage is set to a logic zero on the rising edge of TCLK when the TAP controller is in the Capture-DR state.

The operation of the bypass register should not have any effect on the operation of the device in response to the BYPASS instruction.

# THE BOUNDARY-SCAN REGISTER

The Boundary Scan Register allows serial data TDI be loaded in to or read out of the processor input/output ports. The Boundary Scan Register is a part of the IEEE 1149.1-1990 Standard JTAG Implementation.

# THE DEVICE IDENTIFICATION REGISTER

The Device Identification Register is a Read Only 32-bit register used to specify the manufacturer, part number and version of the processor to be determined through the TAP in response to the IDCODE instruction.

IDT JEDEC ID number is 0xB3. This translates to 0x33 when the parity is dropped in the 11-bit Manufacturer ID field.

For the IDT72P51767/72P51777, the Part Number field contains the following values:

| Device      | Part# Field (HEX) |
|-------------|-------------------|
| IDT72P51767 | 048f              |
| IDT72P51777 | 048e              |

| 31( | MSb) 2        | 8 27 | 12                 | 11 1                     | O(LSB) |
|-----|---------------|------|--------------------|--------------------------|--------|
| Ver | sion (4 bits) | Pa   | rt Number (16-bit) | Manufacturer ID (11-bit) |        |
| 0X0 | )             |      |                    | 0X33                     | 1      |

JTAG DEVICE IDENTIFICATION REGISTER

# **JTAG INSTRUCTION REGISTER**

The Instruction register allows instruction to be serially input into the device when the TAP controller is in the Shift-IR state. The instruction is decoded to perform the following:

- Select test data registers that may operate while the instruction is current. The other test data registers should not interfere with chip operation and the selected data register.
- Define the serial test data register path that is used to shift data between TDI and TDO during data register scanning.

The Instruction Register is a 4 bit field (i.e. IR3, IR2, IR1, IR0) to decode 16 different possible instructions. Instructions are decoded as follows.

| Hex   | Instruction    | Function                                 |
|-------|----------------|------------------------------------------|
| Value |                |                                          |
| 00    | EXTEST         | Select Boundary Scan Register            |
| 01    | SAMPLE/PRELOAD | Select Boundary Scan Register            |
| 02    | IDCODE         | Select Chip Identification data register |
| 03    | HIGH-IMPEDANCE | JTAG                                     |
| 0F    | BYPASS         | Select Bypass Register                   |

**JTAG INSTRUCTION REGISTER DECODING** 

The following sections provide a brief description of each instruction. For a complete description refer to the IEEE Standard Test Access Port Specification (IEEE Std. 1149.1-1990).

# **EXTEST**

The required EXTEST instruction places the IC into an external boundary-test mode and selects the boundary-scan register to be connected between TDI and TDO. During this instruction, the boundary-scan register is accessed to drive test data off-chip via the boundary outputs and receive test data off-chip via the boundary inputs. As such, the EXTEST instruction is the workhorse of IEEE. Std 1149.1, providing for probe-less testing of solder-joint opens/shorts and of logic cluster function.

# **IDCODE**

The optional IDCODE instruction allows the IC to remain in its functional mode and selects the optional device identification register to be connected between TDI and TDO. The device identification register is a 32-bit shift register containing information regarding the IC manufacturer, device type, and version code. Accessing the device identification register does not interfere with the operation of the IC. Also, access to the device identification register should be immediately available, via a TAP data-scan operation, after power-up of the IC or after the TAP has been reset using the optional  $\overline{\text{TRST}}$  pin or by otherwise moving to the Test-Logic-Reset state.

# SAMPLE/PRELOAD

The required SAMPLE/PRELOAD instruction allows the IC to remain in a normal functional mode and selects the boundary-scan register to be connected between TDI and TDO. During this instruction, the boundary-scan register can be accessed via a date scan operation, to take a sample of the functional data entering and leaving the IC. This instruction is also used to preload test data into the boundary-scan register before loading an EXTEST instruction.

# **HIGH-IMPEDANCE**

The optional High-Impedance instruction sets all outputs (including two-state as well as three-state types) of an IC to a disabled (high-impedance) state and selects the one-bit bypass register to be connected between TDI and TDO. During this instruction, data can be shifted through the bypass register from TDI to TDO without affecting the condition of the IC outputs.

# **BYPASS**

The required BYPASS instruction allows the IC to remain in a normal functional mode and selects the one-bit bypass register to be connected between TDI and TDO. The BYPASS instruction allows serial data to be transferred through the IC from TDI to TDO without affecting the operation of the IC.



Figure 65. Standard JTAG Timing

# SYSTEM INTERFACE PARAMETERS

| OTOTEM INTERNATIONAL TERM |                     |                 |                            |      |       |  |
|---------------------------|---------------------|-----------------|----------------------------|------|-------|--|
|                           |                     |                 | IDT72P51767<br>IDT72P51777 |      |       |  |
| Parameter                 | Symbol              | Test Conditions | Min.                       | Max. | Units |  |
| Data Output               | tDO <sup>(1)</sup>  |                 | -                          | 20   | ns    |  |
| Data Output Hold          | tDOH <sup>(1)</sup> |                 | 0                          | -    | ns    |  |
| Data Input                | tDS                 | trise=3ns       | 10                         | -    | ns    |  |
| ·                         | tDH                 | tfall=3ns       | 10                         | -    |       |  |

# NOTE:

1. 50pf loading on external output signals.

# JTAG AC ELECTRICAL CHARACTERISTICS

 $(VDD = 2.5V \pm 5\%; Tcase = 0^{\circ}C \text{ to } +85^{\circ}C)$ 

| Parameter               | Symbol   | Test<br>Conditions | IDT72P51767<br>IDT72P51777 |                  |       |
|-------------------------|----------|--------------------|----------------------------|------------------|-------|
|                         |          |                    | Min.                       | Max.             | Units |
| JTAG Clock Input Period | ttck     | -                  | 100                        | -                | ns    |
| JTAG Clock HIGH         | ttckhigh | -                  | 40                         | -                | ns    |
| JTAG Clock Low          | ttcklow  | -                  | 40                         | -                | ns    |
| JTAG Clock Rise Time    | ttckrise | -                  | 1                          | 5 <sup>(1)</sup> | ns    |
| JTAG Clock Fall Time    | ttckfall | -                  | -                          | 5 <sup>(1)</sup> | ns    |
| JTAG Reset              | trst     | -                  | 50                         | -                | ns    |
| JTAG Reset Recovery     | trsr     | -                  | 50                         | -                | ns    |

# NOTE:

1. Guaranteed by design.

# ORDERING INFORMATION



#### NOTES:

- 1. Industrial temperature range product for the 7-5ns is available as a standard device. All other speed grades available by special order.
- 2. Green parts are available. For specific speeds contact your local sales office.

# **DATASHEET DOCUMENT HISTORY**

01/18/2006 pgs. 1, 17, 19, 20, 30, and 31. 02/11/2009 pg. 88.



6024 Silver Creek Valley Road San Jose, CA 95138 for SALES:

800-345-7015 or 408-284-8200 fax: 408-284-2775 www.idt.com

for Tech Support: 408-360-1533 email: Flow-Controlhelp@idt.com