# Micro Linear

ML6691\*

# **100BASE-T MII-to-PMD Transceiver**

### **GENERAL DESCRIPTION**

The ML6691 implements the upper portion of the physical layer for the Fast Ethernet 100BASE-T standard. Functions contained in the ML6691 include a 4B/5B encoder/ decoder, a Stream Cipher scrambler/descrambler, and collision detect. Additional functions of the ML6691 — accessible through the two-wire MII management interface — include full duplex operation, loopback, power down mode, and MII isolation.

The ML6691 is designed to interface to a 100BASE-T Ethernet Media Access Controller (MAC) via the MII (Media Independent Interface) on one side, and a 100BASE-X PMD transceiver on the other side. A complete 100BASE-TX physical layer (PHY) solution is realized using the ML6691, the ML6673, and one of the available clock recovery/generation devices. A 100BASE-FX physical layer solution is implemented by disabling the scrambler function of the ML6691 and using an external optical PMD.

#### **FEATURES**

- Conforms to the Fast Ethernet 100BASE-T IEEE 802.3µ standard
- Integrated 4B/5B encoder/decoder
- Integrated Stream Cipher scrambler/descrambler
- Compliant MII interface
- Two-wire serial interface management port for configuration and control
- On-chip 25 MHz crystal oscillator
- Interfaces to either AMD's PDT/PDR (AM79865/79866) or Motorola's FCG (MC68836)
- Used with ML6673 for 100BASE-TX solutions
- 44-pin PLCC package

#### \* This Part Is End Of Life As Of August 1, 2000



🔍 Micro Linear

# ML6691

### **PIN CONFIGURATION**



### **PIN DESCRIPTION**

| PIN#            | NAME     | FUNCTION                                                                                                                                                                                     | PIN#  | NAME     | FUNCTION                                                                                                                                                                                     |  |
|-----------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1,21            | $V_{CC}$ | Positive 5 volt supply.                                                                                                                                                                      | 12    | CRS      | Carrier sense output. A logic high                                                                                                                                                           |  |
| 2,3,4,<br>43,44 | AD[4:0]  | Local PHY address. These 5 inputs set<br>the address to which the local physical<br>layer responds. When an address<br>match is detected, the <u>CS</u> output is                            |       |          | indicates that either the transmit or<br>receive medium is non-idle. CRS is<br>deasserted when both transmit and<br>receive are idle.                                                        |  |
|                 |          | asserted.                                                                                                                                                                                    | 13    | COL      | Collision detect output. A logic high                                                                                                                                                        |  |
| 5               | TXCLK    | Transmit clock output. Continuous<br>25MHz clock provides the timing<br>reference for the transfer of TXEN,                                                                                  |       |          | indicates a collision (simultaneous<br>transmit and receive in half duplex<br>mode).                                                                                                         |  |
|                 |          | TXER, and TXD[3:0] from the MAC.<br>TXCLK is generated from the TXC<br>input.                                                                                                                | 14-17 | RXD[3:0] | wide data for transmission to the MAO RXD[0] is the least significant bit.                                                                                                                   |  |
| 6               | TXEN     | Transmit enable input. A logic high<br>enables the transmit section of the<br>ML6691. This signal indicates the<br>MAC is transmitting nibble-wide data.<br>TXEN is synchronous to TXCLK.    | 18    | RXDV     | RXD[3:0] is synchronous to RXCLK.<br>Receive data valid output. A logic high<br>indicates the ML6691 is presenting<br>valid nibble-wide data. RXDV shall<br>remain asserted from the first   |  |
| 7               | TXER     | Transmit error input. When TXER is<br>high , while TXEN is asserted, the<br>ML6691 will insert an "H" symbol in<br>the data stream. TXER is synchronous<br>to TXCLK.                         |       |          | recovered nibble of the frame through<br>the final recovered nibble. RXDV will<br>be de-asserted prior to the first RXCLK<br>that follows the final nibble. RXDV is<br>synchronous to RXCLK. |  |
| 8-11            | TXD[3:0] | Transmit nibble data inputs. Nibble-<br>wide data from the MAC. For data<br>transmission TXEN must be asserted.<br>TXD[0] is the least significant bit.<br>TXD[3:0] is synchronous to TXCLK. | 19    | RXER     | Receive error output. Active high,<br>indicates that a coding error was<br>detected. RXER is synchronous to<br>RXCLK.                                                                        |  |



## PIN DESCRIPTION (Continued)

| PIN# | NAME        | FUNCTION                                                                                                                                                                                                                                                         |
|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20   | RXCLK       | Receive clock output. Continuous<br>25 MHz clock provides the timing<br>reference for the transfer of RXDV,<br>RXER, and RXD[3:0] to the MAC.                                                                                                                    |
| 22   | DCFR        | Scrambler/descrambler disable. A<br>logic high on this input disables the<br>Stream Cipher scrambler/descrambler.                                                                                                                                                |
| 23   | GND         | Ground                                                                                                                                                                                                                                                           |
| 24   | LOCAL       | Local/remote. A logic low on this input<br>places the ML6691 in remote mode, in<br>which the MII interface is disabled at<br>power on or after a reset operation.<br>When low, the isolate bit of the<br>Control register will be set upon power<br>up or reset. |
| 25   | RST         | Reset. A logic high on this input resets<br>the Status and Control registers to their<br>default states.                                                                                                                                                         |
| 26   | <u>CS</u>   | Chip select. A logic low is generated<br>on this output when the ML6691<br>detects an address match.                                                                                                                                                             |
| 27   | <u>LPBK</u> | Loopback. A logic low on this output indicates the loopback function.                                                                                                                                                                                            |
| 28   | RXC         | Receive symbol clock. A 25 MHz<br>clock input from the PMD layer. The<br>rising edge of RXC is used to sample<br>RSM[4:0].                                                                                                                                       |

| PIN#  | NAME     | FUNCTION                                                                                                                                                                      |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29-33 | RSM[4:0] | Receive symbol data inputs. Symbol-<br>wide (encoded) data from the PMD<br>layer.                                                                                             |
| 34    | SD       | Signal detect. A logic high on this<br>input indicates the presence of non-<br>quiet data. The internal signal, linkfail,<br>is enabled 330µs after SD is asserted.           |
| 35-39 | TSM[4:0] | Transmit symbol data outputs. Symbol-<br>wide (encoded) data for transfer to the<br>PMD layer.                                                                                |
| 40    | ТХС      | Transmit symbol clock input. Input<br>used to generate TXCLK. Use either a<br>25 MHz crystal or a 25 MHz clock<br>between TXC input and GND.                                  |
| 41    | MDIO     | Management data input/output. A<br>bi-directional signal used to transfer<br>control and status information<br>between the ML6691 and the MAC.<br>MDIO is synchronous to MDC. |
| 42    | MDC      | Management data clock input. A low-<br>frequency aperiodic clock used as the<br>timing reference for transfer of<br>information on the MDIO signal.                           |



### ABSOLUTE MAXIMUM RATINGS

Absolute maximum ratings are those values beyond which the device could be permanently damaged. Absolute maximum ratings are stress ratings only and functional device operation is not implied.

| Supply Voltage (V <sub>CC</sub> )          | 6.0V                     |
|--------------------------------------------|--------------------------|
| GND                                        |                          |
| Logic Inputs                               | -0.3V to $V_{CC}$ + 0.3V |
| Input Current per Pin                      | ±25mA                    |
| Storage Temperature                        | –65°C to +150°C          |
| Package Dissipation at $T_A = 25^{\circ}C$ | 750mW                    |
| Lead Temperature (soldering 10 sec.).      |                          |

### **OPERATING CONDITIONS**

| Supply Voltage (V <sub>CC</sub> ) | 4.5V to 5.5V                     |
|-----------------------------------|----------------------------------|
| Temperature Range                 | $0^{\circ}C < T_A < 70^{\circ}C$ |

### **ELECTRICAL CHARACTERISTICS**

Unless otherwise specified, V<sub>CC</sub> = 5V  $\pm$  10%, C<sub>L</sub> = 15pF, T<sub>A</sub> = T<sub>MIN</sub> to T<sub>MAX</sub>

| PARAMETER SYMBOL         |                 | CONDITIONS                                                    | MIN         | ТҮР | MAX        | UNITS |  |
|--------------------------|-----------------|---------------------------------------------------------------|-------------|-----|------------|-------|--|
| DC Characteristics       |                 |                                                               |             | 1   |            |       |  |
| Logic Input Low          | V <sub>IL</sub> | All except TXC<br>TXC                                         |             |     | 0.8<br>1.5 | V     |  |
| Logic Input High         | V <sub>IH</sub> | All except TXC<br>TXC                                         | 2.0<br>3.5  |     |            | V     |  |
| Logic Input Low Current  | IIL             | $V_{IN} = 0$ , all except TXC<br>$V_{IN} = 0$ , TXC           | -10<br>-100 |     |            | μΑ    |  |
| Logic Input High Current | IIH             | $V_{IN} = V_{CC}$ , all except TXC<br>$V_{IN} = V_{CC}$ , TXC |             |     | 10<br>100  | μΑ    |  |
| Logic Output Low         | V <sub>OL</sub> | $I_{OL} = -4mA$                                               |             |     | 0.4        | V     |  |
| Logic Output High        | V <sub>OH</sub> | $I_{OH} = 4mA$                                                | 2.4         |     |            | V     |  |
| Input Capacitance        | C <sub>IN</sub> | All except TXC<br>TXC                                         |             |     | 8<br>12    | pF    |  |
| AC Characteristics       |                 |                                                               | ·           |     | ·          | ·     |  |
| TXD Setup Time           | t <sub>1</sub>  |                                                               | 15          |     |            | ns    |  |
| TXD Hold Time            | t <sub>2</sub>  |                                                               | 0           |     |            | ns    |  |
| TXC to TSM Delay         | t <sub>3</sub>  |                                                               | 5           |     | 25         | ns    |  |
| RSM Setup Time           | t <sub>4</sub>  |                                                               | 10          |     |            | ns    |  |
| RSM Hold Time            | t5              |                                                               | 5           |     |            | ns    |  |
| RXCLK to RXD Delay       | t <sub>6</sub>  |                                                               | 0           |     | 10         | ns    |  |
| MDIO Setup Time          | t <sub>7</sub>  |                                                               | 10          |     |            | ns    |  |
| MDIO Hold time           | t <sub>8</sub>  |                                                               | 10          |     |            | ns    |  |
| MDC to MDIO Delay        | t9              |                                                               | 0           |     | 300        | ns    |  |





Transmit Timing Relationships (MII Interface)



Transmit Timing Relationships (Physical Interface)



**Receive Timing Relationships (Physical Interface)** 



**Receive Timing Relationships (MII Interface)** 



Management Timing Relations (Sourced by STA)



Management Timing Relations (Sourced by PHY)



**Receiving Timing** 



### FUNCTIONAL DESCRIPTION

To describe the function of the ML6691, the device is separated into three sections, the Transmit Section, the Receive Section, and the Management section. Each section is discussed below.

#### TRANSMIT SECTION

The transmit section is responsible for converting transmit nibble data on the MII lines from the MAC into encoded and ciphered transmit symbols, as shown in Figure 1. The nibble input register samples the transmit nibble data on the MII lines and passes the nibble data onto the encoder. The encoder then converts the data to 4B/5B code (see Table 1) under the direction of the state machine. The state machine detects the leading edges of transmit enable and impresses the start of frame delimiter — the JK pair ignoring the TXD<3:0> during these two symbol times. If,

| HEX/4B | SYMBOL/5B | HEX/4B | SYMBOL/5B |
|--------|-----------|--------|-----------|
| 0000   | 11110     | J      | 11000     |
| 0001   | 01001     | K      | 10001     |
| 0010   | 10100     | Т      | 01101     |
| 0011   | 10101     | R      | 00111     |
| 0100   | 01010     | Н      | 00100     |
| 0101   | 01011     | IDLE   | 11111     |
| 0110   | 01110     |        |           |
| 0111   | 01111     |        |           |
| 1000   | 10010     |        |           |
| 1001   | 10011     |        |           |
| 1010   | 10110     |        |           |
| 1011   | 10111     |        |           |
| 1100   | 11010     |        |           |
| 1101   | 11011     |        |           |
| 1110   | 11100     |        |           |
| 1111   | 11101     |        |           |

Table 1. 4B/5B Encoding Table

while transmit enable is asserted, the transmit error is asserted, the H symbol will be impressed except during the time the JK pair is emitted. Following the trailing edge of transmit enable, the end of frame delimiter — the TR pair — is generated, after which the IDLE symbol is generated to fill the space between frames. The encoded data is then enciphered by performing a XOR with the output of the cipher register.

The cipher register is a linear feedback shift register which generates the cipher bit stream which is used to scramble the transmit symbol data. The Boolean algebra expression is listed below.

| TCFR11 = TCFR6<br>TCFR10 = TCFR5          |
|-------------------------------------------|
| TCFR9 = TCFR4                             |
| TCFR8 = TCFR3                             |
| TCFR7 = TCFR2                             |
| TCFR6 = NOT (TCFR11 OR TCFR10 OR TCFR9 OR |
| TCFR8 OR TCFR7 OR TCFR6 OR TCFR5 OR       |
| TCFR4 OR TCFR3 OR TCFR2) OR TCFR1         |
| TCFR5 = TCFR11 XOR TCFR9                  |
| TCFR4 = TCFR10 XOR TCFR8                  |
| TCFR3 = TCFR9 XOR TCFR7                   |
| TCFR2 = TCFR8 XOR TCFR6                   |
| TCFR1 = TCFR7 XOR TCFR5                   |

The enciphered data are then passed to the symbol output register which drives the generated symbol data out to the PMD transceiver.

Collision detect is implemented by noting the occurrence of reception during transmission. A linkfail indication at any time causes an immediate transition to the IDLE state and supersedes any other transmit operation.





Micro Linear

#### **RECEIVE SECTION**

The receive section is responsible for converting received unaligned symbols into deciphered, aligned and decoded nibble data on the MII lines, as shown in Figure 2. The receive symbol input register samples the receive symbol data from the PMD transceiver and passes the symbol data onto the decipher process. The cipher lock is restored by reloading the decipher register after detecting 13 consecutive IDLE symbols which must occur between packets. The decipher function is then performed by an exclusive-OR of the output of the decipher register and the input symbols.

The decipher symbol data are then passed to the symbol aligner. The symbols are broken into arbitrary five-bit groups. The alignment is achieved by scanning the codebit stream for the JK pair following the idle symbols. The decoder translates the 4B/5B coded deciphered and aligned symbols into hex nibbles. The decoder along with the state machine also examines the symbol stream for packet framing information. The JK is converted back to 55 and the TR into 00. The decoder also flags invalid symbol codes and generates the receive error signal. The state machine also generates the receive data valid signal.

A premature stream termination is caused by the detection of two IDLE symbols prior to an TR. A linkfail signal will also terminate the receive operation immediately.

Note, the "Bad SSD" state is not implemented in the receive state machine of the ML6691.



Figure 2. Receive Section Block Diagram



# ML6691

#### MANAGEMENT SECTION

The ML6691 implements the applicable portions of the IEEE 802.3 Control and Status registers. The management section provides a two-wire serial interface for the purpose of control and status gathering. The MDIO pin is

a bi-directional signal used to transfer control information between the ML6691 and the MAC. Data on MDIO is clocked using the MDC pin. The following frame structure is used:

|       | PRE | ST | OP | PHYAD | REGAD | TA | DATA            | IDLE |
|-------|-----|----|----|-------|-------|----|-----------------|------|
| READ  | 1   | 01 | 10 | AAAAA | RRRRR | Z0 | DDDDDDDDDDDDDDD | Z    |
| WRITE | 1   | 01 | 01 | AAAAA | RRRRR | 10 | DDDDDDDDDDDDDDD | Z    |

#### PRE (Preamble)

The preamble condition on the two wire interface is a logic one. Prior to initiation of any other transaction, a sequence of 32 consecutive logic ones must be presented on MDIO with 32 corresponding cycles on MDC to establish synchronization.

#### ST (Start of Frame)

The start of frame is indicated by a <01> pattern. This pattern assures transitions from the default logic one line state to zero and back to one.

#### **OP** (Operation Code)

The operation code for a read transaction is <10>, while the operation code for a write transaction is <01>.

#### PHYAD (PHY Address)

The PHY Address is five bits, allowing 32 unique PHY addresses. The first PHY address bit transmitted and received is the MSB of the address.

#### **REGAD (Register Address)**

The Control register is address <00000>, and the Status register is address <00001>.

#### TA (Turnaround)

The turnaround time is a 2 bit time spacing between the Register Address field and the Data field of a management frame to avoid contention during a read transaction.

#### DATA (Data)

The data field is 16-bits. The first data bit transmitted and received shall be bit 15 of the register being addressed.

#### **CONTROL REGISTER**

Table 2 shows the applicable portions of the Control registers that are implemented in the ML6691. Bits 12, 9, and 6–0 are read-only and have default values of logic low.

| BIT | NAME            | DESCRIPTION                      | R/W | DEFAULT             |
|-----|-----------------|----------------------------------|-----|---------------------|
| 15  | Reset           | 1 = reset                        | R/W | 0                   |
|     |                 | 0 = normal operation             | SC  |                     |
| 14  | Loopback        | 1 = loopback                     | R/W | 0                   |
|     |                 | 0 = normal operation             |     |                     |
| 13  | Speed Selection | 1 = 100 Mb/s                     | R   | 1                   |
|     |                 | 0 = 10 Mb/s                      |     |                     |
| 11  | Power Down      | 1 = power down                   | R/W | 0                   |
|     |                 | 0 = normal operation             |     |                     |
| 10  | Isolate         | 1= electrically isolate from MII | R/W | Determined by LOCAL |
|     |                 | 0 = normal operation             |     |                     |
| 8   | Duplex Mode     | 1 = full duplex                  | R/W | 0                   |
|     |                 | 0 = half duplex                  |     |                     |
| 7   | Collision Test  | 1 = test Col signal              | R/W | 0                   |
|     |                 | 0 = normal operation             |     |                     |

#### CONTROL REGISTER

**NOTE:** R/W = Read/Write, SC = Self Clearing

Table 2. Control Register



**Reset:** By setting this bit to a logic one, the Control register will be reset to its default values. This bit self-clears upon completion of the reset operation.

**Loopback:** By setting this bit to a logic one, the <u>LPBK</u> pin will be held at a logic low. The COL signal will remain low at all times, unless bit 7 is set, in which case the COL signal shall behave as described.

**Speed Selection:** This bit is read-only and set at a logic one by default.

**Power Down:** By setting this bit to a logic one, the oscillator and all the MII input buffers except for MDIO and MDC will be shut down.

**Isolate:** By setting this bit a logic one, the ML6691 can be electrically isolated from the MII. In the isolation mode, the input TXEN will be ignored and TXD[3:0] and TXER shall not have any effect on the transmit section. All the output buffers connected to the MII will be tri-stated. The default state of this bit is determined by the LOCAL pin.

**Duplex Mode:** ML6691 will operate in Full Duplex mode when this bit is set to a logic one. The COL signal will remain low unless bit 7 is set.

**Collision Test:** By setting this bit to a logic one, the COL signal will be asserted in response to the assertion of TXEN, and will continue to assert the COL signal until TXEN is deasserted.

#### STATUS REGISTER

Table 3 shows the applicable portions of the Status register that are implemented in the ML6691. Bits 15, 12-3, 1, and 0 are read-only and have default values of logic low.

#### **100BASE-TX Full Duplex**

ML6691 can perform full duplex link transmission and reception using the 100BASE-TX signaling specification. This bit is always read as a logic one.

#### **100BASE-TX Half Duplex**

ML6691 can perform half duplex link transmission and reception using the 100BASE-TX signaling specification. This bit is always read as a logic one.

#### **Link Status**

When read as a logic one, this bit indicates that a valid link has been established. The link status bit is implemented with a latching function, such that the occurrence of a link failure condition will cause the link status bit to become cleared and remain cleared until it is read via the management interface.

| BIT | NAME        | DESCRIPTION                         | R/W |
|-----|-------------|-------------------------------------|-----|
| 14  | 100Base-TX  | 1 = able to perform full duplex     | R/O |
|     | Full Duplex | 0 = not able to perform full duplex |     |
| 13  | 100Base-TX  | 1 = able to perform full duplex     | R/O |
|     | Half Duplex | 0 = not able to perform full duplex |     |
| 2   | Link Status | 1 = link is up                      | R/O |
|     |             | 0 = link is down                    | LL  |

#### **STATUS REGISTER**

NOTE: R/O = Read Only,

LL = Latching Low

#### Table 3. Status Register

### PHYSICAL DIMENSIONS inches (millimeters)



### **ORDERING INFORMATION**

| PART NUMBER | TEMPERATURE RANGE | PACKAGE                         |
|-------------|-------------------|---------------------------------|
| ML6691CQ    | 0°C to 70°C       | 44-PIN PLCC (Q44) (End Of Life) |

© Micro Linear 1997 🕵 Micro Linear is a registered trademark of Micro Linear Corporation

Products described in this document on the covered by one or more of the following patents, U.S.: 4,897,611; 4,964,026; 5,027,116; 5,281,862; 5,283,483; 5,418,502; 5,508,570; 5,510,727; 5,523,940; 5,546,017; 5,559,470; 5,556,761; 5,592,128; 5,594,376; Japan: 2598946. Other patents are pending.

Micro Linear reserves the right to make changes to any product herein to improve reliability, function or design. Micro Linear does not assume any liability arising out of the application or use of any product described herein, neither does it convey any license under its patent right nor the rights of others. The circuits contained in this data sheet are offered as possible applications only. Micro Linear makes no warranties or representations as to whether the illustrated circuits infringe any intellectual property rights of others, and will accept no responsibility or liability for use of any application herein. The customer is urged to consult with appropriate legal counsel before deciding on a particular application.

2092 Concourse Drive San Jose, CA 95131 Tel: 408/433-5200 Fax: 408/432-0295π



