

# Independent Clock Quad HOTLink II™ **Transceiver**

# **Features**

- Second-generation HOTLink<sup>®</sup> technology
- Compliant to multiple standards
	- ESCON, DVB-ASI, SMPTE-292M, SMPTE-259M, Fibre Channel and Gigabit Ethernet (IEEE802.3z)
	- CPRI™ compliant
	- CYW15G0403DXB compliant to OBSAI-RP3
	- 8B/10B coded data or 10 bit uncoded data
- Quad channel transceiver operates from 195 to 1500 MBaud serial data rate
- CYW15G0403DXB operates from 195 to 1540 MBaud
- Aggregate throughput of up to 12 Gbits/second
- Second-generation HOTLink technology
- Truly independent channels
	- Each channel can operate at a different signaling rate
	- Each channel can transport a different type of data
- Selectable input/output clocking options
- Internal phase-locked loops (PLLs) with no external PLL components
- Dual differential PECL-compatible serial inputs per channel
- Internal DC-restoration
- Dual differential PECL-compatible serial outputs per channel
	- $-$  Source matched for 50Ω transmission lines
	- No external bias resistors required
	- Signaling-rate controlled edge-rates
- MultiFrame™ Receive Framer provides alignment options
	- Bit and byte alignment
	- Comma or Full K28.5 detect
	- Single or Multi-byte Framer for byte alignment
	- Low-latency option
- Synchronous LVTTL parallel interface
- JTAG boundary scan
- Built-In Self-Test (BIST) for at-speed link testing
- Compatible with
	- Fiber-optic modules
	- Copper cables
	- Circuit board traces
- Per-channel Link Quality Indicator
	- Analog signal detect
	- Digital signal detect
- Low-power 3W @ 3.3V typical
- Single 3.3V supply
- 256-ball thermally enhanced BGA
- Pb-Free package option available
- 0.25μ BiCMOS technology

# **Functional Description**

The CYP(V)15G0403DXB<sup>[\[1](#page-0-0)]</sup> Independent Clock Quad HOTLink II™ Transceiver is a point-to-point or point-to-multipoint communications building block enabling transfer of data over a variety of high-speed serial links like optical fiber, balanced, and unbalanced copper transmission lines. The signaling rate can be anywhere in the range of 195 to 1500 MBaud per serial link. Each channel operates independently with its own reference clock allowing different rates. Each transmit channel accepts parallel characters in an Input Register, encodes each character for transport, and then converts it to serial data. Each receive channel accepts serial data and converts it to parallel data, decodes the data into characters, and presents these characters to an Output Register. [Figure 1 on page 2](#page-1-0) illustrates typical connections between independent host systems and corresponding CYP(V)(W)15G0403DXB chips

The CYW15G0403DXB<sup>[\[1](#page-0-0)]</sup> operates from 195 to 1540 MBaud, which includes operation at the OBSAI RP3 datarate of both 1536 MBaud and 768 MBaud.

The CYV15G0403DXB satisfies the SMPTE-259M and SMPTE-292M compliance as per SMPTE EG34-1999 Pathological Test Requirements.

As a second-generation HOTLink device, the CYP(V)(W)15G0403DXB extends the HOTLink family with enhanced levels of integration and faster data rates, while maintaining serial-link compatibility (data, command, and BIST) with other HOTLink devices. The transmit (TX) section of the CYP(V)(W)15G0403DXB Quad HOTLink II consists of four independent byte-wide channels. Each channel can accept either 8-bit data characters or preencoded 10-bit transmission characters. Data characters may be passed from the Transmit Input Register to an integrated 8B/10B Encoder to improve their serial transmission characteristics. These encoded characters are then serialized and output from dual Positive ECL (PECL) compatible differential transmission-line drivers at a bit-rate of either 10 or 20 times the input reference clock for that channel.

#### **Note**

.

<span id="page-0-0"></span><sup>1.</sup> CYV15G0403DXB refers to SMPTE 259M and SMPTE 292M compliant devices. CYW15G0403DXB refers to OBSAI RP3 compliant devices (maximum operating<br>data rate is 1540 MBaud). CYP15G0403DXB refers to devices not compliant to SMPT RP3 operating datarate of 1536 MBaud. CYP(V)(W)15G0403DXB refers to all three devices.



<span id="page-1-0"></span>

## **Figure 1. HOTLink II™ System Connections**

The receive (RX) section of the CYP(V)(W)15G0403DXB Quad HOTLink II consists of four independent byte-wide channels. Each channel accepts a serial bit-stream from one of two PECL-compatible differential line receivers, and using a completely integrated Clock and Data Recovery PLL, recovers the timing information necessary for data reconstruction. Each recovered bit-stream is deserialized and framed into characters, 8B/10B decoded, and checked for transmission errors. Recovered decoded characters are then written to an internal Elasticity Buffer, and presented to the destination host system.

The integrated 8B/10B encoder/decoder may be bypassed for systems that present externally encoded or scrambled data at the parallel interface.

The parallel I/O interface may be configured for numerous forms of clocking to provide the highest flexibility in system architecture. In addition to clocking the transmit path with a local reference clock, the receive interface may also be configured to present data relative to a recovered clock or to a local reference clock.

Each transmit and receive channel contains an independent BIST pattern generator and checker. This BIST hardware allows at-speed testing of the high-speed serial data paths in each transmit and receive section, and across the interconnecting links.

The CYP(V)(W)15G0403DXB is ideal for port applications where different data rates and serial interface standards are necessary for each channel. Some applications include















# **Device Configuration and Control Block Diagram Figure 2 and Signal**  $\rightarrow$  = Internal Signal



# **Pin Configuration (Top View)**





# **Pin Configuration (Bottom View)**







#### **Notes**

<span id="page-7-1"></span>2. When REFCLKx± is configured for half-rate operation, these inputs are sampled relative to both the rising and falling edges of the associated REFCLKx±.<br>3. When REFCLKx± is configured for half-rate operation, these outp

<span id="page-7-0"></span>









<span id="page-9-0"></span>Note<br>4. 3-Level Select inputs are used for static configuration. These are ternary inputs that make use of logic levels of LOW, MID, and HIGH. The LOW level is usually<br>implemented by direct connection to V<sub>SS</sub> (ground). T





**Notes**

<span id="page-10-0"></span>5. See ["Device Configuration and Control Interface" on page 20](#page-19-1) for detailed information on the operation of the Configuration Interface.<br>6. See "Device Configuration and Control Interface" on page 20 for detailed informati

<span id="page-10-1"></span>







## **CYP(V)(W)15G0403DXB HOTLink II Operation**

The CYP(V)(W)15G0403DXB is a highly configurable, independent clocking, quad-channel transceiver designed to support reliable transfer of large quantities of data, using high-speed serial links from multiple sources to multiple destinations. This device supports four single-byte channels.

#### **CYP(V)(W)15G0403DXB Transmit Data Path**

#### *Input Register*

The bits in the Input Register for each channel support different assignments, based on if the input data is encoded or unencoded. These assignments are shown in [Table 1](#page-12-1).

When the ENCODER is enabled, each input register captures eight data bits and two control bits on each input clock cycle. When the Encoder is bypassed, the control bits are part of the pre-encoded 10-bit character.

When the Encoder is enabled, the TXCTx[1:0] bits are interpreted along with the associated TXDx[7:0] character to generate a specific 10-bit transmission character.

#### *Phase-Align Buffer*

Data from each Input Register is passed to the associated Phase-Align Buffer, when the TXDx[7:0] and TXCTx[1:0] input registers are clocked using TXCLKx¦ (TXCKSELx = 0 and TXRATE $x = 0$ ). When the TXDx[7:0] and TXCTx[1:0] input registers are clocked using REFCLKx $\pm$  (TXCKSELx = 1) and REFCLKx± is a full-rate clock, the associated Phase Alignment Buffer in the transmit path is bypassed. These buffers are used to absorb clock phase differences between the TXCLKx input clock and the internal character clock for that channel.

Once initialized, TXCLKx is allowed to drift in phase as much as ±180 degrees. If the input phase of TXCLKx drifts beyond the handling capacity of the Phase Align Buffer, TXERRx is asserted to indicate the loss of data, and remains asserted until the Phase Align Buffer is initialized. The phase of the TXCLKx relative to its associated internal character rate clock is initialized when the configuration latch PABRSTx is written as 0. When the associated TXERRx is deasserted, the Phase Align Buffer is initialized and input characters are correctly captured.



## <span id="page-12-1"></span>**Table 1. Input Register Bit Assignments**[[7\]](#page-12-0)

**Note**

<span id="page-12-0"></span>7. LSB shifted out first.

If the phase offset, between the initialized location of the input clock and REFCLKx¦, exceeds the skew handling capabilities of the Phase-Align Buffer, an error is reported on that channel's TXERRx output. This output indicates an error continuously until the Phase-Align Buffer for that channel is reset. While the error remains active, the transmitter for that channel outputs a continuous C0.7 character to indicate to the remote receiver that an error condition is present in the link.

Each Phase-Align Buffer may be individually reset with minimal disruption of the serial data stream. When a Phase-Align Buffer error is present, the transmission of a Word Sync Sequence re-centers the Phase-Align Buffer and clears the error indication.

**Note**. K28.5 characters may be added or removed from the data stream during the Phase Align Buffer reset operation. When used with non-Cypress devices that require a complete 16-character Word Sync Sequence for proper receive Elasticity Buffer Operation, it is recommend that the Phase Alignment Buffer reset be followed by a Word Sync Sequence to ensure proper operation.

#### *Encoder*

Each character received from the Input Register or Phase-Align Buffer is passed to the Encoder logic. This block interprets each character and any associated control bits, and outputs a 10-bit transmission character.

Depending on the operational mode, the generated transmission character may be

- the 10-bit pre-encoded character accepted in the Input Register.
- the 10-bit equivalent of the 8-bit Data character accepted in the Input Register.
- the 10-bit equivalent of the 8-bit Special Character code accepted in the Input Register.
- the 10-bit equivalent of the C0.7 violation character if a Phase-Align Buffer overflow or underflow error is present.
- a character that is part of the 511-character BIST sequence.
- a K28.5 character generated as an individual character or as part of the 16-character Word Sync Sequence.

## *Data Encoding*

Raw data, as received directly from the Transmit Input Register, is seldom in a form suitable for transmission across a serial link. The characters must usually be processed or transformed to guarantee

- a minimum transition density (to allow the receive PLL to extract a clock from the serial data stream).
- a DC-balance in the signaling (to prevent baseline wander).
- run-length limits in the serial data (to limit the bandwidth requirements of the serial link).
- the remote receiver a way of determining the correct character boundaries (framing).

When the Encoder is enabled ( $ENCBYPx = 1$ ), the characters transmitted are converted from Data or Special Character codes to 10-bit transmission characters, using an integrated 8B/10B encoder. When directed to encode the character as a Special Character code, the encoder uses the Special



Character encoding rules listed in [Table 16 on page 43](#page-42-0). When directed to encode the character as a Data character, it is encoded using the Data Character encoding rules in [Table 15](#page-38-0) [on page 39](#page-38-0).

The 8B/10B encoder is standards compliant with ANSI/NCITS ASC X3.230-1994 Fibre Channel, IEEE 802.3z Gigabit<br>Ethernet, the IBM<sup>®</sup> ESCON® and FICON™ channels, ETSI DVB-ASI, and ATM Forum standards for data transport.

Many of the Special Character codes listed in [Table 16](#page-42-0) may be generated by more than one input character. The CYP(V)(W)15G0403DXB is designed to support two independent (but non-overlapping) Special Character code tables. This allows the CYP(V)(W)15G0403DXB to operate in mixed environments with other Cypress HOTLink devices using the enhanced Cypress command code set, and the reduced command sets of other non-Cypress devices. Even when used in an environment that normally uses non-Cypress Special Character codes, the selective use of Cypress command codes can permit operation where running disparity and error handling must be managed.

Following conversion of each input character from eight bits to a 10-bit transmission character, it is passed to the Transmit Shifter and is shifted out LSB first, as required by ANSI and IEEE standards for 8B/10B coded serial data streams.

## **Transmit Modes**

#### *Encoder Bypass*

When the Encoder is bypassed, the character captured from the TXDx[7:0] and TXCTx[1:0] input register is passed directly to the transmit shifter without modification. With the encoder bypassed, the TXCTx[1:0] inputs are considered part of the data character and do not perform a control function that would otherwise modify the interpretation of the TXDx[7:0] bits. The bit usage and mapping of these control bits when the Encoder is bypassed is shown in [Table 2.](#page-13-1)



## <span id="page-13-1"></span>**Table 2. Encoder Bypass Mode**

When the encoder is enabled, the TXCTx[1:0] data control bits control the interpretation of the TXDx[7:0] bits and the characters generated by them. These bits are interpreted as listed in [Table 3](#page-13-0).

#### <span id="page-13-0"></span>**Table 3. Transmit Modes**



#### *Word Sync Sequence*

When  $TXCTx[1:0] = 11$ , a 16-character sequence of K28.5 characters, known as a Word Sync Sequence, is generated on the associated channel. This sequence of K28.5 characters may start with either a positive or negative disparity K28.5 (as determined by the current running disparity and the 8B/10B coding rules). The disparity of the second and third K28.5 characters in this sequence are reversed from what normal 8B/10B coding rules would generate. The remaining K28.5 characters in the sequence follow all 8B/10B coding rules. The disparity of the generated K28.5 characters in this sequence follow a pattern of either ++––+–+–+–+–+–+– or ––++–+–+–+–+–+–+.

The generation of this sequence, once started, cannot be stopped until all 16 characters have been sent. The content of the associated input registers are ignored for the duration of this sequence. At the end of this sequence, if the TXCTx[1:0] = 11 condition is sampled again, the sequence restarts and remains uninterruptible for the following 15 character clocks.

## **Transmit BIST**

Each transmit channel contains an internal pattern generator that can be used to validate both the link and device operation. These generators are enabled by the associated TXBISTx latch via the device configuration interface. When enabled, a register in the associated transmit channel becomes a signature pattern generator by logically converting to a Linear Feedback Shift Register (LFSR). This LFSR generates a 511-character (or 526-character) sequence that includes all Data and Special Character codes, including the explicit violation symbols. This provides a predictable yet pseudo-random sequence that can be matched to an identical LFSR in the attached Receiver(s).

A device reset (RESET sampled LOW) presets the BIST Enable Latches to disable BIST on all channels.

All data and data-control information present at the associated TXDx[7:0] and TXCTx[1:0] inputs are ignored when BIST is active on that channel. If the receive channels are configured for reference clock operation, each pass is preceded by a 16-character Word Sync Sequence to allow Elasticity Buffer alignment and management of clock-frequency variations.

## **Transmit PLL Clock Multiplier**

Each Transmit PLL Clock Multiplier accepts a character-rate or half-character-rate external clock at the associated REFCLKx± input, and that clock is multiplied by 10 or 20 (as selected by TXRATEx) to generate a bit-rate clock for use by the transmit shifter. It also provides a character-rate clock used by the transmit paths, and outputs this character rate clock as TXCLKOx.



Each clock multiplier PLL can accept a REFCLKx± input between 19.5 MHz and 150 MHz (19.5 MHz and 154 MHz for CYW15G0403DXB), however, this clock range is limited by the operating mode of the CYP(V)(W)15G0403DXB clock multiplier (TXRATEx) and by the level on the associated SPDSELx input.

SPDSELx are 3-level select<sup>[\[4](#page-9-0)]</sup> inputs that select one of three operating ranges for the serial data outputs and inputs of the associated channel. The operating serial signaling-rate and allowable range of REFCLKx± frequencies are listed in [Table 4](#page-14-0).

<span id="page-14-0"></span>



The REFCLKx± inputs are differential inputs with each input internally biased to 1.4V. If the REFCLKx+ input is connected to a TTL, LVTTL, or LVCMOS clock source, the input signal is recognized when it passes through the internally biased reference point. When driven by a single-ended TTL, LVTTL, or LVCMOS clock source, connect the clock source to either the true or complement REFCLKx input, and leave the alternate REFCLKx input open (floating).

When both the REFCLKx+ and REFCLKx– inputs are connected, the clock source must be a differential clock. This can either be a differential LVPECL clock that is DC-or AC-coupled or a differential LVTTL or LVCMOS clock.

By connecting the REFCLKx– input to an external voltage source, it is possible to adjust the reference point of the REFCLKx+ input for alternate logic levels. When doing so it is necessary to ensure that the input differential crossing point remains within the parametric range supported by the input.

# **Serial Output Drivers**

The serial output interface drivers use differential Current Mode Logic (CML) drivers to provide source-matched drivers for transmission lines. These drivers accept data from the Transmit Shifters. These drivers have signal swings equivalent to that of standard PECL drivers, and are capable of driving AC-coupled optical modules or transmission lines. When configured for local loopback (LPENx = HIGH), all enabled serial drivers are configured to drive a static differential logic 1. To achieve OBSAI RP3 compliancy, the serial output drivers must be AC-coupled to the transmission medium.

## *Transmit Channels Enabled*

Each driver can be enabled or disabled separately via the device configuration interface.

When a driver is disabled via the configuration interface, it is internally powered down to reduce device power. If both serial drivers for a channel are in this disabled state, the associated internal logic for that channel is also powered down. A device reset (RESET sampled LOW) disables all output drivers.

**Note**. When a disabled transmit channel (i.e., both outputs disabled) is re-enabled:

- data on the serial outputs may not meet all timing specifications for up to 250 μs
- the state of the phase-align buffer cannot be guaranteed, and a phase-align reset is required if the phase-align buffer is used

## **CYP(V)(W)15G0403DXB Receive Data Path**

## **Serial Line Receivers**

Two differential Line Receivers, INx1± and INx2±, are available on each channel for accepting serial data streams. The active Serial Line Receiver on a channel is selected using the associated INSELx input. The Serial Line Receiver inputs are differential, and can accommodate wire interconnect and filtering losses or transmission line attenuation greater than 16 dB. For normal operation, these inputs should receive a signal of at least  $VI_{DIFF} > 100$  mV, or 200 mV peak-to-peak differential. Each Line Receiver can be DC- or AC-coupled to +3.3V powered fiber-optic interface modules (any ECL/PECL family, not limited to 100K PECL) or AC-coupled to +5V powered optical modules. The common-mode tolerance of these line receivers accommodates a wide range of signal termination voltages. Each receiver provides internal DC-restoration, to the center of the receiver's common mode range, for AC-coupled signals.

The local internal loopback (LPENx) allows the serial transmit data outputs to be routed internally back to the Clock and Data Recovery circuit associated with each channel. When configured for local loopback, the associated transmit serial driver outputs are forced to output a differential logic-1. This prevents local diagnostic patterns from being broadcast to attached remote receivers.

## **Signal Detect/Link Fault**

Each selected Line Receiver (i.e., that routed to the clock and data recovery PLL) is simultaneously monitored for

- analog amplitude above amplitude level selected by SDASELx
- transition density above the specified limit
- range controls report the received data stream inside normal frequency range (±1500 ppm<sup>[[30\]](#page-29-0)</sup>)
- receive channel enabled
- Presence of reference clock
- ULCx is not asserted.

All of these conditions must be valid for the Signal Detect block to indicate a valid signal is present. This status is presented on the LFIx (Link Fault Indicator) output associated with each receive channel, which changes synchronous to the selected receive interface clock.



## *Analog Amplitude*

While most signal monitors are based on fixed constants, the analog amplitude level detection is adjustable to allow operation with highly attenuated signals, or in high-noise environments. The analog amplitude level detection is set by the SDASELx latch via device configuration interface. The SDASELx latch sets the trip point for the detection of a valid signal at one of three levels, as listed in [Table 5](#page-15-1). This control input affects the analog monitors for all receive channels.

<span id="page-15-1"></span>**Table 5. Analog Amplitude Detect Valid Signal Levels**[[8\]](#page-15-0)

| <b>SDASEL</b> | <b>Typical Signal with Peak Amplitudes Above</b> |
|---------------|--------------------------------------------------|
| 00            | Analog Signal Detector is disabled               |
| 01            | 140 mV p-p differential                          |
| 10            | 280 mV p-p differential                          |
| 11            | 420 mV p-p differential                          |

The Analog Signal Detect monitors are active for the Line Receiver as selected by the associated INSELx input. When configured for local loopback, no input receivers are selected, and the LFIx output for each channel reports only the receive VCO frequency out-of-range and transition density status of the associated transmit signal. When local loopback is active, the associated Analog Signal Detect Monitor is disabled.

## *Transition Density*

The Transition Detection logic checks for the absence of transitions spanning greater than six transmission characters (60 bits). If no transitions are present in the data received, the Detection logic for that channel asserts LFIx.

## *Range Controls*

The CDR circuit includes logic to monitor the frequency of the PLL Voltage Controlled Oscillator (VCO) used to sample the incoming data stream. This logic ensures that the VCO operates at, or near the rate of the incoming data stream for two primary cases:

- when the incoming data stream resumes after a time in which it has been "missing."
- when the incoming data stream is outside the acceptable signaling rate range.

To perform this function, the frequency of the RXPLL VCO is periodically compared to the frequency of the REFCLKx± input. If the VCO is running at a frequency beyond ±1500 ppm[\[30](#page-29-0)] as defined by the REFCLKx± frequency, it is periodically forced to the correct frequency (as defined by REFCLKx±, SPDSELx, and TXRATEx) and then released in an attempt to lock to the input data stream.

The sampling and relock period of the Range Control is calculated as follows: RANGE\_CONTROL\_ SAMPLING\_PERIOD = (RECOVERED BYTE CLOCK PERIOD) \* (4096).

During the time that the Range Control forces the RXPLL VCO to track REFCLKx±, the LFIx output is asserted LOW. After a valid serial data stream is applied, it may take up to one RANGE CONTROL SAMPLING PERIOD before the PLL locks to the input data stream, after which LFIx should be HIGH.

## *Receive Channel Enabled*

The CYP(V)(W)15G0403DXB contains four receive channels that can be independently enabled and disabled. Each channel can be enabled or disabled separately through the RXPLLPDx input latch as controlled by the device configuration interface. When the  $RXPLLPDx$  latch = 0, the associated PLL and analog circuitry of the channel is disabled. Any disabled channel indicates a constant link fault condition on the LFIx output. When RXPLLPDx = 1, the associated PLL and receive channel is enabled to receive and decode a serial stream.

**Note**. When a disabled receive channel is reenabled, the status of the associated LFIx output and data on the parallel outputs for the associated channel may be indeterminate for up to 2 ms.

## **Clock/Data Recovery**

The extraction of a bit-rate clock and recovery of bits from each received serial stream is performed by a separate CDR block within each receive channel. The clock extraction function is performed by an integrated PLL that tracks the frequency of the transitions in the incoming bit stream and align the phase of the internal bit-rate clock to the transitions in the selected serial data stream.

Each CDR accepts a character-rate (bit-rate  $\div$  10) or half-character-rate (bit-rate  $\div$  20) reference clock from the associated REFCLKx± input. This REFCLKx± input is used to

- ensure that the VCO (within the CDR) is operating at the correct frequency (rather than a harmonic of the bit-rate)
- reduce PLL acquisition time
- limit unlocked frequency excursions of the CDR VCO when there is no input data present at the selected Serial Line Receiver.

Regardless of the type of signal present, the CDR attempts to recover a data stream from it. If the signalling rate of the recovered data stream is outside the limits set by the range control monitors, the CDR tracks REFCLKx± instead of the data stream. Once the CDR output (RXCLK±) frequency returns back close to REFCLKx± frequency, the CDR input is switched back to the input data stream. If no data is present at the selected line receiver, this switching behavior may result in brief RXCLK± frequency excursions from REFCLKx±. However, the validity of the input data stream is indicated by the LFIx output. The frequency of REFCLKx± is required to be within  $\pm 1500$  ppm<sup>[[30\]](#page-29-0)</sup> of the frequency of the clock that drives the REFCLKx± input of the *remote* transmitter to ensure a lock to the incoming data stream.

For systems using multiple or redundant connections, the LFIx output can be used to select an alternate data stream. When an LFIx indication is detected, external logic can toggle selection of the associated INx1± and INx2± input through the associated INSELx input. When a port switch takes place, it is necessary for the receive PLL for that channel to reacquire the

#### **Note**

<span id="page-15-0"></span><sup>8.</sup> The peak amplitudes listed in this table are for typical waveforms that have generally 3–4 transitions for every ten bits. In a worse case environment the signals<br>may have a sine-wave appearance (highest transition dens the values in the table above by approximately 100 mV.



new serial stream and frame to the incoming character boundaries.

#### **Deserializer/Framer**

Each CDR circuit extracts bits from the associated serial data stream and clocks these bits into the Shifter/Framer at the bit-clock rate. When enabled, the Framer examines the data stream looking for one or more COMMA or K28.5 characters at all possible bit positions. The location of this character in the data stream is used to determine the character boundaries of all following characters.

#### *Framing Character*

The CYP(V)(W)15G0403DXB allows selection of different framing characters on each channel. Two combinations of framing characters are supported to meet the requirements of different interfaces. The selection of the framing character is made through the FRAMCHARx latches via the configuration interface.

The specific bit combinations of these framing characters are listed in [Table 6.](#page-16-0) When the specific bit combination of the selected framing character is detected by the framer, the boundaries of the characters present in the received data stream are known.



#### <span id="page-16-0"></span>**Table 6. Framing Character Selector**

#### *Framer*

The framer on each channel operates in one of three different modes. Each framer may be enabled or disabled using the RFENx latches via the configuration interface. When the framer is disabled ( $RFENx = 0$ ), no combination of received bits alters the frame information.

When the Low-Latency framer is selected (RFMODEx[1:0] = 00), the framer operates by stretching the recovered character clock until it aligns with the received character boundaries. In this mode the framer starts its alignment process on the first detection of the selected framing character. To reduce the impact on external circuits that use the recovered clock, the clock period is not stretched by more than two bit-periods in any one clock cycle. When operated with a character-rate output clock, the output of properly framed characters may be delayed by up to nine character-clock cycles from the detection of the selected framing character. When operated with a half-character-rate output clock, the output of properly framed characters may be delayed by up to 14 character-clock cycles from the detection of the framing character.

**Note**. When Receive BIST is enabled on a channel, the Low-Latency Framer must not be enabled. The BIST sequence contains an aliased K28.5 framing character, which causes the Receiver to update its character boundaries incorrectly.

When  $RFMODEx[1:0] = 10$ , the Cypress-Mode Multi-Byte framer is selected. The required detection of multiple framing characters makes the associated link much more robust to incorrect framing due to aliased SYNC characters in the data stream. In this mode, the framer does not adjust the character clock boundary, but instead aligns the character to the already recovered character clock. This ensures that the recovered clock does not contain any significant phase changes or hops during normal operation or framing, and allows the recovered clock to be replicated and distributed to other external circuits or components using PLL-based clock distribution elements. In this framing mode the character boundaries are only adjusted if the selected framing character is detected at least twice within a span of 50 bits, with both instances on identical 10-bit character boundaries.

When  $RFMODEx[1:0] = 01$ , the Alternate-mode Multi-Byte Framer is enabled. Like the Cypress-mode Multi-Byte Framer, multiple framing characters must be detected before the character boundary is adjusted. In this mode, the data stream must contain a minimum of four of the selected framing characters, received as consecutive characters, on identical 10-bit boundaries, before character framing is adjusted.

#### **10B/8B Decoder Block**

The decoder logic block performs two primary functions:

- decoding the received transmission characters to Data and Special Character codes
- comparing generated BIST patterns with received characters to permit at-speed link and device testing.

The framed parallel output of each deserializer shifter is passed to its associated 10B/8B Decoder where, if the decoder is enabled, the input data is transformed from a 10-bit transmission character back to the original Data or Special Character code. This block uses the 10B/8B decoder patterns in [Table 15 on page 39](#page-38-0) and [Table 16 on page 43](#page-42-0)*.* Received Special Code characters are decoded using [Table 16.](#page-42-0) Valid data characters are indicated by a 000b bit-combination on the associated RXSTx[2:0] status bits, and Special Character codes are indicated by a 001b bit-combination of these status outputs. Framing characters, Invalid patterns, disparity errors, and synchronization status are presented as alternate combinations of these status bits.

When DECBYPx = 0, the 10B/8B decoder is bypassed via the configuration interface. When bypassed, raw 10-bit characters are passed through the receiver and presented at the RXDx[7:0] and the RXSTA[1:0] outputs as 10-bit wide characters.

When the decoder is enabled by setting DECBYPx = 1 via the configuration interface, the 10-bit transmission characters are decoded using [Table 15](#page-38-0) and [Table 16.](#page-42-0) Received Special characters are decoded using [Table 16](#page-42-0). The columns used in [Table 16](#page-42-0) are determined by the DECMODEx latch via the device configuration interface. When  $DECMODEx = 0$  the ALTERNATE table is used and when  $DECMODEx = 1$  the CYPRESS table is used.

#### **Note**

<span id="page-16-1"></span><sup>9.</sup> The standard definition of a Comma contains only seven bits. However, since all valid Comma characters within the 8B/10B character set also have the eighth bit as an inversion of the seventh bit, the compare pattern is extended to a full eight bits to reduce the possibility of a framing error.



#### **Receive BIST Operation**

The receiver channel contains an internal pattern checker that can be used to validate both device and link operation. These pattern checkers are enabled by the associated RXBISTx latch via the device configuration interface. When enabled, a register in the associated receive channel becomes a signature pattern generator and checker by logically converting to a Linear Feedback Shift Register (LFSR). This LFSR generates a 511-character or 526-character sequence that includes all Data and Special Character codes, including the explicit violation symbols. This provides a predictable yet pseudo-random sequence that can be matched to an identical LFSR in the attached Transmitter(s). When synchronized with the received data stream, the associated Receiver checks each character in the Decoder with each character generated by the LFSR and indicates compare errors and BIST status at the RXSTx[2:0] bits of the Output Register.

When BIST is first recognized as being enabled in the Receiver, the LFSR is preset to the BIST-loop start-code of D0.0. This code D0.0 is sent only once per BIST loop. The status of the BIST progress and any character mismatches are presented on the RXSTx[2:0] status outputs.

Code rule violations or running disparity errors that occur as part of the BIST loop do not cause an error indication. RXSTx[2:0] indicates 010b or 100b for one character period per BIST loop to indicate loop completion. This status can be used to check test pattern progress. These same status values are presented when the decoder is bypassed and BIST is enabled on a receive channel.

The specific status reported by the BIST state machine are listed in [Table 11 on page 25](#page-24-0). These same codes are reported on the receive status outputs.

The specific patterns checked by each receiver are described in detail in the Cypress application note "HOTLink Built-In Self-Test." The sequence compared by the CYP(V)(W)15G0403DXB is identical to that in the CY7B933, CY7C924DX, and CYP(V)(W)15G0401DXB, allowing interoperable systems to be built when used at compatible serial signaling rates.

If the number of invalid characters received ever exceeds the number of valid characters by 16, the receive BIST state machine aborts the compare operations and resets the LFSR to the D0.0 state to look for the start of the BIST sequence again.

When the receive paths are configured for REFCLKx± operation, each pass must be preceded by a 16-character Word Sync Sequence to allow management of clock frequency variations.

The receive BIST state machine requires the characters to be correctly framed for it to detect the BIST sequence. If the Low Latency Framer is enabled, the Framer misaligns to an aliased SYNC character within the BIST sequence. If the Alternate Multi-Byte Framer is enabled and the Receiver outputs are clocked relative to a recovered clock, it is generally necessary to frame the receiver before BIST is enabled. If the receive outputs are clocked relative to REFCLKx±, the transmitter precedes every 511 character BIST sequence with a 16 character-character Word Sync Sequence.

A device reset (RESET sampled LOW) presets the BIST Enable Latches to disable BIST on all channels.

#### **Receive Elasticity Buffer**

Each receive channel contains an Elasticity Buffer that is designed to support multiple clocking modes. These buffers allow data to be read using a clock that is asynchronous in both frequency and phase from the Elasticity Buffer write clock, or to be read using a clock that is frequency coherent but with uncontrolled phase relative to the Elasticity Buffer write clock.

If the chip is configured for operation with a recovered clock, the Elasticity Buffer is bypassed.

Each Elasticity Buffer is 10 characters deep, and supports and an 11 bit wide data path. It is capable of supporting a decoded character and three status bits for each character present in the buffer. The write clock for these buffers is always the recovered clock for the associated read channel.

#### **Receive Modes**

When the receive channel is clocked by REFCLKx±, the RXCLKx± outputs present a buffered or divided (depending on RXRATEx) and delayed form of REFCLKx±. In this mode, the receive Elasticity Buffers are enabled. For REFCLKx± clocking, the Elasticity Buffers must be able to insert K28.5 characters and delete framing characters as appropriate.

The insertion of a K28.5 or deletion of a framing character can occur at any time on any channel, however, the actual timing of these insertions and deletions is controlled in part by how the transmitter sends its data. Insertion of a K28.5 character can only occur when the receiver has a framing character in the Elasticity Buffer. Likewise, to delete a framing character, one must also be in the Elasticity Buffer. To prevent a buffer overflow or underflow on a receive channel, a minimum density of framing characters must be present in the received data streams.

When the receive channel Output Register is clocked by a recovered clock, no characters are added or deleted and the receiver Elasticity Buffer is bypassed.

#### **Power Control**

The CYP(V)(W)15G0403DXB supports user control of the powered up or down state of each transmit and receive channel. The receive channels are controlled by the RXPLLPDx latch via the device configuration interface. When RXPLLPDx = 0, the associated PLL and analog circuitry of the channel is disabled. The transmit channels are controlled by the OE1x and the OE2x latches via the device configuration interface. When a driver is disabled via the configuration interface, it is internally powered down to reduce device power. If both serial drivers for a channel are in this disabled state, the associated internal logic for that channel is also powered down.

#### *Device Reset State*

When the CYP(V)(W)15G0403DXB is reset by assertion of RESET, all state machines, counters, and configuration latches in the device are initialized to a reset state, and the Elasticity Buffer pointers are set to a nominal offset. Additionally, the JTAG controller must also be reset to ensure valid operation (even if JTAG testing is not performed). See



["JTAG Support" on page 24](#page-23-0) for JTAG state machine initialization. See [Table 9 on page 20](#page-19-0) for the initialize values of the configuration latches.

Following a device reset, it is necessary to enable the transmit and receive channels used for normal operation. This can be done by sequencing the appropriate values on the device configuration interface.<sup>[\[5](#page-10-0)]</sup>

## **Output Bus**

Each receive channel presents an 11-signal output bus consisting of

- an 8-bit data bus
- a 3-bit status bus.

The signals present on this output bus are modified by the present operating mode of the CYP(V)(W)15G0403DXB as selected by the DECBYPx configuration latch. This mapping is shown in [Table 7](#page-18-0).

<span id="page-18-0"></span>**Table 7. Output Register Bit Assignments** 

| <b>Signal Name</b> | <b>BYPASS ACTIVE</b><br>$(DECBYPx = 0)$ | <b>DECODER</b><br>$(DECBYP = 1)$ |
|--------------------|-----------------------------------------|----------------------------------|
| RXSTx[2] (LSB)     | <b>COMDETx</b>                          | RXSTx[2]                         |
| RXSTx[1]           | DOUTx[0]                                | RXSTx[1]                         |
| RXSTx[0]           | DOUTx[1]                                | RXSTx[0]                         |
| RXDx[0]            | DOUTx[2]                                | RXDx[0]                          |
| RXDx[1]            | DOUTx[3]                                | RXDx[1]                          |
| RXDx[2]            | DOUTx[4]                                | RXDx[2]                          |
| RXDx[3]            | DOUTx[5]                                | RXDx[3]                          |
| RXDx[4]            | DOUTx[6]                                | RXDx[4]                          |
| RXDx[5]            | DOUTx[7]                                | RXDx[5]                          |
| RXDx[6]            | DOUTx[8]                                | RXDx[6]                          |
| RXDx[7] (MSB)      | DOUTx[9]                                | RXDx[7]                          |

When the 10B/8B decoder is bypassed, the framed 10-bit value is presented to the associated Output Register, along with a status output signal indicating if the character in the Output Register is one of the selected framing characters. The bit usage and mapping of the external signals to the raw 10B transmission character is shown in [Table 8](#page-18-1).

The COMDETx status output operates the same regardless of the bit combination selected for character framing by the FRAMCHARx latch. COMDETx is HIGH when the character in the output register contains the selected framing character at the proper character boundary, and LOW for all other bit combinations.

When the low-latency framer and half-rate receive port clocking are also enabled, the framer stretches the recovered clock to the nearest 20-bit boundary such that the rising edge of RXCLKx+ occurs when COMDETx is present on the associated output bus.

When the Cypress or Alternate Mode Framer is enabled and half-rate receive port clocking is also enabled, the output clock is not modified when framing is detected, but a single pipeline stage may be added or subtracted from the data stream by the

#### <span id="page-18-1"></span>**Table 8. Decoder Bypass Mode**



framer logic such that the rising edge of RXCLKx+ occurs when COMDETx is present on the associated output bus.

This adjustment only occurs when the framer is enabled. When the framer is disabled, the clock boundaries are not adjusted, and COMDETx may be asserted during the rising edge of RXCLKx– (if an odd number of characters were received following the initial framing).

#### *Receive Status Bits*

When the 10B/8B decoder is enabled, each character presented at the Output Register includes three associated status bits. These bits are used to identify

- if the contents of the data bus are valid,
- the type of character present,
- the state of receive BIST operations,
- character violations.

These conditions often overlap; e.g. a valid data character received with incorrect running disparity is not reported as a valid data character. It is instead reported as a decoder violation of some specific type. This implies a hierarchy or priority level to the various status bit combinations. The hierarchy and value of each status are listed in [Table 11](#page-24-0).

A second status mapping, listed in [Table 11](#page-24-0), is used when the receive channel is configured for BIST operation. This status is used to report receive BIST status and progress.

## *BIST Status State Machine*

When a receive path is enabled to look for and compare the received data stream with the BIST pattern, the RXSTx[2:0] bits identify the present state of the BIST compare operation.

The BIST state machine has multiple states, as shown in [Figure 2](#page-25-0) and [Table 11](#page-24-0). When the receive PLL detects an out-of-lock condition, the BIST state is forced to the Start-of-BIST state, regardless of the present state of the BIST state machine. If the number of detected errors ever exceeds the number of valid matches by greater than 16, the state machine is forced to the WAIT\_FOR\_BIST state where it monitors the receive path for the first character of the next BIST sequence (D0.0). Also, if the Elasticity Buffer ever hits an overflow/underflow condition, the status is forced to the



BIST\_START until the buffer is re-centered (approximately nine character periods).

To ensure compatibility between the source and destination systems when operating in BIST modes, the sending and receiving ends of the link must use the same receive clock configuration.

## <span id="page-19-1"></span>**Device Configuration and Control Interface**

The CYP(V)(W)15G0403DXB is highly configurable via the configuration interface. The configuration interface allows the device to be configured globally or allows each channel to be configured independently. [Table 9](#page-19-0) lists the configuration latches within the device including the initialization value of the latches upon the assertion of RESET. [Table 10 on page 24](#page-23-1) shows how the latches are mapped in the device. Each row in the [Table 10](#page-23-1) maps to a 8-bit latch bank. There are 16 such write-only latch banks. When  $WREN = 0$ , the logic value in the DATA[7:0] is latched to the latch bank specified by the values in ADDR[3:0]. The second column of [Table 10](#page-23-1) specifies the channels associated with the corresponding latch bank. For example, the first three latch banks (0,1 and 2) consist of configuration bits for channel A. The latch banks 12, 13 and 14 consist of Global configuration bits and the last latch bank (15) is the Mask latch bank that can be configured to perform bit-by-bit configuration.

#### *Global Enable Function*

The global enable function, controlled by the GLENx bits, is a feature that can be used to reduce the number of write operations needed to setup the latch banks. This function is beneficial in systems that use a common configuration in multiple channels. The GLENx bit is present in bit 0 of latch banks 0 through 11 only. Its default value (1) enables the global update of the latch bank's contents. Setting the GLENx bit to 0 disables this functionality.

Latch Banks 12, 13, and 14 are used to load values in the related latch banks in a global manner. A write operation to latch bank 12 could do a global write to latch banks 0, 3, 6, and 9 depending on the value of GLENx in these latch banks; latch bank 13 could do a global write to latch banks 1, 4, 7 and 10; and latch banks 14 could do a global write to latch banks 2, 5, 8 and 11. The GLENx bit cannot be modified by a global write operation.

#### *Force Global Enable Function*

FGLENx forces the global update of the target latch banks, but does not change the contents of the GLENx bits. If FGLENx = 1 for the associated global channel, FGLENx forces the global update of the target latch banks.

#### *Mask Function*

An additional latch bank (15) is used as a global mask vector to control the update of the configuration latch banks on a bit-by-bit basis. A logic 1 in a bit location allows for the update of that same location of the target latch bank(s), whereas a logic 0 disables it. The reset value of this latch bank is FFh, thereby making its use optional by default. The mask latch bank is not maskable. The FGLEN functionality is not affected by the bit 0 value of the mask latch bank.

#### *Latch Types*

There are two types of latch banks: static (S) and dynamic (D). Each channel is configured by 2 static and 1 dynamic latch banks. The S type contain those settings that normally do not change for a given application, whereas the D type controls the settings that could change dynamically during the application's lifetime.The first row of latches for each channel (address numbers 0, 3, 7, and 10) are the static receiver control latches. The second row of latches for each channel (address numbers 1, 4, 8, and 11) are the static transmitter control latches. The third row of latches for each channel (address numbers 2, 5, 9, and 12) are the dynamic control latches that are associated with enabling dynamic functions within the device.

Latch Bank 14 is also useful for those users that do not need the latch-based programmable feature of the device. This latch bank could be used in those applications that do not need to modify the default value of the static latch banks, and that can afford a global (i.e., not independent) control of the dynamic signals. In this case, this feature becomes available when ADDR[3:0] is left unchanged with a value of "1110" and WREN is left asserted. The signals present in DATA[7:0] effectively become global control pins, and for the latch banks 2, 5, 8 and 11.

<span id="page-19-0"></span>





## **Table 9. Device Configuration and Control Latch Descriptions** (continued)





## **Table 9. Device Configuration and Control Latch Descriptions** (continued)





## **Table 9. Device Configuration and Control Latch Descriptions** (continued)



## *Device Configuration Strategy*

The following is a series of ordered events needed to load the configuration latches on a per channel basis:

- 1. Pulse RESET Low after device power-up. This operation resets all four channels. Initialize the JTAG state machine to its reset state as detailed in ["JTAG Support" on page 24.](#page-23-0)
- 2. Set the static receiver latch bank for the target channel. May be performed using a global operation, if the application permits it. [Optional step if the default settings match the desired configuration.]
- 3. Set the static transmitter latch bank for the target channel. May be performed using a global operation, if the application permits it. [Optional step if the default settings match the desired configuration.]
- 4. Set the dynamic bank of latches for the target channel. Enable the Receive PLLs and transmit channels. May be performed using a global operation, if the application permits it. [Required step.]
- 5. Reset the Phase Alignment Buffer for the target channel. May be performed using a global operation, if the application permits it. [Optional if phase align buffer is bypassed.]

When a receive channel is configured with the decoder bypassed and the receive clock selected as recovered clock in half-rate mode (DECBYPx =  $0$ , RXRATEx =  $1$ , RXCKSELx = 0), the channel cannot be dynamically reconfigured to enable the decoder with RXCLKx selected as the REFCLKx  $(DECBYPx = 1, RXCKSELx = 1)$ . If such a change is desired, a global reset should be performed and all channels should be reconfigured to the desired settings.



## <span id="page-23-1"></span>**Table 10.Device Control Latch Configuration Table**



# <span id="page-23-0"></span>**JTAG Support**

The CYP(V)(W)15G0403DXB contains a JTAG port to allow system level diagnosis of device interconnect. Of the available JTAG modes, boundary scan, and bypass are supported. This capability is present only on the LVTTL inputs and outputs and the REFCLKx± clock input. The high-speed serial inputs and outputs are not part of the JTAG test chain.

To ensure valid device operation after power-up (including non-JTAG operation), the JTAG state machine should also be initialized to a reset state. This should be done in addition to the device reset (using RESET). The JTAG state machine can be initialized using TRST (asserting it LOW and de-asserting it or leaving it asserted), or by asserting TMS HIGH for at least 5 consecutive TCLK cycles. This is necessary in order to ensure that the JTAG controller does not enter any of the test modes after device power-up. In this JTAG reset state, the rest of the device will be in normal operation.

**Note**. The order of device reset (using RESET) and JTAG initialization does not matter.

## *3-Level Select Inputs*

Each 3-Level select inputs reports as two bits in the scan register. These bits report the LOW, MID, and HIGH state of the associated input as 00, 10, and 11 respectively

## *JTAG ID*

The JTAG device ID for the CYP(V)(W)15G0403DXB is '0C810069'x.



## <span id="page-24-0"></span>**Table 11.Receive Character Status Bits**





<span id="page-25-0"></span>



# **Maximum Ratings**

Above which the useful life may be impaired. User guidelines only, not tested



Static Discharge Voltage.......................................... > 2000 V (per MIL-STD-883, Method 3015)

Latch-up Current..................................................... > 200 mA

## **Power-up Requirements**

The CYP(V)(W)15G0403DXB requires one power-supply. The Voltage on any input or I/O pin cannot exceed the power pin during power-up.

## **Operating Range**



## **CYP(V)(W)15G0403DXB DC Electrical Characteristics**



**Notes**

<span id="page-26-1"></span>10. Tested one output at a time, output shorted for less than one second, less than 10% duty cycle.<br>11. This is the minimum difference in voltage between the true and complement inputs required to ensure detection of a log

<span id="page-26-2"></span>true (+) input is more positive than the complement (-) input. A logic-0 exists when the complement (-) input is more positive than true (+) input.<br>12. The common mode range defines the allowable range of REFCLKx+ and REFC the true and complement inputs as the signal switches between a logic-1 and a logic-0.

<span id="page-26-0"></span>





# **CYP(V)(W)15G0403DXB DC Electrical Characteristics** (continued)

# **AC Test Loads and Waveforms**



#### **Notes**

- <span id="page-27-0"></span>13. The common mode range defines the allowable range of INPUT+ and INPUT− when INPUT+ = INPUT−. This marks the zero-crossing between the true and complement inputs as the signal switches between a logic-1 and a logic-0.
- <span id="page-27-1"></span>14. Maximum I<sub>CC</sub> is measured with V<sub>CC</sub> = MAX, RFENx = 0, T<sub>A</sub> = 25°C, with all channels and Serial Line Drivers enabled, sending a continuous alternating 01 pattern, and outputs unloaded.

<span id="page-27-2"></span>15. Typical I<sub>CC</sub> is measured under similar conditions except with V<sub>CC</sub> = 3.3V, T<sub>A</sub> = 25°C, RFENx = 0, with all channels enabled and one Serial Line Driver per transmit channel sending a continuous alternating 01 patter 16. Cypress uses constant current (ATE) load configurations and forcing functions. This figure is for reference only.

<span id="page-27-4"></span><span id="page-27-3"></span>17. The LVTTL switching threshold is 1.4V. All timing references are made relative to where the signal edges cross the threshold voltage.



## **CYP(V)(W)15G0403DXB AC Electrical Characteristics**



**Notes**

<span id="page-28-8"></span>18. This parameter is 154 MHz for CYW15G0403DXB.

<span id="page-28-9"></span>19. This parameter is 6.49 ns for CYW15G0403DXB.

<span id="page-28-1"></span>

<span id="page-28-2"></span>

<span id="page-28-7"></span><span id="page-28-3"></span>

<span id="page-28-6"></span><span id="page-28-5"></span><span id="page-28-4"></span>

<span id="page-28-0"></span>20. Tested initially and after any design or process changes that may affect these parameters, but not 100% tested.<br>21. The ratio of rise time to falling time must not vary by greater than 2:1.<br>22. For a given operating fr





# **CYP(V)(W)15G0403DXB AC Electrical Characteristics** (continued)



<span id="page-29-1"></span>**Notes**

28. Since this timing parameter is greater than the minimum time period of REFCLK it sets an upper limit to the frequency in which REFCLK x can be used to clock<br>the receive data out of the output register. For predictable the receive data out of the device.

<span id="page-29-2"></span>29. Measured using a 50% duty cycle reference clock.

<span id="page-29-0"></span>30. REFCLKx has no phase or frequency relationship with the recovered clock and only acts as a centering reference to reduce clock synchronization time. REFCLKx<br>must be within ±1500 ppm (±0.15%) of the remote transmitter's necessitates the frequency difference between the transmitter and receiver reference clocks to`be within ±1500 ppm, the stability of the crystal needs to be<br>within the limits specified by the appropriate standard when tra



# **CYP(V)(W)15G0403DXB AC Electrical Characteristics** (continued)



# **Capacitance**[\[20](#page-28-0)]



**Notes**

<span id="page-30-0"></span>31. While sending continuous K28.5s, outputs loaded to a balanced 100Ω load, measured at the cross point of differential outputs, over the operating range.

<span id="page-30-3"></span>32. While sending continuous K28.7s, after 100,000 samples measured at the cross point of differential outputs, time referenced to REFCLKx± input, over the operating range.

<span id="page-30-2"></span><span id="page-30-1"></span>33. Total jitter is calculated at an assumed BER of 1E –12. Hence: Total Jitter (tˌj) = (t<sub>RJ</sub> \* 14) + t<sub>DJ</sub>.<br>34. Also meets all Jitter Generation and Jitter Tolerance requirements as specified by SMPTE 259M, SMPTE 292M, E



# **CYP(V)(W)15G0403DXB HOTLink II Transmitter Switching Waveforms**



#### **Notes**

- <span id="page-31-2"></span>35. When REFCLKx± is configured for half-rate operation (TXRATE = 1) and data is captured using REFCLKx instead of a TXCLKx clock. Data is captured using<br>both the rising and falling edges of REFCLKx.<br>36. The TXCLKOx output
- <span id="page-31-0"></span>

<span id="page-31-1"></span>37. The rising edge of TXCLKOx output has no direct phase relationship to the REFCLKx± input.



# **CYP(V)(W)15G0403DXB HOTLink II Transmitter Switching Waveforms** (continued)



# **Switching Waveforms for the CYP(V)(W)15G0403DXB HOTLink II Receiver**



#### **Notes**

<span id="page-32-0"></span>38. When operated with a half-rate REFCLKx±, the set-up and hold specifications for data relative to RXCLKx are relative to both rising and falling edges of the respective clock output

<span id="page-32-1"></span>39. TXERRx is synchronous to RXCLKx only when RXCLKx is selected as REFCLK.



# **Switching Waveforms for the CYP(V)(W)15G0403DXB HOTLink II Receiver**





## **Table 12.Package Coordinate Signal Allocation**







## **Table 12.Package Coordinate Signal Allocation** (continued)



## **X3.230 Codes and Notation Conventions**

Information transmitted over a serial link is encoded eight bits at a time into a 10-bit Transmission Character and then sent serially, bit by bit. Information received over a serial link is collected ten bits at a time, and those Transmission Characters that are used for data characters are decoded into the correct eight-bit codes. The 10-bit Transmission Code supports all 256 8-bit combinations. Some of the remaining Transmission Characters (Special Characters) are used for functions other than data transmission.

The primary use of a Transmission Code is to improve the transmission characteristics of a serial link. The encoding defined by the Transmission Code ensures that sufficient transitions are present in the serial bit stream to make clock recovery possible at the Receiver. Such encoding also greatly increases the likelihood of detecting any single or multiple bit errors that may occur during transmission and reception of information. In addition, some Special Characters of the Transmission Code selected by Fibre Channel Standard contain a distinct and easily recognizable bit pattern that assists the receiver in achieving character alignment on the incoming bit stream.

## **Notation Conventions**

The documentation for the 8B/10B Transmission Code uses letter notation for the bits in an 8-bit byte. Fibre Channel Standard notation uses a bit notation of A, B, C, D, E, F, G, H for the 8-bit byte for the raw 8-bit data, and the letters a, b, c, d, e, i, f, g, h, j for encoded 10-bit data. There is a correspondence between bit A and bit a, B and b, C and c, D and d, E and e, F and f, G and g, and H and h. Bits i and j are derived, respectively, from (A,B,C,D,E) and (F,G,H).

The bit labeled A in the description of the 8B/10B Transmission Code corresponds to bit 0 in the numbering scheme of the FC-2 specification, B corresponds to bit 1, as shown below.



To clarify this correspondence, the following example shows the conversion from an FC-2 Valid Data Byte to a Transmission Character.

FC-2 45H

\nBits: 
$$
\frac{7654}{0100} \cdot \frac{3210}{0101}
$$

Converted to 8B/10B notation, note that the order of bits has been reversed):

Data Byte Name D5.2

Translated to a transmission Character in the 8B/10B Transmission Code:

Bits: abcdei fghj 101001 0101

 $FGH$  $010$ 

Each valid Transmission Character of the 8B/10B Transmission Code has been given a name using the following convention: cxx.y, where c is used to show whether the Transmission Character is a Data Character (c is set to D, and SC/D

 $=$  LOW) or a Special Character (c is set to K, and SC/D  $=$ HIGH). When c is set to D, xx is the decimal value of the binary number composed of the bits E, D, C, B, and A in that order, and the y is the decimal value of the binary number composed of the bits H, G, and F in that order. When c is set to K, xx and y are derived by comparing the encoded bit patterns of the Special Character to those patterns derived from encoded Valid Data bytes and selecting the names of the patterns most similar to the encoded bit patterns of the Special Character.

Under the above conventions, the Transmission Character used for the examples above, is referred to by the name D5.2. The Special Character K29.7 is so named because the first six bits (abcdei) of this character make up a bit pattern similar to that resulting from the encoding of the unencoded 11101 pattern (29), and because the second four bits (fghj) make up a bit pattern similar to that resulting from the encoding of the unencoded 111 pattern (7).

**Note**. This definition of the 10-bit Transmission Code is based on the following references, which describe the same 10-bit transmission code.

A.X. Widmer and P.A. Franaszek. "A DC-Balanced, Partitioned-Block, 8B/10B Transmission Code" IBM Journal of Research and Development, 27, No. 5: 440-451 (September, 1983).

U.S. Patent 4,486,739. Peter A. Franaszek and Albert X. Widmer. "Byte-Oriented DC Balanced (0.4) 8B/10B Partitioned Block Transmission Code" (December 4, 1984).

Fibre Channel Physical and Signaling Interface (ANS X3.230-1994 ANSI FC-PH Standard).

IBM Enterprise Systems Architecture/390 ESCON I/O Interface (document number SA22-7202).

## **8B/10B Transmission Code**

The following information describes how the tables are used for both generating valid Transmission Characters (encoding) and checking the validity of received Transmission Characters (decoding). It also specifies the ordering rules followed when transmitting the bits within a character and the characters within any higher-level constructs specified by a standard.

#### **Transmission Order**

Within the definition of the 8B/10B Transmission Code, the bit positions of the Transmission Characters are labeled a, b, c, d, e, i, f, g, h, j. Bit "a" is transmitted first followed by bits b, c, d, e, i, f, g, h, and j in that order.

Note that bit i is transmitted between bit e and bit f, rather than in alphabetical order.

#### **Valid and Invalid Transmission Characters**

The following tables define the valid Data Characters and valid Special Characters (K characters), respectively. The tables are used for both generating valid Transmission Characters and checking the validity of received Transmission Characters. In the tables, each Valid-Data-byte or Special-Character-code entry has two columns that represent two Transmission Characters. The two columns correspond to the current value of the running disparity. Running disparity is a binary parameter with either a negative  $(-)$  or positive  $(+)$ value.



After powering on, the Transmitter may assume either a positive or negative value for its initial running disparity. Upon transmission of any Transmission Character, the transmitter selects the proper version of the Transmission Character based on the current running disparity value, and the Transmitter calculates a new value for its running disparity based on the contents of the transmitted character. Special Character codes C1.7 and C2.7 can be used to force the transmission of a specific Special Character with a specific running disparity as required for some special sequences in X3.230.

After powering on, the Receiver may assume either a positive or negative value for its initial running disparity. Upon reception of any Transmission Character, the Receiver decides whether the Transmission Character is valid or invalid according to the following rules and tables and calculates a new value for its Running Disparity based on the contents of the received character.

The following rules for running disparity are used to calculate the new running-disparity value for Transmission Characters that have been transmitted and received.

Running disparity for a Transmission Character is calculated from sub-blocks, where the first six bits (abcdei) form one sub-block and the second four bits (fghj) form the other sub-block. Running disparity at the beginning of the 6-bit sub-block is the running disparity at the end of the previous Transmission Character. Running disparity at the beginning of the 4-bit sub-block is the running disparity at the end of the 6-bit sub-block. Running disparity at the end of the Transmission Character is the running disparity at the end of the 4-bit sub-block.

Running disparity for the sub-blocks is calculated as follows:

- 1. Running disparity at the end of any sub-block is positive if the sub-block contains more ones than zeros. It is also positive at the end of the 6-bit sub-block if the 6-bit sub-block is 000111, and it is positive at the end of the 4-bit sub-block if the 4-bit sub-block is 0011.
- 2. Running disparity at the end of any sub-block is negative if the sub-block contains more zeros than ones. It is also negative at the end of the 6-bit sub-block if the 6-bit sub-block is 111000, and it is negative at the end of the 4-bit sub-block if the 4-bit sub-block is 1100.
- 3. Otherwise, running disparity at the end of the sub-block is the same as at the beginning of the sub-block.

## **Use of the Tables for Generating Transmission Characters**

The appropriate entry in [Table 15](#page-38-0) for the Valid Data byte or [Table 16](#page-42-0) for Special Character byte identify which Transmission Character is generated. The current value of the Transmitter's running disparity is used to select the Transmission Character from its corresponding column. For each

<span id="page-37-1"></span>

Transmission Character transmitted, a new value of the running disparity is calculated. This new value is used as the Transmitter's current running disparity for the next Valid Data byte or Special Character byte encoded and transmitted. [Table 13](#page-37-0) shows naming notations and examples of valid transmission characters.

#### **Use of the Tables for Checking the Validity of Received Transmission Characters**

The column corresponding to the current value of the Receiver's running disparity is searched for the received Transmission Character. If the received Transmission Character is found in the proper column, then the Transmission Character is valid and the associated Data byte or Special Character code is determined (decoded). If the received Transmission Character is not found in that column, then the Transmission Character is invalid. This is called a code violation. Independent of the Transmission Character's validity, the received Transmission Character is used to calculate a new value of running disparity. The new value is used as the Receiver's current running disparity for the next received Transmission Character.

<span id="page-37-0"></span>



Detection of a code violation does not necessarily show that the Transmission Character in which the code violation was detected is in error. Code violations may result from a prior error that altered the running disparity of the bit stream which did not result in a detectable error at the Transmission Character in which the error occurred. [Table 14](#page-37-1) shows an example of this behavior.





## <span id="page-38-0"></span>**Table 15.Valid Data Characters (TXCTx[0] = 0, RXSTx[2:0] = 000)**







# **Table 15.Valid Data Characters (TXCTx[0] = 0, RXSTx[2:0] = 000)** (continued)





# **Table 15.Valid Data Characters (TXCTx[0] = 0, RXSTx[2:0] = 000)** (continued)







# **Table 15.Valid Data Characters (TXCTx[0] = 0, RXSTx[2:0] = 000)** (continued)







## <span id="page-42-0"></span>**Table 16.Valid Special Character Codes and Sequences (TXCTx = special character code or RXSTx[2:0] = 001)**[\[40,](#page-42-1) [41\]](#page-42-2)

**S.C. Byte Name**

#### **Notes**

- <span id="page-42-1"></span>40. All codes not shown are reserved.
- <span id="page-42-2"></span>41. Notation for Special Character Code Name is consistent with Fibre Channel and ESCON naming conventions. Special Character Code Name is intended to describe binary information present on I/O pins. Common usage for the name can either be in the form used for describing Data patterns (i.e., C0.0 through C31.7), or in hex notation (i.e., Cnn where nn = the specified value between 00 and FF).
- <span id="page-42-3"></span>42. Both the Cypress and alternate encodings may be used for data transmission to generate specific Special Character Codes. The decoding process for received characters generates Cypress codes or Alternate codes as select
- <span id="page-42-4"></span>43. These characters are used for control of ESCON interfaces. They can be sent as embedded commands or other markers when not operating using ESCON protocols.
- <span id="page-42-5"></span>44. The K28.5 character is used for framing operations by the receiver. It is also the pad or fill character transmitted to maintain the serial link when no user data is available.

<span id="page-42-6"></span>45. Care must be taken when using this Special Character code. When a C7.0 or a C0.7 is followed by a D11.x or D20.x, an alias K28.5 sync character is created. These sequences can cause erroneous framing and should be avoided while RFENx = 1.

<span id="page-42-7"></span>46. C2.1 = Transmit either -K28.5+ or +K28.5- as determined by Current RD and modify the Transmission Character that follows, by setting its least significant bit<br>to 1 or 0. If Current RD at the start of the following char

47. C0.7 = Transmit a deliberate code rule violation. The code chosen for this function follows the normal Running Disparity rules. Transmission of this Special<br>Character has the same effect as asserting TXSVS = HIGH. The

<span id="page-42-8"></span>not found in the tables.

<span id="page-42-9"></span>48. C1.7 = Transmit Negative K28.5 (-K28.5+) disregarding Current RD. The receiver only outputs this Special Character if K28.5 is received with the wrong running<br>disparity. The receiver outputs C1.7 if -K28.5 is received

<span id="page-42-10"></span>49. C2.7 = Transmit Positive K28.5 (+K28.5–) disregarding Current RD. The receiver only outputs this Special Character if K28.5 is received with the wrong running<br>disparity. The receiver outputs C2.7 if +K28.5 is received

<span id="page-42-11"></span>50. C4.7 = Transmit a deliberate code rule violation to indicate a Running Disparity violation. The receiver only outputs this Special Character if the Transmission<br>Character being decoded is found in the tables, but Runni



# **Ordering Information**



## **Package Diagram**



**Figure 3. 256-Lead L2 Ball Grid Array (27 x 27 x 1.57 mm) BL256**

HOTLink is a registered trademark and HOTLink II and MultiFrame are trademarks of Cypress Semiconductor. CPRI is a trademark of Siemens AG. IBM and ESCON are registered trademarks, and FICON is a trademark, of International Business Machines. All product and company names mentioned in this document may be the trademarks of their respective holders.

## Document #: 38-02065 Rev. \*F **Page 44 of 45**

© Cypress Semiconductor Corporation, 2002-2007. The information contained herein is subject to change without notice. Cypress Semiconductor Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in a Cypress product. Nor does it convey or imply any license under patent or other rights. Cypress products are not warranted nor intended to be used for medical, life support, life saving, critical control or safety applications, unless pursuant to an express written agreement with Cypress. Furthermore, Cypress does not authorize its<br>products for use as critica products in life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges.



# **Document History Page**





#### **ООО "ЛайфЭлектроникс" "LifeElectronics" LLC**

*ИНН 7805602321 КПП 780501001 Р/С 40702810122510004610 ФАКБ "АБСОЛЮТ БАНК" (ЗАО) в г.Санкт-Петербурге К/С 30101810900000000703 БИК 044030703* 

 *Компания «Life Electronics» занимается поставками электронных компонентов импортного и отечественного производства от производителей и со складов крупных дистрибьюторов Европы, Америки и Азии.*

*С конца 2013 года компания активно расширяет линейку поставок компонентов по направлению коаксиальный кабель, кварцевые генераторы и конденсаторы (керамические, пленочные, электролитические), за счёт заключения дистрибьюторских договоров*

 *Мы предлагаем:*

- *Конкурентоспособные цены и скидки постоянным клиентам.*
- *Специальные условия для постоянных клиентов.*
- *Подбор аналогов.*
- *Поставку компонентов в любых объемах, удовлетворяющих вашим потребностям.*
- *Приемлемые сроки поставки, возможна ускоренная поставка.*
- *Доставку товара в любую точку России и стран СНГ.*
- *Комплексную поставку.*
- *Работу по проектам и поставку образцов.*
- *Формирование склада под заказчика.*
- *Сертификаты соответствия на поставляемую продукцию (по желанию клиента).*
- *Тестирование поставляемой продукции.*
- *Поставку компонентов, требующих военную и космическую приемку.*
- *Входной контроль качества.*
- *Наличие сертификата ISO.*

 *В составе нашей компании организован Конструкторский отдел, призванный помогать разработчикам, и инженерам.*

*Конструкторский отдел помогает осуществить:*

- *Регистрацию проекта у производителя компонентов.*
- *Техническую поддержку проекта.*
- *Защиту от снятия компонента с производства.*
- *Оценку стоимости проекта по компонентам.*
- *Изготовление тестовой платы монтаж и пусконаладочные работы.*



 *Tел: +7 (812) 336 43 04 (многоканальный) Email: [org@lifeelectronics.ru](mailto:org@lifeelectronics.ru)*

## *www[.lifeelectronics.ru](http://lifeelectronics.ru/)*