- Port Configurations:
  - **Twenty-Four 10-Mbit/s Ports**
  - Ports Arranged in Three Groups of Eight Ports in a Multiplexed Interface
  - Direct Multiplexer Interface to TNETE2008
  - Full and Half Duplex
  - Half-Duplex Collision-Based Flow Control
  - Full-Duplex IEEE Std 802.3x Flow Control
  - Interoperable Support for IEEE Std 802.1Q VLAN
  - Speed, Duplex, and Pause Autonegotiation With Physical Layer (PHY)

Three 10-/100-Mbit/s Ports

- Direct Interface to TNETE2101
- Full and Half Duplex
- Half-Duplex Collision-Based Flow Control
- Full-Duplex IEEE Std 802.3x Flow Control
- Interoperable Support for IEEE Std 802.1Q VLAN
- Pretagging Support
- Port Trunking and Load Sharing
- LED Indication of Port Status
- SDRAM Interface
  - Direct Interface to 8-Bit/Word and 16-Bit/Word, 16-Mbit, and 64-Mbit SDRAMs
  - 32-Bit-Wide Data Bus

- Up to 32 Mbytes Supported
- 83.33-MHz SDRAM Clock
- 12-ns (-12) SDRAMs Required
- Remote Monitoring (RMON) Support Groups 1, 2, 3, and 9
- Direct I/O (DIO) Management Interface
  - Eight Bits Wide
  - CPU Access to Statistics, Registers, and Management Information Bases (MIBs)
  - Internal Network Management Port
  - Forwards Spanning-Tree Packets to CPU
  - Serial Media-Independent Interface (MII) for PHY Control
- EEPROM Interface for Autoconfiguration (No CPU Required for Nonmanaged Switch)
- Internal Address-Lookup/Frame-Routing Engine
  - Interoperable Support for IEEE Std 802.1Q VLAN
  - Supports IEEE Std 802.1D Spanning Tree
  - Thirty-Two Assignable Virtual LANs (VLANs)
  - Multiple Forwarding Modes
  - 2K Total Addresses Supported
  - Port Mirroring
- IEEE Std 1149.1 (JTAG) Interface (3.3-V Signals)
- 2.5-V Process With 3.3-V-Drive I/O
- Packaged in 240-Terminal Plastic Quad Flatpack





Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.

TI and ThunderSWITCH are trademarks of Texas Instruments Incorporated.

Ethernet is a trademark of Xerox Corporation.

Secure Fast Switching is a trademark of Cabletron Systems, Inc.

Port-trunking and load-sharing algorithms were contributed by Cabletron Systems, Inc. and are derived from, and compatible with, Secure Fast Switching<sup>TM</sup>.

TEXAS INSTRUMENTS

SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### description

The TNETX3270 provides highly integrated switching solutions that allow network designers to lower overall system costs. Based on Texas Instruments (TI™) ThunderSWITCH™ architecture, the TNETX3270 design integrates 24 full-duplex 10-Mbit/s ports and 3 full-duplex 10-/100-Mbit/s ports, as well as an address-lookup engine, all in a single 240-pin package. All ports on the TNETX3270 are designed to support multiple addresses, cut-through or store-and-forward modes of operation, and VLAN. The 10-/100-Mbit/s ports have media-independent interface (MII)-compatible interfaces and can be configured to work as MII uplinks to high-speed switching fabrics. All three of the 10-/100-Mbit/s ports can be logically combined into a single high-performance uplink channel that can be used to provide up to 600-Mbit/s switch-to-switch connections.

The TNETX3270 incorporates an internal content-addressable memory (CAM) capable of supporting 2,048 end stations from a single switch. In addition, the device supports 32 user-configurable VLAN-broadcast domains (IEEE Std 802.1Q), which allows IEEE Std 802.1P priority support interoperability, IEEE Std 802.3X full-duplex flow control, and a collision-based flow-control scheme. The TNETX3270 also integrates an EEPROM interface that allows the device to be initialized and configured without the added expense of a CPU. All of these features on chip greatly reduce the number of external components required to build a switch.

The internal address-lookup engine (IALE) supports up to 2K unicast/multicast and broadcast addresses and up to 32 IEEE Std 802.1Q VLANs. For interoperability, each port can be programmed as an access port or non-access port to recognize VLAN tags and transmit frames with VLAN tags to other systems that support VLAN tagging. The IALE performs destination- and source-address comparisons and forwards unknown source- and destination-address packets to ports specified via programmable masks.

Download from Www.Somanuals.com. All Manuals Search And Download.

## **TNETX3270** ThunderSWITCHTM 24/3 ETHERNETTM SWITCH WITH 24 10-MBIT/S PORTS AND 3 10-/100-MBIT/S PORTS SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Conte                                                                                                   | ents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description PGV Package Terminal Layout TNETX3270 Interface Block Diagram Terminal Functions DIO Register Groups Interface Description  DIO Interface Receiving/Transmitting Management Frames State of DIO Signals During Hardware Reset Network Management Port MII Serial Management Interface (PHY Management) 10-Mbit/s and 10-/100-Mbit/s MAC Interface Receive Control Giant (Long) Frames Short Frames Receive Filtering of Frames Data Transmission Transmit Control Adaptive Performance Optimization (APO) (Transmit Pacing) Interframe Gap Enforcement Backoff Receive Versus Transmit Priority Uplink Pretagging EEPROM Interface Interaction of EEPROM Load With the SIO Register Summary of EEPROM Load Outcomes Compatibility With Future Device Revisions JTAG Interface HIGHZ instruction LED Interface Lamp Test | . 2 . 4 . 5 . 6 13 18 18 18 18 19 22 22 22 22 22 23 23 23 23 23 23 23 24 24 27 28 28 28 29 29 29 30   1 | SDRAM Interface       36         SDRAM-Type and Quantity Indication       38         Initialization       38         Refresh       38         Frame Routing       39         VLAN Support       39         IEEE Std 802.1Q Headers – Reception       40         IEEE Std 802.1Q Headers – Transmission       40         Address Maintenance       40         Spanning-Tree Support       41         Aging Algorithms       41         Frame-Routing Determination       41         Port Mirroring       44         Port Trunking/Load Sharing       45         Flow Control       45         Collision-Based Flow Control       46         IEEE Std 802.3 Flow Control       46         Internal Wrap Test       48         Duplex Wrap Test       49         Port Mirroring       50         Copy to Uplink       50         Absolute Maximum Ratings       51         Recommended Operating Conditions       51         Electrical Characteristics       51         Parameter Measurement Information       52         Test Measurement       52         10-/100-Mbit/s MAC Interface       54         SDRAM |
| Lamp Test                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 30 I                                                                                                    | EEPROM Interface 61                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Multi-LED Display  Hardware Configurations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                         | LED Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 10-Mbit/s MAC Interfaces (Ports 00–23) 10-/100-Mbit/s MAC Interfaces (Ports 24–26) 10-/100-Mbit/s Port Configuration 10-/100-Mbit/s Port Configuration in a Nonmanaged Switch 10-/100-Mbit/s Port Configuration in a Managed Switch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 30 I<br>34<br>34<br>35                                                                                  | Mechanical Data64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



3

SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999







## **PRODUCT PREVIEW**

#### **Terminal Functions**

## 10-Mbit/s MAC multiplexed interface (ports 00–23) is multiplexed into three groups (TH0, TH1, and TH2) of eight ports $\mbox{}^{\dagger}$

| TERMINA                                                                                                   |                                                                        | 1/0 | INTERNAL<br>RESISTOR‡ | DESCRIPTION                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-----|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME                                                                                                      | NO.                                                                    |     | RESISTOR+             |                                                                                                                                                                                                                                                                                                                                       |
| TH0CLK<br>TH1CLK<br>TH2CLK                                                                                | 222<br>2<br>23                                                         | I   | Pullup                | Interface clock. Eight ports are supported on each interface and use this common 20-MHz clock.                                                                                                                                                                                                                                        |
| TH0COL<br>TH1COL<br>TH2COL                                                                                | 223<br>3<br>24                                                         | I   | Pulldown              | Interface collision sense. Assertion of THxCOL <sup>†</sup> during half-duplex operation indicates network collision on the current port. Additionally, during full-duplex operation, transmission of new frames does not start if this terminal is asserted.                                                                         |
| TH0CRS<br>TH1CRS<br>TH2CRS                                                                                | 224<br>5<br>25                                                         | I   | Pulldown              | Interface carrier sense. THxCRS <sup>†</sup> indicates a frame carrier signal is being received on a current port.                                                                                                                                                                                                                    |
| THOLINK<br>TH1LINK<br>TH2LINK                                                                             | 232<br>13<br>32                                                        | I   | Pulldown              | Interface link presence. THxLINK <sup>†</sup> indicates the presence of the connection on a port.  - Low = no link  - High = link good                                                                                                                                                                                                |
| THORENEG<br>TH1RENEG<br>TH2RENEG                                                                          | 213<br>233<br>15                                                       | 0   | None                  | Interface renegotiate. A 1-0-1 sequence output on THxRENEG causes flow control and half/full duplex for a port to be renegotiated with its companion physical-layer (PHY) device. These THxRENEG terminals connect to IFFORCEHD on TNETE2008.                                                                                         |
| THORXD3 THORXD2 THORXD1 THORXD0  TH1RXD3 TH1RXD2 TH1RXD1 TH1RXD0  TH2RXD3 TH2RXD3 TH2RXD1 TH2RXD1 TH2RXD1 | 231<br>230<br>228<br>227<br>11<br>10<br>9<br>7<br>30<br>29<br>28<br>27 | I   | Pullup                | Interface receive data. The receive data nibble from the current port is synchronous to THxCLK. When the THxRXDV signal is 1, the receive data terminals contain valid information. THxRXD0 is the least significant bit and THxRXD3 is the most significant bit. These signals also are used to report the channel state to the MAC. |
| TH0TXEN<br>TH1TXEN<br>TH2TXEN                                                                             | 219<br>240<br>21                                                       | 0   | None                  | Interface transmit enable. THxTXEN indicates valid transmit data on THxTXD.                                                                                                                                                                                                                                                           |
| TH0SYNC<br>TH1SYNC<br>TH2SYNC                                                                             | 221<br>1<br>22                                                         | I   | Pullup                | Interface synchronize. THxSYNC is used to synchronize the port traffic between the media-access controller (MAC) and PHY. When THxSYNC is a 1, the current MAC-to-PHY path is the multiplexer interface TH0, and the PHY-to-MAC path is the multiplexer interface TH2. THxSYNC is sampled by the MAC on the falling edge of THxCLK.   |

<sup>†</sup>THx = TH0, TH1, and TH2



<sup>‡</sup> Internal resistors are provided to pull signals to known values. System designers should determine if additional pullups or pulldowns are required in their system.

#### **Terminal Functions (Continued)**

## 10-Mbit/s MAC multiplexed interface (ports 00–23) is multiplexed into three groups (TH0, TH1, and TH2) of eight ports $^{\dagger}$ (continued)

| TERMINA                                                                                           | AL                                                               | 1/0 | INTERNAL | DESCRIPTION                                                                                                                                                                                                                                                                                                                                           |
|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME                                                                                              | NO.                                                              | .,, | RESISTOR | DESCRIPTION                                                                                                                                                                                                                                                                                                                                           |
| TH0TXD3 TH0TXD2 TH0TXD1 TH0TXD0  TH1TXD3 TH1TXD2 TH1TXD1 TH1TXD0  TH2TXD3 TH2TXD3 TH2TXD2 TH2TXD1 | 218<br>217<br>216<br>215<br>239<br>237<br>236<br>234<br>20<br>19 | 0   | None     | Interface transmit data. The transmit data nibble for the current port is synchronous to THxCLK. When THxTXEN is asserted, these signals carry data. THxTXD3–THxTXD0 are used during renegotiation to convey flow-control and duplex configuration requests to the PHY. THxTXD0 is the least significant bit and THxTXD3 is the most significant bit. |
| TH2TXD0                                                                                           | 16                                                               |     |          |                                                                                                                                                                                                                                                                                                                                                       |
| TH0RXDV<br>TH1RXDV<br>TH2RXDV                                                                     | 226<br>6<br>26                                                   | I   | Pulldown | Interface receive data valid. When THxRXDV is a 1, it indicates that the THxRXD lines contain valid data.                                                                                                                                                                                                                                             |

THx = TH0, TH1, and TH2

#### 10-/100-Mbit/s MAC interface (ports 24-26)‡

| TERMINAL<br>NAME                       | NO.             | I/O              | INTERNAL<br>RESISTOR | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------|-----------------|------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| M24COL<br>M25COL<br>M26COL             | 42<br>65<br>90  | I                | Pulldown             | Collision sense. Assertion of MxxCOL in half-duplex signal indicates a network collision on that port. In full-duplex operation, transmission of new frames does not start if this terminal is asserted.                                                                                                                                                                        |
| M24CRS<br>M25CRS<br>M26CRS             | 43<br>66<br>92  | I                | Pulldown             | Carrier sense. MxxCRS indicates a frame carrier signal is being received.                                                                                                                                                                                                                                                                                                       |
|                                        |                 |                  |                      | Speed selection (force 10 Mbit/s is active low)                                                                                                                                                                                                                                                                                                                                 |
| M24FORCE10<br>M25FORCE10<br>M26FORCE10 | 54<br>80<br>104 | I/O§             | Pullup               | <ul> <li>If pulled low by either the TNETX3270 or a PHY, the port operates at 10 Mbit/s.</li> <li>If not pulled low by either the TNETX3270 or a PHY, the internal pullup resistor holds this signal high and the port operates at 100 Mbit/s. An external 4.7-kΩ pullup resistor connected to V<sub>DD(3.3V)</sub> may be required, depending on the system layout.</li> </ul> |
| M24LINK                                | 52              |                  |                      | Connection status. MxxLINK indicates the presence of a port connection.                                                                                                                                                                                                                                                                                                         |
| M25LINK<br>M26LINK                     | 78<br>102       | I                | Pulldown             | <ul><li>If MxxLINK = 0, there is no link.</li><li>If MxxLINK = 1, the link is good.</li></ul>                                                                                                                                                                                                                                                                                   |
|                                        |                 |                  |                      | Duplex selection (force half duplex is active low)                                                                                                                                                                                                                                                                                                                              |
| M24FORCEHD<br>M25FORCEHD<br>M26FORCEHD | 53<br>79<br>103 | I/O <sup>‡</sup> | Pullup               | – If pulled low by either the TNETX3270 or the PHY, the port operates at half duplex. – If not pulled low by either the TNETX3270 or the PHY, the internal pullup resistor holds this signal high and the port operates at full duplex. An external 4.7-k $\Omega$ pullup resistor connected to $V_{DD(3.3V)}$ may be required, depending on the system layout.                 |
| M24RCLK<br>M25RCLK<br>M26RCLK          | 44<br>67<br>93  | I                | Pullup               | Receive clock. Receive clock source from the attached PHY or PMI device.                                                                                                                                                                                                                                                                                                        |

 $<sup>\</sup>frac{1}{2}$  xx = ports 24, 25, and 26

<sup>§</sup> Not a true bidirectional terminal. It can only be actively pulled down (open drain).



#### 10-/100-Mbit/s MAC interface (ports 24-26) (continued)<sup>†</sup>

| TERMINAL                                 |                      | I/O INTERNAL | DESCRIPTION |                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------|----------------------|--------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME                                     | NO.                  |              | RESISTOR    |                                                                                                                                                                                                                                                                                                                                         |
| M24RXD3<br>M24RXD2<br>M24RXD1<br>M24RXD0 | 49<br>48<br>47<br>46 |              |             |                                                                                                                                                                                                                                                                                                                                         |
| M25RXD3<br>M25RXD2<br>M25RXD1<br>M25RXD0 | 73<br>71<br>70<br>69 | 1            | Pullup      | Receive data (nibble receive data from the attached PHY or PMI device). Data on these signals is synchronous to MxxRCLK. MxxRXD0 is the least significant bit and MxxRXD3 is the most significant bit.                                                                                                                                  |
| M26RXD3<br>M26RXD2<br>M26RXD1<br>M26RXD0 | 98<br>97<br>96<br>95 |              |             |                                                                                                                                                                                                                                                                                                                                         |
| M24RXDV<br>M25RXDV<br>M26RXDV            | 50<br>75<br>99       | I            | Pulldown    | Receive data valid. When high, MxxRXDV indicates valid data is present on the MxxRXD3–MxxRXD0 lines.                                                                                                                                                                                                                                    |
| M24RXER<br>M25RXER<br>M26RXER            | 51<br>76<br>101      | _            | Pulldown    | Receive error. MxxRXER indicates a coding error on received data.                                                                                                                                                                                                                                                                       |
| M24TCLK<br>M25TCLK<br>M26TCLK            | 33<br>56<br>82       | Ι            | Pullup      | Transmit clock. Transmit clock source from the attached PHY or PMI device.                                                                                                                                                                                                                                                              |
| M24TXD3<br>M24TXD2<br>M24TXD1<br>M24TXD0 | 38<br>37<br>36<br>35 |              |             |                                                                                                                                                                                                                                                                                                                                         |
| M25TXD3<br>M25TXD2<br>M25TXD1<br>M25TXD0 | 61<br>60<br>59<br>57 | 0            | None        | Transmit data (nibble transmit data). When MxxTXEN is asserted, these signals carry transmit data. Data on these signals is synchronous to MxxTCLK. MxxTXD0 is the least significant bit and MxxTXD3 is the most significant bit.                                                                                                       |
| M26TXD3<br>M26TXD2<br>M26TXD1<br>M26TXD0 | 86<br>85<br>84<br>83 |              |             |                                                                                                                                                                                                                                                                                                                                         |
| M24TXEN<br>M25TXEN<br>M26TXEN            | 39<br>62<br>87       | 0            | None        | Transmit enable. MxxTXEN indicates valid transmit data on MxxTXD3–MxxTXD0.                                                                                                                                                                                                                                                              |
| M24TXER<br>M25TXER<br>M26TXER            | 41<br>63<br>89       | 0            | None        | Transmit error. MxxTXER allows coding errors to be propagated across the MII. MxxTXER is taken high when an under-run in the transmit FIFO for port xx occurs and causes fill data to be transmitted (MxxTXER is low otherwise). MxxTXER is asserted at the end of an under-running frame, enabling the device to force a coding error. |

tar = 0.05 ports 24, 25, and 26



#### **SDRAM** interface

| JERMI                                                                                                                                                                |                                                                                                                                                                                                                              |     |                      |                                                                                                                                                                                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME                                                                                                                                                                 | NO.                                                                                                                                                                                                                          | 1/0 | INTERNAL<br>RESISTOR | DESCRIPTION                                                                                                                                                                                                                                                                  |
| DA13<br>DA12<br>DA11<br>DA10<br>DA09<br>DA08<br>DA07<br>DA06<br>DA05<br>DA04<br>DA03<br>DA02<br>DA01<br>DA00                                                         | 212<br>210<br>209<br>207<br>206<br>205<br>204<br>203<br>202<br>200<br>199<br>198<br>196<br>195                                                                                                                               | 0   | None                 | SDRAM address bus (time-multiplexed bank, row, and column address). The address bus DA13–DA00 also provides the SDRAM mode register initialization value. DA13 is the most significant bit and DA00 is the least significant bit.                                            |
| DCAS                                                                                                                                                                 | 189                                                                                                                                                                                                                          | 0   | None                 | SDRAM column address strobe. DCAS, in conjunction with DRAS and DW, determines the SDRAM commands.                                                                                                                                                                           |
| DCLK                                                                                                                                                                 | 193                                                                                                                                                                                                                          | 0   | None                 | SDRAM clock (83.33-MHz clock to the SDRAMs). SDRAM commands, addresses, and data are sampled by the SDRAM on the rising edge of this clock.                                                                                                                                  |
| DD31 DD30 DD29 DD28 DD27 DD26 DD25 DD24 DD23 DD22 DD21 DD20 DD19 DD18 DD17 DD16 DD15 DD14 DD13 DD12 DD11 DD10 DD09 DD08 DD07 DD06 DD05 DD04 DD03 DD02 DD01 DD00 DD01 | 187<br>186<br>185<br>183<br>182<br>181<br>180<br>179<br>177<br>176<br>174<br>173<br>172<br>171<br>170<br>168<br>167<br>166<br>164<br>162<br>161<br>159<br>158<br>157<br>156<br>155<br>153<br>152<br>150<br>149<br>147<br>146 | I/O | Pullup               | SDRAM data bus (bidirectional bus used to carry SDRAM data). DD31–DD00 also output status information to indicate buffer operation type and port number. Internal pullup resistors are provided. DD31 is the most significant bit and the DD00 is the least significant bit. |
| DRAS                                                                                                                                                                 | 190                                                                                                                                                                                                                          | 0   | None                 | SDRAM row address strobe. DRAS, with DCAS and DW, supplies the SDRAM commands.                                                                                                                                                                                               |
| DW                                                                                                                                                                   | 191                                                                                                                                                                                                                          | 0   | None                 | SDRAM write select. DW, with DRAS and DCAS, supplies the SDRAM commands.                                                                                                                                                                                                     |



#### host DIO interface

| TERMIN<br>NAME                                                               | IAL<br>NO.                                           | 1/0 | INTERNAL<br>RESISTOR | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------------------------------------------------------------|------------------------------------------------------|-----|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SAD1<br>SAD0                                                                 | 143<br>142                                           | ı   | Pullup               | DIO address bus. SAD1 and SAD0 select the internal host registers, when SDMA is high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SCS                                                                          | 138                                                  | ı   | Pullup               | DIO chip select. When low, SCS indicates a DIO port access is valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| SDMA                                                                         | 123                                                  | I   | Pullup               | DIO DMA select. When low, SDMA modifies the behavior of the DIO interface to allow it to operate with an external DMA controller. The SAD0 and SAD1 terminals are not used to select the internal host register for the access. Instead, the DIO address to access is provided by the DMA address register, and one of two host register addresses is selected according to DMAinc in the Syscontrol register.  — If DMAinc = 1, accesses are the DIOdatainc register and DMAaddress increments after each access.  — If DMAinc = 0, accesses are the DIOdata register, and DMAaddress does not increment after each address. |
| SDATA7<br>SDATA6<br>SDATA5<br>SDATA4<br>SDATA3<br>SDATA2<br>SDATA1<br>SDATA0 | 136<br>135<br>133<br>131<br>130<br>129<br>127<br>126 | I/O | Pullup               | DIO data interface bus (byte-wide bidirectional DIO port). SDATA7 is the most significant bit and SDATA0 is the least significant bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| SINT                                                                         | 140                                                  | 0   | None                 | DIO interrupt line (interrupt to the attached microprocessor). The interrupt originating event is stored in the Int register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| SRDY                                                                         | 139                                                  | 0   | Pullup               | DIO ready signal  - When low during reads, SRDY indicates to the host when data is valid to be read.  - When low during writes, SRDY indicates when data has been received after SCS is taken high. SRDY is driven high for one clock cycle before placing the output in high impedance.                                                                                                                                                                                                                                                                                                                                      |
| SRNW                                                                         | 125                                                  | Ι   | Pullup               | DIO read not write  - When high, read operation is selected.  - When low, write operation is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| SRXRDY                                                                       | 145                                                  | 0   | None                 | Network management port, receive ready. When high, SRXRDY indicates that the network management port's RX buffers are empty and the network management port is able to receive a frame.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| STXRDY                                                                       | 144                                                  | 0   | None                 | Network management port, transmit ready. STXRDY indicates that at least one frame buffer is available to be read by the management CPU.  — It outputs as a 1 if any of the end-of-frame (EOF) bits, start-of-frame (SOF) bits, or one of the bits in NMTxcontrol is set to 1.  — Otherwise, it outputs 0.                                                                                                                                                                                                                                                                                                                     |

#### serial MII management PHY interface

| TERMIN | IAL | 1/0      | INTERNAL | DESCRIPTION                                                                                                                                                                                                              |  |  |  |
|--------|-----|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| NAME   | NO. | 1/0      | RESISTOR | DESCRIPTION                                                                                                                                                                                                              |  |  |  |
| MDCLK  | 121 | O/High Z | Pullup   | Serial MII management data clock. MDCLK can be disabled (high impedance) through the use of the SIO register.                                                                                                            |  |  |  |
| MDIO   | 120 | I/O      | Pullup   | Serial MII management data I/O. MDIO can be disabled, placed in high Z, through the SIO register. An external 4.7-k $\Omega$ pullup resistor, conected to $V_{DD(3.3V)}$ , is needed to meet the rise-time requirements. |  |  |  |
| MRESET | 119 | O/High Z | Pullup   | Serial MII management reset. MRESET can be disabled (high impedance) through the use of the SIO register. If connected to a PHY device, an external pullup resistor is recommended.                                      |  |  |  |

#### **EEPROM** interface

| TERMI<br>NAME | NAL<br>NO. | I/O | INTERNAL<br>RESISTOR | DESCRIPTION                                                                                                                                                                                                                                 |
|---------------|------------|-----|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME          | NO.        |     | KEOIOTOK             | ··                                                                                                                                                                                                                                          |
| ECLK          | 117        | 0   | None                 | EEPROM data clock.                                                                                                                                                                                                                          |
| EDIO          | 116        | I/O | Pullup               | EEPROM data I/O. An external pulldown resistor may be required for proper operation. Since this terminal has an internal pullup, it can be left unconnected if no EEPROM is present. The EEPROM is optional if a management CPU is present. |

#### **LED** interface

| TERMIN  | AL  | 1/0 | INTERNAL | DESCRIPTION                                                                                                                                                                                   |
|---------|-----|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME    | NO. | 1/0 | RESISTOR | DESCRIPTION                                                                                                                                                                                   |
| LEDCLK  | 113 | 0   | None     | LED clock (serial shift clock for the LED status data)                                                                                                                                        |
| LEDDATA | 114 | 0   | None     | LED data (serial LED status data). LEDDATA is active low. All LED information (port link, activity status, software status, flow status, and fault status) is sent via this serial interface. |

#### JTAG interface

| TERMI | NAL | 1/0 | INTERNAL | DESCRIPTION                                                                                                                                                                                                                                                                                       |
|-------|-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME  | NO. | 1/0 | RESISTOR | DESCRIPTION                                                                                                                                                                                                                                                                                       |
| TCLK  | 106 | -   | Pullup   | Test clock. TCLK is used to clock state information, test instructions, and test data into and out of the device during operation of the test port.                                                                                                                                               |
| TDI   | 110 | _   | Pullup   | Test data input. TDI is used to serially shift test data and test instructions into the device during operation of the test port. An internal pullup resistor is provided on TDI to ensure JTAG compliance.                                                                                       |
| TDO   | 108 | 0   | None     | Test data output. TDO is used to serially shift test data and test instructions out of the device during operation of the test port.                                                                                                                                                              |
| TRST  | 111 | _   | Pullup   | Test reset. $\overline{\text{TRST}}$ is used for asynchronous reset of the test-port controller. An internal pullup resistor is provided to ensure JTAG compliance. If the test port is not used, an external pulldown resistor of 10 k $\Omega$ may be used to disable the test-port controller. |
| TMS   | 107 | _   | Pullup   | Test mode select. TMS is used to control the state of the test-port controller. An internal pullup resistor is provided on TMS to ensure JTAG compliance.                                                                                                                                         |



## **TNETX3270** ThunderSWITCH™ 24/3 ETHERNET™ SWITCH WITH 24 10-MBIT/S PORTS AND 3 10-/100-MBIT/S PORTS SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### **Terminal Functions (Continued)**

#### miscellaneous

| TERMI | NAL | 1/0 | INTERNAL | DESCRIPTION                                                                                    |
|-------|-----|-----|----------|------------------------------------------------------------------------------------------------|
| NAME  | NO. | "0  | RESISTOR | DESCRIPTION                                                                                    |
| OSCIN | 112 | Ι   | None     | Master system clock input (83.33-MHz input clock)                                              |
| RESET | 115 | Ι   | None     | Reset. RESET is synchronous and, therefore, the system clock must be operational during reset. |

#### power interface

| TERMINAL<br>NAME NO.   |                                                                                                                  | INTERNAL<br>RESISTOR | DESCRIPTION                                                                           |
|------------------------|------------------------------------------------------------------------------------------------------------------|----------------------|---------------------------------------------------------------------------------------|
| GND                    | 8, 14, 34, 40, 55, 68, 74, 81, 88, 94, 100, 128, 134, 141, 148, 154, 160, 175, 188, 194, 201, 208, 214, 220, 235 | None                 | Ground. GND is the 0-V reference for the device. All GND terminals must be connected. |
| V <sub>DD</sub> (3.3V) | 12, 72, 109, 122, 132, 163, 169, 192, 229                                                                        | None                 | 3.3-V supply voltage. Power for the input, output, and I/O terminals.                 |
| V <sub>DD(2.5V)</sub>  | 4, 17, 31, 45, 58, 64, 77, 91,<br>105, 118, 124, 137, 151, 165, 178,<br>184, 197, 211, 225, 238                  | None                 | 2.5-V supply voltage. Power for the core.                                             |

#### summary of signal terminals by signal group function

| PORT DESCRIPTION       | NUMBER OF<br>SIGNALS | MULTIPLIER | TOTAL |  |
|------------------------|----------------------|------------|-------|--|
| LED                    | 2                    | 1          | 2     |  |
| 10-Mbit/s port         | 16                   | 3          | 48    |  |
| 10-/100-Mbit/s port    | 19                   | 3          | 57    |  |
| DIO                    | 17                   | 1          | 17    |  |
| EEPROM interface       | 2                    | 1          | 2     |  |
| DRAM interface         | 50                   | 1          | 50    |  |
| Miscellaneous          | 2                    | 1          | 2     |  |
| JTAG                   | 5                    | 1          | 5     |  |
| Serial MII management  | 3                    | 1          | 3     |  |
| Total signals          | 186                  |            |       |  |
|                        | SUMMARY              |            |       |  |
| Assigned terminals     |                      |            | 186   |  |
| V <sub>DD</sub> (3.3V) |                      |            |       |  |
| V <sub>DD</sub> (2.5V) |                      |            |       |  |
| GND                    |                      |            |       |  |
| Total terminals        |                      |            | 240   |  |

### **DIO** register groups

**Table 1. Internal Register and Statistics Memory Map** 

| REGISTERS             | LOADABLE<br>USING 24C02<br>EEPROM? | LOADABLE<br>USING 24C08<br>EEPROM? | DIO<br>ADDRESS<br>RANGE |
|-----------------------|------------------------------------|------------------------------------|-------------------------|
| Port configuration    | Yes                                | Yes                                | 0x0000:0x002F           |
| Spanning tree         | Yes                                | Yes                                | 0x0030:0x007F           |
| Trunking              | Yes                                | Yes                                | 0x0080:0x0088           |
| VLAN                  | No                                 | Yes                                | 0x0089:0x03FF           |
| Port status           | No                                 | No                                 | 0x0400:0x043F           |
| Address configuration | No                                 | No                                 | 0x0440:0x08FF           |
| Port statistics       | No                                 | No                                 | 0x0900:0xFFFF           |

## **TNETX3270** ThunderSWITCH™ 24/3 ETHERNET™ SWITCH WITH 24 10-MBIT/S PORTS AND 3 10-/100-MBIT/S PORTS SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### Table 2. Detailed DIO Register Map

| BYTE 3       | BYTE 2            | BYTE 1        | BYTE 0        | DIO<br>ADDRESS |
|--------------|-------------------|---------------|---------------|----------------|
| Port1control |                   | Port0c        | ontrol        | 0x0000         |
| Port3d       | control           | Port2control  |               | 0x0004         |
| Port5c       | control           | Port4c        | ontrol        | 0x0008         |
| Port7d       | control           | Port6c        | ontrol        | 0x000C         |
| Port9d       | control           | Port8c        | ontrol        | 0x0010         |
| Port110      | control           | Port10        | control       | 0x0014         |
| Port13       | control           | Port12d       | control       | 0x0018         |
| Port15       | control           | Port14        | control       | 0x001C         |
| Port17       | control           | Port16        | control       | 0x0020         |
| Port19       | control           | Port18d       | control       | 0x0024         |
| Port21       | control           | Port20        | control       | 0x0028         |
| Port23       | control           | Port22d       | control       | 0x002C         |
| Port25       | control           | Port24        | control       | 0x0030         |
| Rese         | rved              | Port26        | control       | 0x0034         |
| Rese         | rved              | Rese          | rved          | 0x0038:0x003F  |
| Reserved     | UnkVLANport       | Mirrorport    | Uplinkport    | 0x0040         |
| Rese         | rved              | Aging th      | reshold       | 0x0044         |
|              | Rese              | erved         | 0x0048:0x004F |                |
|              | Nlearr            | ports         |               | 0x0050         |
| Txblockports |                   |               |               | 0x0054         |
|              | Rxuniblockports   |               |               |                |
|              | Rxmultiblockports |               |               | 0x005C         |
|              | Unkur             | niports       |               | 0x0060         |
|              | Unkmu             | Itiports      |               | 0x0064         |
|              | Unksr             | cports        |               | 0x0068         |
|              | UnkVLA            | Vintports     |               | 0x006C         |
|              | Rese              | erved         |               | 0x0070:0x007F  |
| Trunkmap3    | Trunkmap2         | Trunkmap1     | Trunkmap0     | 0x0080         |
| Trunkmap7    | Trunkmap6         | Trunkmap5     | Trunkmap4     | 0x0084         |
|              | Reserved          |               | Trunkports    | 0x0088         |
|              | Rese              | erved         |               | 0x008C:0x009F  |
| Devcode      | Reserved          | SIO Revision  |               | 0x00A0         |
|              | Rese              | erved         |               | 0x00A4:0x00DF  |
| RAMsize      | Reserved          | IOBcontrol    |               | 0x00E0         |
|              | Rese              | erved         |               | 0x00E4         |
| Pauseti      | me100             | Pausetime10   |               | 0x00E8         |
|              | Rese              | erved         |               | 0x00EC         |
| Reserved     |                   | Flowthreshold |               | 0x00F0         |
| Rese         | erved             | LEDcontrol    |               | 0x00F4         |
| Sysco        | ontrol            | Stated        | ontrol        | 0x00F8         |

#### Table 2. Detailed DIO Register Map (Continued)

| BYTE 3 | BYTE 2            | BYTE 1     | BYTE 0 | DIO<br>ADDRESS |  |  |
|--------|-------------------|------------|--------|----------------|--|--|
|        | Reserved (for E   | EPROM CRC) |        | 0x00FC         |  |  |
|        | 0x0100            |            |        |                |  |  |
|        | VLAN1ports        |            |        |                |  |  |
|        | VLAN              | 2ports     |        | 0x0108         |  |  |
|        | VLAN:             | 3ports     |        | 0x010C         |  |  |
|        | VLAN-             | 4ports     |        | 0x0110         |  |  |
|        | VLAN              | 5ports     |        | 0x0114         |  |  |
|        | VLAN              | 6ports     |        | 0x0118         |  |  |
|        | VLAN <sup>-</sup> | 7ports     |        | 0x011C         |  |  |
|        | VLAN              | 8ports     |        | 0x0120         |  |  |
|        | VLAN              | 9ports     |        | 0x0124         |  |  |
|        | VLAN1             | 0ports     |        | 0x0128         |  |  |
|        | VLAN1             | 1ports     |        | 0x012C         |  |  |
|        | VLAN1             | 2ports     |        | 0x0130         |  |  |
|        | VLAN1             | 3ports     |        | 0x0134         |  |  |
|        | VLAN1             | 4ports     |        | 0x0138         |  |  |
|        | VLAN1             | 5ports     |        | 0x013C         |  |  |
|        | VLAN1             | 6ports     |        | 0x0140         |  |  |
|        | VLAN1             | •          |        | 0x0144         |  |  |
|        | 0x0148            |            |        |                |  |  |
|        | 0x014C            |            |        |                |  |  |
|        | 0x0150            |            |        |                |  |  |
|        | 0x0154            |            |        |                |  |  |
|        | 0x0158            |            |        |                |  |  |
|        | 0x015C            |            |        |                |  |  |
|        | VLAN2<br>VLAN2    | ·          |        | 0x0160         |  |  |
|        | VLAN2             |            |        | 0x0164         |  |  |
|        | VLAN2             | •          |        | 0x0168         |  |  |
|        | VLAN2             | <u> </u>   |        | 0x016C         |  |  |
|        | VLAN2             |            |        | 0x0170         |  |  |
|        | VLAN2             | ·          |        | 0x0174         |  |  |
|        | VLAN3             |            |        | 0x0178         |  |  |
|        | VLAN3             | ·          |        | 0x017C         |  |  |
|        | Rese              | ·          |        | 0x0180:0x02FF  |  |  |
| VLAN   |                   | VLAN       | 0QID   | 0x0300         |  |  |
| VLAN   |                   | VLAN       |        | 0x0304         |  |  |
| VLAN   |                   | VLAN       |        | 0x0308         |  |  |
| VLAN   |                   | VLAN       |        | 0x030C         |  |  |
| VLAN   |                   | VLAN       |        | 0x0310         |  |  |
| VLAN1  |                   | VLAN1      |        | 0x0314         |  |  |
| VLAN1  |                   | VLAN1      |        | 0x0318         |  |  |
|        | 15QID             | VLAN1      |        | 0x031C         |  |  |

## **TNETX3270** ThunderSWITCH™ 24/3 ETHERNET™ SWITCH WITH 24 10-MBIT/S PORTS AND 3 10-/100-MBIT/S PORTS SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### Table 2. Detailed DIO Register Map (Continued)

| BYTE 3       | BYTE 2       | BYTE 1       | BYTE 0       | DIO<br>ADDRESS |
|--------------|--------------|--------------|--------------|----------------|
| VLAN17QID    |              | VLAN16QID    |              | 0x0320         |
| VLAN19QID    |              | VLAN18QID    |              | 0x0324         |
| VLAN21QID    |              | VLAN2        | 20QID        | 0x0328         |
| VLAN2        | 3QID         | VLAN2        | 2QID         | 0x032C         |
| VLAN2        | 5QID         | VLAN2        | 4QID         | 0x0330         |
| VLAN2        | 7QID         | VLAN2        | 6QID         | 0x0334         |
| VLAN2        | 9QID         | VLAN2        | 8QID         | 0x0338         |
| VLAN3        | 1QID         | VLAN3        | 80QID        | 0x033C         |
|              | Rese         | rved         |              | 0x0340:0x037F  |
| Port10       | Qtag         | Port00       | Qtag         | 0x0380         |
| Port30       | Qtag         | Port20       | Qtag         | 0x0384         |
| Port50       | Qtag         | Port40       | Qtag         | 0x0388         |
| Port70       | Qtag         | Port60       | Qtag         | 0x038C         |
| Port90       | Qtag         | Port80       | Qtag         | 0x0390         |
| Port11       | Qtag         | Port10       | Qtag         | 0x0394         |
| Port13       | Qtag         | Port12       | :Qtag        | 0x0398         |
| Port15       | Qtag         | Port14       | Qtag         | 0x039C         |
| Port17       | 'Qtag        | Port16Qtag   |              | 0x03A0         |
| Port19       | Qtag         | Port18Qtag   |              | 0x03A4         |
| Port21       | Qtag         | Port20Qtag   |              | 0x03A8         |
| Port23       | Qtag         | Port22       | :Qtag        | 0x03AC         |
| Port25       | Qtag         | Port24Qtag   |              | 0x03B0         |
| Rese         | rved         | Port26Qtag   |              | 0x03B4         |
|              | Rese         | rved         |              | 0x03B8:0x03FF  |
| Port1s       | tatus        | Port0s       | tatus        | 0x0400         |
| Port3s       | tatus        | Port2s       | tatus        | 0x0404         |
| Port5s       | tatus        | Port4s       | tatus        | 0x0408         |
| Port7s       | tatus        | Port6status  |              | 0x040C         |
| Port9s       | tatus        | Port8status  |              | 0x0410         |
| Port11s      | status       | Port10status |              | 0x0414         |
| Port13s      | status       | Port12status |              | 0x0418         |
| Port15s      | status       | Port14status |              | 0x041C         |
| Port17s      | status       | Port16status |              | 0x0420         |
| Port19status |              | Port18status |              | 0x0424         |
| Port21status |              | Port20status |              | 0x0428         |
| Port23s      | Port23status |              | Port22status |                |
| Port25s      | status       | Port24status |              | 0x0430         |
| Rese         | rved         | Port26s      | status       | 0x0434         |
|              | Rese         | rved         |              | 0x0438:0x043F  |

#### **Table 2. Detailed DIO Register Map (Continued)**

| BYTE 3                                                | BYTE 2                                | BYTE 1                  | BYTE 0          | DIO<br>ADDRESS               |  |
|-------------------------------------------------------|---------------------------------------|-------------------------|-----------------|------------------------------|--|
| Findnode<23-16>                                       | Findnode<31-24>                       | Findnode<39-32>         | Findnode<47-40> | 0x0440                       |  |
| FindVLAN                                              | Findcontrol                           | Findnode<7-0>           | Findnode<15-8>  | 0x0444                       |  |
|                                                       | Find                                  | port                    |                 | 0x0448                       |  |
| Newnode<23-16>                                        | Newnode<31-24>                        | Newnode<39-32>          | Newnode<47-40>  | 0x044C                       |  |
| Rese                                                  | erved                                 | Newnode<7-0>            | Newnode<15-8>   | 0x0450                       |  |
| New\                                                  | /LAN                                  | New                     | port            | 0x0454                       |  |
| Addnode<23-16>                                        | Addnode<31-24>                        | Addnode<39-32>          | Addnode<47-40>  | 0x0458                       |  |
| AddVLAN                                               | Adddelcontrol                         | Addnode<7-0>            | Addnode<15-8>   | 0x045C                       |  |
|                                                       | Add                                   | port                    |                 | 0x0460                       |  |
| Agednode<23-16>                                       | Agednode<31-24>                       | Agednode<39-32>         | Agednode<47-40> | 0x0464                       |  |
| AgedVLAN                                              | Agedport                              | Agednode<7-0>           | Agednode<15-8>  | 0x0468                       |  |
| Delnode<23-16>                                        | Delnode<31-24>                        | Delnode<39-32>          | Delnode<47-40>  | 0x046C                       |  |
| DelVLAN                                               | Delport                               | Delnode<7-0>            | Delnode<15-8>   | 0x0470                       |  |
| Agingo                                                | counter                               | Numr                    | nodes           | 0x0474                       |  |
|                                                       | Rese                                  | erved                   |                 | 0x0478:0x07FF                |  |
| Rese                                                  | erved                                 | DMAa                    | ddress          | 0x0800                       |  |
| Reserved                                              |                                       | Int                     |                 | 0x0804                       |  |
| Reserved                                              |                                       | Intenable               | Intenable       |                              |  |
| Systest                                               |                                       | Freestacklength         |                 | 0x080C                       |  |
|                                                       | RAMaddress 0:                         |                         | RAMaddress      |                              |  |
|                                                       | Reserved                              |                         | RAMdata         | 0x0814                       |  |
| Rese                                                  | erved                                 | NMRx                    | control         | 0x0818                       |  |
| Reserved                                              |                                       | NMTxcontrol             |                 | 0x081C                       |  |
|                                                       | Reserved                              |                         | NMdata          | 0x0820                       |  |
|                                                       | Rese                                  | erved                   |                 | 0x0824:0x3FFF                |  |
|                                                       | TNETX3270 reset: reini                | tializes the TNETX3270  |                 | 0x4000:0x5FFF                |  |
|                                                       | Rese                                  | erved                   |                 | 0x6000:0x7FFF                |  |
|                                                       | Port and network man                  | agement port statistics |                 | 0x8000:8DFF                  |  |
| Port and network management port statistics  Reserved |                                       |                         |                 |                              |  |
| TX pause, RX pause, and security-violation counters   |                                       |                         |                 | 0x8E00:8FFF<br>0x9000:0x91BF |  |
| Reserved                                              |                                       |                         |                 |                              |  |
|                                                       | Unknown unicast destination addresses |                         |                 |                              |  |
| Unknown multicast destination addresses               |                                       |                         |                 |                              |  |
|                                                       | Unknown so                            | urce address            |                 | 0XA008                       |  |
|                                                       | Rese                                  |                         |                 | 0xA00C:0xFFFF                |  |

## interface description

#### **DIO** interface

The DIO interface is a general-purpose interface that can be used with a wide range of microprocessor or computer systems. The interface supports external DMA controllers.

This interface can be used to configure the TNETX3270 using an optional attached CPU (or EEPROM), and to access statistics registers. In addition, this allows access to an internal network management (NM) port that can be transferred between the CPU and the TNETX3270 to support spanning tree, SNMP, and RMON. Either the CPU can read and write packets directly under software control or an external DMA controller can be used to improve performance.

When accessing the statistics values from the DIO port, it is necessary to perform four 1-byte DIO reads to obtain the full 32-bit counter. Counters always should be read in ascending byte-address order (0, 1, 2, 3). To prevent the counter being updated while reading the four bytes, the entire 32-bit counter value is transferred to a holding register when byte 0 is read.

#### receiving/transmitting management frames

Frames originating within the host are written to the NM port via the NMRxcontrol and NMdata registers. Once a frame has been fully written, it is then received by the switch and routed to the destination port(s).

Frames that were routed to this port from any of the switch ports are placed in a queue until the host is ready to read them via the NMTxcontrol and NMdata registers. They then are effectively transmitted out of the switch.

SDMA can be used to transmit or receive management frames (the SAD1–SAD0 pins are ignored when SDMA is asserted) (see Table 3). When SDMA is asserted, the switch uses the value in the DMAaddress register instead of the DIO address registers to access frame data (this also can be used to access the switch statistics). STXRDY and SRXRDY, the interrupts, freebuffs, eof, sof, and iof mechanisms can be used, as desired, to prevent unwanted stalls on the DIO bus during busy periods.

**Table 3. DMA Interface Signals** 

| SIGNAL | DESCRIPTION                                                                      |
|--------|----------------------------------------------------------------------------------|
| SDMA   | Automatically sets up DIO address using the DMAaddress register                  |
| STXRDY | Indicates that at least one data frame buffer can be read by the management CPU  |
| SRXRDY | Indicates that the management CPU can write a frame of any size up to 1535 bytes |

#### state of DIO signals during hardware reset

The CPU can perform a hardware reset by writing to an address in the range 0x4000–0x5FFF (writes to a DMA address in this range have no effect on reset). This is equivalent to asserting the hardware RESET pin. During hardware reset, the output and bidirectional DIO pins behave as shown in Table 4.

**Table 4. DIO Interface During Hardware Reset** 

| DIO INTERFACE<br>SIGNAL | STATE DURING HARDWARE RESET            |  |
|-------------------------|----------------------------------------|--|
| SDATA7-SDATA0           | High impedance. Resistively pulled up. |  |
| SRDY                    | High impedance. Resistively pulled up. |  |
| SRXRDY                  | Driven high                            |  |
| STXRDY                  | Driven low                             |  |



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### network management port

Frames can be received or transmitted via the DIO interface using a built-in port, the network management (NM) port.

Frames originating within the host are written to this port via the NMRxcontrol and NMdata registers. Once a frame has been fully written, it is then received by the switch and routed to the destination port(s).

Frames that were routed to this port from any of the switch's ports queue until the host is ready to read them via the NMTxcontrol and NMdata registers. They are then effectively transmitted out of the switch.

#### IEEE Std 802.1Q VLAN headers on the NM port

Frames received from the host via the NM port are required to contain a valid IEEE Std 802.1Q header. Frames that do not contain a valid header are incorrectly routed. They may be corrupted at the transmission port(s), as the header-stripping process does not verify that the four bytes after the source address are actually a valid header because they always are a valid header under all other circumstances.

When a frame is transmitted to the NM port, no header-stripping occurs, so the frame contains one, or possibly two headers, depending on how the frame was originally received.

#### full-duplex NM port

The NM port can intermix reception and transmission as desired. The direction of the NMdata access (i.e., read or write) determines whether a byte is removed from the transmit queue or added to the receive queue. The DIO interface is half duplex since it can do only a read or write at one time.

#### NM bandwidth and priority

The NM port is capable of transferring a byte to or from NMdata once every five cycles, so the burst rate of this port approximates eight bits per 60 ns (or ≈133 Mbit/s). This can be sustained between the DIO port and the NM port's dedicated transmit or receive buffers.

However, the NM port is prioritized lower than the other ports between its receive and transmit buffers and the external memory system so that at periods of high activity, the NM port does not cause frames to be dropped on the other ports. STXRDY and SRXRDY, the interrupts and freebuffs, EOF, SOF, and interior-of-frame (IOF) mechanisms can be used as desired to prevent unwanted stalls on the DIO bus during busy periods.

The burst rate is unaffected by traffic on other ports.

#### interrupt processing

There are two interrupts available on the NM port.

The interrupt process uses RXRDY and the nmrx interrupts to indicate when the receive FIFO is empty. This indicates that the NM port is ready to accept a frame of any length (up to 1536 bytes).

If the host needs to download a sequence of frames, it can use the freebuffs field to indicate space availability.

#### frame format on the NM port

The frame format on the NM port differs slightly from a standard Ethernet frame format. The key differences are: the frame always contains an IEEE Std 802.1Q header in the four bytes following the source address (see Figure 2). The TPID (tag protocol identifier or ethertype) field, however, is used in the switch for other purposes, so a frame transmitted out of the switch on the NM port does not have the IEEE Std 802.1Q TPID of 81–00 (ethertype constant) value in these two bytes.

The first TPID byte output contains:

SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

- The frame source port number in the least significant bits. This allows the frame source port number to be carried within the frame, which is useful for processing BPDUs, for example.
- A cyclic redundancy check (CRC) type indicator (crctype) in the most significant bit (bit 7).
  - If crctype = 1, then the CRC word in the frame excludes the IEEE Std 802.1Q header.
  - If crctype = 0, then the CRC word in the frame includes the IEEE Std 802.1Q header. This CRC word is for a regular IEEE Std 802.1Q frame format with the value in the IEEE Std 802.1Q TPID of 81–00 (ethertype constant) in the TPID field. Because the internal frame format uses the TPID field for other purposes in the manner being described, it is necessary to insert the IEEE Std 802.1Q TPID of 81–00 (ethertype constant) value into the TPID field if the frame needs to be restored to a normal IEEE Std 802.1Q frame format, which passes a CRC check.

To provide a CRC word, which includes the header, the NM port generates a new CRC word as the frame is being read out. It simultaneously checks the existing CRC in the frame and, if an error is found, ensures that the final byte of the newly generated CRC is corrupted to contain an error, too. The CRC word is deliberately corrupted if the header parity protection (described in the following) indicates an error in the header. In either case, the pfe bit also is set to 1 after the final byte of the frame has been read from NMdata.

If the frame was received on a port other than the NM port, then the crctype bit is set if an IEEE Std 802.1Q tag header was inserted into the frame during ingress.

- If crctype = 1, a header was inserted.
- If crctype = 0, a header was not inserted (crctype also is 0 if the frame VLAN ID was 0x000 and was replaced by the port VLANID (PVID) from the PortxQtag register).

In an IEEE Std 802.1D-compliant application, the header simply can be removed from the frame to produce a headerless frame with a correct CRC word.

All other bits in the byte are reserved and are 0.

The second TPID byte output contains:

- Odd-parity protection bits for the other three bytes in the tag header
- Bit 5 protects the first byte of the TPID field (i.e., the one containing crctype and source port number).
- Bit 6 protects the first byte of the VLAN ID field.
- Bit 7 protects the second byte of the VLAN ID field.
- All other bits in the byte are reserved and are 0.



frame format on the NM port (continued)



Figure 2. NM Frame Format

Any device reading frames out of the NM port must expect frames to be in the format shown in Figure 2.

Frames received into the switch on the NM port also must conform to this format, with the following caveats:

#### • crc = 0 in NMRxcontrol

When the host provides a frame containing valid CRC it also must provide in the TPID field valid header parity protection and indicate via the crctype bit which type of CRC the frame contains [i.e., including the header (crctype = 0), or excluding the header (crctype = 1)]. If crctype indicates that the header is included, as for NM port transmissions, this pretends that IEEE Std 802.1Q TPID of 81–00 (ethertype constant) is present in the TPID field. If a CRC error or parity error is detected, the frame is discarded.

When crctype indicates that the header is included, the NM port regenerates CRC to exclude the header during the reception process (this converts the frame into the required internal frame format).

#### crc = 1 in NMRxcontrol

If the switch is asked to generate a CRC word for the frame, the values in the TPID field are ignored by the NM port. The switch inserts header parity protection. It replaces the final four bytes of the frame with the calculated CRC (the values in the final four bytes provided are don't care).

In either case, the NM port inserts its own port number into the source port field in the least significant bits of the first TPID byte, sets the crctype bit to 0, and also sets the reserved bits to 0.

Frames received from the host via the NM port must contain a valid IEEE Std 802.1Q VLAN ID in the third and fourth bytes, following the source address (the NM port does not have a PortxQtag register for inserting a VLAN tag if none is provided and does not have an rxacc bit). Frames that do not contain a VLAN tag are incorrectly routed. They also can be corrupted at the transmission port(s). The header-stripping process does not verify that the two bytes after the source address are a valid IEEE Std 802.1Q TPID because there is a valid header under all other circumstances.



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### frame format on the NM port (continued)

When a frame is transmitted on the NM port, no header stripping occurs (again because the NM port does not have a PortxQtag register or txacc bit), so the frame read by the host software contains one header (or possibly more, depending on how the frame was received).

In either case, the NM port inserts its own port number into the source port field in the least significant bits of the first TPID byte and sets the reserved bits to 0. Frames received from the host via the NM port are required to contain a valid IEEE Std 802.1Q VLAN ID (VID) in the third and fourth bytes following the source address. (The NM port does not have a default VLAN ID register for inserting a VLAN tag if none is provided. It cannot also be configured as an access port.) Frames that do not contain a valid tag are incorrectly routed. They also can be corrupted at the transmission port(s), as the tag-stripping process does not verify that the four bytes after the source address are a valid tag because they are valid tags under all other circumstances.

When a frame is transmitted on (read from) the NM port, no tag stripping occurs (because the NM port does not have the default VLAN ID register or access configuration control), so the frame read by the host software can contain one or more header tags, depending on how the frame was received.

#### MII serial management interface (PHY management)

This interface gives the user an easy way to implement a software-controlled bit serial MII.

MII devices that implement the management interface, consisting of MDIO and MDCLK, can be accessed in this way through the SIO register. The direction of MDIO is controlled by the SIO register. In addition, a third signal, MRESET, is provided to allow hardware reset of PHYs that support it.

All three signals have internal pullup resistors, since they all can be placed into high impedance via the MDIOEN bit of the SIO register, to allow another bus master.

The interface does not implement timing or data structure. The timing and frame format must be ensured by the management software setting the bits within the SIO register in an appropriate manner. Refer to IEEE Std 802.2u and MII data sheets for the appropriate protocol requirements.

#### 10-Mbit/s and 10-/100-Mbit/s MAC interface

#### receive control

Data received from the PHYs is interpreted and assembled into the TNETX3270 buffer memory. Interpretation involves detection and removal of the preamble, extraction of the address and frame length, extraction of the IEEE Std 802.1Q header (if present), and data handling and CRC. A jabber-detection timer also is included to detect frames that exceed maximum length being received on the network.

#### giant (long) frames

The maxlen bit within each port's Portxcontrol register controls the maximum received frame size on that port.

- If maxlen = 0, the maximum received frame length Is 1535 bytes if no VLAN header is inserted, or 1531 bytes
  if a VLAN header is inserted. (When stored within the switch, a frame never can be longer than 1535 bytes.)
- If maxlen = 1, the maximum received frame length is 1518 bytes, as specified by the IEEE Std 802.3. This is the maximum length on the wire. If a VLAN header is inserted into a 1518-byte frame within the MAC, the frame is stored as a 1522-byte frame within the switch.

All received frames longer than the maximum size are discarded by the switch.

The long option bit in StatControl indicates how the statistics for long frames should be recorded.

#### short frames

All received frames shorter than 64 bytes are discarded upon reception and are not stored in memory or transmitted.



#### receive filtering of frames

Received frames that contain an error (e.g., CRC, alignment, jabber, etc.) are discarded before transmission and the relevant statistics counter is updated.

#### data transmission

The MAC takes data from the TNETX3270 internal buffer memory and passes it to the PHY. The data also is synchronized to the transmit clock rate.

A CRC block verifies that the outgoing frame has not been corrupted within the switch by verifying that it still has a valid CRC as the frame is being transmitted. If a CRC error is detected, it is counted in the transmit data errors counter.

#### transmit control

The frame control block handles the output of data to the PHYs. Several error states are handled. If a collision is detected, the state machine jams the output. If the collision was late (after the first 64-byte buffer has been transmitted), the frame is lost. If it is an early collision, the controller backs off before retrying. While operating in full duplex, both carrier-sense (CRS) mode and collision-sensing modes are disabled (the switch does not start transmitting a new frame if collision is active in full-duplex mode).

Internally, frame data only is removed from buffer memory once it has been successfully transmitted without collision (for the half-duplex ports). Transmission recovery also is handled in this state machine. If a collision is detected, frame recovery and retransmission are initiated.

#### adaptive performance optimization (APO) (transmit pacing)

Each Ethernet MAC incorporates APO logic. This can be enabled on an individual port basis. When enabled, the MAC uses transmission pacing to enhance performance (when connected on networks using other transmit pacing-capable MACs). Adaptive performance pacing introduces delays into the normal transmission of frames, delaying transmission attempts between stations, reducing the probability of collisions occurring during heavy traffic (as indicated by frame deferrals and collisions), thereby, increasing the chance of successful transmission.

When a frame is deferred, suffers a single collision, multiple collisions, or excessive collisions, the pacing counter is loaded with an initial value of 31. When a frame is transmitted successfully (without a deferral, single collision, multiple collision, or excessive collision), the pacing counter is decremented by 1, down to 0.

With pacing enabled, a new frame is permitted to immediately [after one inter-packet gap (IPG)] attempt transmission only if the pacing counter is 0. If the pacing counter is not 0, the frame is delayed by the pacing delay (a delay of approximately four interframe gap delays).

#### NOTE:

APO affects only the IPG preceding the first attempt at transmitting a frame. It does not affect the backoff algorithm for retransmitted frames. APO should be used only with other endstations that also support APO.

#### interframe gap enforcement

The measurement reference for the interpacket gap of 96-bit times is changed, depending on frame traffic conditions. If a frame is transmitted successfully (without collision), 96-bit times is measured from MxxTXEN. If the frame suffered a collision, 96-bit times is measured from MxxCRS.

#### backoff

The device implements the IEEE Std 802.3 binary exponential backoff algorithm.



#### receive versus transmit priority

SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

The gueue manager prioritizes receive and transmit traffic as follows:

- Highest priority is given to frames that currently are being transmitted. This ensures that transmitting frames
  do not underrun.
- Next priority is given to frames that are received if the free-buffer stack is not empty. This ensures that received frames are not dropped unless it is impossible to receive them.
- Lowest priority is given to frames that are queued for transmission but have not yet started to transmit. These frames are promoted to the highest priority only when there is spare capacity on the memory bus.
- The NM port receives the lowest priority to prevent frame loss during busy periods.

The memory bus has enough bandwidth to support the two highest priorities. The untransmitted frame queues grow when frames received on different ports require transmission on the same port(s) and when frames are repeatedly received on ports that are at a higher speed than the ports on which they are transmitted. This is likely to be exacerbated by the reception of multicast frames, which typically require transmission on several ports. When the backlog grows to such an extent that the free buffer stack is nearly empty, flow control is initiated (if it has been enabled) to limit further frame reception.

#### uplink pretagging

TNETX3270 can be incorporated into a switch where routing decisions can be made at a higher level. To facilitate this, two forms of tags are provided on ports 24–26:

- Source-port pretag on transmission
- Port-routing-code pretag on reception

#### source-port pretag on transmission

Ports 24–26 provide the frame's source-port-number pretag one cycle before MxxTXEN goes high (this tag is ignored by an externally connected PHY). The 5-bit tag appears as an encoding on terminals MxxTXER and MxxTXD3 to MxxTXD0 (most significant bit to least significant bit). This is shown in Figure 3 and Table 5.



Figure 3. Source-Port Pretag

**Table 5. Source-Port Pretag Encoding** 

| MxxTXER | MxxTXD3-<br>MxxTXD0 | SOURCE PORT       |
|---------|---------------------|-------------------|
| 0       | 0000                | Port 00           |
| 0       | 0001                | Port 01           |
| 0       | 0010                | Port 02           |
| 0       | 0011                | Port 03           |
| 0       | 0100                | Port 04           |
| 0       | 0101                | Port 05           |
| 0       | 0110                | Port 06           |
| 0       | 0111                | Port 07           |
| 0       | 1000                | Port 08           |
| 0       | 1001                | Port 09           |
| 0       | 1010                | Port 10           |
| 0       | 1011                | Port 11           |
| 0       | 1100                | Port 12           |
| 0       | 1101                | Port 13           |
| 0       | 1110                | Port 14           |
| 0       | 1111                | Port 15           |
| 1       | 0000                | Port 16           |
| 1       | 0001                | Port 17           |
| 1       | 0010                | Port 18           |
| 1       | 0011                | Port 19           |
| 1       | 0100                | Port 20           |
| 1       | 0101                | Port 21           |
| 1       | 0110                | Port 22           |
| 1       | 0111                | Port 23           |
| 1       | 1000                | Port 24           |
| 1       | 1001                | Port 25           |
| 1       | 1010                | Port 26           |
| 1       | 1011                | Port 27 (NM port) |
| 1       | 11xx                | Reserved          |

#### port-routing-code pretag on reception

If the pretag bit is set to 1 in the appropriate Portxcontrol register, during the seven MxxRCLK cycles prior to MxxRXDV going high, the port expects to receive a seven-nibble pretag on MxxRXD3–MxxRXD0 (see Figure 4).



Figure 4. Port-Routing-Code Pretag

Each of the 28 bits contained within these nibbles represents a destination port for the frame. If a bit is 1, the frame is queued to that port. If the port is disabled or its link is inactive, the frame subsequently is drained from the port's queue, which again returns to zero length.

The port assignments for these tag bits are shown in Table 6.

**TAG** MxxRXD3 MxxRXD2 MxxRXD1 MxxRXD0 Port 27 (NM) 6 Port 26 Port 25 Port 24 5 Port 23 Port 22 Port 21 Port 20 4 Port 19 Port 18 Port 17 Port 16 3 Port 15 Port 14 Port 13 Port 12 2 Port 11 Port 10 Port 09 Port 08 1 Port 07 Port 06 Port 05 Port 04 Port 08 Port 02 Port 01 Port 00

**Table 6. Received Pretag Port Assignments** 

The 28 bits are examined during the reception process to see if just one destination bit is set. If this is the case, the frame is received and handled like a unicast frame (such frames can be cut through). If more than one bit is set, the frame is handled as an in-order-broadcast (and cannot be cut through). The frame is routed to all the port(s) specified regardless of whether the destination address is unicast or multicast (i.e., the destination address is not examined).

If all 28 tag bits are 0, the frame is discarded. If the frame has not been discarded in the MAC (for some reason), the portx-filtered RX-frames statistic is incremented.

The tag bits are not examined to see if the source port is specified as a destination port, so it is possible, for example, for port 25 to send a frame to itself by setting bit 1 in tag 6.

The IALE sees and processes pretagged frames exactly as nonpretagged frames (it does not know that a frame has been pretagged). However, the final port-routing code generated by the IALE is ignored (the information in the pretag determines the destination ports). Normal IALE behavior occurs in terms of address learning and interrupt generation and statistics updates with one exception – the portx-filtered RX-frames statistic is incremented if the pretag contained all 0s. (Whether or not the IALE generates its own (ignored) port-routing code of all 0s has no effect on this statistic if the frame is a pretagged frame.)

Since the IALE's routing decision is ignored on pretagged frames, the Txblockports, Rxuniblockports, and Rxmultiblockports registers have no effect on frame reception or transmission.



#### **EEPROM** interface

The EEPROM interface is provided so the system-level manufacturer can produce a CPU-less, preconfigured system to their customers. Customers also may want to change or reconfigure their system and retain their preferences between system power downs. The device cannot be used without either an EEPROM or CPU connected to it (see Figure 5).

The EEPROM contains configuration and initialization information that are accessed infrequently, typically at power up and after a reset. The organization of the EEPROM data is in accordance with the DIO address map.

EEPROM downloads can be initiated in one of two ways:

- At the end of hard reset (rising edge on RESET, or completion of a DIO write to DIOaddrhi register that changes the value of the three most significant bits from 010 to another value).
- Writing a 1 to load in Syscontrol register. This bit is cleared automatically when the download completes.
   It cannot be set during the download by the EEPROM data, thereby preventing a download loop.

During the download, no DIO writes are permitted. If a DIO write is attempted, SRDY is held high until the download has completed.

The EEPROM size is detected automatically according to the address assigned to the EEPROM:

- 2048 bits organized as a 256 × 8 EEPROM should have its A0, A1, and A2 pins tied low.
- 8192 bits organized as a 1024 × 8 EEPROM should have its A0 and A1 pins tied low and A2 pin tied high.



Figure 5. EEPROM Interface Connections

After the initial start condition, a slave address containing a device address of 000 is output on EDIO, and then EDIO is observed for an acknowledge from the EEPROM. If an acknowledge is received, operation continues for the 24C02 EEPROM. If none is received, a stop condition is generated, followed by another start condition and slave address, this time containing a device address of 100. If this receives no acknowledge, no EEPROM is present, and device operation continues, using the current register settings (i.e., those following a hardware reset, or those previously entered by software).

When this device is driving EDIO, it drives out only a strong logic 0. When a logic 1 is intended to be driven out, the pin must be resistively pulled high. An on-chip  $50-\mu A$  current-source pullup device is provided on this pin. The system designer must decide if this is sufficient to achieve a logic 1 level in a timely manner or if an external supplementary resistor is required.



### EEPROM interface (continued)

SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

Multiple bus masters are not supported on the EEPROM interface because the ECLK pin always is driven by the device with a strong 0/strong 1 (i.e., not a strong 1/resistively pulled-up 1).

An Ethernet CRC check is used to ensure the EEPROM data is valid. The 4-byte CRC should be placed within the EEPROM in four data bytes immediately following the last byte to be loaded (equivalent to locations 0x00FC–0x00FF, just above Syscontrol). As each byte is loaded from the EEPROM, the bits within that byte are entered into the CRC checker bit-wise, most significant bit first.

A valid CRC always must be provided by the EEPROM. The EEPROM data for the most significant bit of Syscontrol is withheld until the CRC computed by the device has been checked against the one read from the EEPROM. If the CRC is invalid:

- The reset bit is set to 1 in Syscontrol, load and initd are both 0, and the TNETX3270 does not begin operation.
- The fault LED is illuminated and remains in that state until the TNETX3270 is hardware reset or until load in Syscontrol is set to 1.

#### interaction of EEPROM load with the SIO register

The EDIO pin is shared with the SIO register edata bit. The edata and etxen bits must not both be set to 1 when the load bit is set or the EDIO pin is held at resistive 1 and the EEPROM load fails.

The value of the eclk bit in SIO is don't care when load is set, but to ensure the EEPROM does not see a glitch on its clock signal, the load bit should not be set until the minimum clock high or low time required by the EEPROM on its clock signal has expired since the eclk bit was last changed.

The SIO register is not loaded during the EEPROM download.

#### summary of EEPROM load outcomes

Table 7 summarizes the various states of register bits and the fault LED for each possible outcome, following an EEPROM load attempt.

| OUTCOME            | STOP | LOAD | INITD† | FAULT LED | ECLK       |
|--------------------|------|------|--------|-----------|------------|
| Successful load    | 0    | 0    | 1      | 0‡        | Not locked |
| No EEPROM present  | 0    | 0    | 0      | 0‡        | Locked     |
| CRC error detected | 1    | 0    | 0      | 1         | Not locked |

**Table 7. Summary of EEPROM Load Outcomes** 

#### compatibility with future device revisions

All EEPROM locations that correspond to reserved addresses in the memory map, register bits that are read only, and register bits that are marked as reserved should be set to 0 to ensure compatibility with future versions of the device. Failure to do so may result in the unintentional activation of features in future devices. All such bits are included in the CRC calculation.



<sup>†</sup>Assuming the start bit was set to 1 by the EEPROM load

<sup>‡</sup> Assuming the fault bit in LEDControl = 0 and no memory system parity error is detected

#### JTAG interface

The TNETX3270 is fully IEEE Std 1149.1 compliant. It also includes on-chip pullup resistors on the five JTAG terminals to eliminate the need for external ones. All JTAG inputs and outputs are 3.3-V tolerant.

The following instructions are supported:

- EXTEST, BYPASS, and SAMPLE/PRELOAD
- HIGHZ and IDCODE
- Private (various private instructions are used by TI for test purposes)

The opcodes for the various instructions (6-bit instruction register) are shown in Table 8.

| INSTRUCTION<br>TYPE | INSTRUCTION<br>NAME | JTAG<br>OPCODE |
|---------------------|---------------------|----------------|
| Mandatory           | EXTEST              | 000000         |
| Mandatory           | SAMPLE/PRELOAD      | 000001         |
| Optional            | IDCODE              | 000100         |
| Optional            | HIGHZ               | 000101         |
| Optional            | RACBIST             | 000110         |
| Private             | TI testing          | Others         |
| Mandatory           | BYPASS              | 111111         |

**Table 8. JTAG Instruction Opcodes** 

#### HIGHZ instruction

When selected, the HIGHZ instruction causes all outputs and bidirectional pins to become high impedance. All pullup and pulldown resistors are disabled.

#### **LED** interface

This interface allows a visual status for each port to be displayed. In addition, the state of the internal flow control and fault functions are displayed along with 12 software-controllable LEDs.

Each port has a single LED, which can convey three states (see Table 9).

Table 9. LED States

| STATE                  | DISPLAY          |  |
|------------------------|------------------|--|
| No link                | Off              |  |
| Link, but no activity  | On               |  |
| Activity (bits moving) | Flashing at 8 Hz |  |

The interface is intended for use with external octal shift registers clocked with LEDCLK. Every 16th of a second, all the status bits are shifted out via LEDDATA.

The status bits are shifted out in one of two possible orders, as determined by slast in LEDControl, to ensure that systems that do not require all the LED status can be implemented with the minimum number of octal shift registers (see Table 10).

- If slast = 0, the software-controlled status bits are shifted out before the port status bits.
- If slast = 1, the software-controlled status bits are shifted out after the port status bits.

The fault status bit is shifted out last, enabling a minimal system that displays only the fault status to be implemented without any shift registers.



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### Table 10. LED Status Bit Definitions and Shift Order

| ORDER     |           | NAME     | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|-----------|-----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| slast = 0 | slast = 1 | NAIVIE   | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 1–7       | 1–7       | 0        | Zero. Dummy data for first seven of 48 LEDCLK cycles.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 8–19      | 35–46     | SW0-SW11 | Software LEDs 0–11. These allow additional software-controlled status to be displayed. These 12 LEDs reflect the values of bits 0–11 of the swled field in LEDControl at the moment that the LED interface samples them. If this occurs between writes to the most significant and least significant bytes of LEDControl, these values appear on the LEDs, separated by 1/16th of a second.                                                                                                                               |  |  |
| 20–46     | 8–34      | P00-P26  | Port status LEDs 00–26. These 27 LEDs indicate the status of ports 00–26, in this order (port 00 is output first). Note that port 27 (management port) does not have an LED. The transmit multicast content of these bits can be controlled by the txais bit in LEDControl. Note that IEEE Std 802.3X pause frames never appear on the LEDs as port activity. The port's LED toggles each 1/16th of a second if there was any frame traffic (other than pause frames) on the port during the previous 1/16th of a second. |  |  |
| 47        | 47        | FLOW     | Flow control. LED is on when the internal flow control is enabled and active. Active means that flow control is asserted during the previous 1/16th of a second.                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 48        | 48        | FAULT    | Fault. LED indicates:  - the EEPROM CRC is invalid.  - an external DRAM parity error has occurred.  - the fitled in LEDControl has been set.  The CRC and parity error indications are cleared by hardware reset (terminal or DIO). The CRC error indication also is cleared by setting load to 1. The parity error indication also is cleared by setting start to 1.                                                                                                                                                     |  |  |

#### lamp test

When the device is in the hardware reset state, LEDDATA is driven high and LEDCLK runs continuously. This causes all LEDs to be illuminated and serves as a lamp test function.

#### multi-LED display

The LED interface is intended to provide the lowest-cost display with a single multifunction LED per port. In systems requiring a full-feature display (more than levels of activity) using multiple LEDs per port, this can be achieved by driving the LEDs directly from the PHY signals.

#### hardware configurations

#### 10-Mbit/s MAC interfaces (ports 00-23)

Each group of eight 10-Mbit/s ports (ports 00 to 07, 08 to 15, and 16 to 23) interfaces directly with a TI TNETE2008, which contains eight 10-Mbit/s PHYs. This interface is time multiplexed between the eight ports, with receive and transmit data being transferred over nibble-wide buses. Any given port needs only to transfer data at 2.5 MHz (i.e., 2.5 MHz  $\times 4$  bits = 10 Mbit/s), but because TNETE2008 contains eight PHYs, the frequency of nibble transfers is 20 MHz (i.e., 2.5 MHz  $\times 8$  ports). The remaining control and status signals also are transferred at this rate.

Table 11 shows how the terminals of a TNETE2008 device are connected to each 10-Mbit/s interface on the TNETX3270.



Table 11. 10-Mbit/s Interface Connections

| TNETX3270<br>TERMINAL |               | TNETE2008<br>TERMINAL |  |
|-----------------------|---------------|-----------------------|--|
| THxCLK                | <b>←</b>      | IFCLK                 |  |
| THxSYNC               | $\leftarrow$  | IFSYNC                |  |
| THxCOL                | <b>←</b>      | IFCOL                 |  |
| THxCRS                | $\leftarrow$  | IFCRS                 |  |
| THxLINK               | $\leftarrow$  | IFLINK                |  |
| THxRXD3               | $\leftarrow$  | IFRXD3                |  |
| THxRXD2               | $\leftarrow$  | IFRXD2                |  |
| THxRXD1               | <b>←</b>      | IFRXD1                |  |
| THxRXD0               | <b>←</b>      | IFRXD0                |  |
| THxRXDV               | <b>←</b>      | IFRXDV                |  |
| THxTXD3               | $\rightarrow$ | IFTXD3                |  |
| THxTXD2               | $\rightarrow$ | IFTXD2                |  |
| THxTXD1               | $\rightarrow$ | IFTXD1                |  |
| THxTXD0               | $\rightarrow$ | IFTXD0                |  |
| THxTXEN               | $\rightarrow$ | IFTXEN                |  |
| THxRENEG              | $\rightarrow$ | IFFORCEHD             |  |

Where x = 0, 1, or 2

The time multiplexing of this interface is shown in Figure 6. The interface runs synchronous to the PHY-generated 20-MHz clock IFCLK. The MAC-to-PHY information for the first port in each group of eight (i.e., port 00, port 08, or port 16) is presented on the interface when the THxSYNC terminal is high. The next clock cycle that the interface carries is the information for the second port. This process continues for all eight ports, each using the interface for one cycle. When all ports have been processed in this manner, the sequence resumes with the first port and again when the THxSYNC signal is asserted.

To improve latency-related issues, the PHY-to-MAC data are skewed by two slots, allowing the MAC to respond to the input signals from the PHY in the same 400-ns cycle, rather than waiting for the next 400-ns cycle (which would be the case if the signals were not skewed).



Figure 6. 10-Mbit/s Interface-Port Signal Timing





Figure 7. Connecting to TNETE2008 PHY<sup>†</sup>

†THx = TH0, TH1, and TH2



#### 10-/100-Mbit/s MAC interfaces (ports 24-26)

Unlike the 10-Mbit/s ports, each 10-/100-Mbit/s port has a dedicated set of signals to interface to its PHY. Table 12 shows how a TNETE2101 10-/100-Mbit/s PHY would be connected to one of the 10-/100-Mbit/s ports of TNETX3270.

Table 12. 10-/100-Mbit/s Interface Connections

| SWITCH<br>TERMINAL |                   | TNETE2101<br>TERMINAL |  |
|--------------------|-------------------|-----------------------|--|
| MxxTCLK            | $\leftarrow$      | MTCLK                 |  |
| MxxTXD3            | $\rightarrow$     | MTXD3                 |  |
| MxxTXD2            | $\rightarrow$     | MTXD2                 |  |
| MxxTXD1            | $\rightarrow$     | MTXD1                 |  |
| MxxTXD0            | $\rightarrow$     | MTXD0                 |  |
| MxxTXEN            | $\rightarrow$     | MTXEN                 |  |
| MxxTXER            | $\rightarrow$     | MTXER                 |  |
| MxxCOL             | ←                 | MCOL                  |  |
| MxxCRS             | $\leftarrow$      | MCRS                  |  |
| MxxRCLK            | ←                 | MRCLK                 |  |
| MxxRXD3            | ←                 | MRXD3                 |  |
| MxxRXD2            | $\leftarrow$      | MRXD2                 |  |
| MxxRXD1            | <b>←</b>          | MRXD1                 |  |
| MxxRXD0            | <b>←</b>          | MRXD0                 |  |
| MxxRXDV            | <b>←</b>          | MRXDV                 |  |
| MxxRXER            | <b>←</b>          | MRXER                 |  |
| MxxLINK            | <b>←</b>          | SLINK                 |  |
| MDCLK              | $\rightarrow$     | MDCLK                 |  |
| MDIO               | $\leftrightarrow$ | MDIO                  |  |
| MRESET             | $\rightarrow$     | MRST                  |  |

Where xx = 24, 25, or 26, y = 0-3

Other differences from the 10-Mbit/s ports are noted in following paragraphs.

#### 10-/100-Mbit/s port configuration

The 100-Mbit/s ports (24–26) can negotiate with the PHY (speed and duplex) at power-up via the EEPROM contents using the  $\overline{\text{MxxFORCE10}}$  and  $\overline{\text{MxxFORCEHD}}$  terminals, respectively.

Each of these terminals (per port):

- Has an integral 50-μA current-source pullup resistor. The system designer must decide if this is sufficient to achieve a logic-1 level in a timely manner or if an external supplementary resistor is required.
- Has a strong open-drain pulldown transistor, which is enabled by setting to 1 the appropriate bit in the Portxcontrol register.
- Is connected (via synchronization logic) to the appropriate bit in the Portxstatus register. These bits directly control the configuration of the ports.



#### 10-/100-Mbit/s port configuration (continued)

Each terminal is considered to be bidirectional, when pulled low by either TNETX3270 or by the PHY (or other external connections). If neither pulls the terminal low, then the pullup resistor maintains a value of 1 on the terminal. When the PHY does not pull down a terminal, then it can determine the desired option that is being requested by TNETX3270. TNETX3270 observes the terminal to determine if its desired option has been granted.

The sense of these three signals is such that the higher-performance option is represented by a value of 1; if the MAC does not require the higher performance or the PHY cannot supply it, either can pull the signal low, forcing the port to use the lower-performance option.

The status of the link for each of these ports is indicated on the MxxLINK terminal and observable in the port's Portxstatus register. The MxxLINK terminal plays no part in the negotiation of speed or duplex or their recording in the Portxstatus register.

The behavior of these terminals is summarized in Tables 13 and 14.

**Portxcontrol Portxstatus OUTCOME** MxxFORCE10 **SPEED** (Mbit/s) req10 0  $\rightarrow$ Floating 1  $\rightarrow$ 100 Driven 0 (by TNETX3270) 0 10 1  $\rightarrow$  $\rightarrow$ 

 $\rightarrow$ 

0

10

Table 13. Speed Configuration – MxxFORCE10

| Table 14. Duplex | Configuration - | MxxFORCEHD |
|------------------|-----------------|------------|
|------------------|-----------------|------------|

Driven 0 (by PHY)

| Portxcontrol reqhd |               | MxxFORCEHD              |               | Portxstatus<br>DUPLEX | OUTCOME     |
|--------------------|---------------|-------------------------|---------------|-----------------------|-------------|
| 0                  | $\rightarrow$ | Floating 1              | $\rightarrow$ | 1                     | Full duplex |
| 1                  | $\rightarrow$ | Driven 0 (by TNETX3270) | $\rightarrow$ | 0                     | Half duplex |
| Х                  |               | Driven 0 (by PHY)       | $\rightarrow$ | 0                     | Half duplex |

#### 10-/100-Mbit/s port configuration in a nonmanaged switch

Χ

The 10-/100-Mbit/s ports can be configured in a nonmanaged switch using the following procedure:

 The EEPROM loads the req10 and reqhd bits of the Portxcontrol registers as required. If either of these bits becomes a 1, the corresponding terminal is not pulled low and thus, floats high. (The reqnp bit also can be loaded from EEPROM to enable/disable pause-frame control in the MAC, but this cannot be communicated to the PHY. The system designer should ensure that the MAC and PHY operate using the same pause-frame regime.)

#### 2. The PHYs either:

- a. Look at the MxxFORCE10 and MxxFORCEHD terminals and configure themselves as specified (if not autonegotiating), or as the highest common denominator with the link partner, if they are autonegotiating. If the PHYs use the information on these terminals, they must wait until TNETX3270 loads the EEPROM contents before doing so (this may require delaying the reset to the PHYs if necessary).
- b. Ignore TNETX3270 requests and configure themselves in some other manner.
- 3. The PHYs (or external system) then drive MxxFORCE10 and MxxFORCEHD low for those features that are supported only at the lower performance. These are continuously sampled into the Portxstatus register.
- 4. The MACs then operate as indicated by the Portxstatus register.



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### 10-/100-Mbit/s port configuration in a managed switch

The 10-/100-Mbit/s ports can be configured in a managed switch using either of the following procedures:

- The management CPU sets the req10 and reqhd bits of the Portxcontrol registers as required while the PHYs are held in reset. If either of these bits becomes a 1, the corresponding terminal is not pulled low and thus, floats high. (The reqnp bit also can be loaded from EEPROM to enable/disable pause-frame control in the MAC, but this cannot be communicated to the PHY. The system designer should ensure that the MAC and PHY operate using the same pause-frame regime.)
- 2. The PHYs are then released from reset and either:
  - a. Look at the MxxFORCE10 and MxxFORCEHD terminals and configure themselves as specified (if not autonegotiating), or as the highest common denominator with the link partner, if they are autonegotiating.
  - b. Ignore TNETX3270 requests and configure themselves in some other manner.
- 3. The PHYs (or external system) subsequently drive MxxFORCE10 and MxxFORCEHD low for those features that are supported only at the lower performance. These are continuously sampled into the Portxstatus register.
- 4. The MACs then operate as indicated by the Portxstatus register.
- 5. The operating state of the PHYs subsequently can be altered by using the IEEE Std 802.3u MII management interface. Any change of state should be reflected on the values presented on MxxFORCE10 and MxxFORCEHD so that the MACs are similarly reconfigured.

Or:

- 1. MxxFORCE10 and MxxFORCEHD should not be connected to anything.
- 2. Software uses the IEEE Std 802.3u MII management interface to configure the PHYs to the required operating conditions, possibly interrogating the PHY as to the results of autonegotiation.
- 3. The MACs should then be set to operate in the required manner by writing the appropriate values to the req10 and reqhd bits in the Portxcontrol register. This causes MxxFORCE10 and MxxFORCEHD to reflect the operating conditions that are sampled into the Portxstatus registers to configure the MACs. The reqnp bit also should be set to 1 for those PHYs that are configured to support IEEE Std 802.3x pause frames. This also is communicated to the MACs.

#### **SDRAM** interface

All valid frames pass over this interface to the external SDRAM, where they are temporarily buffered between reception and transmission.

The data bus within the SDRAM interface is 32 bits wide and supports the following configurations:

- Two 1M × 16-bit SDRAMs (4 Mbytes of storage)
- Four 2M × 8-bit SDRAMs (8 Mbytes of storage)
- Two 4M × 16-bit SDRAMs (16 Mbytes of storage)
- Four 8M × 8-bit SDRAMs (32 Mbytes of storage)

The interface is clocked at 83.33 MHz, so 12-ns SDRAMS are required. If one of the above configurations is used, then no additional glue logic is required. The SDRAMs should be connected to the SDRAM interface pins (see Table 15).



#### **SDRAM** interface (continued)

**Table 15. TNETX3270 Terminal Interface to SDRAMs** 

| TERMIN    | IALS     | SDRAM TERMINAL FUNCTION               |
|-----------|----------|---------------------------------------|
| TNETX3270 | SDRAM    | SDRAW TERMINAL FUNCTION               |
| DA13      | A13      | Row/bank address (64-M SDRAMs only)   |
| DA12      | A12      | Row/bank address (64-M SDRAMs only)   |
| DA11      | A11      | Row/bank address                      |
| DA10      | A10      | Row address/auto-precharge select     |
| DA09      | A9       | Row address                           |
| DA08      | A8       | Row address/column address (× 8 only) |
| DA07      | A7       | Row address/column address            |
| DA06      | A6       | Row address/column address            |
| DA05      | A5       | Row address/column address            |
| DA04      | A4       | Row address/column address            |
| DA03      | А3       | Row address/column address            |
| DA02      | A2       | Row address/column address            |
| DA01      | A1       | Row address/column address            |
| DA00      | A0       | Row address/column address            |
| DRAS      | RAS      | Row address strobe                    |
| DCAS      | CAS      | Column address strobe                 |
| DW        | W        | Write enable                          |
| DCLK      | CLK      | Clock                                 |
| DD31-DD16 | DQ15-DQ0 | SDRAM1. Data I/O (× 16 SDRAMs)        |
| DD15-DD00 | DQ15-DQ0 | SDRAM0                                |
| DD31-DD24 | DQ7-DQ0  | SDRAM3. Data I/O (× 8 SDRAMs)         |
| DD23-DD16 | DQ7-DQ0  | SDRAM2                                |
| DD15-DD08 | DQ7-DQ0  | SDRAM1                                |
| DD07-DD00 | DQ7-DQ0  | SDRAM0                                |

DA13 and DA12 should be left unconnected if 16M-bit SDRAMs are used. The remaining functional SDRAM terminals that are not directly controlled by the SDRAM interface should be tied off from the external system during operation (see Table 16).

Table 16. SDRAM Terminals Not Driven by the TNETX3270

| HELD | SDRAM<br>TERMINAL | SDRAM<br>TERMINAL FUNCTION |
|------|-------------------|----------------------------|
| Low  | CS                | Chip select                |
| High | CKE               | CLK enable                 |
| Low  | DQM               | Data mask (× 8 SDRAMs)     |
| Low  | DQML              | Data mask (× 16 SDRAMs)    |
| Low  | DQMU              | Data mask (× 16 SDRAMs)    |

SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

## SDRAM-type and quantity indication

Before beginning operation (by writing to the start bit of Syscontrol), it is necessary to indicate to the SDRAM interface whether  $\times$  8 or  $\times$  16 SDRAMs are being used. This is done by setting the bit in the RAMsize register (by 8 = 0 for  $\times$  16, by 8 = 1 for  $\times$  8) during the load from EEPROM or via a DIO write. It also is necessary to inform the SDRAM interface of the quantity of external SDRAM available. This is done by writing to the RAMsize register, while at the same time setting the  $\times$  8 or  $\times$  16 SDRAMs.

#### initialization

SDRAMs require controlled initialization. Specifically, SDRAMs require up to  $200\,\mu s$  of inactivity after power has been supplied, during which they are supplied only with an active CLK. The system designer must ensure that this inactivity period is observed while TNETX3270 is held in hardware or software reset.

Table 17 shows the state of the SDRAM interface terminals during hardware or software reset.

Table 17. SDRAM Interface Terminal State During Hardware or Software Reset

| TNETX3270<br>TERMINAL | STATE<br>DURING RESET |
|-----------------------|-----------------------|
| DA13-DA00             | Driven high           |
| DRAS                  | Driven high           |
| DCAS                  | Driven high           |
| DW                    | Driven high           |
| DCLK                  | Active                |
| DD31-DD00             | High impedance        |

Any other SDRAM requirements during this period that need to be observed, such as the state of chip selects and clock-enable and data-mask controls, also are the responsibility of the system designer. This SDRAM interface does not drive the DD bus during hardware or software reset, or following either reset, until the SDRAM initialization process has been completed.

#### refresh

After the initialization process, the SDRAM interface then performs 4096 REFR commands at least every 64 ms. SDRAM data is, however, lost during any subsequent resets, as the SDRAM interface does not issue any REFR commands during any hardware or software reset.

## frame routing

#### **VLAN** support

The internal routing engine supports the IEEE Std 802.1Q VLANs as shown in Figure 8 and described in the following paragraphs.



Figure 8. VLAN Overview



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### IEEE Std 802.1Q headers - reception

When the internal address-lookup engine (IALE) examines the received frame, it contains an IEEE Std 802.1Q header (after the source address). The header used depends on the port configuration. If the port is configured as an access port, then IALE always uses the default VLAN ID (VID) programmed for this port. It accepts all received frames on this port as untagged. If the frame already contains a header, it is tagged again. If the port is programmed as a non-access port, then the header added depends on the received frame. If the frame is not tagged, or the value of the header field is 0x000, then the default port VID is used to tag the frame internally. Otherwise, the VID contained in the frame is used by the IALE.

The IALE does not support all 4096 VLAN IDs that can be encoded within the IEEE Std 802.1Q header at the same time. The TNETX3270 has support for 32 VLANs, the VID in the received frame is compared with these 32 VLAN IDs to see which (if any) it matches. The designer can use any of the 4096 VLAN ID values for these 32 VLAN IDs.

#### unknown VLAN

If there is no match, then the rest of the address-lookup process is abandoned. A new VLAN interrupt is provided to the attached CPU. The source address, VLAN ID, and port information is provided in internal registers so that the CPU can determine if it wants to add this VID to the lookup table. If the destination address is unicast, then the frame is discarded. If the destination address is multicast/broadcast, then the frame is forwarded based on a programmable port mask.

#### known VLAN

If there is a match, the VLAN index associated with this VID together with the destination and source address, are forwarded to the address-lookup and subsequent routing process. Only one of the VLAN IDs match if they have been programmed correctly. If more than one matches, the hardware chooses one of them.

#### new VLAN member

The IALE checks to see if the source port already has been declared as a member of this VLAN. If not, then an interrupt is provided to allow the attached CPU to add this port as a new member of the VLAN.

#### IEEE Std 802.1Q headers - transmission

The IEEE Std 802.1Q header is carried in the frame to the transmitting MAC port, where the decision to strip out the header before transmission is made, based on the port configuration. If the port is configured as an access port, the header is stripped before transmission. If the frame is only 64 bytes long, then 4 bytes of pad (0s) are inserted between the end of the data and the start of the CRC word (a new CRC value is calculated and inserted in the frame). If the port is configured as a non-access port, the VID is compared with the default port VID. If they match, the header is stripped. Otherwise, the header is retained.

If the frame is transmitted to the NM port, then no header stripping occurs. The frame is transmitted unaltered. It may contain one or two headers, depending on how the frame was originally received.

#### address maintenance

The addresses within the IALE can be maintained automatically by the TNETX3270, where addresses are learned/updated from the wire and deleted, using one of two aging algorithms. Multicast addresses are not automatically learned or aged. The attached CPU can add/update, find, or delete address records via the DIO interface.

At times of peak activity, it may not be possible to learn or update every source address that is received. The IALE backlogs up to one source address per port under these circumstances. Subsequent source addresses received on a backlogged port are not learned/updated until that port's backlog has been cleared. Lookups are always given priority in the IALE, so these can never backlog.

The learning and aging processes are independent. This allows addresses to be learned automatically from the wire, but allows the CPU to manage the aging process under software control.



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### spanning-tree support

Each port provides independent controls to block reception or transmission of frames, for learning of addresses, or to disable the port on a per-port basis. Blocking can be overridden to allow reception or transmission of spanning-tree frames.

### aging algorithms

#### time-threshold aging

When processing (learning) addresses, the IALE adds the source address to the table and tags it with a time stamp. If another frame is received with this source address, then the time stamp is refreshed. If the aging counter expires before another frame is received from this source address, then the address is deleted from the table. If the table is full, then the oldest address is deleted to make room for a new address, even if the age for this address has not expired.

#### table-full aging

In table-full aging, the oldest address (or one of the oldest addresses if there is more than one) is automatically deleted from the IALE records only if the table is full and a new address needs to be added to the table. In this mode, the age stamp for the addresses is not refreshed.

### frame-routing determination

When a frame is received, its 48-bit destination and source addresses are extracted and the VLAN index is determined. The destination address and VLAN index are then looked up in the IALE records to determine if a match exists. If a match is found, the information associated with the record is passed on to the frame-routing algorithm. After removing disabled ports and checking for mirrored and trunking ports, the frame is sent to the correct ports and the source address time stamp is reported.

The source address and VLAN index combination also are looked up in the IALE records to determine if a match exists. If a match is found, additional information is provided to the routing process. Figure 9 provides a flow diagram of the routing algorithm.





Figure 9. Frame-Routing Algorithm





Figure 9. Frame-Routing Algorithm (Continued)





NOTE A: See Port Trunking/Load Sharing

Figure 9. Frame-Routing Algorithm (Continued)

#### port mirroring

The TNETX3270 allows all transmitted frames on a particular port to be copied (or mirrored) to a designated port.



#### port trunking/load sharing

Port trunking is a technique that allows two or more ports to be parallel connected between switches and counted as one port to increase the bandwidth between those devices. The trunking algorithm determines on which of these ports a frame is transmitted, spreading the load evenly across these ports and maintaining packet order.

The TNETX3270 supports trunking on the 10-/100-Mbit/s ports. Trunk-port determination is the final step in the IALE frame-routing algorithm. Once the destination port(s) for a frame has been determined, the port-routing code is examined to see if any of the destination ports are members of the trunk. If so, the trunking algorithm is applied to select which port within that trunk transmits the frame – it may or may not be the one currently in the port-routing code. To determine the destination port within a trunk, bits 3–1 of the source and destination address are XORed to produce a map index. This map index is used to index to a group of eight internal registers to determine the destination port. The actual transmit port of a unicast packet is dynamic, based on the eight internal registers.

Load sharing is similar to trunking, with the following differences:

- If the destination address was found in the IALE records when it was looked up, the port-routing code is not adjusted by the load-sharing/-trunking algorithm.
- The 3-bit map index is determined only from the source address as follows:
  - Bits 47–32 are XORed to produce the most significant bit of the map index.
  - Bits 31–16 are XORed to produce the middle of the map index.
  - Bits 15–0 are XORed to produce the least significant bit of the map index.

Once assigned, the tx port for a unicast packet is static.

#### flow control

The switch incorporates two forms of flow control: collision based, and IEEE Std 802.3 pause frames.

In either case, the switch recognizes when it is becoming congested by monitoring the size of the free-buffer queue. When the number of free buffers drops below the specified threshold, the switch prevents frames from entering the device by issuing the flow control appropriate to each port's current mode of operation. This prevents reception of any more frames on those ports until the frame backlog is reduced and the number of free buffers has risen above the threshold, at which point flow control ceases and frames again can be received. The default free-buffer threshold after a hardware reset is chosen to ensure that all ports simultaneously can start reception of a maximum-length frame and ensure complete reception.

The purpose of flow control is to reduce the risk of data loss if a long burst of activity caused the switch to backlog frames to the point where the memory system is full. However, there is no way to prevent frame reception on those ports operating in full-duplex mode that have not negotiated IEEE Std 802.3 flow control. Such ports can exhaust the free buffer gueue, with subsequent data loss.

Each 10-/100-Mbit/s port can request collision or IEEE Std 802.3X flow control through internal registers.

Flow control is globally enabled/disabled. Each individual port can request half- or full-duplex or IEEE Std 802.3 flow to be negotiated by the PHY device.

In full duplex, a port does not start transmitting a new frame if the collision pin is active, although the value of this pin is ignored at other times.



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### collision-based flow control

These forced collisions are not limited to a maximum of 16 consecutive collisions, and are independent of the normal backoff algorithm.

#### IEEE Std 802.3 flow control

IEEE Std 802.3X flow control provides a means of reducing network congestion on ports that are operating in full duplex mode, via special pause frames. It is symmetrical, so that devices that transmit pause frames also must respond to received pause frames.

Pause frames and their behavior are fully described in the IEEE Std 802.3X standard, but in essence they comprise:

- 48-bit multicast destination address 01.80.C2.00.00.01
- 48-bit source address is read from the Devnode register when transmitted by this device.
- 16-bit length/type field, containing the value 88.08
- 16-bit pause opcode equal to 00.01
- 16-bit pausetime. This specifies a nonzero number of pausequanta. A pausequantum is 512 bit times.
- Padding as required/desired
- 32-bit frame-check sequence (CRC word)

All quantities above are hexadecimal and are transmitted most significant byte first. Within the byte they are transmitted least significant bit first.

The padding is required to fill out the frame to a minimum of 64 bytes. The standard allows pause frames longer than 64 bytes to be discarded or interpreted as valid pause frames. This device recognizes any pause frame that is between 64 bytes and 1531 bytes long. It always transmits 64-byte pause frames.

Each 10-/100-Mbit/s port can request IEEE Std 802.3X pause-frame support via the reqnp (= 0) bit within its Portxcontrol register. The 100-/1000-Mbit/s port has independent control for transmission and reception of IEEE Std 802.3X pause frames, and can request IEEE Std 802.3X flow control via the reqntxp (= 0) and reqnrxp (= 0) bits within its Portxcontrol.

Outgoing pause frames are issued only when:

- pause (10/100) = 1
- The port is operating in the full-duplex mode.
- flow = 1 in Syscontrol

Incoming pause frames are acted on only when:

 pause = 1 or pausetx = 1 (i.e., incoming pause frames are recognized in both full-duplex and half-duplex modes, regardless of the value of the flow bit)



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### pause frame reception

The IEEE Std 802.3X standard defines a MAC control frame as any frame containing a length/type value = 88.08 (hex). This device always absorbs (i.e., discards) within the MAC all such frames that it receives, regardless of the configuration of the port (i.e., pause and duplex have no effect on this behavior). MAC control frames are not forwarded to any other port and are not used by IALE for learning source addresses. They appear in the MAC statistics in the same manner as data frames, but are not seen by the IALE, so do not appear in its statistics (i.e., receive filtered frames, security violations, unknown unicast destination, unknown multicast destination, or unknown source).

Pause frames are the subset of MAC control frames with the opcode field = 0x0001. These are acted on by a port only if:

- pause = 1 in its Portxstatus register
- The frame's length is 64–1531 bytes, inclusive.
- MxxRXER does not go active at any time during its reception.
- Its FCS passes the CRC.

The pause\_time value from such valid frames is extracted from the two bytes following the opcode. This is loaded into the port's pause timer and the pause\_time period is timed.

If a valid pause frame is received during the pause\_time period of a previous pause frame:

- If its destination address is not equal to the reserved multicast address or the address in the Devnode register, the pause timer immediately expires.
- If the new pause time value is 0, the pause timer immediately expires.
- If the pause timer within the port immediately is set to the pause\_time value of the new pause frame (any remaining pause time from the previous pause frame is disregarded).

If the pause bit in Portxstatus ever becomes a 0 (because pause frames are no longer supported), the pause timer immediately expires.

A port does not begin to transmit any new data frame any later than 512-bit times after a pause frame with a nonzero pause time has been received (RXDV going inactive). It does not begin to transmit any data frame until the pause timer has expired. (However, it can transmit pause frames of its own if it needs to initiate flow control). Any frame already in mid-transmission when a pause frame is received is unaffected; it completes transmission as normal.

## pause frame transmission

When the number of free buffers within the switch becomes less than the number specified in Flowthreshold, full-duplex ports that have had pause frames negotiated/enabled transmit a pause frame at the first available opportunity (immediately if currently idle, or following completion of the frame currently being transmitted). The pause frame contains the pausetime field from Pausetimex register that matches the current operating speed of the port.

If the number of free buffers still is less than the number specified in Flowthreshold after 80% of the time interval represented by the respective pausetime field has elapsed, then another pause frame is transmitted at the earliest opportunity.

If the value in Pausetimex is 0, then no pause frames are transmitted on ports with that speed.

It is anticipated that the pausetime values for the different port speeds will be programmed to have a 10:1 ratio, so that different-speed ports pause for the same amount of real time.

Note that transmitted pause frames are only a request to the other end station to stop transmitting. Frames that are received during the pause interval are received normally (provided the buffer memory is not full).



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### pause frame transmission (continued)

Pause frames are transmitted if required, even if the port is observing the pausetime period from a pause frame it has received.

#### internal wrap test

Internal wrap mode causes some or all of the Ethernet MACs to be configured to loop back transmitted data into the receive path. This allows a frame to be sent into a designated source port and then selectively routed successively to and from ports involved in the test, before finally transmitting the frame out of the original port. By varying the number of ports between which the frame is forwarded, the potential fault capture area is expanded or constrained.

Intwrap in Systest determines which ports loop back. Ports 0 or 8 can be configured to not loop back, allowing them to be used as the start/end port for the test. Alternatively, the NM port (accessed via DIO) can be used for this purpose, with all MII ports configured to loop back.

For a frame to be forwarded from one port to another in this fashion, the switch must be programmed as follows:

- Assign a unique VID to each of the PortxQtag registers, and program these tags into the VLANnQID registers.
- The VLANnports register associated with each of the VLANnQID registers should have only one bit set, indicating the port to which frames containing that IEEE Std 802.3 tag should be routed.
- Rxacc and Txacc for each port must be 1. This causes the port to add the VID from its PortxQtag to the frame on reception, and strip the tag before transmission.
- The destination address of the frames to be applied is not known, and UnkUniPorts and UnkMultiPorts should be all 1s.

This causes the following:

- The VID from the source port PortxQtag register is added to the frame upon reception. As the address of the frame is unknown, it is forwarded to the AND of the appropriate VLANnports and Unkuniports (unicast) or Unkmultiports (multicast). As VLANnports should contain only a single 1, this should be a single port.
- 2. The frame is transmitted from the destination port selected in 1. Its VLAN tag is stripped beforehand; the frame loops back to the receive path.
- 3. Steps 1 and 2 are repeated, but the VID added upon reception is different from the one just stripped off at transmission. This means a different VLANnports register is used to determine the destination.
- 4. Eventually, the frame is sent to a port that is not configured for loopback and leaves the switch.

The operational status of the PHYs or external connections to the device do not have to be considered or assumed good when in internal loopback mode.





Figure 10. Internal Wrap Example

#### duplex wrap test

Duplex wrap test is similar to internal wrap mode (see Figure 11). The ports can be set to accept frame data that is wrapped at the PHY. This permits network connections between the device and the PHY to be verified. Any port can be the source port (not just the NM port as shown in Figure 10). By using multicast/broadcast frames, traffic can be routed selectively between ports involved in the test or return the frame directly before retransmission on the uplink. Software control of the external PHYs is required to configure them for loopback.

If the internal PCS is in use (port configured in PMA mode) loopback in PCSxcontrol also must be asserted. This causes MxxEWRAP to be high, forcing external PMD into loopback mode.

Duplex frame-wrap test mode is selected by setting dpwrap in Systest. When selected, the port is forced into full duplex, allowing it to receive frames it transmits.

The switch is configured in the same manner as internal wrap.



Figure 11. Duplex Wrap Example



SPWS043B - NOVEMBER 1997 - REVISED APRIL 1999

#### port mirroring

It is possible to copy (or mirror) all frames that are received by and transmitted to a port designated by the Mirrorport register to the port designated by the Uplinkport register. This feature is enabled if the mirr bit in Syscontrol is set to 1, and disabled if it is 0.

If Mirrorport selects a port that is a member of a trunk, only that single specific port is mirrored. Frame traffic on the other trunk port(s) is not mirrored. The Uplinkport register should not select a port within a trunk (undesired behavior can occur if this is done).

## copy to uplink

If destination address is a unicast and the cuplnk bit of its address record is set to 1 (via a DIO add), when a frame specifies that address as the destination, a copy of the frame also is sent to the port specified in the Uplinkport register. The Uplinkport register should not be set to select a port within a trunk (undesired behavior can occur if this is done).



## absolute maximum ratings over operating junction temperature range (unless otherwise noted)†

| Supply voltage range: V <sub>DD(2.5V)</sub> 0.5 V to 2.7 V                            | S  |
|---------------------------------------------------------------------------------------|----|
| V <sub>DD(3.3V)</sub>                                                                 |    |
| Input voltage range, V <sub>I</sub> : Standard                                        | In |
| Output voltage range, V <sub>O</sub> : Standard                                       | 0  |
| Thermal impedance: Junction-to-ambient package, airflow = 0, Z <sub>0JA</sub> ´15°C/W | TI |
| Junction-to-ambient package, airflow = 150 fpm, Z <sub>0JA</sub>                      |    |
| Junction-to-case package, 0 Z <sub>0</sub> JC                                         |    |
| Operating case temperature range, T <sub>C</sub>                                      | 0  |
| Storage temperature range, T <sub>stq</sub>                                           | S  |

<sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## recommended operating conditions

|                        |                             | MIN | NOM | MAX  | UNIT |
|------------------------|-----------------------------|-----|-----|------|------|
| VDD(2.5V)              | Supply voltage              | 2.3 | 2.5 | 2.7  | V    |
| V <sub>DD</sub> (3.3V) | Supply voltage              | 3   | 3.3 | 3.6  | V    |
| VIH                    | High-level dc input voltage | 2.3 |     | 3.3  | V    |
| VIL                    | Low-level dc input voltage  | 0   |     | 0.65 | V    |
| IOH                    | High-level output current   |     |     | -2   | mA   |
| loL                    | Low-level output current    |     |     | -2   | mA   |

## electrical characteristics over recommended operating conditions (unless otherwise noted)

|                       | PARAMETER                           | TEST CONDITIONS                      | MIN | TYP | MAX   | UNIT |
|-----------------------|-------------------------------------|--------------------------------------|-----|-----|-------|------|
| Vон                   | High-level output voltage           | I <sub>OH</sub> = rated              | 2.5 |     |       | V    |
| VOL                   | Low-level output voltage            | I <sub>OL</sub> = rated              |     |     | 0.5   | V    |
| lн                    | High-level input current            | $V_I = V_{DD(3.3V)}$                 |     |     | 1     | μΑ   |
| IIL                   | Low-level input current             | V <sub>I</sub> = GND                 |     |     | -1    | μΑ   |
| loz                   | High-impedance-state output current | $V_O = V_{DD(3.3V)}, \qquad V_O = 0$ |     |     | ±10   | μΑ   |
| I <sub>DD(2.5V)</sub> | Supply current                      | $V_{DD(2.5V)} = max$ , f = 83.33 MHz |     |     | 1.5   | Α    |
| I <sub>DD(3.3V)</sub> | Supply current                      | $V_{DD(3.3V)} = max$ , f = 83.33 MHz |     |     | 0.175 | Α    |
| Ci                    | Capacitance, input                  |                                      |     | 6   |       | pF   |
| Co                    | Capacitance, output                 |                                      |     | 6   |       | pF   |

NOTES: 1. Applies to external input buffers. Level-shifting inputs are relative to V<sub>DD(3.3V)</sub>.

<sup>2.</sup> Applies to external output buffers. Level-shifting outputs are relative to VDD(3.3V).

#### PARAMETER MEASUREMENT INFORMATION

Outputs are driven to a minimum high-logic level of 3.3 V and to a maximum low-logic level of 0 V.

Output transition times are specified as follows: For a high-to-low transition on either an input or output signal, the level at which the signal is said to be no longer high is 1.4 V and the level at which the signal is said to be low is 1.4 V. For a low-to-high transition, the level at which the signal is said to be no longer low is 0.8 V and the level at which the signal is said to be high is 2 V, as shown in the following.

The rise and fall times are not specified but are assumed to be those of standard TTL devices, which are typically 1.5 ns.



#### test measurement

The test-and-load circuit shown in Figure 12 represents the programmable load of the tester pin that is used to verify timing parameters of the TNETX3270 output signals.



TTL OUTPUT TEST LOAD

Where:  $I_{OL}$  = Refer to  $I_{OL}$  in recommended operating conditions.

I<sub>OH</sub> = Refer to I<sub>OH</sub> in recommended operating conditions.

V<sub>LOAD</sub>= 1.5 V, typical dc-level verification or

1.5 V, typical timing verification

C<sub>L</sub> = 45 pF, typical load-circuit capacitance

Figure 12. Test-and-Load Circuit

## 10-Mbit/s interface (ports 00-23)

## timing requirements (see Notes 3 through 6 and Figure 13)

| NO. |                          |                                                  | MIN | MAX | UNIT |
|-----|--------------------------|--------------------------------------------------|-----|-----|------|
| 1   | t <sub>c(THxCLK)</sub> † | Cycle time, THxCLK                               | 50  | 58  | ns   |
| 2   | T <sub>w(THxCLK)</sub>   | Pulse duration, THxCLK high or low               | 23  | 27  | ns   |
| 3   | t <sub>su(THxSYNC)</sub> | Setup time, THxSYNC high before THxCLK↓          | 8   |     | ns   |
| 4   | tsu(THxCOL)              | Setup time, THxCOL high before THxCLK↑           | 8   |     | ns   |
| 4   | t <sub>su</sub> (THxCRS) | Setup time, THxCRS high before THxCLK↑           | 8   |     | ns   |
| 4   | <sup>t</sup> su(THxLINK) | Setup time, THxLINK high before THxCLK↑          | 8   |     | ns   |
| 4   | t <sub>su</sub> (THxRXD) | Setup time, THxRXD3–THxRXD0 valid before THxCLK↑ | 8   |     | ns   |
| 4   | <sup>t</sup> su(THxRXDV) | Setup time, THxRXDV high before THxCLK↑          | 8   |     | ns   |
| 5   | th(THxSYNC)              | Hold time, THxSYNC high after THxCLK↓            | 8   |     | ns   |
| 6   | th(THxCOL)               | Hold time, THxCOL high after THxCLK↑             | 8   |     | ns   |
| 6   | th(THxCRS)               | Hold time, THxCRS high after THxCLK↑             | 8   |     | ns   |
| 6   | th(THxLINK)              | Hold time, THxLINK high after THxCLK↑            | 8   |     | ns   |
| 6   | <sup>t</sup> h(THxRXD)   | Hold time, THxRXD3–THxRXD0 valid after THxCLK↑   | 8   |     | ns   |
| 6   | <sup>t</sup> h(THxRXV)   | Hold time, THxRXDV high after THxCLK↑            | 8   |     | ns   |
|     | tr(THxCLK)               | Rise time, THxCLK                                |     | 2   | ns   |
|     | <sup>t</sup> f(THxCLK)   | Fall time, THxCLK                                |     | 2   | ns   |

† THx = TH0, TH1, and TH2

NOTES: 3. The TNETE2008 must supply at least two THxSYNC pulses under normal conditions before driving valid data on the inputs to the TNETX3270, or before expecting valid data on the outputs from the TNETX3270. This means that at least two full sequences must be executed; only with the third THxSYNC pulse is valid data presented/expected.

- 4. At least two clocks must be driven before the deassertion of the system reset signal, and a minimum of two clocks must be driven after the deassertion of the the system reset signal to ensure complete initialization of the internal circuitry of the TNETX3270 before there is any valid activity across the interface.
- 5. For receive data, the TNETE2008 asserts the THxCOL signal during the appropriate slot time if it was asserted for any of the four bits of data corresponding to that slot time.
- 6. For receive data, the TNETE2008 asserts the THxRXDV signal only if there are four valid bits of data in the nibble.

## operating characteristics over recommended operating conditions (see Notes 3 through 6 and Figure 13)

| NO. |                          | PARAMETER                                           | MIN | MAX  | UNIT |
|-----|--------------------------|-----------------------------------------------------|-----|------|------|
| 7   | t <sub>d(THxEN)</sub> †  | Delay time, from THxCLK↑ to THxTXEN↑                |     | 13.5 | ns   |
| 7   | <sup>t</sup> d(THxTXD)   | Delay time, from THxCLK↑ to THxTXD3–THxTXD0 valid   |     | 13.5 | ns   |
| 7   | <sup>t</sup> d(THxRENEG) | Delay time, from THxCLK↑ to THxRENEG↓               |     | 13.5 | ns   |
| 8   | <sup>t</sup> d(THxTXEN)  | Delay time, from THxCLK↑ to THxTXEN↓                |     | 0    | ns   |
| 8   | <sup>t</sup> d(THxTXD)   | Delay time, from THxCLK↑ to THxTXD3–THxTXD0 invalid |     | 0    | ns   |
| 8   | td(THxRENEG)             | Delay time, from THxCLK↑ to THxRENEG↑               |     | 0    | ns   |

†THx = TH0, TH1, and TH2

NOTES: 3. The TNETE2008 must supply at least two THxSYNC pulses under normal conditions before driving valid data on the inputs to the TNETX3270, or before expecting valid data on the outputs from the TNETX3270. This means that at least two full sequences must be executed; only with the third THxSYNC pulse is valid data presented/expected.

- 4. At least two clocks must be driven before the deassertion of the system reset signal, and a minimum of two clocks must be driven after the deassertion of the the system reset signal to ensure complete initialization of the internal circuitry of the TNETX3270 before there is any valid activity across the interface.
- 5. For receive data, TNETE2008 asserts the THxCOL signal during the appropriate slot time if it was asserted for any of the four bits of data corresponding to that slot time.
- 6. For receive data, the TNETE2008 asserts the THxRXDV signal only if there are four valid bits of data in the nibble.





Figure 13. 10-Mbit/s Interface (Ports 00-23)

#### 10-/100-Mbit/s MAC interface

Figures 14 and 15 show the timings at 100 Mbit/s and 10 Mbit/s for the 10-/100-Mbit/s port interfaces to the TNETE2101 devices.

#### 10-/100-Mbit/s receive ports (24, 25, 26)

## timing requirements (see Note 7 and Figure 14)

| NO. |                           |                                                   | MIN | MAX | UNIT |
|-----|---------------------------|---------------------------------------------------|-----|-----|------|
| 1   | t <sub>c</sub> (MxxRCLK)  | Cycle time, MxxRCLK                               | 25  | 25  | ns   |
| 2   | tw(MxxRCLKL)              | Pulse duration, MxxRCLK low                       |     |     | ns   |
| 3   | tw(MxxRCLKH)              | Pulse duration, MxxRCLK high                      | 14  |     | ns   |
| 4†  | t <sub>su</sub> (MxxRXD)  | Setup time, MxxRXD3-MxxRXD0 valid before MxxRCLK↑ | 5   |     | ns   |
| 4†  | t <sub>su</sub> (MxxRXDV) | Setup time, MxxRXDV valid before MxxRCLK↑         | 5   |     | ns   |
| 4†  | t <sub>su</sub> (MxxRXER) | Setup time, MxxRXER valid before MxxRCLK↑         | 5   |     | ns   |
| 5†  | th(MxxRXD)                | Hold time, MxxRXD3–MxxRXD0 valid after MxxRCLK↑   | 5   |     | ns   |
| 5†  | th(MxxRXDV)               | Hold time, MxxRXDV valid after MxxRCLK↑           | 5   |     | ns   |
| 5†  | th(MxxRXER)               | Hold time, MxxRXER valid after MxxRCLK↑           | 5   |     | ns   |

 $^{\dagger}$  xx = ports 24, 25, and 26

NOTE 7: Both MxxCRS and MxxCOL are driven asynchronously by the PHY. MxxRXD3–MxxRXD0 is driven by the PHY on the falling edge of MxxRCLK. MxxRXD3–MxxRXD0 timing must be met during clock periods when MxxRXDV is asserted. MxxRXDV is asserted and deasserted by the PHY on the falling edge of MxxRCLK. MxxRXER is driven by the PHY on the falling edge of MxxRCLK.



Figure 14. 10-/100-Mbit/s Receive Ports



#### 10-/100-Mbit/s transmit ports (24, 25, and 26)

## timing requirements (see Figure 15)

| NO. |                                                        | MIN | MAX | UNIT |
|-----|--------------------------------------------------------|-----|-----|------|
| 1   | t <sub>C(MxxTCLK)</sub> Cycle time, MxxTCLK            | 25  | 25  | ns   |
| 2   | t <sub>W(MxxTCLKL)</sub> Pulse duration, MxxTCLK low   |     |     | ns   |
| 3   | t <sub>W</sub> (MxxTCLKH) Pulse duration, MxxTCLK high | 14  |     | ns   |

## operating characteristics over recommended operating conditions (see Note 8 and Figure 15)

| NO. | PARAMETER                                                                 | MIN | MAX | UNIT |
|-----|---------------------------------------------------------------------------|-----|-----|------|
| 4†  | t <sub>d(MxxTXD)</sub> Delay time, from MxxTCLK↑ to MxxTXD3–MxxTXD0 valid | 0   | 25  | ns   |
| 4†  | t <sub>d(MxxTXEN)</sub> Delay time, from MxxTCLK↑ to MxxTXEN valid        | 0   | 25  | ns   |
| 4†  | t <sub>d(MxxTXER)</sub> Delay time, from MxxTCLK↑ to MxxTXER valid        | 0   | 25  | ns   |

 $\dagger xx = ports 24, 25, and 26$ 

NOTE 8: Both MxxCRS and MxxCOL are driven asynchronously by the PHY. MxxTXD3–MxxTXD0 is driven by the reconciliation sublayer synchronous to the MxxTCLK. MxxTXEN is asserted and deasserted by the reconciliation sublayer synchronous to the MxxTCLK rising edge. MxxTXER is driven synchronous to the rising edge of MxxTCLK.



Figure 15. 10-/100-Mbit/s Transmit Ports

#### **SDRAM** interface

The SDRAM interface observes two types of timing:

- Multicycle timings between commands
- Subcycle timings between signals and DCLK

Figure 16 illustrates the SDRAM interfaces signal timing in which each type of SDRAM command and its interrelated timings are shown. It is not intended to be representative of any particular receive or transmit buffer operation.

## SDRAM command to command (see Figure 16)

| SYMBOL           | PARAMETER                                                                        | MIN | MAX | UNIT |
|------------------|----------------------------------------------------------------------------------|-----|-----|------|
| <sup>t</sup> RSA | MRS to ACTV or REFR                                                              | 24  |     | ns   |
| tRC              | Row cycle time (ACTV to REFR to next ACTV or REFR)                               | 120 |     | ns   |
| t <sub>RAS</sub> | Row active time (ACTV to DCAB)                                                   | 72  |     | ns   |
| t <sub>RP</sub>  | Row recharge time (DCAB to ACTV, REFR, or MRS)                                   | 36  |     | ns   |
| <sup>t</sup> RCD | Row to column delay (ACTV to READ or WRT)                                        | 36  |     | ns   |
| tAC3             | Column access time [READ (CAS) latency] (READ to data sample)                    | 36  |     | ns   |
| nCCD             | Column address to column address (WRT to next READ or WRT, or READ to next READ) | 24  |     | ns   |
| nCWL             | Last data or write to new column address (WRT to next READ or WRT)               | 24  |     | ns   |
| tRWD             | Read to write delay (READ to next WRT)                                           | 60  |     | ns   |
| twR              | Write recovery time (WRT to DCAB)                                                | 24  |     | ns   |



Figure 16. SDRAM Command to Command



## **SDRAM** subcycle

## operating characteristics over recommended operating conditions (see Figure 17)

| NO. |                       | PARAMETER                                                                        | MIN | MAX | UNIT |
|-----|-----------------------|----------------------------------------------------------------------------------|-----|-----|------|
| 1   | t <sub>c(DCLK)</sub>  | Cycle time, DCLK                                                                 | 12  | 12  | ns   |
| 2   | tw(DCLKL)             | Pulse duration, DCLK low                                                         | 5   |     | ns   |
| 3   | tw(DCLKH)             | Pulse duration, DCLK high                                                        | 5   |     | ns   |
| 4   | <sup>t</sup> d(DCLK)  | Delay time, from DA, DRAS, DCAS, and DW valid to DCLK↑                           | 4   |     | ns   |
| 5   | td(DA)                | Delay time, from DCLK↑ to DA, DRAS, DCAS, and DW invalid                         | 2   |     | ns   |
| 6   | ten(DDW)              | Enable time, from DCLK↑ to before DD31–DD00 driven (write cycle)                 | 0   |     | ns   |
| 7   | ten(DDR)              | Enable time, from DCLK↑ to before DD31–DD00 driven (read cycle)                  | 0   |     | ns   |
| 8   | <sup>t</sup> dis(DDW) | Disable time, from DCLK↑ to after DD31–DD00 (after final write cycle) to Z state |     | 10  | ns   |
| 9   | <sup>t</sup> dis(DDR) | Disable time, from DCLK↑ to after DD31–DD00 (after final read cycle) to Z state  |     | 11  | ns   |
| 10  | td(DDW)1              | Delay time, from DD valid to DCLK↑ (write cycle)                                 | 4   |     | ns   |
| 11  | td(DDW)2              | Delay time, from DCLK↑ to DD31–DD00 Z state (write cycle)                        | 2   |     | ns   |
| 12  | <sup>t</sup> d(DDR)1  | Delay time, from DCLK↑ to DD31–DD00 valid (read cycle)                           |     | 10  | ns   |
| 13  | <sup>t</sup> d(DDR)2  | Delay time, from DCLK↑ to DD31–DD00 invalid (read cycle)                         | 0   |     | ns   |
|     | t <sub>t</sub>        | Transition time, rise and fall, all signals                                      | 1   | 4   | ns   |



Figure 17. SDRAM Subcycle

#### **DIO/DMA** interface

The DIO interface is asynchronous to allow easy adaptation to a range of microprocessor devices and computer system interfaces.

## DIO/DMA write cycle

### timing requirements (see Figure 18)

| NO. |                        |                                                  | MIN | MAX | UNIT |
|-----|------------------------|--------------------------------------------------|-----|-----|------|
| 1   | tw(SCSL)               | Pulse duration, SCS low                          | 24  |     | ns   |
| 2   | tw(SCSH)               | Pulse duration, SCS high                         |     | 12  | ns   |
| 3   | t <sub>su(SRNW)</sub>  | Setup time, SRNW low before SCS↓                 | 0   |     | ns   |
| 4   | t <sub>su(SAD)</sub>   | Setup time, SAD1–SAD0 and SDMA valid before SCS↓ | 0   |     | ns   |
| 5   | t <sub>su(SDATA)</sub> | Setup time, SDATA7–SDATA0 valid before SCS↓      | 0   |     | ns   |

## operating characteristics over recommended operating conditions (see Figure 18)

| NO. |                       | PARAMETER                                            | MIN | MAX | UNIT |
|-----|-----------------------|------------------------------------------------------|-----|-----|------|
| 6   | tw(SRDYH)             | Pulse duration, SRDY high                            |     | 12  | ns   |
| 7   | <sup>t</sup> d(SRNW)  | Delay time, from SRDY↓ to SRNW↑                      | 0   |     | ns   |
| 8   | <sup>t</sup> d(SAD)   | Delay time, from SRDY↓ to SAD1–SAD0 and SDMA invalid | 0   |     | ns   |
| 9   | <sup>t</sup> d(SDATA) | Delay time, from SRDY↓ to SDATA7–SDATA0 invalid      | 0   |     | ns   |
| 10  | td(SCS)               | Delay time, from SRDY↓ to SCS↑                       | 0   |     | ns   |
| 11  | td(SRDY)1             | Delay time, from SCS↓ to SRDY↑                       | 0   |     | ns   |
| 12  | td(SRDY)2             | Delay time, from SCS↓ to SRDY↓†                      | 0   | ·   | ns   |
| 13  | td(SRDY)3             | Delay time, from SCS↑ to SRDY↑                       | 0   | 24  | ns   |

<sup>†</sup> When the switch is performing certain internal operations (e.g., EEPROM load), there may be a considerable delay (approximately 25–100 ms) between SCS being asserted and SRDY being asserted.



Figure 18. DIO/DMA Write Cycle



## DIO/DMA read cycle

## timing requirements (see Figure 19)

| NO. |                                                                                                    | MIN | MAX | UNIT |
|-----|----------------------------------------------------------------------------------------------------|-----|-----|------|
| 1   | t <sub>W(SCSL)</sub> Pulse duration, SCS low                                                       |     |     | ns   |
| 2   | t <sub>W</sub> (SCSH) Pulse duration, SCS high                                                     |     | 14  | ns   |
| 3   | t <sub>SU(SRNW)</sub> Setup time, SRNW high before SCS↓                                            | 0   |     | ns   |
| 4   | $t_{SU(SAD)}$ Setup time, SAD1–SAD0 and $\overline{SDMA}$ valid before $\overline{SCS} \downarrow$ | 0   |     | ns   |

## operating characteristics over recommended operating conditions (see Figure 19)

| NO. |                        | PARAMETER                                            | MIN | MAX | UNIT |
|-----|------------------------|------------------------------------------------------|-----|-----|------|
| 5   | <sup>t</sup> w(SRDYH)  | Pulse duration, SRDY high                            |     | 12  | ns   |
| 6   | <sup>t</sup> d(SRNW)   | Delay time, from SRDY↓ to SRNW↓                      | 0   |     | ns   |
| 7   | <sup>t</sup> d(SAD)    | Delay time, from SRDY↓ to SAD1–SAD0 and SDMA invalid | 0   |     | ns   |
| 8   | td(SCS)                | Delay time, from SRDY↓ to SCS↑                       | 0   |     | ns   |
| 9   | <sup>t</sup> d(SRDY)   | Delay time, from SDATA7–SDATA0 to SRDY↓              | 0   |     | ns   |
| 10  | <sup>t</sup> d(SRDYZH) | Delay time, from SCS↓ to SRDY↑                       | 0   |     | ns   |
| 11  | <sup>t</sup> d(SRDY)2  | Delay time, from SCS↓ to SRDY↓†                      | 0   |     | ns   |
| 12  | <sup>t</sup> d(SDATAZ) | Delay time, from SCS↑ to SDATA7–SDATA0 Z state       | 0   | 6   | ns   |
| 13  | <sup>t</sup> d(SRDY)3  | Delay time, from SCS↑ to SRDY↑                       | 0   | 12  | ns   |

<sup>†</sup> When the switch is performing certain internal operations (e.g., EEPROM load), there may be a considerable delay (approximately 25–100 ms) between SCS being asserted and SRDY being asserted.



Figure 19. DIO/DMA Read Cycle



## SPWS043B – NOVEMBER 1997 – REVISED APRIL 1999 serial MII management interface

## timing requirements (see Figure 20)

| NO. |                                                                  | MIN | MAX | UNIT |
|-----|------------------------------------------------------------------|-----|-----|------|
| 1   | t <sub>su(MDIO)</sub> Setup time, MDIO valid before OSCIN↑, read | 7   |     | ns   |
| 2   | th(MDIO) Hold time, MDIO valid after OSCIN↑, read                | 3   |     | ns   |

## operating characteristics over recommended operating conditions (see Figure 20)

| NO. |                          | PARAMETER                                                        | MIN | MAX | UNIT |
|-----|--------------------------|------------------------------------------------------------------|-----|-----|------|
| 3   | <sup>t</sup> d(MDIO)     | Delay time, from OSCIN↑ to MDIO valid, write                     |     | 11  | ns   |
| 4   | <sup>t</sup> d(MDCLK)    | Delay time, from OSCIN↑ to MDCLK↑                                |     | 11  | ns   |
| 5   | <sup>t</sup> d(MRESET)   | Delay time, from OSCIN↑ to MRESET↓                               |     | 11  | ns   |
| 6   | <sup>t</sup> dis(MDIO)   | Disable time, from OSCIN↑ to after MDIO to Z state, read         |     | 11  | ns   |
| 7   | <sup>t</sup> dis(MDCLK)  | Disable time, from OSCIN↑ to after MDCLK to Z state              |     | 11  | ns   |
| 8   | <sup>t</sup> dis(MRESET) | Disable time, from OSCIN <sup>↑</sup> to after MRESET to Z state |     | 11  | ns   |
| 9   | ten(MDIO)                | Enable time, from OSCIN <sup>↑</sup> to before MDIO valid        |     | 11  | ns   |
| 10  | ten(MDCLK)               | Enable time, from OSCIN <sup>↑</sup> to before MDCLK valid       |     | 11  | ns   |
| 11  | ten(MRESET)              | Enable time, from OSCIN <sup>↑</sup> to before MRESET valid      |     | 11  | ns   |



Figure 20. Serial MII Management Read/Write Cycle

#### **EEPROM** interface

## operating characteristics over recommended operating conditions (see Figure 21)

| NO. |                  | PARAMETER                                             | TNET | (3150 | TNETX | 3150A | UNIT |
|-----|------------------|-------------------------------------------------------|------|-------|-------|-------|------|
| NO. |                  | PARAMETER                                             | MIN  | MAX   | MIN   | MAX   | UNIT |
|     | fclock (ECLK)    | Clock frequency, ECLK                                 |      | 98    |       | 98    | kHz  |
| 1   | td (ECLKH-EDIOL) | Delay time, from ECLK↑ to EDIO↓ (see Note 9)          | 5    |       | 5     |       | μs   |
| 2   | td (EDIOL-ECLKL) | Delay time, from EDIO↓ to ECLK↓ (see Note 9)          | 5    |       | 5     |       | μs   |
| 3   | td (ECLKL-EDIOX) | Delay time, from ECLK↓ to EDIO changing (see Note 10) | 0    |       | 0     |       | μs   |
| 4   | td (EDIOV-ECLKH) | Delay time, from EDIO valid output to ECLK↑           | 0    |       | 0     |       | μs   |
| 5   | td (ECLKL-EDIOV) | Delay time, from ECLK↓ to EDIO valid                  | 0    |       | 0     |       | μs   |
| 6   | td (ECLKL-EDIOX) | Delay time, from ECLK↓ to EDIO changing (see Note 11) | 0    |       | 0     |       | μs   |
| 7   | td (ECLKH-EDIOX) | Delay time, from ECLK↑ to EDIO invalid                | 5    |       | 5     |       | μs   |
| 8   | td (EDIOV-ECLKH) | Delay time, from EDIO valid input to ECLK↑            | 10   |       | 10    |       | μs   |

NOTES: 9. This is a start condition delay time during ECLK high.

- 10. This is a changing-data condition delay time for output EDIO.
- 11. This is a changing-data condition delay time for input EDIO.



Figure 21. EEPROM

### **LED** interface

## operating characteristics over recommended operating conditions (see Figure 22)

| NO. |                         | PARAMETER                                             | MIN | MAX | UNIT |
|-----|-------------------------|-------------------------------------------------------|-----|-----|------|
| 1   | t <sub>C</sub> (LEDCLK) | Cycle time, LEDCLK                                    |     | 96  | ns   |
| 2   | tw(LEDCLKH)             | Pulse duration, LEDCLK high                           | 38  | 58  | ns   |
| 3   |                         | Number of LEDCLK pulses in burst                      |     | 48† |      |
| 4   | tc(BURST)               | Cycle time, LEDCLK burst                              |     | 62  | ms   |
| 5   | td(LEDCLK)              | Delay time, from LEDDATA to LEDCLK↑                   |     | 12  | μs   |
| 6   | <sup>t</sup> d(LEDDATA) | Delay time, from LEDCLK↑ to LEDDATA (1st LED invalid) |     | 84  | μs   |

<sup>†</sup> During hard reset, LEDCLK runs continuously.



Figure 22. LED

## power-up OSCIN and RESET

## timing requirements (see Figure 23)

| NO. |                       |                                                        | MIN | NOM | MAX | UNIT |
|-----|-----------------------|--------------------------------------------------------|-----|-----|-----|------|
|     |                       | Frequency drift, OSCIN clock                           |     |     | ±50 | ppm  |
| 1   | tc(OSCIN)             | Cycle time, OSCIN                                      |     | 12  |     | ns   |
| 2   | tw(OSCINL)            | Pulse duration, OSCIN low                              | 4.8 |     | 7.2 | ns   |
| 3   | tw(OSCINH)            | Pulse duration, OSCIN high                             | 4.8 |     | 7.2 | ns   |
| 4   | tw(RESET)             | Pulse duration, RESET low                              | 200 |     |     | μs   |
| 5   | tsu(RESET)            | Setup time, RESET low before OSCIN↑                    | 7   |     |     | ns   |
| 6   | th(RESET)             | Hold time, RESET low after OSCIN↑                      | 3   |     |     | ns   |
| 7   | td(OSCIN)             | Delay time, from OSCIN invalid to OSCIN valid (stable) | 25  |     |     | ms   |
| 8   | <sup>t</sup> d(RESET) | Delay time, from OSCIN stable to RESET↑                | 25  |     |     | ms   |
| 9   | tt(OSCIN)             | Transition time, OSCIN rise and fall                   |     |     | 2   | ns   |

RESET must be held low at least 25 ms after both power supplies are stable and OSCIN has reached its stable operating frequency. RESET can be set to 0 for a minimum of 200 µs to reset the device.



Figure 23. Power-Up OSCIN and RESET

#### **MECHANICAL DATA**

## PGV (S-PQFP-G240)

## PLASTIC QUAD FLATPACK (DIE-DOWN)



NOTES: A. All linear dimensions are in millimeters.

- B. This drawing is subject to change without notice.
- C. Thermally enhanced molded plastic package with a heat slug (HSL)



#### **IMPORTANT NOTICE**

Texas Instruments and its subsidiaries (TI) reserve the right to make changes to their products or to discontinue any product or service without notice, and advise customers to obtain the latest version of relevant information to verify, before placing orders, that information being relied on is current and complete. All products are sold subject to the terms and conditions of sale supplied at the time of order acknowledgement, including those pertaining to warranty, patent infringement, and limitation of liability.

TI warrants performance of its semiconductor products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems necessary to support this warranty. Specific testing of all parameters of each device is not necessarily performed, except those mandated by government requirements.

CERTAIN APPLICATIONS USING SEMICONDUCTOR PRODUCTS MAY INVOLVE POTENTIAL RISKS OF DEATH, PERSONAL INJURY, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE ("CRITICAL APPLICATIONS"). TI SEMICONDUCTOR PRODUCTS ARE NOT DESIGNED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS. INCLUSION OF TI PRODUCTS IN SUCH APPLICATIONS IS UNDERSTOOD TO BE FULLY AT THE CUSTOMER'S RISK.

In order to minimize risks associated with the customer's applications, adequate design and operating safeguards must be provided by the customer to minimize inherent or procedural hazards.

TI assumes no liability for applications assistance or customer product design. TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor products or services might be or are used. TI's publication of information regarding any third party's products or services does not constitute TI's approval, warranty or endorsement thereof.

Copyright © 1999, Texas Instruments Incorporated

Free Manuals Download Website

http://myh66.com

http://usermanuals.us

http://www.somanuals.com

http://www.4manuals.cc

http://www.manual-lib.com

http://www.404manual.com

http://www.luxmanual.com

http://aubethermostatmanual.com

Golf course search by state

http://golfingnear.com

Email search by domain

http://emailbydomain.com

Auto manuals search

http://auto.somanuals.com

TV manuals search

http://tv.somanuals.com